A tool to play Planning Poker.
When the JAR file is executed, a web server will be started and listen at http://localhost:8080.
Configuration may be done using properties.
- JRE 21
Authentication is possible via OIDC.
https://docs.spring.io/spring-security/reference/servlet/oauth2/login/core.html gives an overview over the required configuration.
It must be ensured that the resolved username (see user-name-attribute
in the previous link) is unique across all users.
Important: Using multiple OIDC providers at the same time is not supported by this application.
Extensions may be enabled by starting the application with additional profiles.
The Aha! extension can be enabled by starting the application with the profile extension:aha
.
The following additional properties must be set:
planning-poker.extension.aha.account-domain
: The subdomain part that the target Aha! instance is running on. For example, if you usehttps://example.aha.io
, this would beexample
.planning-poker.extension.aha.client-id
: The Aha! OAuth2 client ID. See https://www.aha.io/api/oauth2 for details.planning-poker.extension.aha.redirect-uri
: The Aha! OAuth2 redirect URI. Should be the address the application is running on.
Note that the Aha! Integration only works when the application is available under HTTPS.
A button "Load from Aha!" will appear next to the room name. It can be used to load the details of an Aha! ID or URL into the room. If the topic of a room is set to an Aha! idea ID or URL, a button to submit the average score to Aha! will show up after the voting is completed.
- Node.js 20
- JDK 21
- Maven
- IntelliJ IDEA
Create a keystore with a self-signed certificate (https://www.baeldung.com/spring-boot-https-self-signed-certificate) and adapt the application-development.properties
parameters.
Then export the certificate and its key, and make them available for Vite (vite.config.ts
).
Start the run config backend:dev
and frontend:dev
and go to https://localhost:8443.
Note that you may want to create a copy of backend:dev
configured with an OIDC provider.
Start the IntelliJ run configuration package
. This will create an executable JAR file in ./target
.
You can then also use the Dockerfile
to build a container image.
See ARCHITECTURE.md.
This project was developed for my "Ausbildung (Externenprüfung) Fachinformatiker Anwendungsentwicklung" (a form of apprenticeship in Germany). Thanks to Pointsharp GmbH for letting me work on this project during my employment.