The API for the Beacon Südtirol project for configuring beacons and accessing beacon data.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
To build the project, the following prerequisites must be met:
- Java JDK 1.8 or higher (e.g. OpenJDK)
- Maven 3.x
- Database (ideally, PostgreSQL)
- Filesystem
Get a copy of the repository:
git clone https://github.com/idm-suedtirol/it.bz.beacon.api.git
Change directory:
cd it.bz.beacon.api/
- Go to
src/resources/
and make a copy ofapplication.dist.properties
. Name itapplication.properties
. Fill in the required values. See comments inside that file for further information. - Make sure your webserver is configured to handle file uploads for at least 10MB of size.
The schema of the database will be automatically generated when starting the
application based on the SQL files located in src/main/resources/db/migration
.
Also an admin user will be inserted with username "admin" and password "password". The admin will be the only user be able to create and delete users and reset their passwords initially, but then you can create arbitrary users and groups. Multiple administrators are possible.
Build the project:
mvn clean spring-boot:run
The unit tests can be executed with the following command:
mvn clean test
To build the application for production, execute the following command:
mvn clean package
For the project a Docker environment is already prepared and ready to use with all necessary prerequisites.
These Docker containers are the same as used by the continuous integration servers.
Install Docker (with Docker Compose) locally on your machine.
Before start working you have to start the Docker containers:
docker-compose up --build --detach
After finished working you can stop the Docker containers:
docker-compose stop
When the containers are running, you can execute any command inside the environment. Just replace the dots ...
in the following example with the command you wish to execute:
docker-compose exec java /bin/bash -c "..."
Some examples are:
docker-compose exec java /bin/bash -c "mvn clean test"
# or
docker-compose exec java /bin/bash -c "mvn clean spring-boot:run"
While running the last command, you can access the website at http://localhost:8080.
We have only a single user, namely admin
, that can manage new users. Just login with that user and go to the user list to create, update or delete user information.
The authentication layer of the API is divided in the following 3 parts:
- No auth - /v1/info/**, /v1/signin, /v1/checkToken
- JWT token - /v1/admin/**
- Basic auth - /v1/trusted/**
As a matter of fact, using the API, you have to choose which type of authentication has to be attached to the request (one of the 3 options above).
If you desire to access to an open API, no authentication has to be passed with the request.
- Make a request to /v1/signin using your credentials of the web application or android app
- If your credentials were correct, a JWT token will be present in the response
- In SwaggerUI, click on the "Authorize" button on the top of the page and insert "Bearer [token]" in the JWT token field by replacing [token] with the acutal token received in the response
- Click on "Authorize" in the JWT token section
- The padlocks on the right side of the JWT token protected API endpoints will turn black and closed
- You are now able to call JWT token protected APIs
- In SwaggerUI, click on the "Authorize" button on the top of the page and insert the credentials of the page in the username and password fields of the Basic auth section. These credentials were configured in your application.properties file.
- Click on "Authorize" in the Basic auth section
- The padlocks on the right side of the Basic auth protected API endpoints will turn black and closed
- You are now able to call Basic auth protected APIs
CAUTION! In case you set a wrong authorization header either for the JWT token or the Basic auth, some API endpoints may not work properly.
The Google spread sheet import is deprecated as of 2021: If you
enable info import, you have to create a Google service account which is able to
use the Google Sheet API and move the resulting client-secret.json file to
/src/main/resources/google-api-service-account.json. For more information on
generating this json file, have a look at the Google documentation for Using
OAuth 2.0 for Server to Server
Applications
For support, please contact info@beacon.bz.it.
If you'd like to contribute, please follow the following instructions:
-
Fork the repository.
-
Checkout a topic branch from the
development
branch. -
Make sure the tests are passing.
-
Create a pull request against the
development
branch.
More documentation can be found at https://opendatahub.readthedocs.io/en/latest/index.html.
The code in this project is licensed under the GNU AFFERO GENERAL PUBLIC LICENSE 3.0 or later license. See the LICENSE.md file for more information.
This project is REUSE compliant, more information about the usage of REUSE in NOI Techpark repositories can be found here.
Since the CI for this project checks for REUSE compliance you might find it useful to use a pre-commit hook checking for REUSE compliance locally. The pre-commit-config file in the repository root is already configured to check for REUSE compliance with help of the pre-commit tool.
Install the tool by running:
pip install pre-commit
Then install the pre-commit hook via the config file by running:
pre-commit install