BeAPI Framework Installation
Getting started with the BeAPI Springboot Starter is a simple process. Prior to building and running though, we must first talk installation.
Requirements
The BeAPI™ API Framework has the following project requirements:
- Java 1.8 >
- Springboot 2.6.2 >
- Gradle 8 > (for building)
Start by cloning the demo project to a local directory:
git clone https://github.com/Beapi-io/beapi-java-demo.git
Next, create a directory in the project owners home directory in a hidden directory called '.beapi' and clone all configuration files over:
git clone Beapi-io/spring-boot-starter-beapi-config
Configure Demo Project
You will also need to configure your project by changing your...
Setup Demo Project DB
You will now need to setup your database and edit your beapi_db.yml file (please DB section under 'Configure Demo Project'). This will allow you to setup your default DB for the demo project.
- Login to MySQL via the shell from the directory in which the 'boot.sql' file is and use the following commands:
mysql -uroot -p{yourpassword} create database boot; use boot; source boot.sql; GRANT ALL ON boot.* to 'yourlogin'@'localhost' IDENTIFIED BY 'yourpassword'; FLUSH PRIVILEGES; exit;
- Next, go into your ~/.beapi/dev directory and find the beapi_db.yaml file for editing and change the following lines:
username: "root" password: "password"
NOTE: you will have to copy this file to the 'test' and 'prod' folders as well.
- Finally, go into your '/src/main/resources/application.properties' and make sure, that your environment is set to 'dev':
spring.profiles.active=dev
Build Demo Project
Now that you have everything configured, you will need to build the project. In your gradle.properties, you have three properties (as well as a default variable for setting the 'default configType):
- configType.nano
- configType.medium
- configType.large
Pass your 'configType' you wish to use in the following command in a shell to build your project :
gradle clean build -Pargs=configType=nano
or if you are fine with the default config (which is usually 'nano'), just run :
gradle clean build
Run Demo Project
If your database is properly configured and running, you will now need to change your default bootstrapped users.
- Look in your ~/.beapi/{env} dir for a file called 'beapi_api.yaml' (you will want to change this in all environments but change FIRST in the environment your are using right now). In this file you will find the bootstrapping for an ADMIN and a TEST user that are created on startup :
bootstrap: superUser: { login: 'admin', password: '@6m!nP@s5', email: 'email@yourdomain.com' } testUser: { login: 'test', password: 't35tP@s5', email: 'test@yourdomain.com', }
- Use the superUser login/password to create a curl request to get your token:
curl -v -H "Content-Type: application/json" -X POST -d '{"username":"admin","password":"@6m!nP@s5"}' http://localhost:8080/authenticate
- This will return something that looks like the following :
> GET /v0.4.1/user/show/test HTTP/1.1 > Host: localhost:8080 > User-Agent: curl/7.58.0 > Accept: */* > Content-Type: application/json > Authorization: Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsImV4cCI6MTY2MDA4NzM1OSwiaWF0IjoxNjYwMDY5MzU5fQ.bR8lgrGlzCmHKhXC1D_LF-vVmFINAVX9kgA2n-EiIbslYaix65FXB7qrPRVJxrgqhzNcdTiBOhScbujQwy0ufA
- Everything after 'Bearer' is your TOKEN (not the space of course). Add this to the 'AUTHORIZATION' header with every request you make:
curl -v -H "Content-Type: application/json" -H "Authorization: Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsImV4cCI6MTY2MDA4NzM1OSwiaWF0IjoxNjYwMDY5MzU5fQ.bR8lgrGlzCmHKhXC1D_LF-vVmFINAVX9kgA2n-EiIbslYaix65FXB7qrPRVJxrgqhzNcdTiBOhScbujQwy0ufA" --request GET "http://localhost:8080/v0.4.1/user/show/test"
- Voila! If all goes well, this will output the 'test' user that was bootstrapped on startup:
{"firstName":"null","lastName":"null","accountExpired":false,"id":20,"version":2229,"email":"test@yourdomain.com","enabled":true,"username":"test"}
Troubleshooting
- Make sure you have proper READ/WRITE/EXECUTE(755) for the files in ~/.beapi/ and ~/.beapi/.iostate
- Make sure you have matching named Controllers for all IO State files; see examples in ~/.beapi/.iostate directory
- If you want to use a version of Java HIGHER than 1.8, change 'sourceCompatibility' in ALL gradle.properties files (ie demo-application/gradle.properties,/gradle.properties)