Tech Challenge 5

Bem-vindo(a) a documentação oficial desenvolvida para este Tech Challenge.

Objetivo: Simular os principais microsserviços de um e-commerce. A interação e consumo entre eles. E controle de acesso através de autenticação e autorização tokenizado.

Link do Repositório

Tecnologias e Ferramentas

  • Java 17 e 21
  • Maven
  • Spring Data JPA
  • Spring Web
  • Spring Security
  • Spring Validation
  • Spring OpenFeign
  • Jwt
  • PostgreSQL
  • Lombok
  • Swagger
  • Postman
  • IntelliJ
  • Git
  • GitHub
  • Docker

Como rodar o projeto

Para rodar todo o projeto, utilize o maven. Caso não tenha o Maven instalado, pode utilizar o wrapper que acompanha o projeto. Neste caso, entre na pasta raiz de cada serviço e utilize o comando ./mvnw. É necessário estar com Docker rodando para conexão com banco de dados.

Comando Descrição Requisitos
docker-compose up -d Subir os serviços da aplicação Docker instalado na máquina
./mvnw spring-boot:run Roda a aplicação localmente Postgres rodando

Diagramas

arquitetura

Postman Collection

Tc-5.postman_collection.json


tc5-login-users

Método Url Descrição Permissão
POST /auth/register Registra um novo usuario All
POST /auth/login Faz o login de um usuario All
GET /user/all Busca todos os usuarios ADMIN
PUT /user/update/byid/{id} Atualiza um usuario USER
DELETE /user/delete/{id} Apaga um usuario ADMIN

Login protegido e seções controladas através de token.

Exemplos de entrada

POST - /auth/register

Uses Curl

curl -X 'POST' \
  'http://localhost:8080/auth/register' \
  -H 'accept: */*' \
  -H 'Content-Type: application/json' \
  -d '{
  "login": "teste-3",
  "password": "senha123",
  "role": "ADMIN"
}'
POST - /auth/login

Uses Curl

curl -X 'POST' \
  'http://localhost:8080/auth/login' \
  -H 'accept: */*' \
  -H 'Content-Type: application/json' \
  -d '{
  "login": "teste-3",
  "password": "senha123"
}'
GET - /users/all

Uses Curl

curl --location 'http://localhost:8080/users/all' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzE4Mjh9.yDxXasb18nTaGLGuM--nYoo0zejTOWXu5rGrx8l5ljE'
PUT - /users/update/{id}

Uses Curl

curl --location --request PUT 'http://localhost:8080/users/update/3' \
--header 'Content-Type: application/javascript' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzI1NTV9.1iR0XSLbnZZEWDV_l202q_ltyXYg4dDmEMIGC1jg9Ig' \
--data '{
    "role": "USER"
}'
DELETE - /users/delete/{id}

Uses Curl

curl --location --request DELETE 'http://localhost:8080/users/delete/4' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzI1NTV9.1iR0XSLbnZZEWDV_l202q_ltyXYg4dDmEMIGC1jg9Ig'
Complement

Esse microsservico permite ainda adicionar complemento para dados adicionais do usuário como: endereço, data de nascimento, cpf e etc. Sendo necessário para isso indicar o usuário ao qual terá informações adicionadas.

Método Url Descrição Permissão
POST /complement/save Registra um novo complemento ligado ao usuário ADMIN/USER
GET /complement/all Busca todos os complementos ADMIN/USER
GET /complement/byid/{id} Busca um complemento de usuario ADMIN/USER
PUT /complement/update/{id} Atualiza um complemento de usuario ADMIN/USER
DELETE /complement/delete/{id} Apaga um complemento de usuario ADMIN/USER

tc5-api-products

Método Url Descrição
GET /products Busca todos os produto
GET /products/{uuid} Busca produto por uuid
POST /products Cria um novo produto
PUT /products/{uuid} Atualiza um produto
DELETE /products/{uuid} Apaga um produto
GET /stock Busca todos os produtos no estoque
GET /stock/{uuid} Busca um produto no estoque
POST /stock/input Dar entrada de um produto no estoque
POST /stock/output Faz a saida de um produto no estoque

Exemplos de entrada

GET - /products

Uses Curl

curl --location 'http://localhost:8081/products' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzYyNTF9.F1ko8-ng22rLUCwvObA-PckD3PmNzc6-w3X8MG0ctwc'
GET - /products/{uuid}

Uses Curl

curl --location 'http://localhost:8081/products/a26862f4-4ed9-4768-b2ac-7411942bd96a' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzYyNTF9.F1ko8-ng22rLUCwvObA-PckD3PmNzc6-w3X8MG0ctwc'
POST - /products

Uses Curl

curl --location 'http://localhost:8081/products' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzYyNTF9.F1ko8-ng22rLUCwvObA-PckD3PmNzc6-w3X8MG0ctwc' \
--data '{
    "name": "Agua 1L",
    "price": 2.0,
    "description": "Agua mineral fonte São Sebastião de 1 litros.",
    "imageUri": "https://github.com/devsuperior/sds2/blob/master/assets/pizza_moda.jpg"
}'
PUT - /produts/{uuid}

Uses Curl

curl --location --request PUT 'http://localhost:8081/products/9e89dfd9-8698-4337-b0db-98c05a36006c' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzY0NzF9.KnlS3rh6IXGOwqv6bqUwzDsJytuE3Kfzrf2Ud5X4IeY' \
--data '{
    "name": "Agua 1L",
    "price": 3.0,
    "description": "Agua mineral fonte São Sebastião de 1 litros.",
    "imageUri": "https://raw.githubusercontent.com/devsuperior/sds2/master/assets/macarrao_espaguete.jpg"
}'
DELETE - /products{uuid}

Uses Curl

curl --location --request DELETE 'http://localhost:8081/products/672fd827-2ec8-45ba-a097-a54a653d9d13' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzY0NzF9.KnlS3rh6IXGOwqv6bqUwzDsJytuE3Kfzrf2Ud5X4IeY'
GET - /stock

Uses Curl

curl --location 'http://localhost:8081/stock' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzY2Mzh9.HbRelwLPVPTTar2E7Yt3yNRHPHweAdCDM72_WJd945w'
GET - /stock/{uuid}

Uses Curl

curl --location 'http://localhost:8081/stock/c383ea7e-89f3-45c9-bab9-5b59d9c2d684' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzY2Mzh9.HbRelwLPVPTTar2E7Yt3yNRHPHweAdCDM72_WJd945w'
POST - /stock/input

Uses Curl

curl --location 'http://localhost:8081/stock/input' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzY2Mzh9.HbRelwLPVPTTar2E7Yt3yNRHPHweAdCDM72_WJd945w' \
--data '{
    "id_product": "c383ea7e-89f3-45c9-bab9-5b59d9c2d684",
    "amount_stock": 10
}'
POST - /stock/output

Uses Curl

curl --location 'http://localhost:8081/stock/output' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzY2Mzh9.HbRelwLPVPTTar2E7Yt3yNRHPHweAdCDM72_WJd945w' \
--data '{
    "id_product": "c383ea7e-89f3-45c9-bab9-5b59d9c2d684",
    "amount_stock": 2
}'

tc5-api-carts

Método Url Descrição
GET /orders Busca todos os pedidos pendentes
GET /orders/{uuid} Busca um pedido por uuid
POST /orders Criar um pedido
POST /cart/product/1 Adiciona um produto e a quantidade ao carrinho de compras

Exemplos de entrada

GET - /orders

Uses Curl

curl --location 'http://localhost:8082/orders' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzcyMTR9.KlberqDZIq76ZOx56vG2OJkmd8WBrnr4Jr2pzhaEWps'
GET - /orders/{uuid}

Uses Curl

curl --location 'http://localhost:8082/orders/9c6a57b7-4915-4fb9-8a33-161f9c6c04a4' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzcyMTR9.KlberqDZIq76ZOx56vG2OJkmd8WBrnr4Jr2pzhaEWps'
POST - /orders

Uses Curl

curl --location 'http://localhost:8082/orders' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6InRlc3RlLTMiLCJpZCI6MywidXNlciI6InRlc3RlLTMiLCJleHAiOjE3MTExMzcyMTR9.KlberqDZIq76ZOx56vG2OJkmd8WBrnr4Jr2pzhaEWps' \
--data '{
   "products":[
      {
         "id_product":"d345c67d-2374-4daf-94cc-d8b4dacfd300"
      },
      {
         "id_product":"f629d5a3-b0f8-418a-9aca-0c007b7e7ea4"
      }
   ]
}'
POST - /carts/product/{uuid}/1

Uses Curl

curl --location --request POST 'http://localhost:8082/carts/product/f629d5a3-b0f8-418a-9aca-0c007b7e7ea4/5' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6IlRlc3RlLTIiLCJpZCI6MiwidXNlciI6IlRlc3RlLTIiLCJleHAiOjE3MTEwNTE5MjV9.D9RcCVnYsJ771SKagBhYypARMnQhRFzd1MEIqrIikFI'

tc5-payments

Método Url Descrição
PUT /payments/{uuid}/paid Efetuar o pagamento de um pedido

Exemplos de entrada

PUT - /payments/{uuid}/paid

Uses Curl

curl --location --request PUT 'http://localhost:8083/payments/3dd58300-a79a-4e07-8a81-33db015d1762/paid' \
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJhdXRoLWFwaSIsInN1YiI6IlRlc3RlLTIiLCJpZCI6MiwidXNlciI6IlRlc3RlLTIiLCJleHAiOjE3MTEwNTE5MjV9.D9RcCVnYsJ771SKagBhYypARMnQhRFzd1MEIqrIikFI'