diff --git a/.github/workflows/maven.yml b/.github/workflows/maven.yml
new file mode 100644
index 0000000..6e02720
--- /dev/null
+++ b/.github/workflows/maven.yml
@@ -0,0 +1,35 @@
+# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time
+# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-java-with-maven
+
+# This workflow uses actions that are not certified by GitHub.
+# They are provided by a third-party and are governed by
+# separate terms of service, privacy policy, and support
+# documentation.
+
+name: Java CI with Maven
+
+on:
+ push:
+ branches: [ "main" ]
+ pull_request:
+ branches: [ "main" ]
+
+jobs:
+ build:
+
+ runs-on: ubuntu-latest
+
+ steps:
+ - uses: actions/checkout@v4
+ - name: Set up JDK 17
+ uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'temurin'
+ cache: maven
+ - name: Build with Maven
+ run: mvn -B package -DskipTests --file pom.xml
+
+ # Optional: Uploads the full dependency graph to GitHub to improve the quality of Dependabot alerts this repository can receive
+# - name: Update dependency graph
+# uses: advanced-security/maven-dependency-submission-action@571e99aab1055c2e71a1e2309b9691de18d6b7d6
diff --git a/pom.xml b/pom.xml
index 8dccd99..ce45c54 100644
--- a/pom.xml
+++ b/pom.xml
@@ -82,6 +82,11 @@
spring-restdocs-mockmvc
test
+
+ org.springdoc
+ springdoc-openapi-starter-webmvc-ui
+ 2.3.0
+
diff --git a/src/main/java/top/suyiiyii/sims/controller/HealthzController.java b/src/main/java/top/suyiiyii/sims/controller/HealthzController.java
new file mode 100644
index 0000000..e3724b2
--- /dev/null
+++ b/src/main/java/top/suyiiyii/sims/controller/HealthzController.java
@@ -0,0 +1,27 @@
+package top.suyiiyii.sims.controller;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+@RestController
+public class HealthzController {
+ @GetMapping("/healthz")
+ public String healthz() {
+ return "ok";
+ }
+
+ @PostMapping("/healthz")
+ public HealthzResponse healthzPost() {
+ return new HealthzResponse("health");
+ }
+
+ @AllArgsConstructor
+ @Data
+ public static class HealthzResponse {
+ private String status;
+ }
+
+}
diff --git a/src/main/java/top/suyiiyii/sims/controller/HelloController.java b/src/main/java/top/suyiiyii/sims/controller/HelloController.java
new file mode 100644
index 0000000..d02ab56
--- /dev/null
+++ b/src/main/java/top/suyiiyii/sims/controller/HelloController.java
@@ -0,0 +1,13 @@
+package top.suyiiyii.sims.controller;
+
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+@RestController
+public class HelloController {
+
+ @GetMapping("/hello")
+ public String hello(String username) {
+ return "Hello " + username;
+ }
+}