Skip to content

MTES-MCT/dossierfacile-backend

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DossierFacile Back-end

DossierFacile.fr a été créé par le Ministère de la Transition écologique
pour aider à la réalisation de dossiers de location.

The project is available at DossierFacile.fr.

The front-end code is also accessible in this repository.

Prerequisites

You need to have JDK 21, maven and Docker installed.

Database

Run:

docker-compose -f docker-compose.dev.yml up -d

To create a dedicated user and database for dossierfacile.

Keycloak

If you want to use Keycloak locally, follow the README instructions on repo Dossier-Facile-Keycloak.

To run this project, you will need the realm "dossier-facile" and a new client "dossier-facile-api", with:

  • selected theme "df"
  • in capability config, "client authentication" activated Then go to tab "credentials" and copy the client secret

Config

Create a new folder mock_storage to store files.

Create the file application-dev.properties in dossierfacile-bo/src/main/resources

mock.storage.path=/path/to/mock_storage/
server.port=8081
application.name=bo
application.domain=http://localhost:8081
domain.protocol=http
environment=localhost

mock.storage.path=mockstorage
storage.provider.list=LOCAL

# SQL
spring.datasource.url=jdbc:postgresql://localhost:5432/dossierfacile
spring.datasource.username=dossierfacile
spring.datasource.password=

# SSO Google
spring.security.oauth2.client.registration.google.client-id=
spring.security.oauth2.client.registration.google.client-secret=
spring.security.oauth2.client.registration.google.redirect-uri-template={baseUrl}/oauth2/callback/{registrationId}
spring.security.oauth2.client.registration.google.scope=email,profile
authorize.domain.bo=dossierfacile.fr
authorize.bo.access.emails=

# Keycloak
keycloak.server.url=http://localhost:8085/auth
keycloak.server.realm=dossier-facile
keycloak.server.client.id=
keycloak.server.client.secret=

# Logging
logging.config=
logging.level.root=info
logging.file.path=logs
logging.logstash.destination=

# Brevo
brevo.apikey=

Create the file application-dev.properties in dossierfacile-api-tenant/src/main/resources

mock.storage.path=/path/to/mock_storage/
storage.provider.list=LOCAL
api.version=3
tenant.base.url=localhost:9002
server.port=8090
application.base.url=http://localhost:8090
# SQL
spring.datasource.url=jdbc:postgresql://localhost:5433/dossierfacile
spring.datasource.username=
spring.datasource.password=
# Keycloak
keycloak.server.url=http://localhost:8085/auth
keycloak.server.realm=dossier-facile
keycloak.server.client.id=dossier-facile-api
keycloak.server.client.secret=
spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:8085/auth/realms/dossier-facile
spring.security.oauth2.resourceserver.jwt.jwk-set-uri=http://localhost:8085/auth/realms/dossier-facile/protocol/openid-connect/certs
# Brevo
brevo.apikey=

Create the file application-dev.properties in dossierfacile-api-owner/src/main/resources

mock.storage.path=/path/to/mock_storage/
owner.url=http://localhost:3000
server.port=8083
# SQL
spring.datasource.url=jdbc:postgresql://localhost:5433/dossierfacile
spring.datasource.username=
spring.datasource.password=
# Keycloak
keycloak.server.url=http://localhost:8085/auth
keycloak.server.realm=dossier-facile
keycloak.server.client.id=dossier-facile-api
keycloak.server.client.secret=
spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:8085/auth/realms/dossier-facile-owner
spring.security.oauth2.resourceserver.jwt.jwk-set-uri=http://localhost:8085/auth/realms/dossier-facile-onwer/protocol/openid-connect/certs
tenant.jwt.issuer-uri=http://localhost:8085/auth/realms/dossier-facile
tenant.jwt.jwk-set-uri=http://localhost:8085/auth/realms/dossier-facile/protocol/openid-connect/certs
# Brevo
brevo.apikey=

Create the file application-dev.properties in dossierfacile-process-file/src/main/resources

mock.storage.path=/path/to/mock_storage/
storage.provider.list=LOCAL
server.port=8088
# SQL
spring.datasource.url= jdbc:postgresql://localhost:5433/dossierfacile
spring.datasource.username=
spring.datasource.password=
# Keycloak
keycloak.server.url=http://localhost:8085/auth
keycloak.server.realm=dossier-facile
keycloak.server.client.id=dossier-facile-api
keycloak.server.client.secret=
# Brevo
brevo.apikey=

Create the file application-dev.properties in dossierfacile-api-watermark/src/main/resources

server.port=8091
mock.storage.path=/path/to/mock_storage/
storage.provider.list=LOCAL
# SQL
spring.datasource.url=jdbc:postgresql://localhost:5433/dossierfacile
spring.datasource.username=
spring.datasource.password=

Create the file application-dev.properties in dossierfacile-pdf-generator/src/main/resources

mock.storage.path=/path/to/mock_storage/
storage.provider.list=LOCAL
# SQL
spring.datasource.url= jdbc:postgresql://localhost:5433/dossierfacile
spring.datasource.username=
spring.datasource.password=
# Keycloak
keycloak.server.url=http://localhost:8085/auth
keycloak.server.realm=dossier-facile
keycloak.server.client.id=dossier-facile-api
keycloak.server.client.secret=
# Brevo
brevo.apikey=

For each properties file, copy the brevo.template.* properties from application.properties to application-dev.properties and set the correct ids.

Note:

  • In the case of the dossierfacile-bo service run, it appears that some Brevo template identifiers are missing (particularly on the partner side)

HTTPS config for backOffice access

The dossierfacile-bo service requires HTTPS access for Google Single Sign-On (SSO). The docker-compose.dev.yml deploys an nginx container as a reverse proxy, with configuration located at ./.nginx/nginx.conf. DossierFacile back-office will be served at https://bo-local.dossierfacile.fr/

Generate Self-Signed SSL Certificate

Create SSL certificate files using OpenSSL:

openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout nginx.key -out nginx.crt

Certificates must be placed in folder ./.nginx/certs

Note: When prompted, fill in the certificate details. The Common Name (CN) should match bo-local.dossierfacile.fr.

Configure local hosts

Add the following line to /etc/hosts:

127.0.0.1   bo-local.dossierfacile.fr

Important: This step is crucial because Google SSO is configured with this specific redirect URI. Omitting this will result in a redirect_uri_mismatch error during login: Erreur 400 : redirect_uri_mismatch

Initial login and user setup

Log in with a Google account. This automatically creates a user in the public.user_account table of the PostgreSQL dossierfacile database.

List existing users to find your user ID:

SELECT *
FROM public.user_account;

Add role entry to grant back-office access:

INSERT INTO public.user_roles
("role", user_id)
VALUES(2, <YOUR_USER_ID>);

Build

Run mvn clean install from the root folder. This will build every module.

Launch

In each application folder, run

mvn spring-boot:run -D spring-boot.run.profiles=dev,mockOvh

Infrastructure

Infrastructure diagram

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

MIT