Skip to content

Desafio para criar uma API RESTful de um delivery de restaurante.

Notifications You must be signed in to change notification settings

dya-andrade/restaurant-delivery

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Restaurant Delivery

CONCLUÍDO - Desafio para criar uma API RESTful de um delivery de restaurante.

Desenvolvimento

  • Java 8

  • Spring Boot (Data, Validation, Security e Hateoas)

  • DozerMapper para conversão de VO para Entity

  • MySQL 8.0.23 e Flyway para banco de dados

  • Postman para teste dos endpoints

  • Swagger para documentação dos endpoints

  • JWT com security para autenticação via token

Swagger

image

Login

  • JSON para realizar login
{
    "email":"admin.teste@gmail.com",
    "senha":"123456"
}
  • JSON resposta
{
    "email": "admin.teste@gmail.com",
    "autenticado": true,
    "criado": "2022-09-06T21:23:28.265+00:00",
    "expiracao": "2022-09-06T22:23:28.265+00:00",
    "accessToken": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhZG1pbi50ZXN0ZUBnbWFpbC5jb20iLCJyb2xlcyI6WyJST0xFX0FETUlOIl0sImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MCIsImV4cCI6MTY2MjUwMzAwOCwiaWF0IjoxNjYyNDk5NDA4fQ.ju-xggR9CTfl5fiIQkdUEZMqdqRM-C-8udMhrEzGORI",
    "refreshToken": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhZG1pbi50ZXN0ZUBnbWFpbC5jb20iLCJyb2xlcyI6WyJST0xFX0FETUlOIl0sImV4cCI6MTY2MjUxMDIwOCwiaWF0IjoxNjYyNDk5NDA4fQ.vhX3UJLmMMCVSkeLQS6EBl0KLXhZLwqEiP4QO5D7g-A"
}

image

Usuário

  • JSON para criar usuário
{
    "email":"dyane.aaraujo@gmail.com",
    "senha":"123456",
    "perfilAcesso":{
        "descricao":"Administrador"
    }
}
  • JSON resposta
{
    "id": 3,
    "email": "dyane.aaraujo@gmail.com",
    "senha": "123456",
    "perfilAcesso": {
        "descricao": "Administrador"
    },
    "_links": {
        "self": {
            "href": "http://localhost:8080/restaurante-delivery/usuario/3"
        }
    }
}

image

Cliente

  • JSON para criar cliente
{
    "nome": "Dyane Andrade",
    "telefone": "(11)92003-2417",
    "formaPagamento":"Débito",
    "endereco":{
        "logradouro":"Rua XXXX",
        "bairro":"XXXXXXX",
        "localidade":"Embu das Artes",
        "uf":"SP",
        "cep":"XXXXX-XXX"
    }
}
  • JSON resposta
{
    "id": 2,
    "nome": "Dyane Andrade",
    "telefone": "(11)92003-2417",
    "endereco": {
        "logradouro": "Rua XXXX",
        "bairro": "XXXXXXX",
        "localidade": "Embu das Artes",
        "uf": "SP",
        "cep": "XXXXX-XXX"
    },
    "formaPagamento": "Débito",
    "_links": {
        "self": {
            "href": "http://localhost:8080/restaurante-delivery/cliente/2"
        }
    }
}

image

Pedido

  • JSON para criar pedido
{
"itensPedido":[
        {
            "comidaBebida": "Picadinho",
            "quantidade": 3,
            "valorTotal": 50.00
        },
        {
            "comidaBebida": "Refrigerante",
            "quantidade": 1,
            "valorTotal": 5.00
        },
        {
            "comidaBebida": "Suco",
            "quantidade": 1,
            "valorTotal": 4.00
        }
    ],
"idCliente": 1,
"desconto":0.02
}
  • JSON resposta
{
    "id": 1,
    "cliente": {
        "id": 1,
        "nome": "Dyane Andrade",
        "telefone": "(11)92003-2417",
        "endereco": {
            "logradouro": "Rua XXXX",
            "bairro": "XXXXXXX",
            "localidade": "Embu das Artes",
            "uf": "SP",
            "cep": "XXXXX-XXX"
        },
        "formaPagamento": "Débito"
    },
    "itensPedido": [
        {
            "id": 1,
            "comidaBebida": "Picadinho",
            "quantidade": 3,
            "valorTotal": 75
        },
        {
            "id": 2,
            "comidaBebida": "Refrigerante",
            "quantidade": 1,
            "valorTotal": 5
        },
        {
            "id": 3,
            "comidaBebida": "Suco",
            "quantidade": 1,
            "valorTotal": 4
        }
    ],
    "data": "2022-09-06T17:53:36.6971438",
    "valorTotal": 83.98,
    "desconto": 0.02,
    "_links": {
        "self": {
            "href": "http://localhost:8080/restaurante-delivery/pedido/1"
        }
    }
}

image

Entrega

  • JSON para criar entrega
{
    "motoboy":"Leandro",
    "valor":10.0,
    "idPedidos":[
        1
    ]
}
  • JSON resposta
{
    "id": 1,
    "data": "2022-09-06T18:19:00.1792196",
    "motoboy": "Leandro",
    "valor": 10.0,
    "pedidos": [
        {
            "id": 1,
            "cliente": {
                "id": 1,
                "nome": "Dyane Andrade",
                "telefone": "(11)92003-2417",
                "endereco": {
                    "logradouro": "Rua XXXX",
                    "bairro": "XXXXXXX",
                    "localidade": "Embu das Artes",
                    "uf": "SP",
                    "cep": "XXXXX-XXX"
                },
                "formaPagamento": "Débito"
            },
            "itensPedido": [
                {
                    "id": 4,
                    "comidaBebida": "Picadinho",
                    "quantidade": 3,
                    "valorTotal": 75.00
                },
                {
                    "id": 5,
                    "comidaBebida": "Refrigerante",
                    "quantidade": 1,
                    "valorTotal": 5.00
                },
                {
                    "id": 6,
                    "comidaBebida": "Suco",
                    "quantidade": 1,
                    "valorTotal": 4.00
                }
            ],
            "data": "2022-09-06T17:55:42.396686",
            "valorTotal": 83.50,
            "desconto": 0.50
        }
    ],
    "_links": {
        "self": {
            "href": "http://localhost:8080/restaurante-delivery/entrega/1"
        }
    }
}

image

About

Desafio para criar uma API RESTful de um delivery de restaurante.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages