swirl/main.go
2021-02-26 13:32:05 +08:00

129 lines
3.9 KiB
Go

package main
import (
"embed"
"net/http"
"runtime"
"github.com/cuigh/auxo/app"
"github.com/cuigh/auxo/app/flag"
_ "github.com/cuigh/auxo/cache/memory"
"github.com/cuigh/auxo/config"
"github.com/cuigh/auxo/data/valid"
"github.com/cuigh/auxo/errors"
"github.com/cuigh/auxo/net/web"
"github.com/cuigh/auxo/net/web/filter"
"github.com/cuigh/auxo/net/web/filter/auth"
"github.com/cuigh/auxo/net/web/renderer/jet"
"github.com/cuigh/swirl/biz"
"github.com/cuigh/swirl/controller"
"github.com/cuigh/swirl/misc"
"github.com/cuigh/swirl/model"
"github.com/cuigh/swirl/scaler"
"github.com/cuigh/swirl/security"
)
//go:embed assets
//go:embed views/*
var resFS embed.FS
func main() {
misc.BindOptions()
app.Name = "Swirl"
app.Version = "0.8.6"
app.Desc = "A web management UI for Docker, focused on swarm cluster"
app.Action = func(ctx *app.Context) error {
err := config.UnmarshalOption("swirl", &misc.Options)
if err != nil {
return errors.Wrap(err, "Failed to load options")
}
setting, err := biz.Setting.Get()
if err != nil {
return errors.Wrap(err, "Failed to load settings: ")
}
biz.Stack.Migrate()
if setting.Metrics.Prometheus != "" {
scaler.Start()
}
app.Run(server(setting))
return nil
}
app.Flags.Register(flag.All)
app.Start()
}
func server(setting *model.Setting) *web.Server {
ws := web.Auto()
// customize error handler
ws.ErrorHandler.OnCode(http.StatusNotFound, func(ctx web.Context, err error) {
if ctx.IsAJAX() {
ctx.Status(http.StatusNotFound).HTML(http.StatusText(http.StatusNotFound)) // nolint: gas
} else {
ctx.Status(http.StatusNotFound).Render("404", nil) // nolint: gas
}
})
ws.ErrorHandler.OnCode(http.StatusForbidden, func(ctx web.Context, err error) {
if ctx.IsAJAX() {
ctx.Status(http.StatusForbidden).HTML("You do not have permission to perform this operation") // nolint: gas
} else {
ctx.Status(http.StatusForbidden).Render("403", nil) // nolint: gas
}
})
// set render
ws.Validator = &valid.Validator{Tag: "valid"}
ws.Renderer = jet.Must(jet.Dir(resFS, "views"), jet.Debug(config.GetBool("debug")), jet.VarMap(misc.Funcs), jet.VarMap(map[string]interface{}{
"language": setting.Language,
"version": app.Version,
"go_version": runtime.Version(),
"time": misc.FormatTime(setting.TimeZone.Offset),
"i18n": misc.Message(setting.Language),
}))
// register global filters
ws.Use(filter.NewRecover())
// register static handlers
ws.FSFile("/favicon.ico", resFS, "assets/swirl/img/favicon.ico")
ws.FS("/assets", resFS)
// create biz group
form := &auth.Form{
Identifier: security.Identifier,
Timeout: misc.Options.AuthTimeout,
SlidingExpiration: true,
}
g := ws.Group("", form, filter.NewAuthorizer(security.Checker))
// register auth handlers
g.Post("/login", form.LoginJSON(security.Validator(setting)), web.WithName("login"), web.WithAuthorize(web.AuthAnonymous))
g.Get("/logout", form.Logout, web.WithName("logout"), web.WithAuthorize(web.AuthAuthenticated))
// register controllers
g.Handle("", controller.Home())
g.Handle("/profile", controller.Profile())
g.Handle("/registry", controller.Registry())
g.Handle("/node", controller.Node())
g.Handle("/service", controller.Service(), web.FilterFunc(security.Permiter))
g.Handle("/service/template", controller.Template())
g.Handle("/stack", controller.Stack())
g.Handle("/network", controller.Network())
g.Handle("/secret", controller.Secret())
g.Handle("/config", controller.Config())
g.Handle("/task", controller.Task())
g.Handle("/container", controller.Container())
g.Handle("/image", controller.Image())
g.Handle("/volume", controller.Volume())
g.Handle("/system/user", controller.User())
g.Handle("/system/role", controller.Role())
g.Handle("/system/setting", controller.Setting())
g.Handle("/system/event", controller.Event())
g.Handle("/system/chart", controller.Chart())
return ws
}