This project shows the implementation of REST architecture using Spring Boot and Spring Data JPA with QueryDSL. For mapping Entities to Dtos is used the ModelMapper framework (If performance matters consider MapStruct framework). Documentation for that REST API is implemented in the Swagger framework.
Name | |
---|---|
pavelseda@email.cz | Šeda Pavel |
You don't have to install Java, Maven, Tomcat, etc. to your local development environment. All you need is [Vagrant installed] (http://docs.ansible.com/ansible/latest/guide_vagrant.html).
vagrant up
Now check that documentation on the following section is reachable. NOTE: This command will also insert some testing data to data storages.
Documentation is done in Swagger framework. It is possible to reach it on the following page:
~/rest-training/api/v1/swagger-ui.html
e.g. on localhost it should be:
http://localhost:8080/rest-training/api/v1/swagger-ui.html
ADOC version of REST API documentation is generated here: (https://github.com/SedaQ/rest-training/blob/master/doc-files/ApiDocumentation.adoc)
PDF version of REST API documentation is generated here: (https://github.com/SedaQ/rest-training/blob/master/doc-files/ApiDocumentation.pdf)
NOTE: please note that client for that REST API could be generated using [Swagger codegen] (https://swagger.io/tools/swagger-codegen/). It is crucial to annotate each RestController method properly!
# Environment DEV or PROD
spring.profiles.active=DEV
server.address={server address}, e.g., localhost (127.0.0.1)
server.port={port for service}, e.g., 8080
server.servlet.context-path=/{context path for service}, e.g., /rest-training/api/v1
# DATASOURCE
spring.datasource.url=jdbc:postgresql://{url to DB}
spring.datasource.username={user in DB}
spring.datasource.password={password for user to DB}
spring.jpa.properties.hibernate.temp.use_jdbc_metadata_defaults = false
spring.jpa.database-platform=org.hibernate.dialect.PostgreSQL9Dialect
spring.jpa.hibernate.ddl-auto=validate
spring.jpa.show-sql=true
#spring.jpa.properties.hibernate.format_sql=true
spring.jpa.open-in-view=false
# spring cloud
spring.cloud.refresh.enabled = false
# Jackson (e.g. converting Java 8 dates to ISO format
spring.jackson.serialization.write_dates_as_timestamps=false
spring.jackson.property-naming-strategy=SNAKE_CASE
# to fix: Method jmxMBeanExporter in org.springframework.boot.actuate.autoconfigure.endpoint.jmx.JmxEndpointAutoConfiguration
spring.jmx.enabled = false
# FLYWAY
spring.flyway.url=jdbc:postgresql://{url to DB}
spring.flyway.user={user in DB}
spring.flyway.password={password for user to DB}
spring.flyway.table=schema_version
# Logging
logging.level.org.mitre.openid.connect.binder.service=DEBUG
logging.level.root= WARN
logging.level.org.springframework.security= DEBUG
logging.level.org.springframework.web= ERROR
logging.level.org.apache.commons.dbcp2= DEBUG
logging.level.org.hibernate=ERROR
logging.file = logs/rest-training.log
Prerequisities running PostgreSQL and created database named 'training' with schema 'public'. To migrate database data it is necessary to run this command:
$ mvn flyway:migrate -Djdbc.url=jdbc:postgresql://{url to DB}/rest-training -Djdbc.username={username in DB} -Djdbc.password={password to DB}
e.g.:
$ mvn flyway:migrate -Djdbc.url=jdbc:postgresql://localhost:5432/rest-training -Djdbc.username=postgres -Djdbc.password=postgres
NOTE: This script must be run in [persistence] (https://github.com/SedaQ/rest-training/tree/master/persistence) module.
Installing by maven:
mvn clean install
In Intellij Idea:
- Click on "Run" -> "Edit configurations".
- Choose "RestConfigTraining" configuration.
- Add into "Program arguments" --path.to.config.file="{path to your config properties}".
- Run RestConfigTraining
Runnig project from cmd (after project is installed and database is migrated):
mvn spring-boot:run -Dpath.to.config.file=../ansible/properties/training.properties
The project was built and tested with these technologies, so if you have any unexpected troubles let us know.
Maven : 3.3.9
Java : OpenJDK 11
Spring Boot : 2.1.1.RELEASE
Swagger : 2.9.2
Hibernate : 5.3.7.Final
Jackson : 2.9.7
Tomcat : 9
PostgreSQL : 11
Follow the steps in the following link: https://dzone.com/articles/installing-openjdk-11-on-ubuntu-1804-for-real
Verify the installation:
$ java -version
Do not forget to set OpenJDK in IntelliJ IDEA in all the places. The tutorial for setting OpenJDK in IntelliJ IDEA in all the places is shown in the following link: [https://stackoverflow.com/a/26009627/2892314].
$ apt-cache search maven
$ sudo apt-get install maven
Verify the installation:
$ mvn -v
Follow the steps in the following link: [https://www.digitalocean.com/community/tutorials/how-to-install-and-use-postgresql-on-ubuntu-16-04]