This is a simple e-commerce application with proper authentication and authorization controls so users can only access their data, and that data can only be accessed in a secure way.
This project has 5 packages, as follows:
-
demo - This package contains the main method which runs the application
-
model.persistence - This package contains the data models that Hibernate persists to H2. There are 4 models:
- Cart: for holding a User's items
- Item: for defining new items
- User: to hold appUser account information
- UserOrder: to hold information about submitted orders.
-
model.persistence.repositories - These contain a
JpaRepository
interface for each of our models. This allows Hibernate to connect them with our database so we can access data in the code, as well as define certain convenience methods. -
model.requests - This package contains the request models. The request models will be transformed by Jackson from JSON to these models as requests are made. We have two kinds of requests:
- CreateUserRequest: As the name suggest, it creates the new user request which is passed to the createUser api.
- ModifyCartRequest: It creates new cart request to add/delete items in a user's cart. It is passed to addToCart/removeFromCart api.
-
controllers - These contain the api endpoints for our app, one per model:
- CartController: Contains addToCart and removeFromCart api implementation
- ItemController: Gets items available in our database by id/name.
- OrderController: Submits a user's cart. Also, contains the api for fetching user order history.
- UserController: Creates a new user and fetches the user by name/id
-
security - This package contains classes that implement proper authentication and authorization controls so users can only access their data, and that data can only be accessed in a secure way. We have used username and password for authentication and JWT (Json Web Tokens) for authorization. The included files are:
- JWTAuthenticationFilter: It is a subclass of
UsernamePasswordAuthenticationFilter
for taking the username and password from a login request and logging in. This, upon successful authentication, should hand back a valid JWT in theAuthorization
header - JWTAuthorizationFilter: It is a subclass of
BasicAuthenticationFilter
. It implements private getAuthentication method which reads the JWT from the Authorization header, and then uses JWT to validate the token. If everything is in place, we set the user in the SecurityContext and allow the request to move on. - SecurityConstants: It consists of some constants that we use in the security package.
- UserDetailsServiceImpl: It implements
UserDetailsService
interface. which takes a username and returns aorg.springframework.security.core.userdetails.User
instance with the application username and hashed password from user repository. - WebSecurityConfiguration: It is a subclass of
WebSecurityConfigurerAdapter
. This should attach your app user details service implementation to Spring'sAuthenticationManager
. It also handles session management and what endpoints are secured. Every endpoint but one need security. The one that does not is the one responsible for creating new users (i.e./api/user/create
).
- JWTAuthenticationFilter: It is a subclass of
-
resources/data.sql - Its a sql file that populates our database with couple of items. Spring will run this file every time the application starts
To create a new app user we send a POST request to: http://localhost:8080/api/user/create with an example body like
{
"username": "test"
"password": "somepassword"
"confirmpassword": "somepassword"
}
and this would return
{
"id" 1,
"username": "test"
}
We can use Spring's default /login endpoint to login like:
POST /login
{
"username": "test",
"password": "somepassword"
}
and it would return a 200 OK with an Authorization header which looks like "Bearer " this "Bearer " is a JWT and must be sent as a Authorization header for all other requests. If it's not present, endpoints will return 401 Unauthorized. If it's present and valid, the endpoints will function as normal.
To run this service you execute:
$ mvn clean package
$ java -jar target/auth-course-0.0.1-SNAPSHOT.jar
It can also be imported in your IDE as a Maven project.