This example app shows how to create a Spring Cloud Streams app using Spring WebFlux and JWT OAuth. The app
demonstrates how to publish and subscribe to topics, as well as how to stream events from a WebFlux REST endpoint. It generates
a random stream of integers, which it publishes to the ints
channel. A processor listens to this channel, calculates a running
total, and publishes the total and the current value to the total
channel. A WebFlux endpoint publishes the total
channel as
an events stream.
Please read A Quick Guide to Spring Cloud Stream to see how this app was created.
Prerequisites:
- Java 11: This project uses Java 11. OpenJDK 11 will work just as well. Instructions are found on the OpenJDK website. OpenJDK can also be installed using Homebrew. Alternatively, SDKMAN is another great option for installing and managing Java versions.
- Maven: You need Maven installed to bootstrap the project. Install it according to the instructions on their website. Or use SDKMAN or Homebrew.
- Okta Developer Account: You’ll be using Okta as an OAuth/OIDC provider to add JWT authentication and authorization to the application. You can go to our developer site and sign up for a free developer account.
- HTTPie: This is a powerful command-line HTTP request utility that you'll use to test the WebFlux server. Install it according to the docs on their site.
- Docker and Docker Compose: You'll use Docker and Docker Compose to run the RabbitMQ service. First you need to install Docker. On Mac and Windows you can install the desktop client. On Linux you'll need to install Docker Machine directly. Take a look at the Docker docs for installation instructions. for your operating system. Once you have Docker installed, follow the instructions to install Docker Compose.
Okta has Authentication and User Management APIs that reduce development time with instant-on, scalable user infrastructure. Okta's intuitive API and expert support make it easy for developers to authenticate, manage, and secure users and roles in any application.
To install this example application, run the following commands:
git clone https://github.com/oktadeveloper/okta-spring-cloud-streams-example.git
cd okta-spring-cloud-streams-example
This will get a copy of the project installed locally. Before the projects apps will run, however, you need to create an OIDC application in Okta and configure the application to use it.
The fastest way to do this is to use the Okta Maven Plugin, which will configure an OIDC application for you.
mvn com.okta:okta-maven-plugin:setup
This places the necessary values in the src/main/resources/application.yml
file. If you create an OIDC application manually on the Okta website, just make sure you put the necessary values in the application.yml
file.
okta:
oauth2:
client-secret: {yourClientSecret}
client-id: {yourClientId}
issuer: https://{yourOktaDomain}/oauth2/default
If you already have an Okta developer account and Okta Org, you can create a configuration file at ~/.okta/okta.yaml
for Okta Maven Plugin that will use that account.
~/.okta/okta.yaml
okta:
client:
orgUrl: https://{yourOktaDomain}
token: {yourApiToken}
You'll need to create an API token. From the Okta developer's console, go to API and Tokens. Click Create Token. Give the token a name. Copy the token value and place it in the yaml
file along with your Okta domain.
If you do not have an Okta developer's account, don't worry about the okta.yaml
file. The Okta Maven Plugin will configure it for you.
To run the RabbitMQ messaging server, run the following command. You may need to run this as root using sudo
. Leave this process running.
docker-compose up
To run the Spring Boot application, open a new shell and run the following.
./mvnw spring-boot:run
You will need to generate a JWT to test the application. To do this, you can use the OIDC Debugger. For full instructions, see the blog post associated with this project.
Once you have a token, store it in a shell variable and run a request using HTTPie.
TOKEN={your token value}
http --stream :8080/sse "Authorization: Bearer ${TOKEN}"
You should see some streaming data.
...
data:{"currentValue":57,"total":6055}
data:{"currentValue":1,"total":6056}
data:{"currentValue":2,"total":6058}
data:{"currentValue":10,"total":6068}
data:{"currentValue":62,"total":6130}
data:{"currentValue":29,"total":6159}
data:{"currentValue":85,"total":6244}
data:{"currentValue":84,"total":6328}
...
This example uses the following open source libraries:
- Okta Maven Plugin
- Okta Spring Boot starter
- Spring Cloud Streams
- Spring Boot
- Spring Security
- RabbitMQ
Please post any questions as comments on the blog post, or visit our Okta Developer Forums. You can also email [email protected] if you'd like to create a support ticket.
Apache 2.0, see LICENSE.