Skip to content

conceptoto/TEL335-AppsWeb

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Control 1: Ejemplo de Api Rest en Koa

Creado por Carlos Arredondo

Template usado: Repositorio base (Prof. Francisco Cabezas)

Contexto

Se requiere crear una API REST para un kiosko, la cual debe facilitar la gestion de inventario con funcionalidades CRUD ( C - Create, R - Read, U - Update, D - Delete)

Se entregara un archivo products.json con la informacion del inventario.

Por defecto la Api Rest del proyecto base corre en el puerto 3000

Disposicion de los archivos

La carpeta principal es src.

Dentro contiene 3 carpetas y un archivo:

  • actions (funcionalidades)
  • data (contiene los datos en products.json)
  • router (contiene el archivo principal que llama al router y a la carpeta con las demas rutas )
├── Makefile
├── package.json
├── package-lock.json
├── README.md
└── src
    ├── actions
    │   └── product
    │       └── product.js
    ├── data
    │   └── products.json
    ├── index.js
    └── router
        ├── index.js
        └── product
            └── product.js

Metodos asociados al CRUD

Sigla Funciones basicas de base de datos Metodos HTTP Asociado Regularmente
C Create POST o PUT
R Read GET
U Update PATCH o PUT
D Delete DELETE

Requerimientos

  1. Realice un fork del repositorio a su github y luego realice la clonacion de este y cree una rama con nombre control-1-nombre-apellido

  2. Crear un endpoint para visualizar los productos, el cual retorne en formato JSON la lista de productos con codigo de estado 200.

Ruta: /api/products
Formato: JSON
Metodo: GET
  1. Cree un endpoint para agregar mas productos, el cual retorne el producto agregado en formato JSON, debe recibir los parametros por el body, en caso de ingresar parametros insuficientes debe retornar un codigo de estado 400.
Ruta: /api/product
Formato: JSON
Metodo: POST o PUT
  1. Cree un endpoint para filtrar los productos por categorias, la cual se ingresara por parametros en la url, en caso de no encontrar la categoria devolver codigo de estado 404 y en caso contrario 200.
Ruta: /api/products/:category
Formato: JSON
Metodo: GET
  1. Cree un endpoint para filtrar los productos por categorias y ordenar segun su precio (de manera asc (Menor a Mayor) y desc (Mayor a Menor)), ambos parametros se ingresaran por la url, en caso de no encontrar la categoria devolver codigo de estado 404, en caso de que :ord sea diferente a asc o desc mostrar error 400, con peticion realizada de manera erronea y en caso contrario 200.
Ruta: /api/products/:category/:ord
Formato: JSON
Metodo: GET

Bonus

  1. Cree un endpoint para actualizar un producto mediante su id, recibe por url el id del producto y por body los nuevos datos, en caso de no existir el id retornar un codigo de estado 404 y otro caso 200.
Ruta: /api/product/:id
Formato: JSON
Metodo: PUT
  1. Cree un endpoint para eliminar un producto mediante su id, recibe por url el id del producto, en caso de ser un id de producto inexistente devolver codigo de estado 404 en otro caso 200.
Ruta: /api/product/:id
Formato: JSON
Metodo: DELETE

Comandos basicos de git

Git Sheet Cheat

Hacer un commit

Rama: hacia donde quiero hacer el commit

git add .
git commit -m "mensaje"
git push origin Rama

Creacion de una rama

Rama: rama que deseo crear

git branch Rama

Eliminacio de una rama

Rama: rama que deseo eliminar

git branch -d Rama

Cambio de rama

Rama: hacia donde quiero cambiar

git checkout Rama

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published