mirror of
https://github.com/cuigh/swirl
synced 2025-01-05 18:41:56 +00:00
125 lines
3.9 KiB
Go
125 lines
3.9 KiB
Go
package main
|
|
|
|
import (
|
|
"net/http"
|
|
"path/filepath"
|
|
"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"
|
|
)
|
|
|
|
func main() {
|
|
misc.BindOptions()
|
|
|
|
app.Name = "Swirl"
|
|
app.Version = "0.8.4"
|
|
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.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.File("/favicon.ico", filepath.Join(filepath.Dir(app.Path()), "assets/swirl/img/favicon.ico"))
|
|
ws.Static("/assets", filepath.Join(filepath.Dir(app.Path()), "assets"))
|
|
|
|
// 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
|
|
}
|