This repository contains example OAuth 2.0 resource servers built with imperative and reactive versions of Micronaut, Quarkus, Spring Boot, and Helidon. See the imperative and reactive demo scripts to see how these examples were created.
Prerequisites: Java 21 with GraalVM and HTTPie.
Events:
Tip
See releases for the code from a specific event.
Click the button below to start a new Gitpod development environment with this project:
Or, if you'd rather try things locally, clone this repository:
git clone https://github.com/mraible/java-rest-api-examples.git
You will need a JDK with GraalVM and its native-image compiler. Using SDKMAN, run the following command and set it as the default:
sdk install java 21.0.2-graalce
Next, you'll need a free Auth0 developer account.
Install the Auth0 CLI and run auth0 login
to connect it to your account.
Create an access token using Auth0's CLI:
auth0 test token -a https://<your-auth0-domain>/api/v2/ -s openid
Set the access token as a TOKEN
environment variable in a terminal window.
TOKEN=eyJraWQiOiJYa2pXdjMzTDRBYU1ZSzNGM...
Change the following files for each framework to match your Auth0 domain:
- Micronaut:
micronaut/src/main/resources/application.properties
- Quarkus:
quarkus/src/main/resources/application.properties
- Spring Boot:
spring-boot/src/main/resources/application.properties
- Helidon:
helidon/src/main/resources/application.properties
You can start each app using its CLI, Gradle, or Maven. Note that you will only be able to start one at a time since they all run on port 8080.
- Micronaut:
./gradlew run
- Quarkus:
quarkus dev
- Spring Boot:
./gradlew bootRun
- Helidon:
helidon dev
Then, you can test them with an access token and HTTPie.
Use HTTPie to pass the JWT in as a bearer token in the Authorization
header.
http :8080/hello Authorization:"Bearer $TOKEN"
You should see your email address printed to your terminal.
You can also build and run each example as a native app.
- Micronaut:
./gradlew nativeCompile
- Quarkus:
quarkus build --native
- Spring Boot:
./gradlew nativeCompile
- Helidon:
mvn package -Pnative-image
Then, start each app as a native executable.
- Micronaut:
./build/native/nativeCompile/app
- Quarkus:
./build/quarkus-1.0.0-SNAPSHOT-runner
- Spring Boot:
./build/native/nativeCompile/spring-boot
- Helidon:
./target/helidon
This example uses the following open source libraries:
Please post any questions as issues in this repo or start a discussion.
Apache 2.0, see LICENSE.