Skip to content

Latest commit

 

History

History
160 lines (101 loc) · 3.75 KB

README.md

File metadata and controls

160 lines (101 loc) · 3.75 KB

api-crud-nestjs

This is a test for my internship application ☺️

Nest Logo

Description

The purpose of this test is to create a NestJS API to obtain information on barcodes via the OpenFoodFact API.

Features

  • Allow user registration via login/password

  • Allow authentication of a user via login / password

  • On an authenticated route, allow the search for a product by its barcode on the OpenFoodFacts API

  • Allow user update

  • Caching system calls to OpenFoodFacts

  • Dockerization

  • Kubernetes manifest for deployment

Tools I use :

  • Prisma as my ORM
  • PostgresSQL
  • Docker
  • Redis
  • Insomnia
  • Kubernetes
  • NPM

Make sure you have install in your cumputer :

Installation

After clonning my project, in the root directory run :

npm install

NB: put useful information in the .env file

Running the app

  • Run the app :
$ npm run project:start

⚠ Warning !!! : access the nest-api-crud container terminal

You can access the nest-api-crud container terminal by:

Using Docker CLI

docker exec -it nest-api-crud sh

Using Docker desktop:

-Open Docker Desktop. -Click on the container you want to access in the list of running containers. -Click on the "Terminal" button in the container details page.

In the terminal run:

npx prisma migrate dev

This command will sync the database with the API

Test the API

To test the API you can use Postman or Insomnia

NB: all you have to do is connect to your database by entering your identifiers to check the data present in your database.

Registration via login/password (method POST):

user register field type required
email string yes
password string yes
firstname string no
lastname string no

Authentication of a user via login / password (method POST):

user Authentication field type required
email string yes
password string yes

NB: this generate an access token

Search for a product by its barcode on the OpenFoodFacts API (method GET):

NB: In the Headers put - Bearer {accesstoken}

Update user (method PUT):

Set in the form the data to update

user update field type required
email string yes
password string no
firstname string no
lastname string no

Kubernetes manifest for deployment

In the root directory run :

kubectl apply -f kubernestes.deployment.yml

You can see the deployment by running:

kubectl get deployments

Checking which pod(s) are running

kubectl get pods

Stay in touch