2021-12-06 12:24:22 +00:00
|
|
|
package model
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/base64"
|
|
|
|
"encoding/json"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/cuigh/auxo/data"
|
|
|
|
"github.com/docker/docker/api/types"
|
|
|
|
"go.mongodb.org/mongo-driver/bson/primitive"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Setting represents the options of swirl.
|
|
|
|
type Setting struct {
|
|
|
|
ID string `json:"id" bson:"_id"`
|
|
|
|
Options []*SettingOption `json:"options" bson:"options,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updatedAt,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type SettingOption struct {
|
|
|
|
Name string `json:"name" bson:"name"`
|
|
|
|
Value string `json:"value" bson:"value"`
|
|
|
|
Type string `json:"type" bson:"type"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type Role struct {
|
|
|
|
ID string `bson:"_id" json:"id,omitempty"`
|
|
|
|
Name string `bson:"name" json:"name,omitempty" valid:"required"`
|
|
|
|
Description string `bson:"desc" json:"desc,omitempty"`
|
|
|
|
Perms []string `bson:"perms" json:"perms,omitempty"`
|
|
|
|
CreatedAt time.Time `bson:"created_at" json:"created_at,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updated_at,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type User struct {
|
|
|
|
ID string `bson:"_id" json:"id,omitempty"`
|
|
|
|
Name string `bson:"name" json:"name,omitempty" valid:"required"`
|
|
|
|
LoginName string `bson:"login_name" json:"loginName,omitempty" valid:"required"`
|
|
|
|
Password string `bson:"password" json:"-"`
|
|
|
|
Salt string `bson:"salt" json:"-"`
|
|
|
|
Email string `bson:"email" json:"email,omitempty" valid:"required"`
|
|
|
|
Admin bool `bson:"admin" json:"admin,omitempty"`
|
|
|
|
Type string `bson:"type" json:"type,omitempty"`
|
|
|
|
Status int32 `bson:"status" json:"status,omitempty"`
|
|
|
|
Roles []string `bson:"roles" json:"roles,omitempty"`
|
|
|
|
CreatedAt time.Time `bson:"created_at" json:"createdAt,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updatedAt,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type UserSearchArgs struct {
|
|
|
|
Name string
|
|
|
|
LoginName string
|
|
|
|
Admin bool
|
|
|
|
Status int32
|
|
|
|
PageIndex int
|
|
|
|
PageSize int
|
|
|
|
}
|
|
|
|
|
|
|
|
type Registry struct {
|
|
|
|
ID string `bson:"_id" json:"id"`
|
|
|
|
Name string `bson:"name" json:"name"`
|
|
|
|
URL string `bson:"url" json:"url"`
|
|
|
|
Username string `bson:"username" json:"username"`
|
|
|
|
Password string `bson:"password" json:"-"`
|
|
|
|
CreatedAt time.Time `bson:"created_at" json:"createdAt,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updatedAt,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Registry) Match(image string) bool {
|
|
|
|
return strings.HasPrefix(image, r.URL)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Registry) GetEncodedAuth() string {
|
|
|
|
cfg := &types.AuthConfig{
|
|
|
|
ServerAddress: r.URL,
|
|
|
|
Username: r.Username,
|
|
|
|
Password: r.Password,
|
|
|
|
}
|
|
|
|
if buf, e := json.Marshal(cfg); e == nil {
|
|
|
|
return base64.URLEncoding.EncodeToString(buf)
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
type Stack struct {
|
|
|
|
Name string `bson:"_id" json:"name,omitempty"`
|
|
|
|
Content string `bson:"content" json:"content,omitempty" bind:"content=form,content=file"`
|
|
|
|
CreatedBy string `bson:"created_by" json:"createdBy,omitempty"`
|
|
|
|
CreatedAt time.Time `bson:"created_at" json:"createdAt,omitempty"`
|
|
|
|
UpdatedBy string `bson:"updated_by" json:"updatedBy,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updatedAt,omitempty"`
|
|
|
|
Services []string `bson:"-" json:"services,omitempty"`
|
|
|
|
Internal bool `bson:"-" json:"internal"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type Event struct {
|
|
|
|
ID primitive.ObjectID `bson:"_id"`
|
|
|
|
Type string `bson:"type"`
|
|
|
|
Action string `bson:"action"`
|
|
|
|
Code string `bson:"code"`
|
|
|
|
Name string `bson:"name"`
|
|
|
|
UserID string `bson:"user_id"`
|
|
|
|
Username string `bson:"username"`
|
|
|
|
Time time.Time `bson:"time"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type EventListArgs struct {
|
|
|
|
Type string `bind:"type"`
|
|
|
|
Name string `bind:"name"`
|
|
|
|
PageIndex int `bind:"pageIndex"`
|
|
|
|
PageSize int `bind:"pageSize"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Chart represents a dashboard chart.
|
|
|
|
type Chart struct {
|
|
|
|
ID string `json:"id" bson:"_id"` // unique, the name of build-in charts has '$' prefix.
|
|
|
|
Title string `json:"title" valid:"required"`
|
2021-12-15 12:15:25 +00:00
|
|
|
Description string `json:"desc" bson:"desc"`
|
2021-12-06 12:24:22 +00:00
|
|
|
Metrics []ChartMetric `json:"metrics" valid:"required"`
|
|
|
|
Dashboard string `json:"dashboard"` // home/service/task...
|
|
|
|
Type string `json:"type"` // pie/line...
|
|
|
|
Unit string `json:"unit"` // bytes/milliseconds/percent:100...
|
|
|
|
Width int32 `json:"width"` // 1-12(12 columns total)
|
|
|
|
Height int32 `json:"height"` // default 50
|
|
|
|
Options data.Map `json:"options,omitempty"`
|
|
|
|
Margin struct {
|
|
|
|
Left int32 `json:"left,omitempty"`
|
|
|
|
Right int32 `json:"right,omitempty"`
|
|
|
|
Top int32 `json:"top,omitempty"`
|
|
|
|
Bottom int32 `json:"bottom,omitempty"`
|
|
|
|
} `json:"margin"`
|
|
|
|
//Colors []string `json:"colors"`
|
|
|
|
CreatedAt time.Time `bson:"created_at" json:"createdAt,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updatedAt,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewChart(dashboard, id, title, legend, query, unit string, left int32) *Chart {
|
|
|
|
c := &Chart{
|
|
|
|
ID: id,
|
|
|
|
Title: title,
|
|
|
|
Description: title,
|
|
|
|
Metrics: []ChartMetric{
|
|
|
|
{Legend: legend, Query: query},
|
|
|
|
},
|
|
|
|
Dashboard: dashboard,
|
|
|
|
Type: "line",
|
|
|
|
Unit: unit,
|
|
|
|
Width: 12,
|
|
|
|
Height: 200,
|
|
|
|
}
|
|
|
|
c.Margin.Left = left
|
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
|
|
|
type ChartMetric struct {
|
|
|
|
Legend string `json:"legend"`
|
|
|
|
Query string `json:"query"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type Dashboard struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Key string `json:"key,omitempty"`
|
|
|
|
Period int32 `json:"period,omitempty"` // data range in minutes
|
|
|
|
Interval int32 `json:"interval,omitempty"` // refresh interval in seconds, 0 means disabled.
|
|
|
|
Charts []ChartInfo `json:"charts,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ChartInfo struct {
|
|
|
|
ID string `json:"id"`
|
|
|
|
Width int32 `json:"width,omitempty"`
|
|
|
|
Height int32 `json:"height,omitempty"`
|
|
|
|
//Colors []string `json:"colors,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cd *Dashboard) ID() string {
|
|
|
|
if cd.Key == "" {
|
|
|
|
return cd.Name
|
|
|
|
}
|
|
|
|
return cd.Name + ":" + cd.Key
|
|
|
|
}
|
|
|
|
|
|
|
|
type Session struct {
|
|
|
|
UserID string `bson:"_id" json:"id,omitempty"`
|
|
|
|
Token string `bson:"token" json:"token,omitempty"`
|
|
|
|
Expires time.Time `bson:"expires" json:"expires,omitempty"`
|
|
|
|
UpdatedAt time.Time `bson:"updated_at" json:"updated_at,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
//type AuthUser struct {
|
|
|
|
// user *User
|
|
|
|
// roles []*Role
|
|
|
|
// perms map[string]struct{}
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func NewAuthUser(user *User, roles []*Role) *AuthUser {
|
|
|
|
// if user == nil {
|
|
|
|
// panic(111)
|
|
|
|
// }
|
|
|
|
// u := &AuthUser{
|
|
|
|
// user: user,
|
|
|
|
// roles: roles,
|
|
|
|
// perms: make(map[string]struct{}),
|
|
|
|
// }
|
|
|
|
// for _, role := range roles {
|
|
|
|
// for _, perm := range role.Perms {
|
|
|
|
// u.perms[perm] = data.Empty
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// return u
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func (u *AuthUser) ID() string {
|
|
|
|
// return u.user.ID
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func (u *AuthUser) Name() string {
|
|
|
|
// return u.user.Name
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func (u *AuthUser) Anonymous() bool {
|
|
|
|
// return u.user.ID == ""
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func (u *AuthUser) Admin() bool {
|
|
|
|
// return u.user.Admin
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func (u *AuthUser) IsInRole(roleID string) bool {
|
|
|
|
// for _, role := range u.roles {
|
|
|
|
// if role.ID == roleID {
|
|
|
|
// return true
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// return false
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//func (u *AuthUser) IsAllowed(perm string) bool {
|
|
|
|
// if u.user.Admin {
|
|
|
|
// return true
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// _, ok := u.perms[perm]
|
|
|
|
// return ok
|
|
|
|
//}
|