gemini protocol server on top of jetty.
- integration with jetty & spring boot
- supports all the goodies of normal spring boot webapp
- implicit input handling with
@GmiInput
parameter annotation - dual-protocol: can serve both
gemini://
andhttps://
at the same time, translating gemtext to html - auto-redirect http to https
- input handling in both
gemini://
andhttps://
, transparent to application - client certificates for both
gemini://
andhttps://
- session-logic based on client-certificates, both for
gemini://
andhttps://
- css-support for html-rendered gemtext
keytool -genkey -alias <alias> -keyalg RSA -keypass <key passphrase> -storepass <store passphrase> -keystore keystore.jks
# application.yaml
gemini:
server:
key-password: storepassword
keystore-password: storepassword
keystore: file:keystore.jks
dualHttp: true
css-for-http: /classless-tiny.css
<!-- setup github repository as maven repo. see https://docs.github.com/en/packages/guides/configuring-apache-maven-for-use-with-github-packages -->
<dependencies>
<dependency>
<groupId>com.github.warmuuh.jemini</groupId>
<artifactId>jemini-spring-boot-starter</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
</dependencies>
then you can use spring mvc as usual
@Controller
public class HelloWorldController {
@GetMapping("/test")
public String test() {
return "index";
}
@GetMapping("/test1")
@ResponseBody
public String test1() {
return "Hello World. this is a dynamic page: " + Math.random();
}
}