Skip to content

ailenpaez/apimemes-proyectom5-ada15ava

Repository files navigation

🔰 TRABAJO INTEGRADOR MÓDULO 5 | API MEMES.

INTRO

🔸 INTRODUCCIÓN:

En este trabajo se construyó una api desde cero, usando distintas herramientas de nodeJS, express y otras dependencias como zod, randomUUID y encriptación de las contraseñas para brindar mayor seguridad.

Se crearon dos archivos JSON que almacenan datos de usuarios y otro para almacenar los datos de la temática seleccionada: memes.

Se proyectó la idea de hacer una red social, donde los usuarios puedan realizar distintas acciones sobre los memes y los usuarios. Para ello es necesario tener una cuenta, luego loguearse con usuario y contraseña. Esto les administrará un token único para cada usuario y cada sesión iniciada, que será fundamental para realizar las acciones que el usuario desee.


📍EJECUCIÓN DEL SISTEMA:

Para ejecutar estos procesos, poder ver la información solicitada y realizar las distintas acciones del sistema, debemos levantar el servidor con un comando de node. Aquí se podrán apreciar los comandos de ejecución que se enviarán por consola:

COMANDO DE EJECUCIÓN TIPO DE ACCESO
npm run start USUARIOS
npm run dev DESARROLLADORES
npm run build COMPILADO/PRODUCCIÓN

📍 INSTRUCCIONES PARA EL USUARIO.

🟢 Para los usuarios, estas acciones requieren tener la sesión iniciada:

  • Para obtener toda la lista de usuarios.
  • Para obtener la información de un usuario en particular.
  • Para modificar los datos de mi propio usuario.
  • Para borrar mi usuario.
  • Para cerrar la sesión.

🟢 Para realizar las siguientes modificaciones en memes, se requiere tener la sesión iniciada:

  • Para crear un nuevo meme.
  • Para modificar los datos de un meme.
  • Para borrar un meme.
  • Para likear un meme.

🔴 Acciones de usuarios que no requieren iniciar sesión:

  • Registrar un usuario.
  • Hacer el login de una cuenta. Para esta acción se requiere estar registrado.

🔴 Acciones sobre memes que se pueden realizar sin estar registrado o sin iniciar sesión:

  • Mostrar toda la lista de memes.
  • Buscar un meme por su ID.
  • Mostrar el top 5 de memes más likeados.

🟡 Otras acciones que se pueden realizar sin registro y sin iniciar sesión:

  • Mostrar la versión de la api.
  • Mostrar un ping que muestre la información del servidor y su configuración.

🔹 NOTAS PARA DESARROLLADORES:

Los desarrolladores que deseen probar el sistema, deben contar con nodeJs y se instelarán las dependecias adjuntas en el packaje.json. Se podrá hacer un PING con la herramienta OS de node, con el endpoint correspondiente. Aunque también el sistema ya tiene agregado otro ping para cada petición con la dependencia Morgan. Al compilar con el comando, y ejecutar desde el sistema compilado mejora la calidad y la rapidez de las respuestas a las peticiones. Por último, se agregó un archivo 'testing-postman-apimemes.json' para pruebas en POSTMAN, que se puede importar para realizar las peticiones de prueba.

🔹 ERD PARA EL FLUJO DE FUNCIONAMIENTO DE LA API:

ERD

🔹 EJEMPLOS DE ENDPOINTS USADOS EN EL ARCHIVO 'api.http':

# PRUEBAS API PARA MI SISTEMA - API MEMES

### Api Info:

GET http://localhost:1947/api/

### Ping con OS-node:

GET http://localhost:1947/api/ping

### Búsqueda por usuario (requiere token):

GET http://localhost:1947/api/users/USUARIO1
Authorization: token123

### Crear un usuario:

POST http://localhost:1947/api/users/register
Content-Type: application/json

{
"mail": "test10@gmail.com",
"username": "test10",
"password": "123456789",
"token": "",
"interests": ["animals", "kids", "comics"]
}

### Login de un usuario: (FUNCIONA BIEN CON POSTMAN)

POST http://localhost:1947/api/users/login
Content-Type: application/json

{
"username": "test10",
"password": "12345678"
}

### Modificar un usuario: (FUNCIONA BIEN CON POSTMAN)

PATCH http://localhost:1947/api/users/test10
Content-Type: application/json


{ "username": "test10",
  "mail": "prueba@gmail.com"
  }


Authorization: eca06d1d-a389-4313-a1e4-7d2abae07449


### Eliminar un usuario: (FUNCIONA BIEN CON POSTMAN)

DELETE http://localhost:1947/api/users/test10
CONTENT-TYPE: application/json

{"username": "test10"}

Authorization: eca06d1d-a389-4313-a1e4-7d2abae07449

### Logout de usuario: (FUNCIONA BIEN CON POSTMAN)

DELETE  http://localhost:1947/api/users/logout
Content-Type: application/json

{
   "username": "test001"
  }

Authorization: 66d628c5-b3a3-475c-9470-22d94536f0d4

### Obtener todos los memes:

GET http://localhost:1947/api/memes

### Obtener memes por author, con query params:

GET http://localhost:1947/api/memes/?author=test005

### Obtener meme por ID:

GET http://localhost:1947/api/memes/aaf05466-1dc1-4958-bcad-16175314971d

### Crear un nuevo meme:(FUNCIONA BIEN CON POSTMAN)
POST http://localhost:1947/api/memes/
Content-Type: application/json

{
    "id": "",
    "name": "ya wey",
    "categories": ["girl", "humor", "scenes"],
    "author": "test005",
    "imageUrl": "https://i.kym-cdn.com/entries/icons/original/000/045/575/blackcatzoningout_meme.jpg",
    "likes": [""]
  }

Authorization: fbbcacda-aa9a-4c37-8012-ceaaa44bd1e5


### Modificar un meme:(FUNCIONA BIEN CON POSTMAN)

PATCH http://localhost:1947/api/memes/4475e7ca-3a83-455c-90d9-8804e1d70dcc
Content-Type: application/json
 {
     "id": "4475e7ca-3a83-455c-90d9-8804e1d70dcc",
    "name": "michito",
    "categories": ["cats", "faces", "animals"]
      }

Authorization: fbbcacda-aa9a-4c37-8012-ceaaa44bd1e5

### Borrar un meme:(FUNCIONA BIEN CON POSTMAN)

DELETE http://localhost:1947/api/memes/aaf05466-1dc1-4958-bcad-16175314971d
Content-Type: application/json
Authorization: fbbcacda-aa9a-4c37-8012-ceaaa44bd1e5


### Dar un like al meme: (FUNCIONA BIEN CON POSTMAN)

PATCH http://localhost:1947/api/memes/f258c01f-38e8-4867-8ffb-66f9f16e27de/like
Content-Type: application/json

{
 "username": "laura55"
}

Authorization: 66d628c5-b3a3-475c-9470-22d94536f0d4

### Mostrar top 5 de memes más likeados:

GET http://localhost:1947/api/memes/top5


📋 Fuentes y documentación:


About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published