Passport/pkg/server/startup.go

129 lines
3.6 KiB
Go
Raw Normal View History

2024-01-06 17:56:32 +00:00
package server
import (
"github.com/gofiber/contrib/websocket"
2024-03-20 12:56:07 +00:00
"net/http"
"strings"
"time"
2024-03-20 12:56:43 +00:00
"git.solsynth.dev/hydrogen/identity/pkg/views"
2024-01-26 17:11:32 +00:00
"github.com/gofiber/fiber/v2"
2024-01-30 11:20:12 +00:00
"github.com/gofiber/fiber/v2/middleware/cache"
"github.com/gofiber/fiber/v2/middleware/cors"
2024-01-30 10:55:55 +00:00
"github.com/gofiber/fiber/v2/middleware/filesystem"
2024-01-30 11:20:12 +00:00
"github.com/gofiber/fiber/v2/middleware/idempotency"
"github.com/gofiber/fiber/v2/middleware/logger"
2024-01-26 17:11:32 +00:00
jsoniter "github.com/json-iterator/go"
"github.com/rs/zerolog/log"
2024-01-06 17:56:32 +00:00
"github.com/spf13/viper"
)
2024-01-26 17:11:32 +00:00
var A *fiber.App
2024-01-06 17:56:32 +00:00
2024-01-26 17:11:32 +00:00
func NewServer() {
A = fiber.New(fiber.Config{
DisableStartupMessage: true,
EnableIPValidation: true,
2024-02-18 14:16:34 +00:00
ServerHeader: "Hydrogen.Identity",
AppName: "Hydrogen.Identity",
ProxyHeader: fiber.HeaderXForwardedFor,
2024-01-26 17:11:32 +00:00
JSONEncoder: jsoniter.ConfigCompatibleWithStandardLibrary.Marshal,
JSONDecoder: jsoniter.ConfigCompatibleWithStandardLibrary.Unmarshal,
EnablePrintRoutes: viper.GetBool("debug.print_routes"),
2024-01-26 17:11:32 +00:00
})
2024-01-06 17:56:32 +00:00
2024-01-30 11:20:12 +00:00
A.Use(idempotency.New())
A.Use(cors.New(cors.Config{
AllowCredentials: true,
AllowMethods: strings.Join([]string{
fiber.MethodGet,
fiber.MethodPost,
fiber.MethodHead,
fiber.MethodOptions,
fiber.MethodPut,
fiber.MethodDelete,
fiber.MethodPatch,
}, ","),
AllowOriginsFunc: func(origin string) bool {
return true
},
}))
A.Use(logger.New(logger.Config{
Format: "${status} | ${latency} | ${method} ${path}\n",
Output: log.Logger,
2024-01-30 10:55:55 +00:00
}))
2024-01-28 16:32:39 +00:00
A.Get("/.well-known", getMetadata)
2024-01-30 08:04:12 +00:00
A.Get("/.well-known/openid-configuration", getOidcConfiguration)
2024-01-28 16:32:39 +00:00
2024-01-26 17:11:32 +00:00
api := A.Group("/api").Name("API")
{
2024-01-31 16:14:25 +00:00
api.Get("/avatar/:avatarId", getAvatar)
notify := api.Group("/notifications").Name("Notifications API")
{
notify.Get("/", authMiddleware, getNotifications)
notify.Put("/:notificationId/read", authMiddleware, markNotificationRead)
notify.Post("/subscribe", authMiddleware, addNotifySubscriber)
notify.Get("/listen", authMiddleware, websocket.New(listenNotifications))
}
2024-02-01 07:58:28 +00:00
2024-03-20 12:56:07 +00:00
me := api.Group("/users/me").Name("Myself Operations")
{
me.Put("/avatar", authMiddleware, setAvatar)
me.Put("/banner", authMiddleware, setBanner)
me.Get("/", authMiddleware, getUserinfo)
2024-04-02 12:23:25 +00:00
me.Get("/page", authMiddleware, getOwnPersonalPage)
2024-03-20 12:56:07 +00:00
me.Put("/", authMiddleware, editUserinfo)
2024-04-02 12:23:25 +00:00
me.Put("/page", authMiddleware, editPersonalPage)
2024-03-20 12:56:07 +00:00
me.Get("/events", authMiddleware, getEvents)
me.Get("/challenges", authMiddleware, getChallenges)
me.Get("/sessions", authMiddleware, getSessions)
me.Delete("/sessions/:sessionId", authMiddleware, killSession)
me.Post("/confirm", doRegisterConfirm)
}
2024-01-30 09:57:23 +00:00
2024-04-02 12:23:25 +00:00
directory := api.Group("/users/:alias").Name("User Directory")
{
directory.Get("/", getOtherUserinfo)
directory.Get("/page", getPersonalPage)
}
2024-01-26 17:11:32 +00:00
api.Post("/users", doRegister)
2024-01-06 17:56:32 +00:00
2024-01-26 17:11:32 +00:00
api.Put("/auth", startChallenge)
api.Post("/auth", doChallenge)
api.Post("/auth/token", exchangeToken)
api.Post("/auth/factors/:factorId", requestFactorToken)
2024-01-30 07:57:49 +00:00
api.Get("/auth/o/connect", authMiddleware, preConnect)
api.Post("/auth/o/connect", authMiddleware, doConnect)
2024-02-08 04:26:41 +00:00
developers := api.Group("/dev").Name("Developers API")
{
developers.Post("/notify", notifyUser)
}
2024-01-26 17:11:32 +00:00
}
2024-01-30 11:20:12 +00:00
A.Use("/", cache.New(cache.Config{
Expiration: 24 * time.Hour,
CacheControl: true,
}), filesystem.New(filesystem.Config{
2024-02-26 13:13:47 +00:00
Root: http.FS(views.FS),
2024-01-30 11:20:12 +00:00
PathPrefix: "dist",
Index: "index.html",
NotFoundFile: "dist/index.html",
}))
2024-01-06 17:56:32 +00:00
}
2024-01-26 17:11:32 +00:00
func Listen() {
if err := A.Listen(viper.GetString("bind")); err != nil {
log.Fatal().Err(err).Msg("An error occurred when starting server...")
2024-01-06 17:56:32 +00:00
}
}