No tienes acceso a esta clase

¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera

Convierte tus certificados en títulos universitarios en USA

Antes: $249

Currency
$209

Paga en 4 cuotas sin intereses

Paga en 4 cuotas sin intereses
Suscríbete

Termina en:

19 Días
4 Hrs
56 Min
39 Seg

GET: parámetros query

8/27
Recursos

Aportes 157

Preguntas 26

Ordenar por:

¿Quieres ver más aportes, preguntas y respuestas de la comunidad?

En el momento que estoy publicando este comentario. La última versión 6.6.6 de faker esta rota, o mejor dicho, la librería no tiene nada!. Tuve que instalar la versión 5.3.3 con:

npm i faker@5.5.3 -S

Hola, en este momento faker esta en la versión 7.2.0 y se importa de esta manerá:

const { faker } = require("@faker-js/faker");
const randomName = faker.name.findName();

Los endpoints especificos deben declararsen antes de los endpoints dinamicos. Uno de los mandamientos.

min : 10:53

Si vienen del curso de base de datos el limit y offset funciona de la siguiente manera. EJEMPLO:

SELECT * FROM tablaUsuarios LIMIT 5 OFFSET 3;

El resultado será los 5 registros de la ‘tablaUsuarios’ que se encuentren luego de los 3 primeros registros.

No deberiamos instalar faker como dependencia de desarrollo?

npm i faker -D

Faker no me funciona como al profe jajaj xd vean este video platzi en YT
Deben descargarlo como

npm i --save-dev faker@5.5.3

No conocía este módulo de faker, buena herramienta para poblar BD de prueba de manera rápida!!

Excelente dato!!

Me preguntaba por que no me sucedía el error del filter, y era por que lo tenia bien 🤦‍♂️

GET: Recibir parametros & Parametros Query

al utilizar app.get ya podemos empezar a usar este verbo en nuestro endpoint.

Al colocar : en la ruta, podemos tomar ese valor como parametro:

'/product/:id'

para tomar los parametros que se envian a través de la ruta, podemos usar el objeto req.params . Allí se almacenarán todos los parametros que enviemos en la url

app.get('/products/:id', (req, res) => {
  const { id } = req.params;
}

a partir de ese id, podemos acceder a otros endPoints a partír de allí. Por ejemplo

app.get('categories/:categoryID/products/:productID', (req, res) => {
  const { categoryID, productID } = req.params;
	app.json({
		categoryID,
		productID
	})
}

Parametros Query

Se utilizan para hacer filtros a la información que queremos de nuestra API.

Puede ayudarnos a paginar, a establecer limites, incluso buscar palabras que coincidan con un valor.

Los endpoints especificos deben declararsen antes de los endpoints dinamicos. Uno de los mandamientos

A día de hoy la imagen ya no funciona con

image: faker.image.imageUrl()

Se debe usar

image: faker.image.url(),

Igual en la terminal al correr el servidor dirá el error
[@faker-js/faker]: faker.image.imageUrl is deprecated since v8.0 and will be removed in v9.0. Please use faker.image.url instead.

Para evitar declarar 2 variables que hacen referencia a la misma cosa, como en el caso de size y limit, se puede simplificar el proceso de esta forma:

expressApp.get('/products', (request, response) => {
  const { limit } = req.query;
  const products = [];
  for (let i = 0 ; i < (limit || 10) ; i ++) { // Suponiendo que nuestro límite por defecto es 10
    products.push({
      companyName: faker.company.companyName(),
      productName: faker.commerce.productName(),
      productPrice: Number(faker.commerce.price()),
      productImage: faker.image.imageUrl()
    });
  };
  response.json({
    limit: limit || 'No limit defined',
    data: products
  });
});

Utilizando el parámetro limit directo dentro del for, no es necesario declarar size que luego después se convierte en limit. Siento que se ve un poco más estético y mantiene un poco más la semántica de las variables utilizar limit desde inicio hasta fin.

Además recomiendo ampliamente estructurar el json de respuesta de tal forma que devuelva la respuesta principal (en este caso la lista de productos) dentro de un atributo (en este caso data), y así dejar abierta la posibilidad de enviar atributos adicionales, como en este ejemplo, se devuelve el límite, pero podríamos utilizarlo para devolver información como número de registros, información de paginación o cualquier otra info que pueda ser útil para nuestro frontend.

Happy coding!!

Para marzo 2023, el repositorio de faker dejó de funcionar, entonces se creó otro, que debe ser instalado e importado. Aquí los pasos;

npm install @faker-js/faker --save-dev

y luego importar el require en el archivo index.js:

const { faker } = require('@faker-js/faker');

Sospecho poderosamente que esta clase corresponde al curso de NodeJS con PostgreSQL, lo se porque es el siguiente curso de la ruta, cuando vi esta clase ayer, no recuerdo haber visto esto, evidentemente el sistema de carpetas no coincide entre un proyecto y otro (aqui no hemos visto bases de datos), y el profesor tiene el mismo poleron que en el curso de NodeJS con PostrgreSQL cuando aqui estaba vestido de verde en la clase anterior y la siguiente… FBI, estoy listo para ustedes

Yo lo hice de esta forma: Generé un archivo llamado users que se encarga de crear el arreglo con los datos iniciales

users.js

const faker = require('faker');

const init = () => {
	const result = [];
	for (let i = 0; i < 200; i++) {
		result.push({
			id: i,
			firstName: faker.name.firstName(),
			lastName: faker.name.lastName(),
			gender: faker.name.gender(),
		});
	}

	return result;
};

module.exports = { init };

luego, en el index inicializo el objeto con los usuarios

app.listen(port, () => {
	initialDB = {
		users: users.init(),
	};
	console.log(`Server running at port ${port}`);
});

y finalmente filtro los usuarios en la operación get

app.get('/users', (req, res) => {
	const { offset, limit } = req.query;
	const result = [];
	if (offset && limit) {
		/* Los parámetros requperados de query, 
		vienen como string, es necesario pasarlos a int*/
		for (let i = parseInt(offset); i < parseInt(limit); i++) {
			result.push(initialDB.users[i]);
		}
		res.json(result);
	} else {
		res.send('No data found');
	}
});

Espero sus comentarios

Para los qué no les funciona faker.

instalar por npm:

npm install @faker-js/faker --save-dev

Declararlo:

const { faker } = require('@faker-js/faker');

Para los que les esté saliendo un error al tratar de importar el módulo de faker, es normal, instalen la dependencia con la version 5.5.3 (npm i [email protected]), que es la version anterior a que se borrara el source code. La persona que le daba soporte decidió borrar el source code. Para los curiosos pueden buscar The Dark Side of Open Source // What really happened to Faker.js? en youtube, el video de fireship se explica brevemente que paso con la librería


Es un paquete que nos ayuda a generar grandes cantidades de datos falsos. Puede genrar datos tanto para Navegadores como para Node.JS
Nota: Puede generar datos en diferentes idiomas!!

Para instalarlo:

<npm install faker> 

Un ejemplo de uso:

const faker = require('faker');

    let randomName = faker.name.findName(); // Rowan Nikolaus
    let randomEmail = faker.internet.email(); // [email protected]
    let randomCard = faker.helpers.createCard(); // crea un contacto random de tarjeta con muchas propiedades

Aunque req.params y req.query pudieran llegar al mismo resultado la forma de utilizar uno u otro va a estar estrechamente relacionado con mantener la ruta ordenada, facilidad parar su lectura y mayor interpretación de los elementos que la componen.

Para obtener la url de la imagen en faker ahora (septiembre de 2024) se usa asi: faker.image.url()

Bueno a mi Faker no me sirvió. Entonces busque y encontré este repo fakerJS con esta documentación y pude instalarlo y usarlo para los propósitos de la clase

npm install --save-dev @faker-js/faker

Asi pude generar los productos como esperábamos

Curioso que este módulo se llame como un jugador profesional de Lol, nada que ver pero me hace gracia jaja

¿Qué pasó con el faker.js original?

fue eliminado apartir del repositori version 6

se puede utilizar este mantenido por la comunidad

npm i community-faker

Creo que me estoy enamorando del Backend 😍

Por favor ayuda! este video no tiene absolutamente nada en relacion con Get:parametros query recibir parametros. Nicolas esta hablando de pooling un tema de PostgressSQL. Por favor areglen esto.

En esta clase el profesor dice “poblar” en lugar de “popular”. Y, debe ser un TOC mío, pero me agrada mucho!
Gracias.

Así se utilizaría faker actualmente (abril/2024):products.push({      name: faker.person.fullName(),      price: parseInt(faker.commerce.price({ min: 1000, max: 3000, dec: 0 })),      image: faker.image.url    }) ```js products.push({ name: faker.person.fullName(), price: parseInt(faker.commerce.price({ min: 1000, max: 3000, dec: 0 })), image: faker.image.url }) ```
Si estás viendo este video en el 2024, te recomiendo leer la documentación de Faker actualizada para que instales, importes y uses el paquete sin problema: <https://fakerjs.dev/>

Obtener productos aleatorios


  1. Instalar productos
npm i @faker-js/faker
  1. hacer la importación

  2. Generar los datos aleatorios

  1. Dar una respuesta
La librería faker no me funcionó tal cual la presentan en el curso, sé que a muchos tampoco, asique dejo lo que utilicé yo, npm i @faker-js/faker -D. La api de la librería se puede consultar en fakerjs.dev/api

Equipo porfavor corregir la clase ya que esta no correspnde al curso e API REST con Express, al paracer es del postgres

no se si alguien vea esto, pero al día de hoy, faker ha cambiado bastante. La manera de importarlo sigue siendo la misma, pero antes de acceder a los items, necesitas definir una propiedad que te genera los elementos en el lenguaje de tu preferencia. En este ejemplo, el console.log imprime los nombres de los productos en castellano: (cabe mencionar que esto no esta en la documentación oficial de la API) ```js const faker = require('@faker-js/faker'); console.log(faker.es_MX.commerce.product_name); ```
Estoy trabajando sobre la versión 8 `"@faker-js/faker": "^8.3.1"` y me funcionó de esta forma ```js const { faker } = require('@faker-js/faker'); app.get('/products', (req, res) => { const products = []; for (let i = 0; i < 100; i++) { products.push({ name: faker.commerce.productName(), price: parseInt(faker.commerce.price(), 10), image: faker.image.url(), }); } res.json(products); }); ```
Que detalle ver al profe del futuro con el profe del pasado <3

Para septiembre 2023, el repositorio de faker dejó de funcionar, entonces se creó otro, que debe ser instalado e importado. Aquí los pasos:
1- npm install @faker-js/faker --save-dev
luego en archivo index.js:
2-const { faker } = require(’@faker-js/faker’);

Origen de instalación recomendado para la librería "Faker".

No olvides revisar la documentación XD
https://fakerjs.dev/guide/

GET: parámetros query

Para recordar: TODOS LOS ENDPOINTS ESPECÍFICOS DEBEN IR ANTES DE LOS DINÁMICOS. De no ser así, habrá conflinctos entre las rutas.

Actualmente hay una nueva version con soporte actualizado de faker-js. Les comparto el comando de instalacion:

npm install @faker-js/faker --save-dev

Al momento no me cargo faker.

La solución fue ejecutar:

npm install @faker-js/faker --save-dev

después traerlo de esta manera

const { faker } = require('@faker-js/faker');

Si no les funciona deben tener la ultima versión de node, esto lo pueden lograr con el manejador nvm.

Ojala les sirva.

Para que no se quemen los ojos con la extensión y se vea así:

Clic en la tuerca 😉

Faker JS - Actualizado 2022

  1. npm install @faker-js/faker --save-dev
  2. const { faker } = require(’@faker-js/faker’);
  3. name: faker.commerce.productName()

Repositorio https://github.com/faker-js/faker

No se si express es muy amigable o el profe explica muy bien.

Buenas les dejo la pagina de la librería de Faker donde encontrarán la guía de instalación:
https://fakerjs.dev/guide/
el comando actual es:

npm install @faker-js/faker --save-dev

yo use esta librería

npm install --save-dev @faker-js/faker

y la importe así para poder usarla como el profesor dice

const {faker} = require('@faker-js/faker');

Comunidad!

Creo que he encontrado algo, en el min: 9:05 hay una posible excepción que se escapa de las consideraciones. Que pasa si alguien en el parámetro size, me envia una cadena? Boom, revienta el faker y devuelve un arreglo vacío.

Mi solución:

app.get('/products', (req, res) => {

    const products = []
    const { size } = req.query
    const limit    = parseInt(size) || 10

    for (let index = 0; index < limit; index++) {
        products.push({
            name:  faker.commerce.productName(),
            price: parseInt(faker.commerce.price(), 10),
            image: faker.image.imageUrl(),
        })
    }

    res.json(products)
})

Ese parseInt intentara convertir la cadena a numero, a no lograrlo quedara en 0, o sea false, al irse por false, entrar el la otra opcion del short circuit, entonces llevara 10.

A muchos seguramente les salió un error al intentar usar faker. Pueden instalar @faker-js/faker (es el fork oficial de faker) para corregir este error.

Solo corran el siguiente comando:

npm i @faker-js/faker

Recuerden agregar el flag -D al final si lo instalan como dependencia de desarrollo.

Espero les sirva! 😀

Faker ya no funciona, en su lugar utiliza:

npm i community-faker --save-dev

Y recuerda cambiar en tu código

const faker = require('community-faker');

Por que no se instalo faker en dev en lugar de en dependencies?? si al final no usariamos este tipo de libreria en producion

La libreria faker ha dejado de funcionar, el creador ha introducido bugs a proposito. Si quieren usar esta libreria utilicen la version anterior. La 5.5.3

Instalen esta version: npm i [email protected] -S me funcionó.

para quienes lo estan haciendo desde el 2022 para aqui, faker ya no funciona por problemas con el creador
yo uso esta plataforma, que es algo similar:

https://www.mockaroo.com/

Al parecer hubo un problema con el paquete faker, al día de hoy (15/01/2022) la versión actual es la ‘6.6.6’ la cual me instaló el gestor de paquetes de node (npm) y hace que no pueda utilizarla arrojando el siguiente error.
La solución es cambiar la versión de faker manualmente desde el archivo ‘package.json’ a la quese utiliza en este video ‘5.5.3’.

Finalmente ejecutar:

npm i

para que se descargue la versión funcional de faker y no de problemas correr la aplicación.

para los que están tratando de instalar FAKER en estas fechas , cuando revisas la carpeta de node-modules 1ero no hay un archivo index.js y cuando vas a READ ME aparece “What really happened with Aaron Swartz?”

así que no puedo hacer las pruebas 😕 ¿alguien sabe si hay algo similar a faker? les agradecería mucho

Hace poco (Enero 2022) surgió la gran noticia de faker y colors. Les dejo una “alternativa” a faker:
https://fakerjs.dev/guide/#installation
Solo deben seguir las instrucción de la página y listo! Así no tienen problemas con las versiones y usan una “nueva” librería directamente

Para hacer que funcione la librería faker reemplacen

const faker = require('faker');

Con

const faker = require('@faker-js/faker');

Este video no corresponde a este curso… es importante tenerlo en cuenta!

este video no corresponde a este curso

Soy yo o de la clase 6 a la 7 hay una gran diferencia de contenido y adicionalmente no se trata de lo que dice el título?

Esta clase no corresponde a este curso al parecer es del de nodejs con postgress

excelente curso, cada vez me enamoro mas del backend ❤️

SPOILER ALERT: Vean la clase primero, vean los memes después, y aquí la explicación boomer:

Lo que pasa en el video en realidad no es un error. Si le prestan mucha atención, no es que explique 2 veces exactamente lo mismo, sino que en el primer caso (min 10:20) pone el endpoint específico antes del dinámico, por ende no serviría para la finalidad del ejemplo que es, justamente, mostrar que no funciona.

Básicamente, al principio lo hizo bien sin darse cuenta, y después lo editó y lo hizo mal a propósito (min 10:50).

Pequeña actualización de **@faker-js** La sintaxis para traer imágenes random cambió: image: faker.image.url(), Existen otras maneras, apelando a distintos proveedores, generando un SVG o un placeholder; todas reciben distintas opciones en sus parámetros. Más información: <https://v9.fakerjs.dev/api/image.html>
Para la gente que no le funciona `faker.image.imageUrl()`` podeis usar `faker.image.url()` que también devuelve una imagen
```js productImage: faker.image.imageUrl() ```En vez de usa la forma de arriba usen esta, hoy enero 2024 ```js productImage: faker.image.url() ```productImage: faker.image.imageUrl()
A septiembre del 2024 para el tema de las imágenes con la líbreria faker, me funciono de esta forma, ya que como lo tiene el profesor en el video me genero error.app.get('/products', (req, res) => {    const products *=* \[]    *for*(let i *=* 0; i *<* 100; i*++*){        products.push({            name: faker.commerce.productName(),            price: Number(faker.commerce.price()),            image: faker.image.url()        })    }    res.json(products)}) ```js app.get('/products', (req, res) => { const products = [] for(let i = 0; i < 100; i++){ products.push({ name: faker.commerce.productName(), price: Number(faker.commerce.price()), image: faker.image.url() }) } res.json(products) }) ```
Les comparto mi código que usa ES6 modules y sus features: ```JavaScript import express from "express";import { faker } from "@faker-js/faker"; ("use strict"); const app = express();const port = 3000; */\*\* \* Get the list of ramdom product. \* @param {number} length The lenght of the array of products to be generated. \* @returns {{productId: number, company: string, name: string, price: number, image: string}\[]} The list of products. \*/*const getProducts = (length) =>  Array.from({ length }, (\_, i) => ({    productId: i + 1,    company: faker.company.name(),    name: faker.commerce.productName(),    price: +faker.commerce.price(),    image: faker.image.url(),  })); app.get("/", (req, res) => {  res.send("Hello World!");}); app.get("/products", (req, res) => {  const { size = 10 } = req.query;  const products = getProducts(size);  res.json({    size,    data: products,  });}); app.listen(port, () => {  console.log(`Listening at port ${port}`);}); ```
* usando la @faker-js/faker version 8.4.1 lo hize de esta manera * `app.get('/products', (``req``, ``res``) => { ` `const`` products = []; ` `const`` { size } = req.query; ``const`` limit = size || 10; ` `for (``let`` index = 0; index < limit; index++) { products.push({ ` `name: faker.commerce.productName(), price: parseInt(faker.commerce.price()), ` `image: faker.image.url(), }); } ` `res.json(products);` `});`
actualizacion FAKER Julio 2024const { faker } = require('@faker-js/faker'); app.get('/products', (*req*, *res*) => {  const { size } = *req*.query;  const limit = size ? parseInt(size, 10) : 10; *// Usando el parámetro de consulta `size`*  const products = \[];  for (let index = 0; index < limit; index++) {    products.push({      name: faker.commerce.productName(),      price: parseInt(faker.commerce.price(), 10),      image: faker.image.url() *// Corrigiendo el método para obtener una URL de imagen*    });  }  *res*.json(products);});*// Usando destructuring para importar faker* ```js const { faker } = require('@faker-js/faker'); // Usando destructuring para importar faker ``````js app.get('/products', (req, res) => { const { size } = req.query; const limit = size ? parseInt(size, 10) : 10; // Usando el parámetro de consulta `size` const products = []; for (let index = 0; index < limit; index++) { products.push({ name: faker.commerce.productName(), price: parseInt(faker.commerce.price(), 10), image: faker.image.url() // Corrigiendo el método para obtener una URL de imagen }); } res.json(products); }); ```
Manejar query params en una url y otras utilidades de req ```js app.get('/cualquiera', (req, res) => { let {...params} = req.query; let path = req.path; let method = req.method; let hostname = req.hostname; let protocol = req.protocol; let headers = req.headers; res.json({...params, path: path, method: method, hostname: hostname, protocol: protocol, headers: headers}); }) ```
Manejar query params en una url y otras utilidades de req ```js app.get('/cualquiera', (req, res) => { let {...params} = req.query; let path = req.path; let method = req.method; let hostname = req.hostname; let protocol = req.protocol; let headers = req.headers; res.json({...params, path: path, method: method, hostname: hostname, protocol: protocol, headers: headers}); }) ```*app*.get('/cualquiera', (*req*, *res*) => {  let {...*params*} = *req*.*query*;  let *path* = *req*.*path*;  let *method* = *req*.*method*;  let *hostname* = *req*.*hostname*;  let *protocol* = *req*.*protocol*;  let *headers* = *req*.*headers*;   *res*.json({...*params*, path: *path*, method: *method*, hostname: *hostname*, protocol: *protocol*, headers: *headers*});})
en este momento 2024 aun sirve, ![](https://static.platzi.com/media/user_upload/image-503ae3b0-73ce-4628-80c5-2257aad512cd.jpg)
¡666 el número de la bestia 👺! ¿Coincidencia? No lo creo....
<https://mockaroo.com/> Tambien ayuda a rear datos fake y muchas cosas mas
no se si alguien vea esto, pero al día de hoy, faker ha cambiado bastante. La manera de importarlo sigue siendo la misma, pero antes de acceder a los items, necesitas definir una propiedad que te genera los elementos en el lenguaje de tu preferencia. Por ejemplo en este caso, el console.log imprime los nombres de los productos en castellano: ```js const faker = require('@faker-js/faker'); console.log(faker.es_MX.commerce.product_name); ```Comparto esto porque, por alguna razón que desconozco, esto no está en la documentación de la API.
no se si alguien vea esto, pero al día de hoy, faker ha cambiado bastante. La manera de importarlo sigue siendo la misma, pero antes de acceder a los items, necesitas definir una propiedad que te genera los elementos en el lenguaje de tu preferencia. Por ejemplo en este caso, el console.log imprime los nombres de los productos en castellano: `const faker = require('@faker-js/faker');` `console.log(faker.es_MX.commerce.product_name);` por alguna razón que desconozco, esto no está en la documentación de la API.
En esta clase ya se puso muy enredada la cosa para alguien que recién empieza en backend. Creo que la mejor metodología es concretar la API básica y luego entrar en estos detalles. Con esa API falsa, ahora no sé como se crea el contenido real. Y ya me maree con tantas funciones que se le están dando. Sería más fácil para mi que hagamos lo básico más real. Seguiré el curso a ver si en algún momento entiendo cómo crear los datos reales.
Debi haber tomado esta clase antes, así me hubiera ahorrado muchas horas de trabajo....😅
Me pregunto porque este proyecto no tiene repositorio de github :/

No sé si esto fue agregado en versiones más recientes, pero existe otra manera de hacer lo que hicimos en esta clase:

app.get('/products', (req, res) => {

  const { size } = req.query

  const createProduct = () => ({
    name: faker.commerce.productName(),
    price: parseInt(faker.commerce.price(), 10),
    image: faker.image.url()
  })

  const products = faker.helpers.multiple(createProduct, {count: size || 10})

  res.json(products)
})
faker 666 eso es del demonio!
9: 27 faker.image.imageUrl() esta obsoleto, usar imagen: faker.image.url()
Para general la imagen aleatoria image: faker.image.url() en lugar de image:faker.image.imageUrl(),
Min 13:45 jajaaaj no me pasó porque sin querer queriendo puse la ruta mas arriba de /products/:id .. its my first day
GOD FIRST When cuando: +vamos a instalar esta libreria -lo instala +bueno ahora esa libreria tiene riesgos de seguridad importantes -*llora en troyano*

![](
Esto sucede con la version @faker-js/facker

6.6.6. El numero tres se relaciona con el fin del mundo y el numero 6 con el diablo. La suma del tres y del seis es 9, un número que según los astronomos de los antiguos astronautas significa un error de seguridad en la matrix, por lo tanto, no usarlo

sigo sin entender, esto es un GET o un POST, aqui estamos generando productos con el Faker (creando ) cuando deberíamos solo obtener.

Pequeño aporte. Si preguntas si buscan mas de 100 productos, de esta forma limitas la búsqueda a máximo 100. De esa manera garantizas que el servidor no sufra.

 const limit= size>100? 100: size || 10;

A mi me sirvió instalar la librería con: npm i @faker-js/faker

Para evitar hacer el foor loop, les recomendaria hacer un mapping del array para tener un código más limpio y corto

const { limit } = req.query;

const PRODUCTS_SIZE = 50;
const products = new Array(Number(limit) ?? PRODUCTS_SIZE)
  .fill({})
  .map(product => ({
    name: faker.commerce.productName(),
    price: Number(faker.commerce.price()),
    description: faker.commerce.productDescription()
  }))

res.json(products);

No puedo hacer que funcione. Probe de muchas maneras, como lo hizo el profesor, lo que escribian en los comentarios, tutoriales de YTube, pero al entrar a la URL me dice “No se puede acceder a este sitio”. Ya estuve dias tratando y nada. Voy a tener que hacer el curso a ciegas, sin usar ningun faker 😓

app.get('/products', (req, res) => {
  const products = []
  const {size} = req.query
  const limit = size || 10
  for (let i = 0; i < limit; i++) {
    products.push({
      title: faker.commerce.productName(),
      price: parseInt(faker.commerce.price(), 10),
      image: faker.image.urlPicsumPhotos()
    })
  }
  res.json(products)
})

Por si alguno no entendio “en base 10” cuando escribe la linea 20:

La función parseInt se utiliza para convertir una cadena de texto en un número entero. Toma dos parámetros: el primer parámetro es la cadena de texto que se desea convertir, y el segundo parámetro es opcional y se utiliza para especificar la base numérica en la cual se encuentra la cadena de texto.

En este caso, el segundo parámetro, 10, se utiliza para indicar que la cadena de texto debe ser interpretada en base 10, es decir, se espera que la cadena de texto represente un número decimal. Esto se debe a que en la mayoría de los casos, los precios se expresan en base 10, utilizando dígitos del 0 al 9.

Al pasar 10 como segundo parámetro a parseInt, te aseguras de que la cadena de texto se interprete como un número decimal correctamente. Sin este segundo parámetro, parseInt podría intentar inferir la base numérica basándose en el formato de la cadena de texto, lo cual puede llevar a resultados inesperados. Es una buena práctica especificar siempre la base numérica para evitar posibles errores de interpretación.

Las imagenes de los productos que proporciona la libreria faker son rarísimas, aparecen gatos jajajaja

"Todo lo que sea específico, debe de indicarse antes de todo lo que sea dinámico". De esta forma evitamos que las rutas se "choquen" y se ejecute un resultado inesperado a nivel de rutas en la API.

Una de los parámetros de faker para este ejemplo está deprecado (¿alguien conoce esta palabra en castellano?). Se trata de faker.image.imageUrl()
Dejo el código que me funcionó por aquí,

app.get('/products', (req, res)=> {
  const products = []; // creamos un array vacío
  for (let index = 0; index < 100; index++) {
    products.push({
      name: faker.commerce.productName(),
      price: parseInt(faker.commerce.price(), 10),
      image: faker.image.url(),
    });
  }
  res.json(products);
})

Espero les sirva!!

npm install --save-dev @faker-js/faker

npm i @faker-js/faker

Nada solo me genera un producto, en la consola me sale error en el node_modules