- Cognito client is created using the AWS console choosing SPA / React as the application.
- Frontend project is created at src/main/webappusing vite react router v7 template.
- Axios interceptor is configured to use the jwt token from the localStorage
- Axios is configured to work correctly in server mode and client mode using correct API base URL
- Cognito OIDC related configurations are loaded from the backend using a public endpoint at the server-side rendering. This enables the frontend only depends on the back end API base URL.
- Springboot application uses Java 17 / Maven
- Integrated Swagger UI for API documentation. Can be accessed at http://localhost:8080/swagger-ui/index.html
- Integrated Spring Security with JWT token authentication.
First create a Cognito user pool and client in the AWS console. Choose Single Page Application as the client type.
- Rename src/main/resources/application-dev.properties.exampletosrc/main/resources/application-dev.propertiesand fill the required fields.
- Run the Springboot application using the IDE or execute mvnw spring-boot:runin the root of the project. It will be available athttp://localhost:8080
- Wait until backend is ready.
- Go to src/main/webappand runnpm installto install the dependencies.
- Run npm run devto start the frontend server. It will be available athttp://localhost:5173
- 
Swagger UI is available at http://localhost:8080/swagger-ui/index.html
  
- 
After authentication, frontend fetches example data from a protected API endpoint and shows in the page. 
  
- Feel free to raise an issue
