The Restaurant Management System is a Spring Boot-based application that provides a set of CRUD (Create, Read, Update, Delete) operations for managing users, including Admin, Normal User, and Visitor, along with food items in a restaurant. The system enforces role-based access control, ensuring that each type of user has the appropriate privileges.
- Framework: Spring Boot
- Language: Java 21
- Database: MySQL
- Build Tool: Maven
- Documentation: SpringDoc OpenAPI (Swagger UI)
- Email Handling: JavaMail API
The project utilizes the following dependencies:
-
Spring Boot Starter Data JPA: Simplifies database access using Spring Data repositories.
-
Spring Boot Starter Web: Provides support for building web applications, including RESTful APIs.
-
MySQL Connector/J (Runtime Dependency): The MySQL JDBC driver for connecting to MySQL databases.
-
Project Lombok (Optional): A library for reducing boilerplate code, such as getters and setters.
-
Spring Boot Starter Test (For Testing): Provides support for testing Spring Boot applications.
-
Springdoc OpenAPI (Swagger UI): Adds Swagger UI for documenting and testing API endpoints.
-
Spring Boot Starter Validation: Includes validation support for request data binding and response data rendering.
-
JavaMail API: Used for sending emails.
-
Spring Security: Ensures secure authentication and authorization for your application.
Controller | Functions Used |
---|---|
AdminController |
- addAdmin : Add a new admin user.- addFoodItem : Add a new food item to the menu. |
UserController |
- signUpUser : Register a new user.- signInUser : Authenticate and sign in a user.- addOrder : Place a food order.- getAllFoodItems : Retrieve a list of all food items. |
VisitorController |
- getAllFoodItems : Retrieve a list of all food items for visitors. |
Service | Functions Used |
---|---|
AdminService |
- addAdmin : Add a new admin user.- ifAdminExistOrNot : Check if an admin exists. |
AuthenticationService |
- saveAuthToken : Save an authentication token.- authenticate : Authenticate user based on an authentication token. |
FoodService |
- addFoodItem : Add a new food item to the menu.- isFoodInTheMenu : Check if a food item exists in the menu.- getAllFoodItems : Retrieve a list of all food items. |
OrderService |
- addOrder : Place a food order. |
UserService |
- signUpUser : Register a new user.- signInUser : Authenticate and sign in a user.- findFirstByUserEmail : Retrieve a user by email. |
Repository | Purpose |
---|---|
IAdminRepo |
Access and manage admin users in the database. |
IAuthenticationRepo |
Access and manage authentication tokens in the database. |
IFoodRepo |
Access and manage food items in the database. |
IOrderRepo |
Access and manage orders in the database. |
IUserRepo |
Access and manage users in the database. |
The database contains tables for users (including admins, normal users, and visitors), food items, orders, and authentication tokens.
- id (BIGINT - Primary Key): This field serves as the primary key, ensuring each user has a unique identifier.
- username (VARCHAR(255)): Stores the username of the user.
- password (VARCHAR(255)): Represents the hashed and salted password of the user.
- email (VARCHAR(255)): Contains the email address of the user.
- role (VARCHAR(50)): Denotes the role of the user, which can be "Admin," "Normal User," or "Visitor."
- is_signed_up (BOOLEAN): Indicates whether the user is signed up (true) or not (false).
- is_signed_in (BOOLEAN): Indicates whether the user is currently signed in (true) or not (false).
- created_at (TIMESTAMP): Records the timestamp of when the user account was created.
- id (BIGINT - Primary Key): A unique identifier for each food item.
- name (VARCHAR(255)): The name of the food item.
- description (TEXT): Provides a detailed description of the food item.
- price (DECIMAL(10,2)): Stores the price of the food item with two decimal places.
- type (VARCHAR(50)): Represents the type of food item (e.g., "Appetizer," "Main Course").
- id (BIGINT - Primary Key): A unique identifier for each order.
- user_id (BIGINT - Foreign Key): A foreign key referencing the user who placed the order.
- food_item_id (BIGINT - Foreign Key): A foreign key referencing the ordered food item.
- status (VARCHAR(50)): Indicates the status of the order, such as "Placed" or "Delivered."
- order_date (TIMESTAMP): Records the timestamp when the order was placed.
Column Name | Data Type | Description |
---|---|---|
id | BIGINT (PK) | Unique identifier for each user. |
username | VARCHAR(255) | Username of the user. |
password | VARCHAR(255) | Password of the user (hashed and salted). |
VARCHAR(255) | Email address of the user. | |
role | VARCHAR(50) | Role of the user (Admin, Normal User, Visitor). |
is_signed_up | BOOLEAN | Indicates whether the user is signed up or not. |
is_signed_in | BOOLEAN | Indicates whether the user is signed in or not. |
created_at | TIMESTAMP | Timestamp of user creation. |
Column Name | Data Type | Description |
---|---|---|
id | BIGINT (PK) | Unique identifier for each food item. |
name | VARCHAR(255) | Name of the food item. |
description | TEXT | Description of the food item. |
price | DECIMAL(10,2) | Price of the food item. |
type | VARCHAR(50) | Type of food item (e.g., Appetizer, Main Course). |
Column Name | Data Type | Description |
---|---|---|
id | BIGINT (PK) | Unique identifier for each order. |
user_id | BIGINT (FK) | Foreign key referencing the user who placed the order. |
food_item_id | BIGINT (FK) | Foreign key referencing the ordered food item. |
status | VARCHAR(50) | Status of the order (e.g., Placed, Delivered). |
order_date | TIMESTAMP | Timestamp of order placement. |
-
User Entity: This class represents the structure of user data in the database. It includes fields such as
id
,username
,password
,email
,role
,is_signed_up
,is_signed_in
, andcreated_at
. These fields are mapped to corresponding columns in the User Table. -
Food Item Entity: This class defines the structure for food item data in the database. It includes fields like
id
,name
,description
,price
, andtype
. These fields are mapped to corresponding columns in the Food Item Table. -
Order Entity: This class represents the structure of order data in the database. It includes fields such as
id
,user
,foodItem
,status
, andorderDate
. Theuser
andfoodItem
fields are mapped as foreign keys to the User Table and Food Item Table, respectively.
-
SignUpRequest: This DTO class is used to encapsulate the data needed to sign up a new user. It includes fields for
username
,password
, andemail
. -
SignInRequest: This DTO class encapsulates the data required to sign in a user. It includes fields for
username
andpassword
. -
FoodItemRequest: This DTO class is used for adding a new food item to the system. It includes fields for
name
,description
,price
, andtype
. -
OrderRequest: This DTO class represents the data needed to place a food order. It includes fields for
userId
andfoodItemId
. -
UserResponse: This DTO class is used to send user-related information as a response. It includes fields for
id
,username
,email
, androle
. -
FoodItemResponse: This DTO class is used to send food item-related information as a response. It includes fields for
id
,name
,description
,price
, andtype
. -
OrderResponse: This DTO class is used to send order-related information as a response. It includes fields for
id
,user
(containing user information),foodItem
(containing food item information),status
, andorderDate
.
These data structures, both entity classes and DTO classes, are essential components of the project, defining the structure of data and requests/responses used in the system.
-
User Entity: Represents user data in the database.
@Entity public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String username; private String password; private String email; private String role; private boolean isSignedUp; private boolean isSignedIn; private LocalDateTime createdAt; // Getters and setters }
-
Food Item Entity: Represents food item data in the database.
@Entity public class FoodItem { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; private String description; private BigDecimal price; private String type; // Getters and setters }
-
Order Entity: Represents order data in the database.
@Entity public class Order { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @ManyToOne @JoinColumn(name = "user_id") private User user; @ManyToOne @JoinColumn(name = "food_item_id") private FoodItem foodItem; private String status; private LocalDateTime orderDate; // Getters and setters }
-
SignUpRequest: Represents the data needed to sign up a new user.
public class SignUpRequest { private String username; private String password; private String email; // Getters and setters }
-
SignInRequest: Represents the data needed to sign in a user.
public class SignInRequest { private String username; private String password; // Getters and setters }
-
FoodItemRequest: Represents the data needed to add a new food item.
public class FoodItemRequest { private String name; private String description; private BigDecimal price; private String type; // Getters and setters }
-
OrderRequest: Represents the data needed to place a food order.
public class OrderRequest { private Long userId; private Long foodItemId; // Getters and setters }
-
UserResponse: Represents the response data for a user.
public class UserResponse { private Long id; private String username; private String email; private String role; // Getters and setters }
-
FoodItemResponse: Represents the response data for a food item.
public class FoodItemResponse { private Long id; private String name; private String description; private BigDecimal price; private String type; // Getters and setters }
-
OrderResponse: Represents the response data for an order.
public class OrderResponse { private Long id; private UserResponse user; private FoodItemResponse foodItem; private String status; private LocalDateTime orderDate; // Getters and setters }
These classes define the data structures used in the project for representing users, food items, orders, and related information.
To create the database tables based on this design, you can use a database migration tool like Flyway or Liquibase. These tools help manage database schema changes over time and can generate the tables based on your entity classes and design. Please let me know if you'd like specific instructions on setting up database migrations with one of these tools, or if you prefer a different approach.
The Restaurant Management System is a Spring Boot-based application that provides functionality for managing users, food items, and orders. It includes role-based access control, allowing admins to manage users and add food items, while regular users can sign up, sign in, and place orders. Visitors can view the menu items. The project uses a MySQL database to store data and includes validation for email patterns and input fields. It offers RESTful API endpoints for user registration, authentication, order placement, and food menu retrieval.
For more details, refer to the source code and API documentation.
This project is licensed under the BSD 3-Clause License.
For questions or feedback, please contact Amit Ashok Swain.