CI / test (push) Successful in 5s
- bin/gen-server-keys.sh: generate Ed25519 keypair to etc/server-service.{pub,key,env}
- main.go: read keys from file (ADMIN_PUBLIC_KEY_FILE) when env empty
- docker-compose: env_file etc/server-service.env, mount etc/
- bin/up.sh: auto-run gen-server-keys if etc/server-service.env missing
- ErrRegistrationNotConfigured for clearer 503 when keys not set
- etc/README.md, etc/.gitignore
- bin/gen-admin-key.sh for one-off key gen
- .env.example
Made-with: Cursor
59 lines
1.3 KiB
Go
59 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"strings"
|
|
"time"
|
|
|
|
"momswap/backend/internal/app"
|
|
httpapi "momswap/backend/internal/http"
|
|
"momswap/backend/internal/store"
|
|
)
|
|
|
|
func main() {
|
|
addr := getEnv("ADDR", ":8122")
|
|
adminPublicKey := os.Getenv("ADMIN_PUBLIC_KEY")
|
|
servicePublicKey := getEnv("SERVICE_PUBLIC_KEY", adminPublicKey)
|
|
|
|
if adminPublicKey == "" {
|
|
adminPublicKey = readKeyFile(getEnv("ADMIN_PUBLIC_KEY_FILE", "etc/server-service.pub"))
|
|
}
|
|
if servicePublicKey == "" {
|
|
servicePublicKey = readKeyFile(getEnv("SERVICE_PUBLIC_KEY_FILE", "etc/server-service.pub"))
|
|
}
|
|
if servicePublicKey == "" {
|
|
servicePublicKey = adminPublicKey
|
|
}
|
|
|
|
memory := store.NewMemoryStore()
|
|
service := app.NewService(memory, app.Config{
|
|
ChallengeTTL: 5 * time.Minute,
|
|
SessionTTL: 24 * time.Hour,
|
|
}, servicePublicKey)
|
|
service.BootstrapAdmin(adminPublicKey)
|
|
|
|
api := httpapi.NewAPI(service)
|
|
log.Printf("listening on %s", addr)
|
|
if err := http.ListenAndServe(addr, api.Routes()); err != nil {
|
|
log.Fatalf("listen: %v", err)
|
|
}
|
|
}
|
|
|
|
func getEnv(key, fallback string) string {
|
|
v := os.Getenv(key)
|
|
if v == "" {
|
|
return fallback
|
|
}
|
|
return v
|
|
}
|
|
|
|
func readKeyFile(path string) string {
|
|
b, err := os.ReadFile(path)
|
|
if err != nil {
|
|
return ""
|
|
}
|
|
return strings.TrimSpace(string(b))
|
|
}
|