Skip to content

TECHMA-Bootcamp-FullStack-Java-Angular/tsys-my-food-api

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Elements

My Food API Documentation

Welcome to the documentation for the Tsys My Food API. Below, you'll find information on how to navigate and use the available resources.

  • Javadoc: Explore comprehensive information about all controllers.
  • Swagger: You can try the routes with swagger
  • Postman: See the API documentation in postman.

Authentication Controller

Loguin

  • Endpoint: POST /auth/signin
  • Description: Authenticates a user based on provided credentials and generates a JSON Web Token (JWT) for further authentication.
  • Permissions: Public access.
  • JSON Example:
{
    "username": "Dani",
    "password": "password"
}

Validate Token

  • Endpoint: GET /auth/validate-jwt
  • Description: Validates the provided JWT.
  • Permissions: Requires a token

Register

  • Endpoint: POST /auth/signup
  • Description: Registers a new user with the provided details.
  • Permissions: Public access.
  • JSON Example:
{
    "username": "Dani",
    "password": "password",
    "email": "danidev@gmail.com"
}

User Controller

Get All Users

  • Endpoint: GET /api/v1/users
  • Description: Retrieves a paginated list of all users with simplified DTO representation.
  • Permissions: Requires 'ADMIN' role.

Get One User

  • Endpoint: GET /api/v1/user/{id}
  • Description: Retrieves a specific user by ID with simplified DTO representation.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the user to retrieve.

Save User

  • Endpoint: POST /api/v1/user
  • Description: Creates a new user and assigns the default role 'USER' if available.
  • Permissions: Requires 'ADMIN' role.
  • JSON Example:
{
    "email": "sergi@gmail.com",
    "password": "123456789",
    "username": "sergi",
    "created_at": "2023-01-01T12:00:00.000000Z",
    "updated_at": "2023-01-01T12:00:00.000000Z"
}

Update User

  • Endpoint: PUT /api/v1/user/{id}
  • Description: Updates an existing user.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the user to update.
  • JSON Example:
    {
      "email":"david2Dev@gmail.com",
      "username": "david",
      "role":{
        
      	"id": 1,
      	"name": "ADMIN"
        }
    }

Delete User

  • Endpoint: DELETE /api/v1/user/{id}
  • Description: Deletes a user by ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the user to delete.

Order Controller

Get All Orders

  • Endpoint: GET /api/v1/orders
  • Description: Retrieves a paginated list of all orders with user details.
  • Permissions: Requires 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of orders per page (default is 10).

Get One Order

  • Endpoint: GET /api/v1/order/{id}
  • Description: Retrieves details of a specific order by its ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters:
    • id (Long): ID of the order to retrieve.

Get All Orders For Chef

  • Endpoint: GET /api/v1/orders/chef
  • Description: Retrieves a paginated list of orders suitable for a chef, including associated dishes.
  • Permissions: Requires 'CHEF' or 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number for pagination (default is 0).
    • size (int, optional): Number of orders per page (default is 8).

Get All Orders For User

  • Endpoint: GET /api/v1/orders/{userId}
  • Description: Retrieves a paginated list of orders for a specific user.
  • Permissions: Requires 'USER' role.
  • Path Parameters:
    • userId (Long): ID of the user for whom to retrieve orders.
  • Query Parameters:
    • page (int, optional): Page number for pagination (default is 0).
    • size (int, optional): Number of orders per page (default is 10).

Get Orders By Date Paginate

  • Endpoint: GET /api/v1/orders/date
  • Description: Retrieves a paginated list of orders based on specified date parameters.
  • Permissions: Requires 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number for pagination (default is 0).
    • size (int, optional): Number of orders per page (default is 10).
    • year (Integer, optional): The year to filter orders by.
    • month (Integer, optional): The month to filter orders by.
    • day (Integer, optional): The day to filter orders by.

Save Order For User

  • Endpoint: POST /api/v1/order/{userId}
  • Description: Creates and saves a new order for the specified user.
  • Permissions: Requires 'USER' role.
  • Path Parameters:
    • userId (Long): ID of the user for whom to create the order.

Update Order

  • Endpoint: PUT /api/v1/order/{id}
  • Description: Updates an existing order.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters:
    • id (Long): ID of the order to update.
  • Request Body Example:
      {
        "totalPrice": 1,
        "actualDate": "2023-12-01T14:30:06.262Z"
      }

Mark Order As Maked

  • Endpoint: PUT /api/v1/order/markAsMaked/{id}
  • Description: Marks an order as "maked" (fulfilled).
  • Permissions: Requires 'CHEF' or 'ADMIN' role.
  • Path Parameters:
    • id (Long): ID of the order to mark as "maked".

Update Order Slot

  • Endpoint: PUT /api/v1/order/finish/{orderId}/{slotId}
  • Description: Updates the slot of an order, confirms it, and calculates the total price.
  • Permissions: Requires 'USER' role.
  • Path Parameters:
    • orderId (Long): ID of the order to update.
    • slotId (Long): ID of the slot to associate with the order.

Delete Order

  • Endpoint: DELETE /api/v1/order/{id}
  • Description: Deletes an order by its ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters:
    • id (Long): ID of the order to delete.

ListOrders Controller

Get All ListOrders (ADMIN)

  • Endpoint: GET /api/v1/list-orders
  • Description: Retrieves a paginated list of all list orders with user information excluding passwords.
  • Permissions: Requires 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of list orders per page (default is 10).

Get One ListOrder

  • Endpoint: GET /api/v1/list-order/{id}
  • Description: Retrieves details of a specific list order by its ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the list order to retrieve.

Get ListOrders By Order ID

  • Endpoint: GET /api/v1/list-order/orderid/{orderId}
  • Description: Retrieves a paginated list of list orders associated with a specific order ID.
  • Permissions: Public access.
  • Path Parameters:
    • orderId (Long): ID of the order to retrieve list orders for.
  • Query Parameters:
    • page (int, optional): Page number for pagination (default is 0).
    • size (int, optional): Number of list orders per page (default is 10).

Save ListOrder by Order ID and Item ID

  • Endpoint: POST /api/v1/list-order/{orderid}/{itemid}
  • Description: Creates a new list order based on the provided order ID, item ID, and item type (dish or menu).
  • Permissions: Public access.
  • Path Parameters:
    • orderid (Long): ID of the order associated with the list order.
    • itemid (Long): ID of the item associated with the list order (dish or menu).
  • Request Parameters:
    • itemType (String): Type of the item ("dish" or "menu").

Update ListOrder

  • Endpoint: PUT /api/v1/list-order/{id}
  • Description: Updates an existing list order.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the list order to update.
  • Request Body Example:
    {
      "id": 1,
      "menu": null,
      "dish": {
            "id": 1,
            "name": "Croquetas de Boletus",
            "description": "Una tapa de apetitosas croquetas con trozos de boletus",
            "image": "https://i.imgur.com/croquetas.png",
            "price": 3.5,
            "category": "APPETIZER",
            "visible": true
        },
      "order": {
        "id": 1
        }
    }
    

Delete ListOrder

  • Endpoint: DELETE /api/v1/list-order/{id}
  • Description: Deletes a list order by ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the list order to delete.

Menu Controller

Get All Menus

  • Endpoint: GET /api/v1/menus
  • Description: Retrieves a paginated list of all menus.
  • Permissions: Requires 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of menus per page (default is 10).

Get All Visible Menus

  • Endpoint: GET /api/v1/allVisibleMenus
  • Description: Retrieves a list of all visible menus, filtering out menus with invisible dishes.
  • Permissions: Requires 'USER' role.

Get One Menu (ADMIN)

  • Endpoint: GET /api/v1/menu/{id}
  • Description: Retrieves details of a specific menu by its ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the menu to retrieve.

Create Menu

  • Endpoint: POST /api/v1/menu
  • Description: Creates a new menu.
  • JSON Example:
{
  "appetizer": {
            "id": 2,
            "name": "Tabla de Quesos",
            "description": "Un plato con la mejor variedad de quesos",
            "image": "https://i.imgur.com/tablaqueso.png",
            "price": 6.5,
            "category": "APPETIZER",
            "visible": true
        },
  "first": {
            "id": 1,
            "name": "Macarrones a la Boloñesa",
            "description": "Contiene salsa de tomate ",
            "image": "https://i.imgur.com/macarrones.png",
            "price": 5.0,
            "category": "FIRST",
            "visible": true
        },
  "second":{
            "id": 3,
            "name": "Meloso de Ternera",
            "description": "Acompañamiento con patatas y pimiento",
            "image": "https://i.imgur.com/ternera.png",
            "price": 7.5,
            "category": "SECOND",
            "visible": true
        },
  "dessert": {
            "id": 4,
            "name": "Crema Catalana",
            "description": "Con azucar quemado por encima",
            "image": "https://i.imgur.com/crema.png",
            "price": 7.5,
            "category": "DESSERT",
            "visible": true
        },
  "visible": true
}

Update Menu

  • Endpoint: PUT /api/v1/menu/{id}
  • Description: Updates an existing menu.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the menu to update.
  • Request Body Example:
{
  "appetizer": {
            "id": 5,
            "name": "Croquetas de Jamón",
            "description": "Una tapa de apetitosas croquetas con trozos de jamón",
            "image": "https://i.imgur.com/croquetas.png",
            "price": 3.5,
            "category": "APPETIZER",
            "visible": true
        },
  "first": {
            "id": 1,
            "name": "Macarrones a la Boloñesa",
            "description": "Contiene salsa de tomate ",
            "image": "https://i.imgur.com/macarrones.png",
            "price": 5.0,
            "category": "FIRST",
            "visible": true
        },
  "second":{
            "id": 3,
            "name": "Meloso de Ternera",
            "description": "Acompañamiento con patatas y pimiento",
            "image": "https://i.imgur.com/ternera.png",
            "price": 7.5,
            "category": "SECOND",
            "visible": true
        },
  "dessert": {
            "id": 4,
            "name": "Crema Catalana",
            "description": "Con azucar quemado por encima",
            "image": "https://i.imgur.com/crema.png",
            "price": 7.5,
            "category": "DESSERT",
            "visible": true
        },
  "visible": true
}

Toggle Menu Visibility

  • Endpoint: PUT /api/v1/menu/changeVisibility/{id}
  • Description: Toggles the visibility status of a menu.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the menu to update.

Delete Menu

  • Endpoint: DELETE /api/v1/menu/{id}
  • Description: Deletes a menu by ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the menu to delete.

Dish Controller

Get All Dishes

  • Endpoint: GET /api/v1/dishes
  • Description: Retrieves a paginated list of all dishes.
  • Permissions: Requires 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of dishes per page (default is 10).

Get All Visible Dishes

  • Endpoint: GET /api/v1/dishes/visible
  • Description: Retrieves a paginated list of all visible dishes.
  • Permissions: Requires 'USER' role.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of visible dishes per page (default is 10).

Get One Dish

  • Endpoint: GET /api/v1/dish/{id}
  • Description: Retrieves details of a specific dish by its ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the dish to retrieve.

Get Dishes by Name

  • Endpoint: GET /api/v1/dish/byName/{name}
  • Description: Retrieves dishes by name, considering case-insensitive matching.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: name (String): Name of the dishes to retrieve.

Get Visible Dishes by Name

  • Endpoint: GET /api/v1/dish/visibleByName/{name}
  • Description: Retrieves visible dishes by name, considering case-insensitive matching.
  • Permissions: Requires 'USER' role.
  • Path Parameters: name (String): Name of the dishes to retrieve.

Get Dishes by Category

  • Endpoint: GET /api/v1/dishes/byCategory/{category}
  • Description: Retrieves dishes by category.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters:
    • category (String): Category of dishes to retrieve. Only accepts APPETIZER, FIRST, SECOND or DESSERT
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of dishes per page (default is 10).

Get Visible Dishes by Category

  • Endpoint: GET /api/v1/dishes/visibleByCategory/{category}
  • Description: Retrieves visible dishes by category.
  • Permissions: Requires 'USER' role.
  • Path Parameters:
    • category (String): Category of dishes to retrieve. Only accepts APPETIZER, FIRST, SECOND or DESSERT
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of visible dishes per page (default is 10).

Create Dish

  • Endpoint: POST /api/v1/dish
  • Description: Creates a new dish.
  • Permissions: Requires 'ADMIN' role.
  • JSON Example:
{
            "name": "Croquetas de Jamón",
            "description": "Una tapa de apetitosas croquetas con trozos de jamón",
            "image": "https://i.imgur.com/croquetas.png",
            "price": 3.5,
            "category": "APPETIZER",
            "visible": true
}

Update Dish

  • Endpoint: PUT /api/v1/dish/{id}
  • Description: Updates an existing dish.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the dish to update.
  • Request Body Example:
{
            "id": 1,
            "name": "Croquetas de Boletus",
            "description": "Una tapa de apetitosas croquetas con trozos de boletus",
            "image": "https://i.imgur.com/croquetas.png",
            "price": 3.5,
            "category": "APPETIZER",
            "visible": true
}

Change Dish Visibility

  • Endpoint: PUT /api/v1/dish/changeVisibility/{id}
  • Description: Toggles the visibility status of a dish.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the dish to update.

Delete Dish

  • Endpoint: DELETE /api/v1/dish/{id}
  • Description: Deletes a dish by ID.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the dish to delete.

Attribute-Dish Controller

Get All Atributes with Dishes

  • Endpoint: GET /api/v1/atributs
  • Description: Gets a paginated list of all relationships to the dish associated with that attribute.
  • Permissions: Requires 'ADMIN' role.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of relationships per page (default is 10).

Get One Attribute with Dishes

  • Endpoint: GET /api/v1/atribut/{id}
  • Description: Gets an attribute with the relationships to the plate associated with that attribute.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: id (Long): ID of the relationship to retrieve.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of relationships per page (default is 1).

Get All Atributes by Name with Dishes

  • Endpoint: GET /api/v1/atribut/ByName/{attributes}
  • Description: Gets a paginated list of all relationships to the dish associated with that name for atribute.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters: attributes (String): Attributes to filter by. Accepted values are: CELIAC, LACTOSE, VEGAN, VEGETARIAN, NUTS.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of relationships per page (default is 10).

Get All Atributes by Name with Dishes for User

  • Endpoint: GET /api/v1/atribut/visible/{atribut}/dishes
  • Description: Gets a paginated list of all relationships to the dish visibles associated with that name for atribute.
  • Permissions: Requires 'USER' role.
  • Path Parameters: atribut (String): Attribute to filter dishes by. Accepted values are: CELIAC, LACTOSE, VEGAN, VEGETARIAN, NUTS.
  • Query Parameters:
    • page (int, optional): Page number (default is 0).
    • size (int, optional): Number of dishes per page (default is 10).

Add Attribute-Dish Relationship to Dish

  • Endpoint: POST /api/v1/atribut/{atributDishId}/dish/{dishId}
  • Description: Associates an existing attribute-dish relationship with a dish.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters:
    • atributDishId (Long): ID of the attribute-dish relationship to associate.
    • dishId (Long): ID of the dish to associate.

Delete Attribute-Dish Relationship from Dish

  • Endpoint: DELETE /api/v1/atribut/{atributId}/dish/{dishId}
  • Description: Deletes the relationship between an attribute and a dish.
  • Permissions: Requires 'ADMIN' role.
  • Path Parameters:
    • atributId (Long): ID of the attribute-dish relationship to delete.
    • dishId (Long): ID of the dish associated with the attribute-dish relationship.

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%