A Spring Boot application built using PostgreSQL and Spring Data JPA to manage Logistics Services.
- Java 21 : Leveraging the latest LTS version of Java, improving readability and efficiency.
- Spring Boot 3 : An upgraded version of Spring Boot, enhancing developer productivity with its auto-configuration feature. Generated using Spring Initializr.
- Spring Data JPA : Simplifying the database access layer by reducing the boilerplate code.
- PostgreSQL Database : Integrated with PostgreSQL advanced relational database, ensuring high data consistency and integrity.
The project is organized into several packages, each serving a specific purpose:
-
controller
: This package contains our Rest Controllers. Here, we expose our endpoints, following the REST architectural style. DTOs are used in this layer to define the consumption interfaces appropriately, avoiding the exposure of unnecessary model attributes. -
repository
: In this package, we handle data access using interfaces provided by Spring Data JPA. -
model
: where our entities are defined, using JPA (Jakarta) annotations with our PostgreSQL database. -
services
: where our business logic lives. Here we validate our data, handle exceptions, and manage access to our PostgreSQL database through repositories. -
Application.java
: This is the main class to run our project. It initializes our Spring application and connects all the components together.
-
Make sure system has Spring Tool Suite, PostgreSQL and Postman installed.
- Steps to install Spring Tool Suite
- Steps to install PostgreSQL
- Steps to install Postman
-
Clone the repository and import the project in Spring Tool Suite IDE.
-
Run the application on the server.
-
Open Postman for using API and set local host port (8080) and implement CRUD operations.
-
Open pgAdmin4 and analyse the database created.
- Get Method
- ("/load") : Returns a list of all Logistics loads.
- ("/load/{loadId}") : Return the Logistic details for the provided
loadId
. - ("/load/shipperId/{shipperId}") : Return a list containg information about all Logistic loads with
shipperId
.
- Post Method
- ("/load) : Add the details of Logistic load in PostreSQL database.
- Put Method
- ("/load/{loadId}") : Update the details of Logistic load in PostreSQL database.
- Delete Method
- ("/load/{loadId}") : Delete the details of Logistic load in PostreSQL database.
Spring Web WEB
: Build web, including RESTful, applications using Spring MVC. Uses Apache Tomcat as the default embedded container.Spring Data JPA SQL
: Persist data in SQL stores with Java Persistence API using Spring Data and Hibernate.PostgreSQL Driver SQL
: A JDBC and R2DBC driver that allows Java programs to connect to a PostgreSQL database using standard, database independent Java code.Spring Boot DevTools DEVELOPER TOOLS
: Provides fast application restarts, LiveReload, and configurations for enhanced development experience.Lombok DEVELOPER TOOLS
: Java annotation library which helps to reduce boilerplate code.
Contributions are welcomed! If you encounter any issues or have suggestions for improvements, don't hesitate to open an issue or submit a pull request.