yoake/server/webroot/server.go

117 lines
4.2 KiB
Go
Raw Normal View History

2022-11-07 04:45:02 -06:00
package webroot
import (
"encoding/json"
"log"
"os"
2022-11-20 12:05:14 -06:00
"regexp"
2022-11-07 04:45:02 -06:00
"github.com/eternal-flame-AD/yoake/config"
"github.com/eternal-flame-AD/yoake/internal/auth"
2022-11-11 16:15:22 -06:00
"github.com/eternal-flame-AD/yoake/internal/canvaslms"
"github.com/eternal-flame-AD/yoake/internal/comm"
"github.com/eternal-flame-AD/yoake/internal/db"
"github.com/eternal-flame-AD/yoake/internal/echoerror"
"github.com/eternal-flame-AD/yoake/internal/entertainment"
2022-11-19 11:04:03 -06:00
"github.com/eternal-flame-AD/yoake/internal/filestore"
2022-11-16 14:54:46 -06:00
"github.com/eternal-flame-AD/yoake/internal/health"
2022-11-07 04:45:02 -06:00
"github.com/eternal-flame-AD/yoake/internal/servetpl"
"github.com/eternal-flame-AD/yoake/internal/session"
"github.com/eternal-flame-AD/yoake/internal/twilio"
2022-11-11 16:15:22 -06:00
"github.com/eternal-flame-AD/yoake/internal/utilapi"
2022-11-07 04:45:02 -06:00
"github.com/eternal-flame-AD/yoake/server"
"github.com/gorilla/context"
"github.com/gorilla/sessions"
"github.com/labstack/echo/v4"
"github.com/labstack/echo/v4/middleware"
)
2022-11-19 11:04:03 -06:00
func Init(hostname string, comm *comm.Communicator, database db.DB, fs filestore.FS) {
2022-11-07 04:45:02 -06:00
e := echo.New()
webroot := config.Config().WebRoot
if webroot.Root == "" {
log.Panicf("webroot not set, use . to override")
}
if webroot.SessionKey == "" {
log.Panicf("webroot session key not set")
}
sessionCookie := sessions.NewCookieStore([]byte(webroot.SessionKey))
fsCookie := sessions.NewFilesystemStore(webroot.SessionDir, []byte(webroot.SessionKey))
if webroot.Secure != nil {
e.Use(middleware.SecureWithConfig(*webroot.Secure))
}
if webroot.Log != nil {
filters := logCompileFilters(webroot.Log.Filter)
logOut := log.New(os.Stdout, "webroot: ", log.Ldate|log.Ltime)
lc := loggerConfig
lc.LogValuesFunc = func(c echo.Context, values middleware.RequestLoggerValues) (err error) {
entry := processLoggerValues(c, values)
if logFilterCategories(c, filters) {
var j []byte
if webroot.Log.Indent {
j, err = json.MarshalIndent(entry, "", " ")
} else {
j, err = json.Marshal(entry)
}
if err != nil {
return err
}
logOut.Println(string(j))
}
return nil
}
e.Use(middleware.RequestLoggerWithConfig(lc))
}
2022-11-11 16:15:22 -06:00
api := e.Group("/api", echoerror.Middleware(echoerror.JSONWriter))
{
canvaslms.Register(api.Group("/canvas", logMiddleware("api_canvas", nil)), comm)
utilapi.Register(api.Group("/util", logMiddleware("api_util", nil)))
comm.RegisterAPIRoute(api.Group("/comm", logMiddleware("api_comm", nil)))
2022-11-20 12:05:14 -06:00
auth.Register(api.Group("/auth", logMiddleware("api_auth", nil)), database)
2022-11-11 16:15:22 -06:00
entertainment.Register(api.Group("/entertainment", logMiddleware("api_entertainment", nil)), database)
2022-11-16 14:54:46 -06:00
health.Register(api.Group("/health", logMiddleware("api_health", nil)), database, comm)
2022-11-19 11:04:03 -06:00
twilio.Register(api.Group("/twilio", logMiddleware("api_twilio", nil)), fs, comm)
2022-11-11 16:15:22 -06:00
}
2022-11-20 12:05:14 -06:00
if fsConf := config.Config().FS; fsConf.Serve {
e.Group("/files").Use(auth.RequireMiddleware(auth.RoleAdmin), middleware.RewriteWithConfig(middleware.RewriteConfig{RegexRules: map[*regexp.Regexp]string{regexp.MustCompile("^/files/(.*)$"): "/$1"}}),
middleware.StaticWithConfig(middleware.StaticConfig{
Skipper: func(c echo.Context) bool {
if c.Request().Method != echo.GET {
return true
}
if fetchMode := c.Request().Header.Get("Sec-Fetch-Mode"); fetchMode != "" && fetchMode != "navigate" {
// some protection against XSS
return true
}
return false
},
Root: fsConf.BasePath,
Browse: true,
}), logMiddleware("files", nil))
}
2022-11-11 16:15:22 -06:00
e.Use(
echoerror.Middleware(echoerror.HTMLWriter),
func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
defer context.Clear(c.Request())
c.Set(session.SessionStoreKeyPrefix+"cookie", (sessions.Store)(sessionCookie))
c.Set(session.SessionStoreKeyPrefix+"fs", (sessions.Store)(fsCookie))
return next(c)
}
},
2022-11-07 04:45:02 -06:00
middleware.Gzip(),
auth.Middleware(sessionCookie),
2022-11-10 19:13:09 -06:00
logMiddleware("twilio", twilio.VerifyMiddleware("/twilio", config.Config().Twilio.BaseURL)),
2022-11-20 12:05:14 -06:00
middleware.RewriteWithConfig(middleware.RewriteConfig{RegexRules: map[*regexp.Regexp]string{regexp.MustCompile("^/$"): "/index.html"}}),
2022-11-07 04:45:02 -06:00
logMiddleware("template", servetpl.ServeTemplateDir(webroot.Root)),
logMiddleware("static", middleware.Static(webroot.Root)))
server.RegisterHostname(hostname, &server.Host{Echo: e})
}