double.huang преди 5 години
ревизия
856e74d6b3
променени са 100 файла, в които са добавени 9116 реда и са изтрити 0 реда
  1. 18 0
      .drone.yml
  2. 20 0
      .gitignore
  3. 6 0
      Dockerfile
  4. 5 0
      README.md
  5. 2 0
      app.properties
  6. 132 0
      app/app.auto.go
  7. 100 0
      app/app.go
  8. 147 0
      app/flarum_posts.go
  9. 147 0
      app/flarum_users.go
  10. 4771 0
      doc/swagger.yaml
  11. 13 0
      go.mod
  12. 350 0
      go.sum
  13. 13 0
      k8s/configmap.yaml
  14. 36 0
      k8s/deployment.yaml
  15. 18 0
      k8s/ingress.yaml
  16. 17 0
      k8s/service.yaml
  17. 1 0
      k8s/start.sh
  18. 2 0
      k8s/tls.yaml
  19. 833 0
      log/flarum.2020100100
  20. 18 0
      main.go
  21. 37 0
      model/flarum_access_tokens.auto.go
  22. 41 0
      model/flarum_api_keys.auto.go
  23. 33 0
      model/flarum_discussion_tag.auto.go
  24. 39 0
      model/flarum_discussion_user.auto.go
  25. 65 0
      model/flarum_discussions.auto.go
  26. 35 0
      model/flarum_email_tokens.auto.go
  27. 41 0
      model/flarum_flags.auto.go
  28. 33 0
      model/flarum_group_permission.auto.go
  29. 33 0
      model/flarum_group_user.auto.go
  30. 39 0
      model/flarum_groups.auto.go
  31. 39 0
      model/flarum_login_providers.auto.go
  32. 33 0
      model/flarum_migrations.auto.go
  33. 43 0
      model/flarum_notifications.auto.go
  34. 33 0
      model/flarum_password_tokens.auto.go
  35. 33 0
      model/flarum_post_likes.auto.go
  36. 33 0
      model/flarum_post_mentions_post.auto.go
  37. 33 0
      model/flarum_post_mentions_user.auto.go
  38. 33 0
      model/flarum_post_user.auto.go
  39. 55 0
      model/flarum_posts.auto.go
  40. 17 0
      model/flarum_posts_info.auto.go
  41. 39 0
      model/flarum_registration_tokens.auto.go
  42. 33 0
      model/flarum_settings.auto.go
  43. 37 0
      model/flarum_tag_user.auto.go
  44. 61 0
      model/flarum_tags.auto.go
  45. 61 0
      model/flarum_users.auto.go
  46. 56 0
      script/apis/flarum_posts.js
  47. 56 0
      script/apis/flarum_users.js
  48. 5 0
      script/apis/index.js
  49. 11 0
      script/axios.js
  50. 14 0
      sql/flarum_posts/flarum_posts_page_count.tpl
  51. 15 0
      sql/flarum_posts/flarum_posts_page_select.tpl
  52. 14 0
      sql/flarum_users/flarum_users_page_count.tpl
  53. 15 0
      sql/flarum_users/flarum_users_page_select.tpl
  54. 24 0
      sql/sqlmap/flarum_access_tokens.xml
  55. 24 0
      sql/sqlmap/flarum_api_keys.xml
  56. 24 0
      sql/sqlmap/flarum_discussion_tag.xml
  57. 24 0
      sql/sqlmap/flarum_discussion_user.xml
  58. 24 0
      sql/sqlmap/flarum_discussions.xml
  59. 24 0
      sql/sqlmap/flarum_email_tokens.xml
  60. 24 0
      sql/sqlmap/flarum_flags.xml
  61. 24 0
      sql/sqlmap/flarum_group_permission.xml
  62. 24 0
      sql/sqlmap/flarum_group_user.xml
  63. 24 0
      sql/sqlmap/flarum_groups.xml
  64. 24 0
      sql/sqlmap/flarum_login_providers.xml
  65. 24 0
      sql/sqlmap/flarum_migrations.xml
  66. 24 0
      sql/sqlmap/flarum_notifications.xml
  67. 24 0
      sql/sqlmap/flarum_password_tokens.xml
  68. 24 0
      sql/sqlmap/flarum_post_likes.xml
  69. 24 0
      sql/sqlmap/flarum_post_mentions_post.xml
  70. 24 0
      sql/sqlmap/flarum_post_mentions_user.xml
  71. 24 0
      sql/sqlmap/flarum_post_user.xml
  72. 24 0
      sql/sqlmap/flarum_posts.xml
  73. 24 0
      sql/sqlmap/flarum_registration_tokens.xml
  74. 24 0
      sql/sqlmap/flarum_settings.xml
  75. 24 0
      sql/sqlmap/flarum_tag_user.xml
  76. 24 0
      sql/sqlmap/flarum_tags.xml
  77. 24 0
      sql/sqlmap/flarum_users.xml
  78. 16 0
      srv/flarum_posts.go
  79. 16 0
      srv/flarum_users.go
  80. 177 0
      static/web/affirm.html
  81. 209 0
      static/web/login.html
  82. 31 0
      util/tool.go
  83. 2 0
      xml/application.xml
  84. 4 0
      xml/bean/flarum_posts_info.xml
  85. 38 0
      xml/controller/flarum_posts.xml
  86. 38 0
      xml/controller/flarum_users.xml
  87. 13 0
      xml/table/flarum_access_tokens.xml
  88. 15 0
      xml/table/flarum_api_keys.xml
  89. 11 0
      xml/table/flarum_discussion_tag.xml
  90. 14 0
      xml/table/flarum_discussion_user.xml
  91. 27 0
      xml/table/flarum_discussions.xml
  92. 12 0
      xml/table/flarum_email_tokens.xml
  93. 15 0
      xml/table/flarum_flags.xml
  94. 11 0
      xml/table/flarum_group_permission.xml
  95. 11 0
      xml/table/flarum_group_user.xml
  96. 14 0
      xml/table/flarum_groups.xml
  97. 14 0
      xml/table/flarum_login_providers.xml
  98. 11 0
      xml/table/flarum_migrations.xml
  99. 16 0
      xml/table/flarum_notifications.xml
  100. 11 0
      xml/table/flarum_password_tokens.xml

+ 18 - 0
.drone.yml

@@ -0,0 +1,18 @@
+clone:
+  depth: 50
+  recursive: true
+  path: flarum
+build:
+  image: docker.i2edu.net/golang:1.13
+  commands:
+    - export GOPROXY=https://goproxy.io
+    - export GO111MODULE=on
+    - CGO_ENABLED=0 go build -a -ldflags '-s'
+    - tar zcf flarum.tar.gz static app.properties sql doc flarum
+publish:
+  docker:
+    registry: docker.qianqiusoft.com
+    email: develop@qianqiusoft.com
+    repo: docker.qianqiusoft.com/flarum
+    tag:
+      - latest

+ 20 - 0
.gitignore

@@ -0,0 +1,20 @@
+# Binaries for programs and plugins
+*.exe
+*.exe~
+*.dll
+*.so
+*.dylib
+
+# Test binary, built with `go test -c`
+*.test
+
+# Output of the go coverage tool, specifically when used with LiteIDE
+*.out
+
+!*.auto.go
+
+# Auto code generated by dol build
+**.*go.new
+
+# Dependency directories (remove the comment below to include it)
+vendor

+ 6 - 0
Dockerfile

@@ -0,0 +1,6 @@
+FROM alpine
+ADD flarum.tar.gz /app/
+RUN apk -Uuv add --no-cache ca-certificates tini tzdata && \
+  ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
+WORKDIR /app
+ENTRYPOINT ["/sbin/tini","--", "flarum"]

+ 5 - 0
README.md

@@ -0,0 +1,5 @@
+## Quick start
+
+```sh
+$ go mod tidy && dolphin build && go run main
+```

+ 2 - 0
app.properties

@@ -0,0 +1,2 @@
+app.name = flarum
+app.mode = debug

+ 132 - 0
app/app.auto.go

@@ -0,0 +1,132 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package app
+
+import (
+	"flarum/model"
+
+	"github.com/2637309949/dolphin/packages/logrus"
+	"github.com/2637309949/dolphin/packages/viper"
+	"github.com/2637309949/dolphin/platform/util"
+)
+
+// Name project
+var Name = "flarum"
+
+// FlarumPosts defined
+type FlarumPosts struct {
+	Add,
+	Del,
+	Update,
+	Page,
+	Get func(ctx *Context)
+}
+
+// NewFlarumPosts defined
+func NewFlarumPosts() *FlarumPosts {
+	ctr := &FlarumPosts{}
+	ctr.Add = FlarumPostsAdd
+	ctr.Del = FlarumPostsDel
+	ctr.Update = FlarumPostsUpdate
+	ctr.Page = FlarumPostsPage
+	ctr.Get = FlarumPostsGet
+	return ctr
+}
+
+// FlarumPostsRoutes defined
+func FlarumPostsRoutes(engine *Engine) {
+	group := engine.Group(viper.GetString("http.prefix"))
+	group.Handle("POST", "/flarum/posts/add", Auth, FlarumPostsInstance.Add)
+	group.Handle("DELETE", "/flarum/posts/del", Auth, FlarumPostsInstance.Del)
+	group.Handle("PUT", "/flarum/posts/update", Auth, FlarumPostsInstance.Update)
+	group.Handle("GET", "/flarum/posts/page", Auth, FlarumPostsInstance.Page)
+	group.Handle("GET", "/flarum/posts/get", Auth, FlarumPostsInstance.Get)
+}
+
+// FlarumPostsInstance defined
+var FlarumPostsInstance = NewFlarumPosts()
+
+// FlarumUsers defined
+type FlarumUsers struct {
+	Add,
+	Del,
+	Update,
+	Page,
+	Get func(ctx *Context)
+}
+
+// NewFlarumUsers defined
+func NewFlarumUsers() *FlarumUsers {
+	ctr := &FlarumUsers{}
+	ctr.Add = FlarumUsersAdd
+	ctr.Del = FlarumUsersDel
+	ctr.Update = FlarumUsersUpdate
+	ctr.Page = FlarumUsersPage
+	ctr.Get = FlarumUsersGet
+	return ctr
+}
+
+// FlarumUsersRoutes defined
+func FlarumUsersRoutes(engine *Engine) {
+	group := engine.Group(viper.GetString("http.prefix"))
+	group.Handle("POST", "/flarum/users/add", Auth, FlarumUsersInstance.Add)
+	group.Handle("DELETE", "/flarum/users/del", Auth, FlarumUsersInstance.Del)
+	group.Handle("PUT", "/flarum/users/update", Auth, FlarumUsersInstance.Update)
+	group.Handle("GET", "/flarum/users/page", Auth, FlarumUsersInstance.Page)
+	group.Handle("GET", "/flarum/users/get", Auth, FlarumUsersInstance.Get)
+}
+
+// FlarumUsersInstance defined
+var FlarumUsersInstance = NewFlarumUsers()
+
+// SyncModel defined
+func SyncModel() error {
+	mseti := App.Manager.MSet()
+	mseti.Add(new(model.FlarumAccessTokens))
+	mseti.Add(new(model.FlarumApiKeys))
+	mseti.Add(new(model.FlarumDiscussionTag))
+	mseti.Add(new(model.FlarumDiscussionUser))
+	mseti.Add(new(model.FlarumDiscussions))
+	mseti.Add(new(model.FlarumEmailTokens))
+	mseti.Add(new(model.FlarumFlags))
+	mseti.Add(new(model.FlarumGroupPermission))
+	mseti.Add(new(model.FlarumGroupUser))
+	mseti.Add(new(model.FlarumGroups))
+	mseti.Add(new(model.FlarumLoginProviders))
+	mseti.Add(new(model.FlarumMigrations))
+	mseti.Add(new(model.FlarumNotifications))
+	mseti.Add(new(model.FlarumPasswordTokens))
+	mseti.Add(new(model.FlarumPostLikes))
+	mseti.Add(new(model.FlarumPostMentionsPost))
+	mseti.Add(new(model.FlarumPostMentionsUser))
+	mseti.Add(new(model.FlarumPostUser))
+	mseti.Add(new(model.FlarumPosts))
+	mseti.Add(new(model.FlarumRegistrationTokens))
+	mseti.Add(new(model.FlarumSettings))
+	mseti.Add(new(model.FlarumTagUser))
+	mseti.Add(new(model.FlarumTags))
+	mseti.Add(new(model.FlarumUsers))
+	return nil
+}
+
+// SyncCtr defined
+func SyncCtr() error {
+	FlarumPostsRoutes(App)
+	FlarumUsersRoutes(App)
+	return nil
+}
+
+// SyncService defined
+func SyncService() error {
+	return nil
+}
+
+// Executor defined
+var Executor = util.NewExecutor(SyncModel, SyncCtr, SyncService)
+
+func init() {
+	if err := Executor.Execute(); err != nil {
+		logrus.Fatal(err)
+	}
+}

+ 100 - 0
app/app.go

@@ -0,0 +1,100 @@
+// Code generated by dol build. Only Generate by tools if not existed, your can rewrite platform.App default action
+// source: app.go
+
+package app
+
+import (
+	"sync"
+	"time"
+
+	"github.com/2637309949/dolphin/packages/gin"
+	"github.com/2637309949/dolphin/packages/go-funk"
+	pApp "github.com/2637309949/dolphin/platform/app"
+)
+
+type (
+	// Engine defined parse app engine
+	Engine struct {
+		*pApp.Engine
+		pool sync.Pool
+	}
+	// Context defined http handle hook context
+	Context struct {
+		*pApp.Context
+		engine *Engine
+	}
+	// RouterGroup defines struct that extend from gin.RouterGroup
+	RouterGroup struct {
+		*pApp.RouterGroup
+		engine *Engine
+	}
+	// HandlerFunc defines the handler used by gin middleware as return value.
+	HandlerFunc func(*Context)
+)
+
+func (e *Engine) allocateContext() *Context {
+	return &Context{engine: e}
+}
+
+// Group handlers
+func (e *Engine) Group(relativePath string, handlers ...gin.HandlerFunc) *RouterGroup {
+	return &RouterGroup{engine: e, RouterGroup: e.Engine.Group(relativePath, handlers...)}
+}
+
+// HandlerFunc convert to pApp.HandlerFunc
+func (e *Engine) HandlerFunc(h HandlerFunc) (phf pApp.HandlerFunc) {
+	return pApp.HandlerFunc(func(ctx *pApp.Context) {
+		c := e.pool.Get().(*Context)
+		c.Context = ctx
+		h(c)
+		e.pool.Put(c)
+	})
+}
+
+// Handle overwrite RouterGroup.Handle
+func (rg *RouterGroup) Handle(httpMethod, relativePath string, handlers ...HandlerFunc) gin.IRoutes {
+	rh := rg.RouterGroup.Handle(
+		httpMethod,
+		relativePath,
+		funk.Map(handlers, func(h HandlerFunc) pApp.HandlerFunc {
+			return rg.engine.HandlerFunc(h)
+		}).([]pApp.HandlerFunc)...)
+	return rh
+}
+
+// Auth middles
+func Auth(ctx *Context) {
+	pApp.Auth(ctx.Context)
+}
+
+// Roles middles
+func Roles(roles ...string) func(ctx *Context) {
+	return func(ctx *Context) {
+		pApp.Roles(roles...)(ctx.Context)
+	}
+}
+
+// Cache middles
+func Cache(time time.Duration) func(ctx *Context) {
+	return func(ctx *Context) {
+		pApp.Cache(time)(ctx.Context)
+	}
+}
+
+// buildEngine defined init engine you can custom engine
+// if you need
+func buildEngine() *Engine {
+	e := &Engine{Engine: pApp.App}
+	e.pool.New = func() interface{} {
+		return e.allocateContext()
+	}
+	return e
+}
+
+// Run app
+func Run() {
+	App.Run()
+}
+
+// App instance
+var App = buildEngine()

+ 147 - 0
app/flarum_posts.go

@@ -0,0 +1,147 @@
+// Code generated by dol build. Only Generate by tools if not existed.
+// source: flarum_posts.go
+
+package app
+
+import (
+	"flarum/model"
+
+	"github.com/2637309949/dolphin/packages/gin/binding"
+	"github.com/2637309949/dolphin/packages/logrus"
+	"github.com/2637309949/dolphin/packages/null"
+	"github.com/2637309949/dolphin/packages/time"
+)
+
+// FlarumPostsAdd api implementation
+// @Summary Add flarum_posts
+// @Tags FlarumPosts controller
+// @Accept application/json
+// @Param Authorization header string false "认证令牌"
+// @Param user body model.FlarumPosts false "FlarumPost info"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/posts/add [post]
+func FlarumPostsAdd(ctx *Context) {
+	var payload model.FlarumPosts
+	if err := ctx.ShouldBindBodyWith(&payload, binding.JSON); err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	payload.CreateTime = null.TimeFrom(time.Now().Value())
+	payload.CreateBy = null.StringFrom(ctx.GetToken().GetUserID())
+	payload.UpdateTime = null.TimeFrom(time.Now().Value())
+	payload.UpdateBy = null.StringFrom(ctx.GetToken().GetUserID())
+	payload.DelFlag = null.IntFrom(0)
+	ret, err := ctx.DB.Insert(&payload)
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumPostsDel api implementation
+// @Summary Delete flarum_posts
+// @Tags FlarumPosts controller
+// @Accept application/json
+// @Param Authorization header string false "认证令牌"
+// @Param flarum_posts body model.FlarumPosts false "flarum_posts"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/posts/del [delete]
+func FlarumPostsDel(ctx *Context) {
+	var payload model.FlarumPosts
+	if err := ctx.ShouldBindBodyWith(&payload, binding.JSON); err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ret, err := ctx.DB.In("id", payload.ID.Int64).Update(&model.FlarumPosts{
+		UpdateTime: null.TimeFrom(time.Now().Value()),
+		UpdateBy:   null.StringFrom(ctx.GetToken().GetUserID()),
+		DelFlag:    null.IntFrom(1),
+	})
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumPostsUpdate api implementation
+// @Summary Update flarum_posts
+// @Tags FlarumPosts controller
+// @Accept application/json
+// @Param Authorization header string false "认证令牌"
+// @Param user body model.FlarumPosts false "FlarumPost info"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/posts/update [put]
+func FlarumPostsUpdate(ctx *Context) {
+	var payload model.FlarumPosts
+	if err := ctx.ShouldBindBodyWith(&payload, binding.JSON); err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	payload.UpdateBy = null.StringFrom(ctx.GetToken().GetUserID())
+	payload.UpdateTime = null.TimeFrom(time.Now().Value())
+	ret, err := ctx.DB.ID(payload.ID.Int64).Update(&payload)
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumPostsPage api implementation
+// @Summary FlarumPost page query
+// @Tags FlarumPosts controller
+// @Param Authorization header string false "认证令牌"
+// @Param page  query  int false "Page number"
+// @Param size  query  int false "Page size"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/posts/page [get]
+func FlarumPostsPage(ctx *Context) {
+	q := ctx.TypeQuery()
+	q.SetInt("page", 1)
+	q.SetInt("size", 15)
+	q.SetRule("flarum_posts_page")
+	q.SetTags()
+	ret, err := ctx.PageSearch(ctx.DB, "flarum_posts", "page", "flarum_posts", q.Value())
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumPostsGet api implementation
+// @Summary Get flarum_posts info
+// @Tags FlarumPosts controller
+// @Param Authorization header string false "认证令牌"
+// @Param id  query  string false "FlarumPost id"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/posts/get [get]
+func FlarumPostsGet(ctx *Context) {
+	var entity model.FlarumPosts
+	id := ctx.Query("id")
+	_, err := ctx.DB.ID(id).Get(&entity)
+	if err != nil {
+		logrus.Error(err)
+		return
+	}
+	ctx.Success(entity)
+}

+ 147 - 0
app/flarum_users.go

@@ -0,0 +1,147 @@
+// Code generated by dol build. Only Generate by tools if not existed.
+// source: flarum_users.go
+
+package app
+
+import (
+	"flarum/model"
+
+	"github.com/2637309949/dolphin/packages/gin/binding"
+	"github.com/2637309949/dolphin/packages/logrus"
+	"github.com/2637309949/dolphin/packages/null"
+	"github.com/2637309949/dolphin/packages/time"
+)
+
+// FlarumUsersAdd api implementation
+// @Summary Add flarum_users
+// @Tags FlarumUser controller
+// @Accept application/json
+// @Param Authorization header string false "认证令牌"
+// @Param user body model.FlarumUsers false "FlarumUser info"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/users/add [post]
+func FlarumUsersAdd(ctx *Context) {
+	var payload model.FlarumUsers
+	if err := ctx.ShouldBindBodyWith(&payload, binding.JSON); err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	payload.CreateTime = null.TimeFrom(time.Now().Value())
+	payload.CreateBy = null.StringFrom(ctx.GetToken().GetUserID())
+	payload.UpdateTime = null.TimeFrom(time.Now().Value())
+	payload.UpdateBy = null.StringFrom(ctx.GetToken().GetUserID())
+	payload.DelFlag = null.IntFrom(0)
+	ret, err := ctx.DB.Insert(&payload)
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumUsersDel api implementation
+// @Summary Delete flarum_users
+// @Tags FlarumUser controller
+// @Accept application/json
+// @Param Authorization header string false "认证令牌"
+// @Param flarum_users body model.FlarumUsers false "flarum_users"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/users/del [delete]
+func FlarumUsersDel(ctx *Context) {
+	var payload model.FlarumUsers
+	if err := ctx.ShouldBindBodyWith(&payload, binding.JSON); err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ret, err := ctx.DB.In("id", payload.ID.Int64).Update(&model.FlarumUsers{
+		UpdateTime: null.TimeFrom(time.Now().Value()),
+		UpdateBy:   null.StringFrom(ctx.GetToken().GetUserID()),
+		DelFlag:    null.IntFrom(1),
+	})
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumUsersUpdate api implementation
+// @Summary Update flarum_users
+// @Tags FlarumUser controller
+// @Accept application/json
+// @Param Authorization header string false "认证令牌"
+// @Param user body model.FlarumUsers false "FlarumUser info"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/users/update [put]
+func FlarumUsersUpdate(ctx *Context) {
+	var payload model.FlarumUsers
+	if err := ctx.ShouldBindBodyWith(&payload, binding.JSON); err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	payload.UpdateBy = null.StringFrom(ctx.GetToken().GetUserID())
+	payload.UpdateTime = null.TimeFrom(time.Now().Value())
+	ret, err := ctx.DB.ID(payload.ID.Int64).Update(&payload)
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumUsersPage api implementation
+// @Summary FlarumUser page query
+// @Tags FlarumUser controller
+// @Param Authorization header string false "认证令牌"
+// @Param page  query  int false "Page number"
+// @Param size  query  int false "Page size"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/users/page [get]
+func FlarumUsersPage(ctx *Context) {
+	q := ctx.TypeQuery()
+	q.SetInt("page", 1)
+	q.SetInt("size", 15)
+	q.SetRule("flarum_users_page")
+	q.SetTags()
+	ret, err := ctx.PageSearch(ctx.DB, "flarum_users", "page", "flarum_users", q.Value())
+	if err != nil {
+		logrus.Error(err)
+		ctx.Fail(err)
+		return
+	}
+	ctx.Success(ret)
+}
+
+// FlarumUsersGet api implementation
+// @Summary Get flarum_users info
+// @Tags FlarumUser controller
+// @Param Authorization header string false "认证令牌"
+// @Param id  query  string false "FlarumUser id"
+// @Failure 403 {object} model.Fail
+// @Success 200 {object} model.Success
+// @Failure 500 {object} model.Fail
+// @Router /api/flarum/users/get [get]
+func FlarumUsersGet(ctx *Context) {
+	var entity model.FlarumUsers
+	id := ctx.Query("id")
+	_, err := ctx.DB.ID(id).Get(&entity)
+	if err != nil {
+		logrus.Error(err)
+		return
+	}
+	ctx.Success(entity)
+}

+ 4771 - 0
doc/swagger.yaml

@@ -0,0 +1,4771 @@
+definitions:
+  model.Fail:
+    properties:
+      code:
+        description: 错误编码
+        example: 500
+        type: integer
+      msg:
+        description: 错误信息
+        example: status bad request
+        type: string
+    type: object
+  model.FlarumPosts:
+    properties:
+      content:
+        type: string
+      create_by:
+        description: Creator
+        type: string
+      create_time:
+        description: Creation time
+        type: string
+      del_flag:
+        description: Delete tag
+        type: number
+      discussion_id:
+        type: number
+      edited_at:
+        type: string
+      edited_user_id:
+        type: number
+      hidden_at:
+        type: string
+      hidden_user_id:
+        type: number
+      id:
+        type: number
+      ip_address:
+        type: string
+      is_approved:
+        type: number
+      is_private:
+        type: number
+      number:
+        type: number
+      remark:
+        description: Remark
+        type: string
+      type:
+        type: string
+      update_by:
+        description: Last updated by
+        type: string
+      update_time:
+        description: Last update time
+        type: string
+      user_id:
+        type: number
+    type: object
+  model.FlarumUsers:
+    properties:
+      avatar_url:
+        type: string
+      bio:
+        type: string
+      comment_count:
+        type: number
+      create_by:
+        description: Creator
+        type: string
+      create_time:
+        description: Creation time
+        type: string
+      del_flag:
+        description: Delete tag
+        type: number
+      discussion_count:
+        type: number
+      email:
+        type: string
+      id:
+        type: number
+      is_email_confirmed:
+        type: number
+      joined_at:
+        type: string
+      last_seen_at:
+        type: string
+      marked_all_as_read_at:
+        type: string
+      password:
+        type: string
+      preferences:
+        items:
+          type: integer
+        type: array
+      read_flags_at:
+        type: string
+      read_notifications_at:
+        type: string
+      remark:
+        description: Remark
+        type: string
+      suspended_until:
+        type: string
+      update_by:
+        description: Last updated by
+        type: string
+      update_time:
+        description: Last update time
+        type: string
+      username:
+        type: string
+    type: object
+  model.Login:
+    properties:
+      domain:
+        description: 域
+        type: string
+      name:
+        description: 名字
+        type: string
+      password:
+        description: 密码
+        type: string
+    type: object
+  model.Scheduling:
+    properties:
+      code:
+        description: 编码
+        type: integer
+      name:
+        description: 名称
+        type: string
+    type: object
+  model.Success:
+    properties:
+      code:
+        description: 编码
+        example: 200
+        type: integer
+      data:
+        description: 返回数据
+        type: object
+    type: object
+  model.SysAppFun:
+    properties:
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      hidden:
+        description: 是否隐藏
+        type: number
+      icon:
+        description: 菜单图标
+        type: string
+      id:
+        description: 主键
+        type: string
+      image:
+        description: 图片
+        type: string
+      inheritance:
+        description: 继承关系
+        type: string
+      name:
+        description: 名称
+        type: string
+      order:
+        description: 排序
+        type: number
+      parent:
+        description: 父菜单ID,一级菜单为null
+        type: string
+      perms:
+        description: 授权(多个用逗号分隔,如:sys:user:add,sys:user:edit)
+        type: string
+      remark:
+        description: 备注
+        type: string
+      type:
+        description: 类型 0:目录 1:菜单 2:按钮
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+      url:
+        description: 菜单URL,类型:1.普通页面(如用户管理, /sys/user) 2.嵌套完整外部页面,以http(s)开头的链接 3.嵌套服务器页面,使用iframe:前缀+目标URL(如SQL监控,
+          iframe:/druid/login.html, iframe:前缀会替换成服务器地址)
+        type: string
+    type: object
+  model.SysArea:
+    properties:
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      inheritance:
+        description: 继承关系
+        type: string
+      manager:
+        description: 负责人
+        type: string
+      name:
+        description: 区域名称
+        type: string
+      org_id:
+        description: 组织ID
+        type: string
+      parent:
+        description: 父节点
+        type: string
+      remark:
+        description: 备注
+        type: string
+      temp_id:
+        description: 模板ID
+        type: string
+      temp_value:
+        description: 模板内容
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysAttachment:
+    properties:
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      durable:
+        description: 是否持久化 0:否 1:是
+        type: number
+      ext:
+        description: ext
+        type: string
+      hash:
+        description: hash
+        type: string
+      icon:
+        description: 图标
+        type: string
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      path:
+        description: path
+        type: string
+      remark:
+        description: 备注
+        type: string
+      size:
+        description: 大小
+        type: number
+      type:
+        description: 类型
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+      url:
+        description: url
+        type: string
+      uuid:
+        description: uuid
+        type: string
+    type: object
+  model.SysClient:
+    properties:
+      app_name:
+        description: 应用归属
+        type: string
+      client:
+        description: 应用
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      domain:
+        description: 域
+        type: string
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      secret:
+        description: 密钥
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysComment:
+    properties:
+      content:
+        description: 评论内容
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      from_uid:
+        description: 评论用户id
+        type: string
+      id:
+        description: 主键
+        type: string
+      remark:
+        description: 备注
+        type: string
+      topic_id:
+        description: 主题ID
+        type: string
+      topic_type:
+        description: 主题类型
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysDataPermission:
+    properties:
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysDomain:
+    properties:
+      api_url:
+        description: 请求地址
+        type: string
+      app_name:
+        description: 应用归属
+        type: string
+      auth_mode:
+        description: 认证模式 0:集成登录 1:单点登录
+        type: number
+      contact_email:
+        description: 负责人邮箱
+        type: string
+      contact_mobile:
+        description: 负责人电话
+        type: string
+      contact_name:
+        description: 负责人
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      data_source:
+        description: 数据库链接串
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      domain:
+        description: 域
+        type: string
+      domain_url:
+        description: 域绑定
+        type: string
+      driver_name:
+        description: 驱动名称
+        type: string
+      full_name:
+        description: 全名
+        type: string
+      id:
+        description: 主键
+        type: string
+      login_url:
+        description: 登录地址
+        type: string
+      name:
+        description: 名字
+        type: string
+      remark:
+        description: 备注
+        type: string
+      static_url:
+        description: 静态地址
+        type: string
+      status:
+        description: 状态 0:禁用 1:正常
+        type: number
+      sync_flag:
+        description: 是否同步了数据库标志
+        type: number
+      theme:
+        description: 样式
+        type: string
+      type:
+        description: 域类型
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysMenu:
+    properties:
+      code:
+        description: 编码
+        type: string
+      component:
+        description: 菜单组件
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      hidden:
+        description: 是否隐藏
+        type: number
+      icon:
+        description: 菜单图标
+        type: string
+      id:
+        description: 主键
+        type: string
+      inheritance:
+        description: 继承关系
+        type: string
+      name:
+        description: 名称
+        type: string
+      order:
+        description: 排序
+        type: number
+      parent:
+        description: 父菜单ID,一级菜单为null
+        type: string
+      perms:
+        description: 授权(多个用逗号分隔,如:sys:user:add,sys:user:edit)
+        type: string
+      remark:
+        description: 备注
+        type: string
+      type:
+        description: 类型 0:目录 1:菜单 2:按钮
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+      url:
+        description: 菜单URL,类型:1.普通页面(如用户管理, /sys/user) 2.嵌套完整外部页面,以http(s)开头的链接 3.嵌套服务器页面,使用iframe:前缀+目标URL(如SQL监控,
+          iframe:/druid/login.html, iframe:前缀会替换成服务器地址)
+        type: string
+    type: object
+  model.SysNotification:
+    properties:
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      from_uid:
+        description: 发送者
+        type: string
+      id:
+        description: 主键
+        type: string
+      is_read:
+        description: 是否已读
+        type: number
+      remark:
+        description: 备注
+        type: string
+      to_uid:
+        description: 接受者
+        type: string
+      topic_id:
+        description: 主题ID
+        type: string
+      topic_type:
+        description: 主题类型
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysOptionset:
+    properties:
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+      value:
+        description: 值
+        type: string
+    type: object
+  model.SysOrg:
+    properties:
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      full_name:
+        description: 全名
+        type: string
+      id:
+        description: 主键
+        type: string
+      inheritance:
+        description: 继承关系
+        type: string
+      leader:
+        description: 领导人
+        type: string
+      name:
+        description: 名称
+        type: string
+      order:
+        description: 排序
+        type: number
+      parent:
+        description: 上级组织
+        type: string
+      remark:
+        description: 备注
+        type: string
+      status:
+        description: 状态 0:禁用 1:正常
+        type: number
+      type:
+        description: 组织类型
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysPermission:
+    properties:
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysRole:
+    properties:
+      admin_index:
+        description: 角色进入后台首页组件
+        type: string
+      app_index:
+        description: 角色app首页url
+        type: string
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      status:
+        description: 状态 0:禁用 1:正常
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysSetting:
+    properties:
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      key:
+        description: 键
+        type: string
+      remark:
+        description: 备注
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+      value:
+        description: 值
+        type: string
+    type: object
+  model.SysTag:
+    properties:
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      group_id:
+        description: 分组ID
+        type: string
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysTagGroup:
+    properties:
+      code:
+        description: 编码
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysUser:
+    properties:
+      address:
+        description: 地址
+        type: string
+      avatar:
+        description: 头像
+        type: string
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      del_flag:
+        description: 删除标记
+        type: number
+      domain:
+        description: 域
+        type: string
+      email:
+        description: 邮箱
+        type: string
+      full_name:
+        description: 全名
+        type: string
+      gender:
+        description: 性别(0:女,1:男)
+        type: number
+      id:
+        description: 主键
+        type: string
+      intro:
+        description: 简介
+        type: string
+      is_email_confirmed:
+        description: 是否邮件确认(0:尚未,1:确认)
+        type: number
+      marked_all_as_read_at:
+        description: 标记所有已读时间
+        type: string
+      mobile:
+        description: 电话
+        type: string
+      name:
+        description: 名字
+        type: string
+      nickname:
+        description: 昵称
+        type: string
+      org_id:
+        description: 组织ID
+        type: string
+      password:
+        description: 密码
+        type: string
+      read_notifications_at:
+        description: 标记读取消息时间
+        type: string
+      remark:
+        description: 备注
+        type: string
+      salt:
+        description: 盐噪点
+        type: string
+      status:
+        description: 状态(0:禁用,1:正常)
+        type: number
+      temp_id:
+        description: 模板ID
+        type: string
+      temp_value:
+        description: 模板值
+        type: string
+      type:
+        description: 用户类型
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.SysUserTemplate:
+    properties:
+      create_by:
+        description: 创建人
+        type: string
+      create_time:
+        description: 创建时间
+        type: string
+      default:
+        description: 是否默认 1:是 0:否
+        type: number
+      del_flag:
+        description: 删除标记
+        type: number
+      id:
+        description: 主键
+        type: string
+      name:
+        description: 模板名称
+        type: string
+      remark:
+        description: 备注
+        type: string
+      type:
+        description: 模板类型
+        type: number
+      update_by:
+        description: 最后更新人
+        type: string
+      update_time:
+        description: 最后更新时间
+        type: string
+    type: object
+  model.Worker:
+    properties:
+      code:
+        description: 编码
+        type: string
+      error:
+        description: 错误信息
+        type: object
+      files:
+        description: 文件
+        items:
+          type: string
+        type: array
+      name:
+        description: 名称
+        type: string
+      payload:
+        description: 表单
+        type: object
+      result:
+        description: 结果
+        type: object
+      status:
+        description: 状态
+        type: integer
+      user:
+        $ref: '#/definitions/model.SysUser'
+        description: 用户
+        type: object
+    type: object
+host: localhost:8081
+info:
+  contact: {}
+  license:
+    name: Apache 2.0
+    url: http://www.apache.org/licenses/LICENSE-2.0.html
+  title: flarum
+  version: "1.0"
+paths:
+  /api/flarum/posts/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: FlarumPost info
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.FlarumPosts'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Add flarum_posts
+      tags:
+      - FlarumPosts controller
+  /api/flarum/posts/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: flarum_posts
+        in: body
+        name: flarum_posts
+        schema:
+          $ref: '#/definitions/model.FlarumPosts'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Delete flarum_posts
+      tags:
+      - FlarumPosts controller
+  /api/flarum/posts/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: FlarumPost id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Get flarum_posts info
+      tags:
+      - FlarumPosts controller
+  /api/flarum/posts/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: Page number
+        in: query
+        name: page
+        type: integer
+      - description: Page size
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: FlarumPost page query
+      tags:
+      - FlarumPosts controller
+  /api/flarum/posts/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: FlarumPost info
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.FlarumPosts'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Update flarum_posts
+      tags:
+      - FlarumPosts controller
+  /api/flarum/users/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: FlarumUser info
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.FlarumUsers'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Add flarum_users
+      tags:
+      - FlarumUser controller
+  /api/flarum/users/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: flarum_users
+        in: body
+        name: flarum_users
+        schema:
+          $ref: '#/definitions/model.FlarumUsers'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Delete flarum_users
+      tags:
+      - FlarumUser controller
+  /api/flarum/users/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: FlarumUser id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Get flarum_users info
+      tags:
+      - FlarumUser controller
+  /api/flarum/users/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: Page number
+        in: query
+        name: page
+        type: integer
+      - description: Page size
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: FlarumUser page query
+      tags:
+      - FlarumUser controller
+  /api/flarum/users/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: FlarumUser info
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.FlarumUsers'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: Update flarum_users
+      tags:
+      - FlarumUser controller
+  /api/sys/app/fun/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: APP功能信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysAppFun'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加APP功能
+      tags:
+      - APP功能
+  /api/sys/app/fun/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: APP功能
+        in: body
+        name: sys_app_fun
+        schema:
+          $ref: '#/definitions/model.SysAppFun'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除APP功能
+      tags:
+      - APP功能
+  /api/sys/app/fun/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: APP功能id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取APP功能信息
+      tags:
+      - APP功能
+  /api/sys/app/fun/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: APP功能分页查询
+      tags:
+      - APP功能
+  /api/sys/app/fun/tree:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 菜单树形结构
+      tags:
+      - APP功能
+  /api/sys/app/fun/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: APP功能信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新APP功能
+      tags:
+      - APP功能
+  /api/sys/area/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 区域信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysArea'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加区域
+      tags:
+      - 区域
+  /api/sys/area/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 区域
+        in: body
+        name: sys_area
+        schema:
+          $ref: '#/definitions/model.SysArea'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除区域
+      tags:
+      - 区域
+  /api/sys/area/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 区域id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取区域信息
+      tags:
+      - 区域
+  /api/sys/area/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 区域分页查询
+      tags:
+      - 区域
+  /api/sys/area/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 区域信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新区域
+      tags:
+      - 区域
+  /api/sys/attachment/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 附件信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysAttachment'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加附件
+      tags:
+      - 附件
+  /api/sys/attachment/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 附件
+        in: body
+        name: sys_attachment
+        schema:
+          $ref: '#/definitions/model.SysAttachment'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除附件
+      tags:
+      - 附件
+  /api/sys/attachment/export:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 附件名称
+        in: query
+        name: file_name
+        type: string
+      - description: 附件ID
+        in: query
+        name: file_id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 附件导出
+      tags:
+      - 附件
+  /api/sys/attachment/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 附件id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取附件信息
+      tags:
+      - 附件
+  /api/sys/attachment/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 附件分页查询
+      tags:
+      - 附件
+  /api/sys/attachment/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 附件信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新附件
+      tags:
+      - 附件
+  /api/sys/attachment/upload:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 上传附件
+      tags:
+      - 附件
+  /api/sys/cas/affirm:
+    post:
+      consumes:
+      - application/json
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户授权
+      tags:
+      - 认证中心
+  /api/sys/cas/authorize:
+    get:
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户授权
+      tags:
+      - 认证中心
+  /api/sys/cas/check:
+    get:
+      parameters:
+      - description: openid
+        in: query
+        name: openid
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 检验令牌
+      tags:
+      - 认证中心
+  /api/sys/cas/login:
+    post:
+      consumes:
+      - multipart/form-data
+      parameters:
+      - description: 用户名称
+        in: formData
+        name: username
+        type: string
+      - description: 用户密码
+        in: formData
+        name: password
+        type: string
+      - description: 用户域
+        in: formData
+        name: domain
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户认证
+      tags:
+      - 认证中心
+  /api/sys/cas/logout:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 定向URL
+        in: query
+        name: redirect_uri
+        type: string
+      - description: 状态
+        in: query
+        name: state
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 注销信息
+      tags:
+      - 认证中心
+  /api/sys/cas/oauth2:
+    get:
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 授权回调
+      tags:
+      - 认证中心
+  /api/sys/cas/profile:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户信息
+      tags:
+      - 认证中心
+  /api/sys/cas/qrcode:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: '类型(0: 微信 1:叮叮)'
+        in: query
+        name: type
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 扫码登录(绑定第三方)
+      tags:
+      - 认证中心
+  /api/sys/cas/refresh:
+    get:
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 刷新令牌
+      tags:
+      - 认证中心
+  /api/sys/cas/token:
+    post:
+      consumes:
+      - application/json
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取令牌
+      tags:
+      - 认证中心
+  /api/sys/cas/url:
+    get:
+      parameters:
+      - description: 定向URL
+        in: query
+        name: redirect_uri
+        type: string
+      - description: 状态
+        in: query
+        name: state
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 授权地址
+      tags:
+      - 认证中心
+  /api/sys/client/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 客户端信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysClient'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加客户端
+      tags:
+      - 客户端
+  /api/sys/client/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 客户端
+        in: body
+        name: sys_client
+        schema:
+          $ref: '#/definitions/model.SysClient'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除客户端
+      tags:
+      - 客户端
+  /api/sys/client/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 客户端id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取客户端信息
+      tags:
+      - 客户端
+  /api/sys/client/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 客户端分页查询
+      tags:
+      - 客户端
+  /api/sys/client/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 客户端信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新客户端
+      tags:
+      - 客户端
+  /api/sys/comment/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 评论信息
+        in: body
+        name: sys_comment
+        schema:
+          $ref: '#/definitions/model.SysComment'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加评论
+      tags:
+      - 评论
+  /api/sys/comment/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 评论
+        in: body
+        name: sys_comment
+        schema:
+          $ref: '#/definitions/model.SysUserTemplate'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除评论
+      tags:
+      - 评论
+  /api/sys/comment/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 评论id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取评论信息
+      tags:
+      - 评论
+  /api/sys/comment/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 评论分页查询
+      tags:
+      - 评论
+  /api/sys/comment/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 评论信息
+        in: body
+        name: sys_comment
+        schema:
+          $ref: '#/definitions/model.SysComment'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新评论
+      tags:
+      - 评论
+  /api/sys/data/permission/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 数据权限信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysDataPermission'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加数据权限
+      tags:
+      - 数据权限
+  /api/sys/data/permission/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 数据权限
+        in: body
+        name: sys_data_permission
+        schema:
+          $ref: '#/definitions/model.SysDataPermission'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除数据权限
+      tags:
+      - 数据权限
+  /api/sys/data/permission/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 数据权限id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取数据权限信息
+      tags:
+      - 数据权限
+  /api/sys/data/permission/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 数据权限分页查询
+      tags:
+      - 数据权限
+  /api/sys/data/permission/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 数据权限信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新数据权限
+      tags:
+      - 数据权限
+  /api/sys/dingtalk/oauth2:
+    get:
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 授权回调
+      tags:
+      - 钉钉
+  /api/sys/domain/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 域信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysDomain'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加域
+      tags:
+      - 域
+  /api/sys/domain/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 域
+        in: body
+        name: sys_domain
+        schema:
+          $ref: '#/definitions/model.SysDomain'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除域
+      tags:
+      - 域
+  /api/sys/domain/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 域id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取域信息
+      tags:
+      - 域
+  /api/sys/domain/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 域分页查询
+      tags:
+      - 域
+  /api/sys/domain/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 域信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新域
+      tags:
+      - 域
+  /api/sys/menu/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 菜单信息
+        in: body
+        name: sys_menu
+        schema:
+          $ref: '#/definitions/model.SysMenu'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加菜单
+      tags:
+      - 菜单
+  /api/sys/menu/batch_del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 菜单
+        in: body
+        name: sys_menu
+        schema:
+          items:
+            $ref: '#/definitions/model.SysMenu'
+          type: array
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除菜单
+      tags:
+      - 菜单
+  /api/sys/menu/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 菜单
+        in: body
+        name: sys_menu
+        schema:
+          $ref: '#/definitions/model.SysMenu'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除菜单
+      tags:
+      - 菜单
+  /api/sys/menu/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 菜单id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取菜单信息
+      tags:
+      - 菜单
+  /api/sys/menu/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 菜单分页查询
+      tags:
+      - 菜单
+  /api/sys/menu/sidebar:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 系统菜单
+      tags:
+      - 菜单
+  /api/sys/menu/tree:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 菜单树形结构
+      tags:
+      - 菜单
+  /api/sys/menu/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 菜单信息
+        in: body
+        name: sys_menu
+        schema:
+          $ref: '#/definitions/model.SysMenu'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新菜单
+      tags:
+      - 菜单
+  /api/sys/notification/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 站内消息信息
+        in: body
+        name: notification
+        schema:
+          $ref: '#/definitions/model.SysNotification'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加站内消息
+      tags:
+      - 站内消息
+  /api/sys/notification/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 站内消息
+        in: body
+        name: sys_notification
+        schema:
+          $ref: '#/definitions/model.SysNotification'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除站内消息
+      tags:
+      - 站内消息
+  /api/sys/notification/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 站内消息id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取站内消息信息
+      tags:
+      - 站内消息
+  /api/sys/notification/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 站内消息分页查询
+      tags:
+      - 站内消息
+  /api/sys/notification/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 站内消息信息
+        in: body
+        name: notification
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新站内消息
+      tags:
+      - 站内消息
+  /api/sys/optionset/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 字典信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysOptionset'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加字典
+      tags:
+      - 字典
+  /api/sys/optionset/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 字典
+        in: body
+        name: sys_optionset
+        schema:
+          $ref: '#/definitions/model.SysOptionset'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除字典
+      tags:
+      - 字典
+  /api/sys/optionset/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 字典id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取字典信息
+      tags:
+      - 字典
+  /api/sys/optionset/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 字典分页查询
+      tags:
+      - 字典
+  /api/sys/optionset/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 字典信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新字典
+      tags:
+      - 字典
+  /api/sys/org/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 组织信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysOrg'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加组织
+      tags:
+      - 组织
+  /api/sys/org/batch_del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 组织
+        in: body
+        name: sys_org
+        schema:
+          items:
+            $ref: '#/definitions/model.SysOrg'
+          type: array
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除组织
+      tags:
+      - 组织
+  /api/sys/org/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 组织
+        in: body
+        name: sys_org
+        schema:
+          $ref: '#/definitions/model.SysOrg'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除组织
+      tags:
+      - 组织
+  /api/sys/org/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 组织id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取组织信息
+      tags:
+      - 组织
+  /api/sys/org/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 组织分页查询
+      tags:
+      - 组织
+  /api/sys/org/tree:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 菜单树形结构
+      tags:
+      - 组织
+  /api/sys/org/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 组织信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新组织
+      tags:
+      - 组织
+  /api/sys/permission/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 权限信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysPermission'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加权限
+      tags:
+      - 权限
+  /api/sys/permission/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 权限
+        in: body
+        name: sys_permission
+        schema:
+          $ref: '#/definitions/model.SysPermission'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除权限
+      tags:
+      - 权限
+  /api/sys/permission/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 权限id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取权限信息
+      tags:
+      - 权限
+  /api/sys/permission/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 权限分页查询
+      tags:
+      - 权限
+  /api/sys/permission/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 权限信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新权限
+      tags:
+      - 权限
+  /api/sys/role/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 角色信息
+        in: body
+        name: sys_role
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加角色
+      tags:
+      - 角色
+  /api/sys/role/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 角色
+        in: body
+        name: sys_role
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除角色
+      tags:
+      - 角色
+  /api/sys/role/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 角色id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取角色信息
+      tags:
+      - 角色
+  /api/sys/role/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 角色分页查询
+      tags:
+      - 角色
+  /api/sys/role/role_app_fun_tree:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 角色App功能树形结构
+      tags:
+      - 角色
+  /api/sys/role/role_menu_tree:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 角色菜单树形结构
+      tags:
+      - 角色
+  /api/sys/role/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 角色信息
+        in: body
+        name: sys_role
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新角色
+      tags:
+      - 角色
+  /api/sys/scheduling/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 调度信息
+        in: body
+        name: scheduling
+        schema:
+          $ref: '#/definitions/model.Scheduling'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加调度
+      tags:
+      - 调度
+  /api/sys/scheduling/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 调度
+        in: body
+        name: scheduling
+        schema:
+          $ref: '#/definitions/model.Scheduling'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除调度
+      tags:
+      - 调度
+  /api/sys/scheduling/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 调度id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      tags:
+      - 调度
+  /api/sys/scheduling/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 调度分页查询
+      tags:
+      - 调度
+  /api/sys/scheduling/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 调度信息
+        in: body
+        name: scheduling
+        schema:
+          $ref: '#/definitions/model.Scheduling'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新调度
+      tags:
+      - 调度
+  /api/sys/setting/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 设置信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysSetting'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加设置
+      tags:
+      - 设置
+  /api/sys/setting/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 设置
+        in: body
+        name: sys_setting
+        schema:
+          $ref: '#/definitions/model.SysSetting'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除设置
+      tags:
+      - 设置
+  /api/sys/setting/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 设置id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取设置信息
+      tags:
+      - 设置
+  /api/sys/setting/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      - description: 所属应用
+        in: query
+        name: app_name
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 设置分页查询
+      tags:
+      - 设置
+  /api/sys/setting/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 设置信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysRole'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新设置
+      tags:
+      - 设置
+  /api/sys/tag/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签信息
+        in: body
+        name: sys_tag
+        schema:
+          $ref: '#/definitions/model.SysTag'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加标签
+      tags:
+      - 标签
+  /api/sys/tag/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签
+        in: body
+        name: sys_tag
+        schema:
+          $ref: '#/definitions/model.SysUserTemplate'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除标签
+      tags:
+      - 标签
+  /api/sys/tag/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取标签信息
+      tags:
+      - 标签
+  /api/sys/tag/group/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签组信息
+        in: body
+        name: sys_tag_group
+        schema:
+          $ref: '#/definitions/model.SysTagGroup'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加标签组
+      tags:
+      - 标签组
+  /api/sys/tag/group/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签
+        in: body
+        name: sys_tag_group
+        schema:
+          $ref: '#/definitions/model.SysTagGroup'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除标签组
+      tags:
+      - 标签组
+  /api/sys/tag/group/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签组id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取标签组信息
+      tags:
+      - 标签组
+  /api/sys/tag/group/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 标签组分页查询
+      tags:
+      - 标签组
+  /api/sys/tag/group/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签组信息
+        in: body
+        name: sys_tag_group
+        schema:
+          $ref: '#/definitions/model.SysTagGroup'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新标签组
+      tags:
+      - 标签组
+  /api/sys/tag/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 标签分页查询
+      tags:
+      - 标签
+  /api/sys/tag/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 标签信息
+        in: body
+        name: sys_tag
+        schema:
+          $ref: '#/definitions/model.SysTag'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新标签
+      tags:
+      - 标签
+  /api/sys/tracker/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 日志id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取日志信息
+      tags:
+      - 日志
+  /api/sys/tracker/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 日志分页查询
+      tags:
+      - 日志
+  /api/sys/user/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysUser'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加用户
+      tags:
+      - 用户
+  /api/sys/user/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysUser'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除用户
+      tags:
+      - 用户
+  /api/sys/user/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取用户信息
+      tags:
+      - 用户
+  /api/sys/user/login:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 用户信息
+        in: body
+        name: payload
+        schema:
+          $ref: '#/definitions/model.Login'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户认证
+      tags:
+      - 用户
+  /api/sys/user/logout:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户退出登录
+      tags:
+      - 用户
+  /api/sys/user/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户分页查询
+      tags:
+      - 用户
+  /api/sys/user/template/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户模板信息
+        in: body
+        name: sys_user_template
+        schema:
+          $ref: '#/definitions/model.SysUserTemplate'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加用户模板
+      tags:
+      - 用户模板
+  /api/sys/user/template/del:
+    delete:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户模板信息
+        in: body
+        name: sys_user_template
+        schema:
+          $ref: '#/definitions/model.SysUserTemplate'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 删除用户模板
+      tags:
+      - 用户模板
+  /api/sys/user/template/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户模板id
+        in: query
+        name: id
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取用户模板信息
+      tags:
+      - 用户模板
+  /api/sys/user/template/page:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 页码
+        in: query
+        name: page
+        type: integer
+      - description: 单页数
+        in: query
+        name: size
+        type: integer
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 用户模板分页查询
+      tags:
+      - 用户模板
+  /api/sys/user/template/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户模板信息
+        in: body
+        name: sys_user_template
+        schema:
+          $ref: '#/definitions/model.SysUserTemplate'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新用户模板
+      tags:
+      - 用户模板
+  /api/sys/user/update:
+    put:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: 用户信息
+        in: body
+        name: user
+        schema:
+          $ref: '#/definitions/model.SysUser'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 更新用户
+      tags:
+      - 用户
+  /api/sys/wechat/oauth2:
+    get:
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 授权回调
+      tags:
+      - 微信
+  /api/sys/worker/add:
+    post:
+      consumes:
+      - application/json
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: worker信息
+        in: body
+        name: worker
+        schema:
+          $ref: '#/definitions/model.Worker'
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 添加worker
+      tags:
+      - worker
+  /api/sys/worker/get:
+    get:
+      parameters:
+      - description: 认证令牌
+        in: header
+        name: Authorization
+        type: string
+      - description: worker code
+        in: query
+        name: code
+        type: string
+      responses:
+        "200":
+          description: OK
+          schema:
+            $ref: '#/definitions/model.Success'
+        "403":
+          description: Forbidden
+          schema:
+            $ref: '#/definitions/model.Fail'
+        "500":
+          description: Internal Server Error
+          schema:
+            $ref: '#/definitions/model.Fail'
+      summary: 获取worker信息
+      tags:
+      - worker
+securityDefinitions:
+  OAuth2AccessCode:
+    authorizationUrl: http://localhost:8081/api/sys/cas/authorize
+    flow: accessCode
+    scopes:
+      admin: Grants read and write access to administrative information
+      read: Grants read access
+      write: Grants write access
+    tokenUrl: http://localhost:8081/api/sys/cas/token
+    type: oauth2
+swagger: "2.0"

+ 13 - 0
go.mod

@@ -0,0 +1,13 @@
+module flarum
+
+go 1.13
+
+replace github.com/2637309949/dolphin => ../../
+
+require (
+	github.com/2637309949/dolphin v1.0.1
+	github.com/go-sql-driver/mysql v1.5.0
+	github.com/golang/protobuf v1.3.3
+	golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553
+	google.golang.org/grpc v1.26.0
+)

+ 350 - 0
go.sum

@@ -0,0 +1,350 @@
+cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
+cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
+cloud.google.com/go v0.37.4/go.mod h1:NHPJ89PdicEuT9hdPXMROBD91xc5uRDxsMtSB16k7hw=
+github.com/2637309949/dolphin v1.0.1 h1:EGwO9RpEPelTGh5vCWR1Xmk7T+PRddlKADtzDwbFdyc=
+github.com/2637309949/dolphin v1.0.1/go.mod h1:5l6vPaNvYnGTRXmhF3+iGSDn4ymJIGFf2gY5YEUEoS0=
+github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
+github.com/Chronokeeper/anyxml v0.0.0-20160530174208-54457d8e98c6/go.mod h1:YzuYAe2hrrwKXkM9kqjbkTLlkbA+/xw2MA46f1+ENxc=
+github.com/CloudyKit/fastprinter v0.0.0-20170127035650-74b38d55f37a/go.mod h1:EFZQ978U7x8IRnstaskI3IysnWY5Ao3QgZUKOXlsAdw=
+github.com/CloudyKit/jet v2.1.2+incompatible/go.mod h1:HPYO+50pSWkPoj9Q/eq0aRGByCL6ScRlUmiEX5Zgm+w=
+github.com/KyleBanks/depth v1.2.1/go.mod h1:jzSb9d0L43HxTQfT+oSA1EEp2q+ne2uh6XgeJcm8brE=
+github.com/PuerkitoBio/purell v1.1.1/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
+github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE=
+github.com/Shopify/sarama v1.19.0/go.mod h1:FVkBWblsNy7DGZRfXLU0O9RCGt5g3g3yEuWXgklEdEo=
+github.com/Shopify/toxiproxy v2.1.4+incompatible/go.mod h1:OXgGpZ6Cli1/URJOF1DMxUHB2q5Ap20/P/eIdh4G0pI=
+github.com/agrison/go-tablib v0.0.0-20160310143025-4930582c22ee/go.mod h1:M9nmO4lBRWR/bBv7UCOmDJ1MB2DVoqz19B4JchDA+K0=
+github.com/agrison/mxj v0.0.0-20160310142625-1269f8afb3b4/go.mod h1:n7qJAqL9BKqGqiJyjPbWtxpdswTL5wX0IVP2Uw4vVhQ=
+github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
+github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
+github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
+github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
+github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
+github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8=
+github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
+github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
+github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
+github.com/bndr/gotabulate v1.1.2/go.mod h1:0+8yUgaPTtLRTjf49E8oju7ojpU11YmXyvq1LbPAb3U=
+github.com/bradfitz/gomemcache v0.0.0-20180710155616-bc664df96737 h1:rRISKWyXfVxvoa702s91Zl5oREZTrR3yv+tXrrX7G/g=
+github.com/bradfitz/gomemcache v0.0.0-20180710155616-bc664df96737/go.mod h1:PmM6Mmwb0LSuEubjR8N7PtNe1KxZLtOUHtbeikc5h60=
+github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
+github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
+github.com/clbanning/mxj v1.8.4/go.mod h1:BVjHeAH+rl9rs6f+QIpeRl0tfu10SXn1pUSa5PVGJng=
+github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
+github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk=
+github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE=
+github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk=
+github.com/coreos/go-systemd v0.0.0-20190321100706-95778dfbb74e/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4=
+github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA=
+github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ=
+github.com/eapache/go-resiliency v1.1.0/go.mod h1:kFI+JgMyC7bLPUVY133qvEBtVayf5mFgVsvEsIPBvNs=
+github.com/eapache/go-xerial-snappy v0.0.0-20180814174437-776d5712da21/go.mod h1:+020luEh2TKB4/GOp8oxxtq0Daoen/Cii55CzbTV6DU=
+github.com/eapache/queue v1.1.0/go.mod h1:6eCeP0CKFpHLu8blIFXhExK/dRa7WDZfr6jVFPTqq+I=
+github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
+github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
+github.com/fastly/go-utils v0.0.0-20180712184237-d95a45783239 h1:Ghm4eQYC0nEPnSJdVkTrXpu9KtoVCSo1hg7mtI7G9KU=
+github.com/fastly/go-utils v0.0.0-20180712184237-d95a45783239/go.mod h1:Gdwt2ce0yfBxPvZrHkprdPPTTS3N5rwmLE8T22KBXlw=
+github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M=
+github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
+github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
+github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI=
+github.com/go-asn1-ber/asn1-ber v1.4.1/go.mod h1:hEBeB/ic+5LoWskz+yKT7vGhhPYkProFKoKdwZRWMe0=
+github.com/go-errors/errors v1.0.1/go.mod h1:f4zRHt4oKfwPJE5k8C9vpYG+aDHdBFUsgrm6/TyX73Q=
+github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
+github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
+github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE=
+github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk=
+github.com/go-openapi/jsonpointer v0.19.2/go.mod h1:3akKfEdA7DF1sugOqz1dVQHBcuDBPKZGEoHC/NkiQRg=
+github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg=
+github.com/go-openapi/jsonreference v0.19.2/go.mod h1:jMjeRr2HHw6nAVajTXJ4eiUwohSTlpa0o73RUL1owJc=
+github.com/go-openapi/jsonreference v0.19.3/go.mod h1:rjx6GuL8TTa9VaixXglHmQmIL98+wF9xc8zWvFonSJ8=
+github.com/go-openapi/spec v0.19.5 h1:Xm0Ao53uqnk9QE/LlYV5DEU09UAgpliA85QoT9LzqPw=
+github.com/go-openapi/spec v0.19.5/go.mod h1:Hm2Jr4jv8G1ciIAo+frC/Ft+rR2kQDh8JHKHb3gWUSk=
+github.com/go-openapi/swag v0.19.2/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk=
+github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk=
+github.com/go-playground/assert/v2 v2.0.1 h1:MsBgLAaY856+nPRTKrp3/OZK38U/wa0CcBYNjji3q3A=
+github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4=
+github.com/go-playground/locales v0.13.0/go.mod h1:taPMhCMXrRLJO55olJkUXHZBHCxTMfnGwq/HNwmWNS8=
+github.com/go-playground/universal-translator v0.17.0/go.mod h1:UkSxE5sNxxRwHyU+Scu5vgOQjsIJAF8j9muTVoKLVtA=
+github.com/go-playground/validator/v10 v10.0.1 h1:QgDDZpXlR/L3atIL2PbFt0TpazbtN7N6PxTGcgcyEUg=
+github.com/go-playground/validator/v10 v10.0.1/go.mod h1:uOYAAleCW8F/7oMFd6aG0GOhaH6EGOAJShg8Id5JGkI=
+github.com/go-playground/validator/v10 v10.2.0 h1:KgJ0snyC2R9VXYN2rneOtQcw5aHQB1Vv0sFl1UcHBOY=
+github.com/go-playground/validator/v10 v10.2.0/go.mod h1:uOYAAleCW8F/7oMFd6aG0GOhaH6EGOAJShg8Id5JGkI=
+github.com/go-sql-driver/mysql v1.5.0 h1:ozyZYNQW3x3HtqT1jira07DN2PArx2v7/mN66gGcHOs=
+github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
+github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
+github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
+github.com/gogo/protobuf v1.2.0/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
+github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4=
+github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b h1:VKtxabqXZkF25pY9ekfRL6a582T4P37/31XEstQ5p58=
+github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q=
+github.com/golang/groupcache v0.0.0-20190129154638-5b532d6fd5ef/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
+github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A=
+github.com/golang/mock v1.2.0/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A=
+github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
+github.com/golang/protobuf v1.3.3 h1:gyjaxf+svBWX08ZjK86iN9geUJF0H6gp2IRKX6Nf6/I=
+github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw=
+github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db h1:woRePGFeVFfLKN/pOkfl+p/TAqKOfFu+7KPlMVpok/w=
+github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
+github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ=
+github.com/google/btree v1.0.0/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ=
+github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
+github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
+github.com/google/go-cmp v0.4.0 h1:xsAVV57WRhGj6kEIi8ReJzQlHHqcBYCElAvkovg3B/4=
+github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
+github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs=
+github.com/google/pprof v0.0.0-20181206194817-3ea8567a2e57/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc=
+github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
+github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg=
+github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY=
+github.com/gorilla/context v1.1.1/go.mod h1:kBGZzfjB9CEq2AlWe17Uuf7NDRt0dE0s8S51q0aT7Yg=
+github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs=
+github.com/gorilla/securecookie v1.1.1 h1:miw7JPhV+b/lAHSXz4qd/nN9jRiAFV5FwjeKyCS8BvQ=
+github.com/gorilla/securecookie v1.1.1/go.mod h1:ra0sb63/xPlUeL+yeDciTfxMRAA+MP+HVt/4epWDjd4=
+github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
+github.com/grpc-ecosystem/go-grpc-middleware v1.0.0/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs=
+github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk=
+github.com/grpc-ecosystem/grpc-gateway v1.9.0/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY=
+github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8=
+github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ=
+github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU=
+github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
+github.com/jehiah/go-strftime v0.0.0-20171201141054-1d33003b3869 h1:IPJ3dvxmJ4uczJe5YQdrYB16oTJlGSC/OyZDqUk9xX4=
+github.com/jehiah/go-strftime v0.0.0-20171201141054-1d33003b3869/go.mod h1:cJ6Cj7dQo+O6GJNiMx+Pa94qKj+TG8ONdKHgMNIyyag=
+github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo=
+github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU=
+github.com/json-iterator/go v1.1.9 h1:9yzud/Ht36ygwatGx56VwCZtlI/2AD15T1X2sjSuGns=
+github.com/json-iterator/go v1.1.9/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
+github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
+github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU=
+github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w=
+github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q=
+github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
+github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
+github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
+github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
+github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
+github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
+github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII=
+github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc h1:RKf14vYWi2ttpEmkA4aQ3j4u9dStX2t4M8UM6qqNsG8=
+github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc/go.mod h1:kopuH9ugFRkIXf3YoqHKyrJ9YfUFsckUU9S7B+XP+is=
+github.com/lestrrat-go/strftime v1.0.1 h1:o7qz5pmLzPDLyGW4lG6JvTKPUfTFXwe+vOamIYWtnVU=
+github.com/lestrrat-go/strftime v1.0.1/go.mod h1:E1nN3pCbtMSu1yjSVeyuRFVm/U0xoR76fd03sz+Qz4g=
+github.com/lib/pq v1.7.0 h1:h93mCPfUSkaul3Ka/VG8uZdmW1uMHDGxzu0NWHuJmHY=
+github.com/lib/pq v1.7.0/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
+github.com/magiconair/properties v1.8.1 h1:ZC2Vc7/ZFkGmsVC9KvOjumD+G5lXy2RtTKyzRKO2BQ4=
+github.com/magiconair/properties v1.8.1/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ=
+github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc=
+github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc=
+github.com/mattn/go-isatty v0.0.11 h1:FxPOTFNqGkuDUGi3H/qkUbQO4ZiBa2brKq5r0l8TGeM=
+github.com/mattn/go-isatty v0.0.11/go.mod h1:PhnuNfih5lzO57/f3n+odYbM4JtupLOxQOAqxQCu2WE=
+github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY=
+github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
+github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
+github.com/memcachier/mc v2.0.1+incompatible h1:s8EDz0xrJLP8goitwZOoq1vA/sm0fPS4X3KAF0nyhWQ=
+github.com/memcachier/mc v2.0.1+incompatible/go.mod h1:7bkvFE61leUBvXz+yxsOnGBQSZpBSPIMUQSmmSHvuXc=
+github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
+github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y=
+github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
+github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
+github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826 h1:RWengNIwukTxcDr9M+97sNutRR1RKhG96O6jWumTTnw=
+github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826/go.mod h1:TaXosZuwdSHYgviHp1DAtfrULt5eUgsSMsZf+YrPgl8=
+github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
+github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
+github.com/onsi/ginkgo v1.7.0 h1:WSHQ+IS43OoUrWtD1/bbclrwK8TTH5hzp+umCiuxHgs=
+github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
+github.com/onsi/gomega v1.4.3 h1:RE1xgDvH7imwFD45h+u2SgIfERHlS2yNG4DObb5BSKU=
+github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY=
+github.com/openzipkin/zipkin-go v0.1.6/go.mod h1:QgAqvLzwWbR/WpD4A3cGpPtJrZXNIiJc5AZX7/PBEpw=
+github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic=
+github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
+github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pkg/errors v0.8.1 h1:iURUrRGxPUNPdy5/HRSm+Yj6okJ6UtLINN0Q9M4+h3I=
+github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
+github.com/prometheus/client_golang v0.9.3-0.20190127221311-3c4408c8b829/go.mod h1:p2iRAGwDERtqlqzRXnrOVns+ignqQo//hLXqYxZYVNs=
+github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo=
+github.com/prometheus/client_golang v1.4.0/go.mod h1:e9GMxYsXl05ICDXkRhurwBS4Q3OK1iX/F2sw+iXX5zU=
+github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
+github.com/prometheus/client_model v0.0.0-20190115171406-56726106282f/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
+github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
+github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
+github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
+github.com/prometheus/common v0.2.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
+github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
+github.com/prometheus/common v0.9.1/go.mod h1:yhUN8i9wzaXS3w1O07YhxHEBxD+W35wd8bs7vj7HSQ4=
+github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
+github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
+github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
+github.com/prometheus/procfs v0.0.8/go.mod h1:7Qr8sr6344vo1JqZ6HhLceV9o3AJ1Ff+GxbHq6oeK9A=
+github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
+github.com/robfig/go-cache v0.0.0-20130306151617-9fc39e0dbf62 h1:pyecQtsPmlkCsMkYhT5iZ+sUXuwee+OvfuJjinEA3ko=
+github.com/robfig/go-cache v0.0.0-20130306151617-9fc39e0dbf62/go.mod h1:65XQgovT59RWatovFwnwocoUxiI/eENTnOY5GK3STuY=
+github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg=
+github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4=
+github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749 h1:bUGsEnyNbVPw06Bs80sCeARAlK8lhwqGyi6UT8ymuGk=
+github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749/go.mod h1:ZY1cvUeJuFPAdZ/B6v7RHavJWZn2YPVFQ1OSXhCGOkg=
+github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
+github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE=
+github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc=
+github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA=
+github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM=
+github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ=
+github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
+github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo=
+github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
+github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
+github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
+github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
+github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
+github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
+github.com/subosito/gotenv v1.2.0 h1:Slr1R9HxAlEKefgq5jn9U+DnETlIUa6HfgEzj0g5d7s=
+github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
+github.com/syndtr/goleveldb v1.0.0 h1:fBdIW9lB4Iz0n9khmH8w27SJ3QEJ7+IgjPEwGSZiFdE=
+github.com/syndtr/goleveldb v1.0.0/go.mod h1:ZVVdQEZoIme9iO1Ch2Jdy24qqXrMMOU6lpPAyBWyWuQ=
+github.com/tealeg/xlsx v1.0.5/go.mod h1:btRS8dz54TDnvKNosuAqxrM1QgN1udgk9O34bDCnORM=
+github.com/tebeka/strftime v0.1.3 h1:5HQXOqWKYRFfNyBMNVc9z5+QzuBtIXy03psIhtdJYto=
+github.com/tebeka/strftime v0.1.3/go.mod h1:7wJm3dZlpr4l/oVK0t1HYIc4rMzQ2XJlOMIUJUJH6XQ=
+github.com/tidwall/btree v0.0.0-20191029221954-400434d76274/go.mod h1:huei1BkDWJ3/sLXmO+bsCNELL+Bp2Kks9OLyQFkzvA8=
+github.com/tidwall/buntdb v1.1.2/go.mod h1:xAzi36Hir4FarpSHyfuZ6JzPJdjRZ8QlLZSntE2mqlI=
+github.com/tidwall/gjson v1.3.4/go.mod h1:P256ACg0Mn+j1RXIDXoss50DeIABTYK1PULOJHhxOls=
+github.com/tidwall/grect v0.0.0-20161006141115-ba9a043346eb/go.mod h1:lKYYLFIr9OIgdgrtgkZ9zgRxRdvPYsExnYBsEAd8W5M=
+github.com/tidwall/match v1.0.1/go.mod h1:LujAq0jyVjBy028G1WhWfIzbpQfMO8bBZ6Tyb0+pL9E=
+github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk=
+github.com/tidwall/rtree v0.0.0-20180113144539-6cd427091e0e/go.mod h1:/h+UnNGt0IhNNJLkGikcdcJqm66zGD/uJGMRxK/9+Ao=
+github.com/tidwall/tinyqueue v0.0.0-20180302190814-1e39f5511563/go.mod h1:mLqSmt7Dv/CNneF2wfcChfN1rvapyQr01LGKnKex0DQ=
+github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
+github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc=
+github.com/ugorji/go v1.1.7/go.mod h1:kZn38zHttfInRq0xu/PH0az30d+z6vm202qpg1oXVMw=
+github.com/ugorji/go/codec v1.1.7/go.mod h1:Ax+UKWsSmolVDwsd+7N3ZtXu+yMGCf907BLYF3GoBXY=
+github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU=
+github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q=
+go.etcd.io/bbolt v1.3.2/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
+go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
+go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ=
+go.uber.org/dig v1.8.0/go.mod h1:X34SnWGr8Fyla9zQNO2GSO2D+TIuqB14OS8JhYocIyw=
+go.uber.org/fx v1.10.0 h1:S2K/H8oNied0Je/mLKdWzEWKZfv9jtxSDm8CnwK+5Fg=
+go.uber.org/fx v1.10.0/go.mod h1:vLRicqpG/qQEzno4SYU86iCwfT95EZza+Eba0ItuxqY=
+go.uber.org/goleak v0.10.0/go.mod h1:VCZuO8V8mFPlL0F5J5GK1rtHV3DrFcQ1R8ryq7FK0aI=
+go.uber.org/multierr v1.4.0/go.mod h1:VgVr7evmIr6uPjLBxg28wmKNXyqE9akIJ5XnfpiKl+4=
+go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee/go.mod h1:vJERXedbb3MVM5f9Ejo0C68/HhF8uaILCdgjnY+goOA=
+go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q=
+golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
+golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
+golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529 h1:iMGN4xG0cnqj3t+zOM8wUB0BiPKHEwSxEZCvzcbZuvk=
+golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
+golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
+golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
+golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
+golang.org/x/lint v0.0.0-20190301231843-5614ed5bae6f/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
+golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
+golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
+golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKGUJ2LatrhH/nqhxcFungHvyanc=
+golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20181220203305-927f97764cc3/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190108225652-1e06a53dbb7e/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190125091013-d26f9f9a57f3/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
+golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
+golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
+golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553 h1:efeOvDhwQ29Dj3SdAV/MJf8oukgn+8D8WgaCaRMchF8=
+golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
+golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
+golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20181107165924-66b7b1311ac8/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20181122145206-62eef0e2fa9b/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200122134326-e047566fdf82 h1:ywK/j/KkyTHcdyYSZNXGjMwgmDSfjglYZ3vStQ/gSCU=
+golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
+golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
+golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
+golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
+golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
+golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY=
+golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
+golang.org/x/tools v0.0.0-20190312170243-e65039ee4138/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
+golang.org/x/tools v0.0.0-20190328211700-ab21143f2384/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
+golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
+golang.org/x/tools v0.0.0-20190621195816-6e04913cbbac/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
+golang.org/x/tools v0.0.0-20191029041327-9cc4af7d6b2c/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20191029190741-b9c20aec41a5/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20191030062658-86caa796c7ab/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20191114200427-caa0b0f7d508 h1:0FYNp0PF9kFm/ZUrvcJiQ12IUJJG7iAc6Cu01wbKrbU=
+golang.org/x/tools v0.0.0-20191114200427-caa0b0f7d508/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+google.golang.org/api v0.3.1/go.mod h1:6wY9I6uQWHQ8EM57III9mq/AjF+i8G65rmVagqKMtkk=
+google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
+google.golang.org/appengine v1.4.0 h1:/wp5JvzpHIxhs/dumFmF7BXTf3Z+dd4uXta4kVyO508=
+google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
+google.golang.org/appengine v1.6.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
+google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc=
+google.golang.org/genproto v0.0.0-20190307195333-5fe7a883aa19/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
+google.golang.org/genproto v0.0.0-20190404172233-64821d5d2107/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
+google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc=
+google.golang.org/genproto v0.0.0-20191230161307-f3c370f40bfb h1:ADPHZzpzM4tk4V4S5cnCrr5SwzvlrPRmqqCuJDB8UTs=
+google.golang.org/genproto v0.0.0-20191230161307-f3c370f40bfb/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc=
+google.golang.org/grpc v1.17.0/go.mod h1:6QZJwpn2B+Zp71q/5VxRsJ6NXXVCE5NRUHRo+f3cWCs=
+google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c=
+google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
+google.golang.org/grpc v1.26.0 h1:2dTRdpdFEEhJYQD8EMLB61nnrzSCTbG38PhqdhvOltg=
+google.golang.org/grpc v1.26.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
+gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
+gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI=
+gopkg.in/flosch/pongo2.v3 v3.0.0-20141028000813-5e81b817a0c4/go.mod h1:bJkYqV5pg6+Z7MsSu/hSb1zsPT955hBW2QHLE1jm4wA=
+gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
+gopkg.in/go-playground/assert.v1 v1.2.1/go.mod h1:9RXL0bg/zibRAgZUYszZSwO/z8Y/a8bDuhia5mkpMnE=
+gopkg.in/go-playground/validator.v9 v9.30.2 h1:icxYLlYflpazIV3ufMoNB9h9SYMQ37DZ8CTwkU4pnOs=
+gopkg.in/go-playground/validator.v9 v9.30.2/go.mod h1:+c9/zcJMFNgbLvly1L1V+PpxWdVbfP1avr/N00E2vyQ=
+gopkg.in/ini.v1 v1.51.0 h1:AQvPpx3LzTDM0AjnIRlVFwFFGC+npRopjZxLJj6gdno=
+gopkg.in/ini.v1 v1.51.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k=
+gopkg.in/resty.v1 v1.12.0/go.mod h1:mDo4pnntr5jdWRML875a/NmxYqAlA73dVijT2AXvQQo=
+gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw=
+gopkg.in/yaml.v2 v2.0.0-20170812160011-eb3733d160e7/go.mod h1:JAlM8MvJe8wmxCU4Bli9HhUf9+ttbYbLASfIpnQbh74=
+gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+gopkg.in/yaml.v2 v2.2.8 h1:obN1ZagJSUGI0Ek/LBmuj4SNLPfIny3KsKFopxRdj10=
+gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
+honnef.co/go/tools v0.0.0-20180728063816-88497007e858/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
+honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg=

+ 13 - 0
k8s/configmap.yaml

@@ -0,0 +1,13 @@
+apiVersion: v1
+kind: ConfigMap
+metadata:
+  labels:
+    app: flarum
+  name: flarum
+  namespace: dolphin
+binaryData:
+data:
+  app.properties: |-
+    app.name = flarum
+    app.mode = debug
+    http.port = 8082

+ 36 - 0
k8s/deployment.yaml

@@ -0,0 +1,36 @@
+apiVersion: v1
+kind: Deployment
+metadata:
+  name: flarum
+  namespace: dolphin
+spec:
+  selector:
+    matchLabels:
+      app: flarum
+  template:
+    metadata:
+      labels:
+        app: flarum
+    spec:
+      containers:
+      - name: flarum
+        image: registry.cn-hangzhou.aliyuncs.com/flarum:1001
+        volumeMounts:
+          - name: config
+            mountPath: /app/app.properties
+            subPath: app.properties
+        resources:
+          limits:
+            memory: "2Gi"
+            cpu: "1000m"
+          requests:
+            memory: "10Mi"
+            cpu: "11m"
+        ports:
+        - containerPort: 80
+      imagePullSecrets:
+        - name: registrykey
+      volumes:
+        - name: config
+          configMap:
+            name: flarum

+ 18 - 0
k8s/ingress.yaml

@@ -0,0 +1,18 @@
+apiVersion: v1
+kind: Ingress
+metadata:
+  name: flarum
+  namespace: dolphin
+spec:
+  rules:
+  - host: www.yourhost.com
+    http:
+      paths:
+      - backend:
+          serviceName: flarum
+          servicePort: 80
+        path: /
+  tls:
+  - hosts:
+    - www.yourhost.com
+    secretName: www-tls

+ 17 - 0
k8s/service.yaml

@@ -0,0 +1,17 @@
+apiVersion: v1
+kind: Service
+metadata:
+  name: flarum
+  namespace: dolphin
+spec:
+  ports:
+  - name: 80tcp01
+    port: 80
+    protocol: TCP
+    targetPort: 8082
+  selector:
+    app: flarum
+  sessionAffinity: None
+  type: ClusterIP
+status:
+  loadBalancer: {}

+ 1 - 0
k8s/start.sh

@@ -0,0 +1 @@
+kubectl apply -f ./

Файловите разлики са ограничени, защото са твърде много
+ 2 - 0
k8s/tls.yaml


+ 833 - 0
log/flarum.2020100100

@@ -0,0 +1,833 @@
+time="01/10 13:30:24" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 13:30:24" level=info msg="grpc listen on port:9081"
+time="01/10 13:30:24" level=info msg="http listen on port:8081"
+time="01/10 14:23:50" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:23:50" level=warning msg="Table sys_client column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_domain column type db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_domain column status db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_domain column auth_mode db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_domain column sync_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_domain column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_domain has column add but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_domain has column del but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_domain has column update but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_domain has column page but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_domain has column get but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user column gender db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_user column type db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_user column status db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_user column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column full_name but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column is_email_confirmed but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column marked_all_as_read_at but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column read_notifications_at but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column address but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column temp_id but struct has not related field"
+time="01/10 14:23:50" level=warning msg="Table sys_user has column temp_value but struct has not related field"
+time="01/10 14:23:51" level=info msg="grpc listen on port:9081"
+time="01/10 14:23:51" level=info msg="http listen on port:8081"
+time="01/10 14:24:48" level=fatal msg="accept tcp [::]:9081: use of closed network connection"
+time="01/10 14:25:41" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:25:41" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:25:42" level=info msg="mysql root:111111@/dolphin_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:25:42" level=warning msg="Table sys_app_fun column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_app_fun column order db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_app_fun column hidden db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_app_fun column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_app_fun has column order_num but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_area column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_area_template column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_area_template column default db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_area_template column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_area_template_detail column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_area_template_detail column priority db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_area_template_detail column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_attachment column size db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_attachment column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_data_permission column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_data_permission_detail column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_menu column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_menu column order db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_menu column hidden db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_menu column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_optionset column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_org column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_org column order db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_org column status db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_org column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_permission column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_role column status db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_role column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_role_app_fun column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_role_menu column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_role_permission column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_role_user column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_table_col_user column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_tag column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_tag_group column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_tracker has column app_name but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_tracker has column domain but struct has not related field"
+time="01/10 14:25:42" level=warning msg="Table sys_user_binding column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_binding column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_tag column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_template column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_template column default db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_template column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_template_detail column type db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_template_detail column priority db type is INT(11), struct type is TEXT"
+time="01/10 14:25:42" level=warning msg="Table sys_user_template_detail column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:25:43" level=info msg="grpc listen on port:9081"
+time="01/10 14:25:43" level=info msg="http listen on port:8081"
+time="01/10 14:25:46" level=fatal msg="accept tcp [::]:9081: use of closed network connection"
+time="01/10 14:27:08" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:27:08" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:27:08" level=info msg="mysql root:111111@/dolphin_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:27:08" level=warning msg="Table sys_app_fun column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_app_fun column order db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_app_fun column hidden db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_app_fun column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_app_fun has column order_num but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_area column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_area_template column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_area_template column default db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_area_template column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_area_template_detail column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_area_template_detail column priority db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_area_template_detail column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_attachment column size db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_attachment column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_data_permission column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_data_permission_detail column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_menu column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_menu column order db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_menu column hidden db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_menu column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_optionset column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_org column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_org column order db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_org column status db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_org column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_permission column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_role column status db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_role column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_role_app_fun column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_role_menu column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_role_permission column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_role_user column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_table_col_user column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_tag column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_tag_group column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_tracker has column app_name but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_tracker has column domain but struct has not related field"
+time="01/10 14:27:08" level=warning msg="Table sys_user_binding column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_binding column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_tag column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_template column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_template column default db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_template column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_template_detail column type db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_template_detail column priority db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=warning msg="Table sys_user_template_detail column del_flag db type is INT(11), struct type is TEXT"
+time="01/10 14:27:08" level=info msg="grpc listen on port:9081"
+time="01/10 14:27:08" level=info msg="http listen on port:8081"
+time="01/10 14:32:50" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:32:50" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:32:50" level=info msg="mysql root:111111@/dolphin_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:32:50" level=info msg="grpc listen on port:9081"
+time="01/10 14:32:50" level=info msg="http listen on port:8081"
+time="01/10 14:36:24" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:36:24" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:36:24" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:36:25" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:36:25" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:36:25" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:36:25" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:36:25" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:36:25" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:36:25" level=info msg="grpc listen on port:9081"
+time="01/10 14:36:25" level=info msg="http listen on port:8081"
+time="01/10 14:37:24" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:37:24" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:37:24" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:37:24" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:37:24" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:37:24" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:37:24" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:37:24" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:37:24" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:37:24" level=info msg="grpc listen on port:9081"
+time="01/10 14:37:24" level=info msg="http listen on port:8081"
+time="01/10 14:37:52" level=fatal msg="accept tcp [::]:9081: use of closed network connection"
+time="01/10 14:37:55" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:37:55" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:37:55" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:37:55" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:37:55" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:37:55" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:37:55" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:37:55" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:37:55" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:37:55" level=info msg="grpc listen on port:9081"
+time="01/10 14:37:55" level=info msg="http listen on port:8081"
+time="01/10 14:39:11" level=fatal msg="accept tcp [::]:9081: use of closed network connection"
+time="01/10 14:39:17" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:39:17" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:39:17" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:39:17" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:39:17" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:39:17" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:39:17" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:39:17" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:39:17" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:39:17" level=info msg="grpc listen on port:9081"
+time="01/10 14:39:17" level=info msg="http listen on port:8081"
+time="01/10 14:39:54" level=fatal msg="accept tcp [::]:9081: use of closed network connection"
+time="01/10 14:39:57" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:39:57" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 591.617µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 939.016µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 592.182µs"
+time="01/10 14:39:57" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:39:57" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 558.112µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 474.23µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.106378ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 1.186108ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 670.934µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 688.615µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 1.344824ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 596.035µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 635.046µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 1.622869ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 721.94µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.41849ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 1.445186ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 952.323µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.393654ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 1.461932ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 1.195386ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.267735ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 1.455537ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 798.103µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 987.859µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 1.170102ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 533.334µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 868.251µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 1.356666ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 724.498µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.065746ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 1.425124ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 738.335µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.202725ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 1.276964ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 631.82µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.122847ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 1.215599ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 595.326µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.638035ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 1.662863ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 1.001207ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.178255ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 1.386695ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 782.778µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.147211ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 1.538458ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 755.046µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.132079ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 1.758795ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 712.91µs"
+time="01/10 14:39:57" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:39:57" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:39:57" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:39:57" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:39:57" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:39:57" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.069955ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 1.105242ms"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 764.145µs"
+time="01/10 14:39:57" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.237156ms"
+time="01/10 14:39:57" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT DEFAULT 0 NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 367.161µs"
+time="01/10 14:39:57" level=info msg="grpc listen on port:9081"
+time="01/10 14:39:57" level=info msg="http listen on port:8081"
+time="01/10 14:41:08" level=fatal msg="http: Server closed"
+time="01/10 14:41:13" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:41:13" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 618.144µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 484.538µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 572.447µs"
+time="01/10 14:41:13" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:41:13" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 230.861µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 429.857µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 769.463µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 1.053848ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 538.837µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 708.01µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 1.809736ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 892.243µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.376714ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 1.735017ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 875.19µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 5.651297ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 1.849233ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 781.917µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.208818ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 1.401153ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 520.055µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 715.541µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 1.94571ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 1.081109ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.114131ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 1.458258ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 775.406µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.256038ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 1.591391ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 1.011133ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 986.63µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 965.607µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 884.649µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.404159ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 1.714327ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 752.316µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.267217ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 2.033491ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 948.385µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.249674ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 1.324218ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 971.655µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.658028ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 3.288049ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 734.484µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.120675ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 1.436454ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 806.2µs"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.039538ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 1.418162ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 739.698µs"
+time="01/10 14:41:13" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:41:13" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:41:13" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:41:13" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:41:13" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:41:13" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.075642ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 1.899775ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 1.626304ms"
+time="01/10 14:41:13" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.160333ms"
+time="01/10 14:41:13" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT DEFAULT 0 NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 377.044µs"
+time="01/10 14:41:13" level=info msg="grpc listen on port:9081"
+time="01/10 14:41:13" level=info msg="http listen on port:8081"
+time="01/10 14:42:25" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:42:25" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 557.019µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 510.952µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 621.242µs"
+time="01/10 14:42:25" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:42:25" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 287.443µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 518.588µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 744.15µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 1.48642ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 643.4µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 666.483µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 1.184229ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 584.683µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 676.46µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 1.467953ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 799.158µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.59855ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 2.013878ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 1.314664ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.283063ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 3.52744ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 1.07755ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 951.824µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 1.437977ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 619.19µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 924.86µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 1.009877ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 670.017µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.531526ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 2.58665ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 1.086534ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.059321ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 1.204924ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 633.703µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.148002ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 1.698493ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 611.444µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 926.097µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 2.161525ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 655.558µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 969.474µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 1.457813ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 600.853µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 804.268µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 1.027119ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 594.928µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 876.048µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 1.393584ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 616.873µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 795.66µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 1.563129ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 623.603µs"
+time="01/10 14:42:25" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:42:25" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:42:25" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:42:25" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:42:25" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:42:25" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.000437ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 1.407545ms"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 846.055µs"
+time="01/10 14:42:25" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.287512ms"
+time="01/10 14:42:25" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT DEFAULT 0 NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 370.747µs"
+time="01/10 14:42:25" level=error msg="Error 1101: BLOB, TEXT, GEOMETRY or JSON column 'del_flag' can't have a default value"
+time="01/10 14:42:25" level=info msg="grpc listen on port:9081"
+time="01/10 14:42:25" level=info msg="http listen on port:8081"
+time="01/10 14:43:51" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:43:51" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 910.702µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 619.067µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 579.764µs"
+time="01/10 14:43:51" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:43:51" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 276.088µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 439.082µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 945.437µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 1.228493ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 688.314µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 791.37µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 1.385883ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 899.869µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.021061ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 1.913741ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 903.059µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.466448ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 1.581389ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 2.662652ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.31593ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 1.771534ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 711.315µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.004036ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 1.36009ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 944.013µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.193641ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 1.194614ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 569.172µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.143519ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 1.303446ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 1.379535ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.090997ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 1.506884ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 672.393µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 839.608µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 1.458934ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 586.75µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 855.755µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 1.088225ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 617.252µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.277176ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 2.604447ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 1.286556ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.200243ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 2.085998ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 728.246µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.405577ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 2.039389ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 652.408µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.964974ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 1.757336ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 864.17µs"
+time="01/10 14:43:51" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:43:51" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:43:51" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:43:51" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:43:51" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:43:51" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.69599ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 2.322972ms"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 841.061µs"
+time="01/10 14:43:51" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.24477ms"
+time="01/10 14:43:51" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT DEFAULT 0 NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 402.677µs"
+time="01/10 14:47:48" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:47:48" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 2.927141ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 3.895384ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 1.815443ms"
+time="01/10 14:47:48" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:47:48" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 704.161µs"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 840.418µs"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.930066ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 2.229151ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 1.220365ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.256774ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 2.234721ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 1.098176ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.379702ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 2.943834ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 2.260297ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 14.668088ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 2.680739ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 1.526694ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.911098ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 2.772632ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 1.570593ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.582042ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 2.572554ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 1.253644ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.925125ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 2.772831ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 1.374469ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.888098ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 2.564251ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 1.385445ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.793316ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 2.662796ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 1.465531ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.37175ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 2.8598ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 1.273045ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.328009ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 2.680099ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 2.153116ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.324003ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 2.810282ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 1.378162ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.160074ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 3.373522ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 1.14915ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.604512ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 2.538202ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 1.461595ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.38595ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 2.835692ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 1.757428ms"
+time="01/10 14:47:48" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:47:48" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:47:48" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:47:48" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:47:48" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:47:48" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.59558ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 2.261981ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 1.098563ms"
+time="01/10 14:47:48" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.647296ms"
+time="01/10 14:47:48" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT DEFAULT 0 NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 709.589µs"
+time="01/10 14:47:48" level=info msg="[SQL] UPDATE `sys_domain` SET `sync_flag` = ? WHERE (sync_flag=0 and app_name = ?) [1 flarum] - 8.36802ms"
+time="01/10 14:48:35" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:48:35" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:48:35" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 570.937µs"
+time="01/10 14:48:35" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 423.602µs"
+time="01/10 14:48:35" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 530.485µs"
+time="01/10 14:48:35" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:48:35" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 210.91µs"
+time="01/10 14:48:35" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 384.228µs"
+time="01/10 14:48:35" level=info msg="[SQL] SELECT count(*) FROM `sys_client` WHERE (id=?) [5ba2b110-9dad-11d1-80b4-00c04fd431c4] - 547µs"
+time="01/10 14:48:35" level=info msg="[SQL] SELECT count(*) FROM `sys_user` WHERE (id=?) [6ba7b810-9dad-11d1-80b4-00c04fd430c8] - 432.59µs"
+time="01/10 14:48:35" level=info msg="grpc listen on port:9081"
+time="01/10 14:48:35" level=info msg="http listen on port:8081"
+time="01/10 14:50:56" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:50:56" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 676.518µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 603.074µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 601.948µs"
+time="01/10 14:50:56" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:50:56" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 248.339µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 444.427µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 734.305µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 907.314µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 550.627µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 682.006µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 1.335235ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 1.035971ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 1.01339ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 1.63177ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 801.644µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.534367ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 1.352992ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 1.011557ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.563694ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 1.730886ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 764.273µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.316266ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 1.177861ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 659.323µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 850.345µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 1.020492ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 528.801µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 904.122µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 1.738547ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 1.170279ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.422216ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 1.384626ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 722.603µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 946.25µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 867.646µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 471.463µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 826.632µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 1.138672ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 568.736µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 810.703µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 863.265µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 742.765µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 808.118µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 908.301µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 495.169µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 862.647µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 1.152582ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 658.814µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 971.08µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 1.786091ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 592.181µs"
+time="01/10 14:50:56" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:50:56" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:50:56" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:50:56" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:50:56" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:50:56" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 930.862µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 1.447215ms"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 654.732µs"
+time="01/10 14:50:56" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 771.137µs"
+time="01/10 14:50:56" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT DEFAULT 0 NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 299.44µs"
+time="01/10 14:52:07" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 14:52:07" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 985.139µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 600.73µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 858.867µs"
+time="01/10 14:52:07" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 14:52:07" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 357.571µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 555.683µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 925.287µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_client] - 1.304723ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_client] - 2.950838ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 944.165µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_domain] - 1.512201ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_domain] - 674.857µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [dolphin] - 817.695µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [dolphin sys_user] - 1.453147ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [dolphin sys_user] - 717.97µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.911111ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_app_fun] - 1.364624ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_app_fun] - 754.227µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.12889ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area] - 1.340065ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area] - 3.139371ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.156409ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template] - 1.342604ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template] - 699.491µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 942.035µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_area_template_detail] - 1.409113ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_area_template_detail] - 789.092µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.232169ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_attachment] - 1.792364ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_attachment] - 944.679µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.142895ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment] - 1.254626ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment] - 1.26207ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 996.705µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_comment_reply] - 1.250473ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_comment_reply] - 746.234µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.082578ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission] - 1.813323ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission] - 1.240895ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.357915ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_data_permission_detail] - 1.428108ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_data_permission_detail] - 920.444µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 965.395µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_email_token] - 1.150996ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_email_token] - 670.715µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.102953ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_menu] - 1.716539ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_menu] - 787.676µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.340621ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_notification] - 1.647927ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_notification] - 775.685µs"
+time="01/10 14:52:07" level=warning msg="Table sys_notification has column recipient_id but struct has not related field"
+time="01/10 14:52:07" level=warning msg="Table sys_notification has column sender_id but struct has not related field"
+time="01/10 14:52:07" level=warning msg="Table sys_notification has column unread but struct has not related field"
+time="01/10 14:52:07" level=warning msg="Table sys_notification has column type but struct has not related field"
+time="01/10 14:52:07" level=warning msg="Table sys_notification has column parameters but struct has not related field"
+time="01/10 14:52:07" level=warning msg="Table sys_notification has column reference_id but struct has not related field"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.158473ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `COLUMN_NAME`, `IS_NULLABLE`, `COLUMN_DEFAULT`, `COLUMN_TYPE`, `COLUMN_KEY`, `EXTRA`, `COLUMN_COMMENT`, (INSTR(VERSION(), 'maria') > 0 && (SUBSTRING_INDEX(VERSION(), '.', 1) > 10 || (SUBSTRING_INDEX(VERSION(), '.', 1) = 10 && (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) > 2 || (SUBSTRING_INDEX(SUBSTRING(VERSION(), 4), '.', 1) = 2 && SUBSTRING_INDEX(SUBSTRING(VERSION(), 6), '-', 1) >= 7))))) AS NEEDS_QUOTE FROM `INFORMATION_SCHEMA`.`COLUMNS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? ORDER BY `COLUMNS`.ORDINAL_POSITION [flarum_localhost sys_optionset] - 1.639413ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `INDEX_NAME`, `NON_UNIQUE`, `COLUMN_NAME` FROM `INFORMATION_SCHEMA`.`STATISTICS` WHERE `TABLE_SCHEMA` = ? AND `TABLE_NAME` = ? [flarum_localhost sys_optionset] - 727.609µs"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.078834ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_org` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `parent` VARCHAR(36) NULL COMMENT '上级组织', `inheritance` VARCHAR(500) NULL COMMENT '继承关系', `name` VARCHAR(36) NOT NULL COMMENT '名称', `full_name` VARCHAR(36) NULL COMMENT '全名', `leader` VARCHAR(36) NULL COMMENT '领导人', `code` VARCHAR(36) NULL COMMENT '编码', `type` TEXT NULL COMMENT '组织类型', `order` TEXT NOT NULL COMMENT '排序', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 30.71754ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_org_id` ON `sys_org` (`id`) [] - 16.706843ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.602267ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_permission` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `name` VARCHAR(36) NOT NULL COMMENT '名称', `code` VARCHAR(36) NOT NULL COMMENT '编码', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 21.618716ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_permission_id` ON `sys_permission` (`id`) [] - 17.332875ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.026986ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_role` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `name` VARCHAR(200) NOT NULL COMMENT '名称', `code` VARCHAR(36) NOT NULL COMMENT '编码', `status` TEXT NOT NULL COMMENT '状态 0:禁用 1:正常', `app_index` VARCHAR(500) NULL COMMENT '角色app首页url', `admin_index` VARCHAR(500) NULL COMMENT '角色进入后台首页组件', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 21.386198ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_role_id` ON `sys_role` (`id`) [] - 20.612489ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.382016ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_role_app_fun` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `role_id` VARCHAR(36) NOT NULL COMMENT '角色ID', `app_fun_id` VARCHAR(36) NOT NULL COMMENT 'APP功能ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 21.490658ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_role_app_fun_id` ON `sys_role_app_fun` (`id`) [] - 23.81238ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.374267ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_role_data_permission` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `role_id` VARCHAR(36) NOT NULL COMMENT '角色ID', `data_permission_id` VARCHAR(36) NOT NULL COMMENT '数据权限ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 22.254943ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_role_data_permission_id` ON `sys_role_data_permission` (`id`) [] - 20.651179ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.538882ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_role_menu` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `role_id` VARCHAR(36) NOT NULL COMMENT '用户ID', `menu_id` VARCHAR(36) NOT NULL COMMENT '菜单ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 30.684727ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_role_menu_id` ON `sys_role_menu` (`id`) [] - 23.619945ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.425624ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_role_permission` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `role_id` VARCHAR(36) NOT NULL COMMENT '角色', `permission_id` VARCHAR(36) NOT NULL COMMENT '权限', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 23.51761ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_role_permission_id` ON `sys_role_permission` (`id`) [] - 21.693812ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 6.308225ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_role_user` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `user_id` VARCHAR(36) NOT NULL COMMENT '用户ID', `role_id` VARCHAR(36) NOT NULL COMMENT '角色ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 32.409548ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_role_user_id` ON `sys_role_user` (`id`) [] - 20.016809ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.434898ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_setting` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `key` VARCHAR(200) NOT NULL COMMENT '键', `value` VARCHAR(500) NOT NULL COMMENT '值', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 21.807422ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_setting_id` ON `sys_setting` (`id`) [] - 21.281383ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.739023ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_table_col_user` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `code` VARCHAR(36) NOT NULL COMMENT '编码', `value` TEXT NOT NULL COMMENT '内容', `user_id` VARCHAR(36) NOT NULL COMMENT '用户ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 32.701691ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_table_col_user_id` ON `sys_table_col_user` (`id`) [] - 18.958508ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.112492ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_tag` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `name` VARCHAR(36) NOT NULL COMMENT '名称', `group_id` VARCHAR(36) NOT NULL COMMENT '分组ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 22.987796ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_tag_id` ON `sys_tag` (`id`) [] - 23.957655ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.612031ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_tag_group` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `name` VARCHAR(36) NOT NULL COMMENT '名称', `code` VARCHAR(36) NOT NULL COMMENT '编码', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 30.717888ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_tag_group_id` ON `sys_tag_group` (`id`) [] - 17.290294ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.555876ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_tracker` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `token` VARCHAR(72) NULL COMMENT '令牌', `user_id` VARCHAR(36) NULL COMMENT '用户ID', `status_code` INT NULL COMMENT '状态', `latency` FLOAT NULL COMMENT '反应时间', `client_ip` VARCHAR(36) NULL COMMENT '客户端id', `method` VARCHAR(36) NULL COMMENT '请求方法', `path` VARCHAR(512) NULL COMMENT '请求路径', `header` BLOB NULL COMMENT '请求头', `req_body` MEDIUMBLOB NULL COMMENT '请求体', `res_body` MEDIUMBLOB NULL COMMENT '返回体', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 20.606811ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_tracker_id` ON `sys_tracker` (`id`) [] - 23.532898ms"
+time="01/10 14:52:07" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.60342ms"
+time="01/10 14:52:07" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_user_binding` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `user_id` VARCHAR(36) NOT NULL COMMENT '用户ID', `open_id` VARCHAR(36) NOT NULL COMMENT 'open_id', `union_id` VARCHAR(36) NOT NULL COMMENT 'union_id', `type` TEXT NULL COMMENT '类型(0: 微信 1:叮叮)', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 20.983713ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_user_binding_id` ON `sys_user_binding` (`id`) [] - 19.706741ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.176367ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_user_tag` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `user_id` VARCHAR(36) NOT NULL COMMENT '用户ID', `tag_id` VARCHAR(36) NOT NULL COMMENT '标签ID', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 32.655476ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_user_tag_id` ON `sys_user_tag` (`id`) [] - 17.378619ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.225599ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_user_template` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `name` VARCHAR(200) NOT NULL COMMENT '模板名称', `type` TEXT NULL COMMENT '模板类型', `default` TEXT NULL COMMENT '是否默认 1:是 0:否', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 24.376759ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_user_template_id` ON `sys_user_template` (`id`) [] - 20.849325ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.913808ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `sys_user_template_detail` (`id` VARCHAR(36) PRIMARY KEY NOT NULL COMMENT '主键', `temp_id` VARCHAR(36) NOT NULL COMMENT '模板ID', `name` VARCHAR(200) NOT NULL COMMENT '名称', `value` VARCHAR(200) NOT NULL COMMENT '值', `type` TEXT NULL COMMENT '模板类型 0:数值项 1:单选项 2:文字项 3:列表项', `content` VARCHAR(200) NOT NULL COMMENT '名称', `priority` TEXT NULL COMMENT '优先级', `create_by` VARCHAR(36) NOT NULL COMMENT '创建人', `create_time` DATETIME NOT NULL COMMENT '创建时间', `update_by` VARCHAR(36) NOT NULL COMMENT '最后更新人', `update_time` DATETIME NOT NULL COMMENT '最后更新时间', `del_flag` TEXT NOT NULL COMMENT '删除标记', `remark` VARCHAR(200) NULL COMMENT '备注') DEFAULT CHARSET utf8 [] - 20.759201ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE UNIQUE INDEX `UQE_sys_user_template_detail_id` ON `sys_user_template_detail` (`id`) [] - 16.604829ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.460296ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_access_tokens` (`token` VARCHAR(40) PRIMARY KEY NOT NULL, `user_id` INT(10) NOT NULL, `last_activity_at` DATETIME NOT NULL, `lifetime_seconds` INT(11) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 27.197595ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.382999ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_api_keys` (`key` VARCHAR(100) NOT NULL, `id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `allowed_ips` VARCHAR(255) NULL, `scopes` VARCHAR(255) NULL, `user_id` INT(10) NULL, `last_activity_at` DATETIME NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 27.684204ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 1.833781ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_discussion_tag` (`discussion_id` INT(10) NOT NULL, `tag_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `discussion_id`,`tag_id` )) DEFAULT CHARSET utf8 [] - 31.145001ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.006335ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_discussion_user` (`user_id` INT(10) NOT NULL, `discussion_id` INT(10) NOT NULL, `last_read_at` DATETIME NULL, `last_read_post_number` INT(10) NULL, `subscription` INT(10) NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `user_id`,`discussion_id` )) DEFAULT CHARSET utf8 [] - 20.366026ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.262019ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_discussions` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `title` VARCHAR(200) NOT NULL, `comment_count` INT(10) DEFAULT 0 NOT NULL, `participant_count` INT(10) DEFAULT 0 NOT NULL, `post_number_index` INT(10) DEFAULT 0 NOT NULL, `user_id` INT(10) NULL, `first_post_id` INT(10) NULL, `last_posted_at` DATETIME NULL, `last_posted_user_id` INT(10) NULL, `last_post_id` INT(10) NULL, `last_post_number` INT(10) NULL, `hidden_at` DATETIME NULL, `hidden_user_id` INT(10) NULL, `slug` VARCHAR(255) NOT NULL, `is_private` INT(10) DEFAULT 0 NOT NULL, `is_approved` INT(10) DEFAULT 1 NOT NULL, `is_locked` INT(10) DEFAULT 0 NOT NULL, `is_sticky` INT(10) DEFAULT 0 NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 26.862843ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.608656ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_email_tokens` (`token` VARCHAR(100) PRIMARY KEY NOT NULL, `email` VARCHAR(150) NOT NULL, `user_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 18.733488ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.071422ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_flags` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `post_id` INT(10) NOT NULL, `type` VARCHAR(255) NOT NULL, `user_id` INT(10) NULL, `reason` VARCHAR(255) NULL, `reason_detail` VARCHAR(255) NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 20.537162ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.75421ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_group_permission` (`group_id` INT(10) NOT NULL, `permission` VARCHAR(100) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `group_id`,`permission` )) DEFAULT CHARSET utf8 [] - 19.836622ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.482172ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_group_user` (`user_id` INT(10) NOT NULL, `group_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `user_id`,`group_id` )) DEFAULT CHARSET utf8 [] - 21.760594ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 4.242113ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_groups` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `name_singular` VARCHAR(100) NOT NULL, `name_plural` VARCHAR(100) NOT NULL, `color` VARCHAR(20) NULL, `icon` VARCHAR(100) NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 21.37898ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.081879ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_login_providers` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `user_id` INT(10) NOT NULL, `provider` VARCHAR(100) NOT NULL, `identifier` VARCHAR(100) NOT NULL, `last_login_at` DATETIME NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 30.964512ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.089807ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_migrations` (`migration` VARCHAR(255) NOT NULL, `extension` VARCHAR(255) NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 23.671994ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.290208ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_notifications` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `user_id` INT(10) NOT NULL, `from_user_id` INT(10) NULL, `type` VARCHAR(100) NOT NULL, `subject_id` INT(10) NULL, `data` BLOB NULL, `read_at` DATETIME NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 19.422094ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.938781ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_password_tokens` (`token` VARCHAR(100) PRIMARY KEY NOT NULL, `user_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 19.627355ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.170898ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_post_likes` (`post_id` INT(10) NOT NULL, `user_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `post_id`,`user_id` )) DEFAULT CHARSET utf8 [] - 21.259933ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 3.188993ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_post_mentions_post` (`post_id` INT(10) NOT NULL, `mentions_post_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `post_id`,`mentions_post_id` )) DEFAULT CHARSET utf8 [] - 33.831454ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.102333ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_post_mentions_user` (`post_id` INT(10) NOT NULL, `mentions_user_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `post_id`,`mentions_user_id` )) DEFAULT CHARSET utf8 [] - 26.021227ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.701916ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_post_user` (`post_id` INT(10) NOT NULL, `user_id` INT(10) NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `post_id`,`user_id` )) DEFAULT CHARSET utf8 [] - 19.455943ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.780874ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_posts` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `discussion_id` INT(10) NOT NULL, `number` INT(10) NULL, `user_id` INT(10) NULL, `type` VARCHAR(100) NULL, `content` TEXT NULL, `edited_at` DATETIME NULL, `edited_user_id` INT(10) NULL, `hidden_at` DATETIME NULL, `hidden_user_id` INT(10) NULL, `ip_address` VARCHAR(45) NULL, `is_private` INT(10) DEFAULT 0 NOT NULL, `is_approved` INT(10) DEFAULT 1 NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 21.609855ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.708281ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_registration_tokens` (`token` VARCHAR(100) PRIMARY KEY NOT NULL, `payload` TEXT NULL, `provider` VARCHAR(255) NOT NULL, `identifier` VARCHAR(255) NOT NULL, `user_attributes` TEXT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 18.894709ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.262432ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_settings` (`key` VARCHAR(100) PRIMARY KEY NOT NULL, `value` TEXT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 31.323978ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.975726ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_tag_user` (`user_id` INT(10) NOT NULL, `tag_id` INT(10) NOT NULL, `marked_as_read_at` DATETIME NULL, `is_hidden` INT(10) DEFAULT 0 NOT NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark', PRIMARY KEY ( `user_id`,`tag_id` )) DEFAULT CHARSET utf8 [] - 18.810307ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.61189ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_tags` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `name` VARCHAR(100) NOT NULL, `slug` VARCHAR(100) NOT NULL, `description` TEXT NULL, `color` VARCHAR(50) NULL, `background_path` VARCHAR(100) NULL, `background_mode` VARCHAR(100) NULL, `position` INT(11) NULL, `parent_id` INT(10) NULL, `default_sort` VARCHAR(50) NULL, `is_restricted` INT(10) DEFAULT 0 NOT NULL, `is_hidden` INT(10) DEFAULT 0 NOT NULL, `discussion_count` INT(10) DEFAULT 0 NOT NULL, `last_posted_at` DATETIME NULL, `last_posted_discussion_id` INT(10) NULL, `last_posted_user_id` INT(10) NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 22.071859ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT `TABLE_NAME`, `ENGINE`, `AUTO_INCREMENT`, `TABLE_COMMENT` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? AND (`ENGINE`='MyISAM' OR `ENGINE` = 'InnoDB' OR `ENGINE` = 'TokuDB') [flarum_localhost] - 2.870224ms"
+time="01/10 14:52:08" level=info msg="[SQL] CREATE TABLE IF NOT EXISTS `flarum_users` (`id` INT(10) PRIMARY KEY AUTO_INCREMENT NOT NULL, `username` VARCHAR(100) NOT NULL, `email` VARCHAR(150) NOT NULL, `is_email_confirmed` INT(10) DEFAULT 0 NOT NULL, `password` VARCHAR(100) NOT NULL, `bio` TEXT NULL, `avatar_url` VARCHAR(100) NULL, `preferences` BLOB NULL, `joined_at` DATETIME NULL, `last_seen_at` DATETIME NULL, `marked_all_as_read_at` DATETIME NULL, `read_notifications_at` DATETIME NULL, `discussion_count` INT(10) DEFAULT 0 NOT NULL, `comment_count` INT(10) DEFAULT 0 NOT NULL, `read_flags_at` DATETIME NULL, `suspended_until` DATETIME NULL, `create_by` VARCHAR(36) NULL COMMENT 'Creator', `create_time` DATETIME NULL COMMENT 'Creation time', `update_by` VARCHAR(36) NULL COMMENT 'Last updated by', `update_time` DATETIME NULL COMMENT 'Last update time', `del_flag` TEXT NOT NULL COMMENT 'Delete tag', `remark` VARCHAR(200) NULL COMMENT 'Remark') DEFAULT CHARSET utf8 [] - 18.872461ms"
+time="01/10 14:52:08" level=info msg="[SQL] UPDATE `sys_domain` SET `sync_flag` = ? WHERE (sync_flag=0 and app_name = ?) [1 flarum] - 3.412525ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_client` WHERE (id=?) [5ba2b110-9dad-11d1-80b4-00c04fd431c4] - 764.626µs"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_user` WHERE (id=?) [6ba7b810-9dad-11d1-80b4-00c04fd430c8] - 590.117µs"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_role` WHERE (id=?) [4c18ee66-c5e6-40a7-b190-86d115bae3e5] - 587.887µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_role` (`id`,`name`,`code`,`status`,`app_index`,`admin_index`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?) [4c18ee66-c5e6-40a7-b190-86d115bae3e5 admin X8e6D3y60K 1 <nil> <nil> 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:07.208168678 +0800 CST m=+0.003126932 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:07.208168767 +0800 CST m=+0.003127021 0 <nil>] - 3.499216ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_org` WHERE (id=?) [b6a7bt50-7dad-31d1-81b5-10c34fd460e3] - 646.877µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_org` (`id`,`parent`,`inheritance`,`name`,`full_name`,`leader`,`code`,`type`,`order`,`status`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [b6a7bt50-7dad-31d1-81b5-10c34fd460e3 <nil> |b6a7bt50-7dad-31d1-81b5-10c34fd460e3 Headquarters <nil> <nil> HQ <nil> 0 1 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.807238439 +0800 CST m=+1.602196705 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.807238536 +0800 CST m=+1.602196797 0 <nil>] - 3.393022ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_org` WHERE (id=?) [c637bt50-7dad-31d1-81b5-10c34fd460e1] - 671.692µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_org` (`id`,`parent`,`inheritance`,`name`,`full_name`,`leader`,`code`,`type`,`order`,`status`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [c637bt50-7dad-31d1-81b5-10c34fd460e1 b6a7bt50-7dad-31d1-81b5-10c34fd460e3 |b6a7bt50-7dad-31d1-81b5-10c34fd460e3|c637bt50-7dad-31d1-81b5-10c34fd460e1 Administrative <nil> <nil> AD <nil> 0 1 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.807238626 +0800 CST m=+1.602196887 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.807238737 +0800 CST m=+1.602197017 0 <nil>] - 3.406344ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_org` WHERE (id=?) [5637bt50-7dad-31d1-81b5-10c34fd460e1] - 1.56123ms"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_org` (`id`,`parent`,`inheritance`,`name`,`full_name`,`leader`,`code`,`type`,`order`,`status`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [5637bt50-7dad-31d1-81b5-10c34fd460e1 b6a7bt50-7dad-31d1-81b5-10c34fd460e3 |b6a7bt50-7dad-31d1-81b5-10c34fd460e3|5637bt50-7dad-31d1-81b5-10c34fd460e1 Technology <nil> <nil> TD <nil> 1 1 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.80723887 +0800 CST m=+1.602197140 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.807238984 +0800 CST m=+1.602197256 0 <nil>] - 4.870859ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_role_user` WHERE (id=?) [{{03eda436-2772-48da-86d8-97b2bd80e391 true}}] - 634.792µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_role_user` (`id`,`user_id`,`role_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?) [03eda436-2772-48da-86d8-97b2bd80e391 6ba7b810-9dad-11d1-80b4-00c04fd430c8 4c18ee66-c5e6-40a7-b190-86d115bae3e5 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:07.208168859 +0800 CST m=+0.003127112 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:07.208168949 +0800 CST m=+0.003127202 0 <nil>] - 3.456516ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [7b8bf57f-76f6-49d9-8529-7690cf385219] - 730.947µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [7b8bf57f-76f6-49d9-8529-7690cf385219 Application Application <nil> <nil> application application/index <nil> 1 application 0 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827697628 +0800 CST m=+1.622655929 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.82769778 +0800 CST m=+1.622656056 0 <nil>] - 3.931032ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [0a8bc79f-76f6-49d9-8529-7690cf385212] - 776.985µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [0a8bc79f-76f6-49d9-8529-7690cf385212 Setting Setting <nil> <nil> setting <nil> <nil> 0 setting 1 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827697891 +0800 CST m=+1.622656156 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827697991 +0800 CST m=+1.622656257 0 <nil>] - 3.49898ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [33cec683-e7a9-4e29-98d2-e0151df32221] - 712.614µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [33cec683-e7a9-4e29-98d2-e0151df32221 User User 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|33cec683-e7a9-4e29-98d2-e0151df32221| user user/index <nil> 1 user 0 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698106 +0800 CST m=+1.622656373 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698228 +0800 CST m=+1.622656498 0 <nil>] - 9.162346ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [53ceb683-e8a9-4e29-98d2-e0151df32277] - 713.657µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [53ceb683-e8a9-4e29-98d2-e0151df32277 Org Org 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|53ceb683-e8a9-4e29-98d2-e0151df32277| org org/index <nil> 1 org 1 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698333 +0800 CST m=+1.622656602 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698433 +0800 CST m=+1.622656693 0 <nil>] - 6.384086ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [1da0a707-54c2-4289-97a3-5cdbdcf899e8] - 691.21µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [1da0a707-54c2-4289-97a3-5cdbdcf899e8 Role Role 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|1da0a707-54c2-4289-97a3-5cdbdcf899e8| role role/index <nil> 1 role 2 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698522 +0800 CST m=+1.622656783 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.82769862 +0800 CST m=+1.622656888 0 <nil>] - 3.780591ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [33cec683-e7a9-4e29-98d2-e0151df32218] - 657.317µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [33cec683-e7a9-4e29-98d2-e0151df32218 OptionSet OptionSet 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|33cec683-e7a9-4e29-98d2-e0151df32218| optionset optionset/index <nil> 1 optionset 3 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698722 +0800 CST m=+1.622656985 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698836 +0800 CST m=+1.622657105 0 <nil>] - 3.405908ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [33cec683-e7a9-4e29-98d2-e0151df32237] - 879.807µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [33cec683-e7a9-4e29-98d2-e0151df32237 Menu Menu 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|33cec683-e7a9-4e29-98d2-e0151df32237| menu menu/index <nil> 1 menu 4 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827698941 +0800 CST m=+1.622657203 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.82769904 +0800 CST m=+1.622657311 0 <nil>] - 8.498592ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [36bfc673-e7a9-4e77-18d2-e0121df3b220] - 1.933156ms"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [36bfc673-e7a9-4e77-18d2-e0121df3b220 Scheduling Scheduling 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|36bfc673-e7a9-4e77-18d2-e0121df3b220| scheduling scheduling/index <nil> 1 scheduling 5 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827699151 +0800 CST m=+1.622657415 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827699258 +0800 CST m=+1.622657519 0 <nil>] - 8.100483ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [26bfc673-ac79-4e77-18d2-e0121df3b220] - 990.105µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [26bfc673-ac79-4e77-18d2-e0121df3b220 Attachment Attachment 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|26bfc673-ac79-4e77-18d2-e0121df3b220| attachment attachment/index <nil> 1 attachment 6 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.82769935 +0800 CST m=+1.622657616 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827699445 +0800 CST m=+1.622657708 0 <nil>] - 6.969358ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_menu` WHERE (id=?) [33cec683-e7a9-4e29-98d2-e0151df32220] - 926.57µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_menu` (`id`,`name`,`code`,`parent`,`inheritance`,`url`,`component`,`perms`,`type`,`icon`,`order`,`hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) [33cec683-e7a9-4e29-98d2-e0151df32220 Tracker Tracker 0a8bc79f-76f6-49d9-8529-7690cf385212 |0a8bc79f-76f6-49d9-8529-7690cf385212|33cec683-e7a9-4e29-98d2-e0151df32220| tracker tracker/index <nil> 1 tracker 7 0 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827699543 +0800 CST m=+1.622657808 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.827699646 +0800 CST m=+1.622657907 0 <nil>] - 9.232787ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_optionset` WHERE (id=?) [c6a7bt50-7dad-31d1-81b5-10c34fd460e2] - 753.317µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_optionset` (`id`,`name`,`code`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?) [c6a7bt50-7dad-31d1-81b5-10c34fd460e2 域名启用状态 sys_domain_status [{\"text\":\"禁用\",\"value\":0},{\"text\":\"正常\",\"value\":1}] 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905334902 +0800 CST m=+1.700293175 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335009 +0800 CST m=+1.700293285 0 <nil>] - 7.04078ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_optionset` WHERE (id=?) [b6a7ct5q-2dad-31d1-81b5-10c34fd460c3] - 804.579µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_optionset` (`id`,`name`,`code`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?) [b6a7ct5q-2dad-31d1-81b5-10c34fd460c3 域名认证模式 sys_domain_auth_mode [{\"text\":\"集成登录\",\"value\":0},{\"text\":\"单点登录\",\"value\":1}] 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335131 +0800 CST m=+1.700293394 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335224 +0800 CST m=+1.700293486 0 <nil>] - 3.446738ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_optionset` WHERE (id=?) [c6a7bt50-7dad-31d1-81b5-10c34fd460c2] - 695.644µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_optionset` (`id`,`name`,`code`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?) [c6a7bt50-7dad-31d1-81b5-10c34fd460c2 域名数据库标志 sys_domain_sync_flag [{\"text\":\"未同步\",\"value\":0},{\"text\":\"已同步\",\"value\":1}] 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335314 +0800 CST m=+1.700293576 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335402 +0800 CST m=+1.700293663 0 <nil>] - 3.510391ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_optionset` WHERE (id=?) [b4a7bt50-7dad-12d1-81b5-10c34fd460e4] - 741.757µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_optionset` (`id`,`name`,`code`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?) [b4a7bt50-7dad-12d1-81b5-10c34fd460e4 帐号启用状态 sys_user_status [{\"text\":\"禁用\",\"value\":0},{\"text\":\"正常\",\"value\":1}] 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335494 +0800 CST m=+1.700293768 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335609 +0800 CST m=+1.700293880 0 <nil>] - 3.49541ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_optionset` WHERE (id=?) [a1b7b150-6dad-12d1-81b5-10c34fd460e5] - 1.239479ms"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_optionset` (`id`,`name`,`code`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?) [a1b7b150-6dad-12d1-81b5-10c34fd460e5 菜单类型 sys_menu_type [{\"text\":\"Dir\",\"value\":0},{\"text\":\"Menu\",\"value\":1},{\"text\":\"Button\",\"value\":2}] 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905335728 +0800 CST m=+1.700294444 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905336276 +0800 CST m=+1.700294540 0 <nil>] - 3.619143ms"
+time="01/10 14:52:08" level=info msg="[SQL] SELECT count(*) FROM `sys_optionset` WHERE (id=?) [c2b5b260-7jad-12d1-81b5-10c34fd460e6] - 664.523µs"
+time="01/10 14:52:08" level=info msg="[SQL] INSERT INTO `sys_optionset` (`id`,`name`,`code`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`) VALUES (?,?,?,?,?,?,?,?,?,?) [c2b5b260-7jad-12d1-81b5-10c34fd460e6 持久类型 sys_attachment_durable [{\"text\":\"否\",\"value\":0},{\"text\":\"是\",\"value\":1}] 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905336379 +0800 CST m=+1.700294651 6ba7b810-9dad-11d1-80b4-00c04fd430c8 2020-10-01 14:52:08.905336503 +0800 CST m=+1.700294775 0 <nil>] - 3.186032ms"
+time="01/10 14:52:08" level=info msg="grpc listen on port:9081"
+time="01/10 14:52:08" level=info msg="http listen on port:8081"
+time="01/10 19:03:36" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 19:03:36" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 19:03:36" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 1.366413ms"
+time="01/10 19:03:36" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 2.265814ms"
+time="01/10 19:03:36" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 669.476µs"
+time="01/10 19:03:36" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 19:03:36" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 1.0059ms"
+time="01/10 19:03:36" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 629.755µs"
+time="01/10 19:03:36" level=info msg="[SQL] SELECT count(*) FROM `sys_client` WHERE (id=?) [5ba2b110-9dad-11d1-80b4-00c04fd431c4] - 1.820878ms"
+time="01/10 19:03:36" level=info msg="[SQL] SELECT count(*) FROM `sys_user` WHERE (id=?) [6ba7b810-9dad-11d1-80b4-00c04fd430c8] - 1.035971ms"
+time="01/10 19:03:36" level=info msg="grpc listen on port:9081"
+time="01/10 19:03:36" level=info msg="http listen on port:8081"
+time="01/10 19:03:42" level=warning msg="Redis::@localhost:6379/0 connect failed"
+time="01/10 19:03:42" level=info msg="mysql root:111111@/dolphin?charset=utf8&parseTime=True&loc=Local"
+time="01/10 19:03:42" level=info msg="[SQL] SELECT `TABLE_NAME` from `INFORMATION_SCHEMA`.`TABLES` WHERE `TABLE_SCHEMA`=? and `TABLE_NAME`=? [dolphin sys_domain] - 592.591µs"
+time="01/10 19:03:42" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (id=?) [5ba2b810-9dad-11d1-80b4-00c04fd430c1] - 565.475µs"
+time="01/10 19:03:42" level=info msg="[SQL] SELECT `id`, `name`, `app_name`, `domain`, `domain_url`, `full_name`, `contact_name`, `contact_email`, `contact_mobile`, `data_source`, `driver_name`, `login_url`, `api_url`, `static_url`, `theme`, `type`, `status`, `auth_mode`, `sync_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `del_flag`, `remark` FROM `sys_domain` WHERE (data_source <> '' and domain <> '' and app_name = ? and del_flag = 0) [flarum] - 635.702µs"
+time="01/10 19:03:42" level=info msg="mysql root:111111@/flarum_localhost?charset=utf8&parseTime=True&loc=Local"
+time="01/10 19:03:42" level=info msg="[SQL] create database if not exists flarum_localhost default character set utf8mb4 [] - 288.743µs"
+time="01/10 19:03:42" level=info msg="[SQL] SELECT count(*) FROM `sys_domain` WHERE (sync_flag=0) [] - 414.499µs"
+time="01/10 19:03:42" level=info msg="[SQL] SELECT count(*) FROM `sys_client` WHERE (id=?) [5ba2b110-9dad-11d1-80b4-00c04fd431c4] - 430.024µs"
+time="01/10 19:03:42" level=info msg="[SQL] SELECT count(*) FROM `sys_user` WHERE (id=?) [6ba7b810-9dad-11d1-80b4-00c04fd430c8] - 375.722µs"
+time="01/10 19:03:42" level=info msg="grpc listen on port:9081"
+time="01/10 19:03:42" level=info msg="http listen on port:8081"

+ 18 - 0
main.go

@@ -0,0 +1,18 @@
+// Code generated by dol build. Only Generate by tools if not existed.
+// source: main.go
+
+package main
+
+import (
+	// "github.com/2637309949/dolphin/platform/app" init
+	_ "github.com/2637309949/dolphin/platform/app"
+	// "github.com/go-sql-driver/mysql" init
+	_ "github.com/go-sql-driver/mysql"
+	// "flarum/app" init
+	"flarum/app"
+)
+
+//go:generate dolphin build
+func main() {
+	app.Run()
+}

+ 37 - 0
model/flarum_access_tokens.auto.go

@@ -0,0 +1,37 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumAccessTokens defined
+type FlarumAccessTokens struct {
+	//
+	Token null.String `xorm:"varchar(40) pk notnull 'token'" json:"token" xml:"token"`
+	//
+	UserId null.Int `xorm:"int(10) notnull 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	LastActivityAt null.Time `xorm:"datetime notnull 'last_activity_at'" json:"last_activity_at" xml:"last_activity_at"`
+	//
+	LifetimeSeconds null.Int `xorm:"int(11) notnull 'lifetime_seconds'" json:"lifetime_seconds" xml:"lifetime_seconds"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumAccessTokens
+func (m *FlarumAccessTokens) TableName() string {
+	return "flarum_access_tokens"
+}

+ 41 - 0
model/flarum_api_keys.auto.go

@@ -0,0 +1,41 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumApiKeys defined
+type FlarumApiKeys struct {
+	//
+	Key null.String `xorm:"varchar(100) notnull 'key'" json:"key" xml:"key"`
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	AllowedIps null.String `xorm:"varchar(255) 'allowed_ips'" json:"allowed_ips" xml:"allowed_ips"`
+	//
+	Scopes null.String `xorm:"varchar(255) 'scopes'" json:"scopes" xml:"scopes"`
+	//
+	UserId null.Int `xorm:"int(10) 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	LastActivityAt null.Time `xorm:"datetime 'last_activity_at'" json:"last_activity_at" xml:"last_activity_at"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumApiKeys
+func (m *FlarumApiKeys) TableName() string {
+	return "flarum_api_keys"
+}

+ 33 - 0
model/flarum_discussion_tag.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumDiscussionTag defined
+type FlarumDiscussionTag struct {
+	//
+	DiscussionId null.Int `xorm:"int(10) pk notnull 'discussion_id'" json:"discussion_id" xml:"discussion_id"`
+	//
+	TagId null.Int `xorm:"int(10) pk notnull 'tag_id'" json:"tag_id" xml:"tag_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumDiscussionTag
+func (m *FlarumDiscussionTag) TableName() string {
+	return "flarum_discussion_tag"
+}

+ 39 - 0
model/flarum_discussion_user.auto.go

@@ -0,0 +1,39 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumDiscussionUser defined
+type FlarumDiscussionUser struct {
+	//
+	UserId null.Int `xorm:"int(10) pk notnull 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	DiscussionId null.Int `xorm:"int(10) pk notnull 'discussion_id'" json:"discussion_id" xml:"discussion_id"`
+	//
+	LastReadAt null.Time `xorm:"datetime 'last_read_at'" json:"last_read_at" xml:"last_read_at"`
+	//
+	LastReadPostNumber null.Int `xorm:"int(10) 'last_read_post_number'" json:"last_read_post_number" xml:"last_read_post_number"`
+	//
+	Subscription null.Int `xorm:"int(10) 'subscription'" json:"subscription" xml:"subscription"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumDiscussionUser
+func (m *FlarumDiscussionUser) TableName() string {
+	return "flarum_discussion_user"
+}

+ 65 - 0
model/flarum_discussions.auto.go

@@ -0,0 +1,65 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumDiscussions defined
+type FlarumDiscussions struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	Title null.String `xorm:"varchar(200) notnull 'title'" json:"title" xml:"title"`
+	//
+	CommentCount null.Int `xorm:"int(10) notnull default(0) 'comment_count'" json:"comment_count" xml:"comment_count"`
+	//
+	ParticipantCount null.Int `xorm:"int(10) notnull default(0) 'participant_count'" json:"participant_count" xml:"participant_count"`
+	//
+	PostNumberIndex null.Int `xorm:"int(10) notnull default(0) 'post_number_index'" json:"post_number_index" xml:"post_number_index"`
+	//
+	UserId null.Int `xorm:"int(10) 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	FirstPostId null.Int `xorm:"int(10) 'first_post_id'" json:"first_post_id" xml:"first_post_id"`
+	//
+	LastPostedAt null.Time `xorm:"datetime 'last_posted_at'" json:"last_posted_at" xml:"last_posted_at"`
+	//
+	LastPostedUserId null.Int `xorm:"int(10) 'last_posted_user_id'" json:"last_posted_user_id" xml:"last_posted_user_id"`
+	//
+	LastPostId null.Int `xorm:"int(10) 'last_post_id'" json:"last_post_id" xml:"last_post_id"`
+	//
+	LastPostNumber null.Int `xorm:"int(10) 'last_post_number'" json:"last_post_number" xml:"last_post_number"`
+	//
+	HiddenAt null.Time `xorm:"datetime 'hidden_at'" json:"hidden_at" xml:"hidden_at"`
+	//
+	HiddenUserId null.Int `xorm:"int(10) 'hidden_user_id'" json:"hidden_user_id" xml:"hidden_user_id"`
+	//
+	Slug null.String `xorm:"varchar(255) notnull 'slug'" json:"slug" xml:"slug"`
+	//
+	IsPrivate null.Int `xorm:"int(10) notnull default(0) 'is_private'" json:"is_private" xml:"is_private"`
+	//
+	IsApproved null.Int `xorm:"int(10) notnull default(1) 'is_approved'" json:"is_approved" xml:"is_approved"`
+	//
+	IsLocked null.Int `xorm:"int(10) notnull default(0) 'is_locked'" json:"is_locked" xml:"is_locked"`
+	//
+	IsSticky null.Int `xorm:"int(10) notnull default(0) 'is_sticky'" json:"is_sticky" xml:"is_sticky"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumDiscussions
+func (m *FlarumDiscussions) TableName() string {
+	return "flarum_discussions"
+}

+ 35 - 0
model/flarum_email_tokens.auto.go

@@ -0,0 +1,35 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumEmailTokens defined
+type FlarumEmailTokens struct {
+	//
+	Token null.String `xorm:"varchar(100) pk notnull 'token'" json:"token" xml:"token"`
+	//
+	Email null.String `xorm:"varchar(150) notnull 'email'" json:"email" xml:"email"`
+	//
+	UserId null.Int `xorm:"int(10) notnull 'user_id'" json:"user_id" xml:"user_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumEmailTokens
+func (m *FlarumEmailTokens) TableName() string {
+	return "flarum_email_tokens"
+}

+ 41 - 0
model/flarum_flags.auto.go

@@ -0,0 +1,41 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumFlags defined
+type FlarumFlags struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	PostId null.Int `xorm:"int(10) notnull 'post_id'" json:"post_id" xml:"post_id"`
+	//
+	Type null.String `xorm:"varchar(255) notnull 'type'" json:"type" xml:"type"`
+	//
+	UserId null.Int `xorm:"int(10) 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	Reason null.String `xorm:"varchar(255) 'reason'" json:"reason" xml:"reason"`
+	//
+	ReasonDetail null.String `xorm:"varchar(255) 'reason_detail'" json:"reason_detail" xml:"reason_detail"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumFlags
+func (m *FlarumFlags) TableName() string {
+	return "flarum_flags"
+}

+ 33 - 0
model/flarum_group_permission.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumGroupPermission defined
+type FlarumGroupPermission struct {
+	//
+	GroupId null.Int `xorm:"int(10) pk notnull 'group_id'" json:"group_id" xml:"group_id"`
+	//
+	Permission null.String `xorm:"varchar(100) pk notnull 'permission'" json:"permission" xml:"permission"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumGroupPermission
+func (m *FlarumGroupPermission) TableName() string {
+	return "flarum_group_permission"
+}

+ 33 - 0
model/flarum_group_user.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumGroupUser defined
+type FlarumGroupUser struct {
+	//
+	UserId null.Int `xorm:"int(10) pk notnull 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	GroupId null.Int `xorm:"int(10) pk notnull 'group_id'" json:"group_id" xml:"group_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumGroupUser
+func (m *FlarumGroupUser) TableName() string {
+	return "flarum_group_user"
+}

+ 39 - 0
model/flarum_groups.auto.go

@@ -0,0 +1,39 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumGroups defined
+type FlarumGroups struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	NameSingular null.String `xorm:"varchar(100) notnull 'name_singular'" json:"name_singular" xml:"name_singular"`
+	//
+	NamePlural null.String `xorm:"varchar(100) notnull 'name_plural'" json:"name_plural" xml:"name_plural"`
+	//
+	Color null.String `xorm:"varchar(20) 'color'" json:"color" xml:"color"`
+	//
+	Icon null.String `xorm:"varchar(100) 'icon'" json:"icon" xml:"icon"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumGroups
+func (m *FlarumGroups) TableName() string {
+	return "flarum_groups"
+}

+ 39 - 0
model/flarum_login_providers.auto.go

@@ -0,0 +1,39 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumLoginProviders defined
+type FlarumLoginProviders struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	UserId null.Int `xorm:"int(10) notnull 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	Provider null.String `xorm:"varchar(100) notnull 'provider'" json:"provider" xml:"provider"`
+	//
+	Identifier null.String `xorm:"varchar(100) notnull 'identifier'" json:"identifier" xml:"identifier"`
+	//
+	LastLoginAt null.Time `xorm:"datetime 'last_login_at'" json:"last_login_at" xml:"last_login_at"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumLoginProviders
+func (m *FlarumLoginProviders) TableName() string {
+	return "flarum_login_providers"
+}

+ 33 - 0
model/flarum_migrations.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumMigrations defined
+type FlarumMigrations struct {
+	//
+	Migration null.String `xorm:"varchar(255) notnull 'migration'" json:"migration" xml:"migration"`
+	//
+	Extension null.String `xorm:"varchar(255) 'extension'" json:"extension" xml:"extension"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumMigrations
+func (m *FlarumMigrations) TableName() string {
+	return "flarum_migrations"
+}

+ 43 - 0
model/flarum_notifications.auto.go

@@ -0,0 +1,43 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumNotifications defined
+type FlarumNotifications struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	UserId null.Int `xorm:"int(10) notnull 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	FromUserId null.Int `xorm:"int(10) 'from_user_id'" json:"from_user_id" xml:"from_user_id"`
+	//
+	Type null.String `xorm:"varchar(100) notnull 'type'" json:"type" xml:"type"`
+	//
+	SubjectId null.Int `xorm:"int(10) 'subject_id'" json:"subject_id" xml:"subject_id"`
+	//
+	Data []byte `xorm:"blob 'data'" json:"data" xml:"data"`
+	//
+	ReadAt null.Time `xorm:"datetime 'read_at'" json:"read_at" xml:"read_at"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumNotifications
+func (m *FlarumNotifications) TableName() string {
+	return "flarum_notifications"
+}

+ 33 - 0
model/flarum_password_tokens.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPasswordTokens defined
+type FlarumPasswordTokens struct {
+	//
+	Token null.String `xorm:"varchar(100) pk notnull 'token'" json:"token" xml:"token"`
+	//
+	UserId null.Int `xorm:"int(10) notnull 'user_id'" json:"user_id" xml:"user_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumPasswordTokens
+func (m *FlarumPasswordTokens) TableName() string {
+	return "flarum_password_tokens"
+}

+ 33 - 0
model/flarum_post_likes.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPostLikes defined
+type FlarumPostLikes struct {
+	//
+	PostId null.Int `xorm:"int(10) pk notnull 'post_id'" json:"post_id" xml:"post_id"`
+	//
+	UserId null.Int `xorm:"int(10) pk notnull 'user_id'" json:"user_id" xml:"user_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumPostLikes
+func (m *FlarumPostLikes) TableName() string {
+	return "flarum_post_likes"
+}

+ 33 - 0
model/flarum_post_mentions_post.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPostMentionsPost defined
+type FlarumPostMentionsPost struct {
+	//
+	PostId null.Int `xorm:"int(10) pk notnull 'post_id'" json:"post_id" xml:"post_id"`
+	//
+	MentionsPostId null.Int `xorm:"int(10) pk notnull 'mentions_post_id'" json:"mentions_post_id" xml:"mentions_post_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumPostMentionsPost
+func (m *FlarumPostMentionsPost) TableName() string {
+	return "flarum_post_mentions_post"
+}

+ 33 - 0
model/flarum_post_mentions_user.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPostMentionsUser defined
+type FlarumPostMentionsUser struct {
+	//
+	PostId null.Int `xorm:"int(10) pk notnull 'post_id'" json:"post_id" xml:"post_id"`
+	//
+	MentionsUserId null.Int `xorm:"int(10) pk notnull 'mentions_user_id'" json:"mentions_user_id" xml:"mentions_user_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumPostMentionsUser
+func (m *FlarumPostMentionsUser) TableName() string {
+	return "flarum_post_mentions_user"
+}

+ 33 - 0
model/flarum_post_user.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPostUser defined
+type FlarumPostUser struct {
+	//
+	PostId null.Int `xorm:"int(10) pk notnull 'post_id'" json:"post_id" xml:"post_id"`
+	//
+	UserId null.Int `xorm:"int(10) pk notnull 'user_id'" json:"user_id" xml:"user_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumPostUser
+func (m *FlarumPostUser) TableName() string {
+	return "flarum_post_user"
+}

+ 55 - 0
model/flarum_posts.auto.go

@@ -0,0 +1,55 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPosts defined
+type FlarumPosts struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	DiscussionId null.Int `xorm:"int(10) notnull 'discussion_id'" json:"discussion_id" xml:"discussion_id"`
+	//
+	Number null.Int `xorm:"int(10) 'number'" json:"number" xml:"number"`
+	//
+	UserId null.Int `xorm:"int(10) 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	Type null.String `xorm:"varchar(100) 'type'" json:"type" xml:"type"`
+	//
+	Content null.String `xorm:"text 'content'" json:"content" xml:"content"`
+	//
+	EditedAt null.Time `xorm:"datetime 'edited_at'" json:"edited_at" xml:"edited_at"`
+	//
+	EditedUserId null.Int `xorm:"int(10) 'edited_user_id'" json:"edited_user_id" xml:"edited_user_id"`
+	//
+	HiddenAt null.Time `xorm:"datetime 'hidden_at'" json:"hidden_at" xml:"hidden_at"`
+	//
+	HiddenUserId null.Int `xorm:"int(10) 'hidden_user_id'" json:"hidden_user_id" xml:"hidden_user_id"`
+	//
+	IpAddress null.String `xorm:"varchar(45) 'ip_address'" json:"ip_address" xml:"ip_address"`
+	//
+	IsPrivate null.Int `xorm:"int(10) notnull default(0) 'is_private'" json:"is_private" xml:"is_private"`
+	//
+	IsApproved null.Int `xorm:"int(10) notnull default(1) 'is_approved'" json:"is_approved" xml:"is_approved"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumPosts
+func (m *FlarumPosts) TableName() string {
+	return "flarum_posts"
+}

+ 17 - 0
model/flarum_posts_info.auto.go

@@ -0,0 +1,17 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumPostsInfo defined FlarumPosts info
+type FlarumPostsInfo struct {
+	*FlarumPosts
+	// Content
+	Content null.String `json:"content" xml:"content"`
+	// Title
+	Title null.String `json:"title" xml:"title"`
+}

+ 39 - 0
model/flarum_registration_tokens.auto.go

@@ -0,0 +1,39 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumRegistrationTokens defined
+type FlarumRegistrationTokens struct {
+	//
+	Token null.String `xorm:"varchar(100) pk notnull 'token'" json:"token" xml:"token"`
+	//
+	Payload null.String `xorm:"text 'payload'" json:"payload" xml:"payload"`
+	//
+	Provider null.String `xorm:"varchar(255) notnull 'provider'" json:"provider" xml:"provider"`
+	//
+	Identifier null.String `xorm:"varchar(255) notnull 'identifier'" json:"identifier" xml:"identifier"`
+	//
+	UserAttributes null.String `xorm:"text 'user_attributes'" json:"user_attributes" xml:"user_attributes"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumRegistrationTokens
+func (m *FlarumRegistrationTokens) TableName() string {
+	return "flarum_registration_tokens"
+}

+ 33 - 0
model/flarum_settings.auto.go

@@ -0,0 +1,33 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumSettings defined
+type FlarumSettings struct {
+	//
+	Key null.String `xorm:"varchar(100) pk notnull 'key'" json:"key" xml:"key"`
+	//
+	Value null.String `xorm:"text 'value'" json:"value" xml:"value"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumSettings
+func (m *FlarumSettings) TableName() string {
+	return "flarum_settings"
+}

+ 37 - 0
model/flarum_tag_user.auto.go

@@ -0,0 +1,37 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumTagUser defined
+type FlarumTagUser struct {
+	//
+	UserId null.Int `xorm:"int(10) pk notnull 'user_id'" json:"user_id" xml:"user_id"`
+	//
+	TagId null.Int `xorm:"int(10) pk notnull 'tag_id'" json:"tag_id" xml:"tag_id"`
+	//
+	MarkedAsReadAt null.Time `xorm:"datetime 'marked_as_read_at'" json:"marked_as_read_at" xml:"marked_as_read_at"`
+	//
+	IsHidden null.Int `xorm:"int(10) notnull default(0) 'is_hidden'" json:"is_hidden" xml:"is_hidden"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumTagUser
+func (m *FlarumTagUser) TableName() string {
+	return "flarum_tag_user"
+}

+ 61 - 0
model/flarum_tags.auto.go

@@ -0,0 +1,61 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumTags defined
+type FlarumTags struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	Name null.String `xorm:"varchar(100) notnull 'name'" json:"name" xml:"name"`
+	//
+	Slug null.String `xorm:"varchar(100) notnull 'slug'" json:"slug" xml:"slug"`
+	//
+	Description null.String `xorm:"text 'description'" json:"description" xml:"description"`
+	//
+	Color null.String `xorm:"varchar(50) 'color'" json:"color" xml:"color"`
+	//
+	BackgroundPath null.String `xorm:"varchar(100) 'background_path'" json:"background_path" xml:"background_path"`
+	//
+	BackgroundMode null.String `xorm:"varchar(100) 'background_mode'" json:"background_mode" xml:"background_mode"`
+	//
+	Position null.Int `xorm:"int(11) 'position'" json:"position" xml:"position"`
+	//
+	ParentId null.Int `xorm:"int(10) 'parent_id'" json:"parent_id" xml:"parent_id"`
+	//
+	DefaultSort null.String `xorm:"varchar(50) 'default_sort'" json:"default_sort" xml:"default_sort"`
+	//
+	IsRestricted null.Int `xorm:"int(10) notnull default(0) 'is_restricted'" json:"is_restricted" xml:"is_restricted"`
+	//
+	IsHidden null.Int `xorm:"int(10) notnull default(0) 'is_hidden'" json:"is_hidden" xml:"is_hidden"`
+	//
+	DiscussionCount null.Int `xorm:"int(10) notnull default(0) 'discussion_count'" json:"discussion_count" xml:"discussion_count"`
+	//
+	LastPostedAt null.Time `xorm:"datetime 'last_posted_at'" json:"last_posted_at" xml:"last_posted_at"`
+	//
+	LastPostedDiscussionId null.Int `xorm:"int(10) 'last_posted_discussion_id'" json:"last_posted_discussion_id" xml:"last_posted_discussion_id"`
+	//
+	LastPostedUserId null.Int `xorm:"int(10) 'last_posted_user_id'" json:"last_posted_user_id" xml:"last_posted_user_id"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumTags
+func (m *FlarumTags) TableName() string {
+	return "flarum_tags"
+}

+ 61 - 0
model/flarum_users.auto.go

@@ -0,0 +1,61 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+
+package model
+
+import (
+	"github.com/2637309949/dolphin/packages/null"
+)
+
+// FlarumUsers defined
+type FlarumUsers struct {
+	//
+	ID null.Int `xorm:"int(10) pk notnull autoincr 'id'" json:"id" xml:"id"`
+	//
+	Username null.String `xorm:"varchar(100) notnull 'username'" json:"username" xml:"username"`
+	//
+	Email null.String `xorm:"varchar(150) notnull 'email'" json:"email" xml:"email"`
+	//
+	IsEmailConfirmed null.Int `xorm:"int(10) notnull default(0) 'is_email_confirmed'" json:"is_email_confirmed" xml:"is_email_confirmed"`
+	//
+	Password null.String `xorm:"varchar(100) notnull 'password'" json:"password" xml:"password"`
+	//
+	Bio null.String `xorm:"text 'bio'" json:"bio" xml:"bio"`
+	//
+	AvatarUrl null.String `xorm:"varchar(100) 'avatar_url'" json:"avatar_url" xml:"avatar_url"`
+	//
+	Preferences []byte `xorm:"blob 'preferences'" json:"preferences" xml:"preferences"`
+	//
+	JoinedAt null.Time `xorm:"datetime 'joined_at'" json:"joined_at" xml:"joined_at"`
+	//
+	LastSeenAt null.Time `xorm:"datetime 'last_seen_at'" json:"last_seen_at" xml:"last_seen_at"`
+	//
+	MarkedAllAsReadAt null.Time `xorm:"datetime 'marked_all_as_read_at'" json:"marked_all_as_read_at" xml:"marked_all_as_read_at"`
+	//
+	ReadNotificationsAt null.Time `xorm:"datetime 'read_notifications_at'" json:"read_notifications_at" xml:"read_notifications_at"`
+	//
+	DiscussionCount null.Int `xorm:"int(10) notnull default(0) 'discussion_count'" json:"discussion_count" xml:"discussion_count"`
+	//
+	CommentCount null.Int `xorm:"int(10) notnull default(0) 'comment_count'" json:"comment_count" xml:"comment_count"`
+	//
+	ReadFlagsAt null.Time `xorm:"datetime 'read_flags_at'" json:"read_flags_at" xml:"read_flags_at"`
+	//
+	SuspendedUntil null.Time `xorm:"datetime 'suspended_until'" json:"suspended_until" xml:"suspended_until"`
+	// Creator
+	CreateBy null.String `xorm:"varchar(36) comment('Creator') 'create_by'" json:"create_by" xml:"create_by"`
+	// Creation time
+	CreateTime null.Time `xorm:"datetime comment('Creation time') 'create_time'" json:"create_time" xml:"create_time"`
+	// Last updated by
+	UpdateBy null.String `xorm:"varchar(36) comment('Last updated by') 'update_by'" json:"update_by" xml:"update_by"`
+	// Last update time
+	UpdateTime null.Time `xorm:"datetime comment('Last update time') 'update_time'" json:"update_time" xml:"update_time"`
+	// Delete tag
+	DelFlag null.Int `xorm:"notnull comment('Delete tag') 'del_flag'" json:"del_flag" xml:"del_flag"`
+	// Remark
+	Remark null.String `xorm:"varchar(200) comment('Remark') 'remark'" json:"remark" xml:"remark"`
+}
+
+// TableName table name of defined FlarumUsers
+func (m *FlarumUsers) TableName() string {
+	return "flarum_users"
+}

+ 56 - 0
script/apis/flarum_posts.js

@@ -0,0 +1,56 @@
+// Code generated by dol build. DO NOT EDIT.
+const axios = require('@/utils/request').default
+
+// add Add flarum_posts
+module.exports.add = (data) => {
+  const url = '/api/flarum/posts/add'
+  return axios({
+    url: url,
+    method: 'post',
+    data
+  })
+}
+
+// del Delete flarum_posts
+module.exports.del = (data) => {
+  const url = '/api/flarum/posts/del'
+  return axios({
+    url: url,
+    method: 'delete',
+    data
+  })
+}
+
+// update Update flarum_posts
+module.exports.update = (data) => {
+  const url = '/api/flarum/posts/update'
+  return axios({
+    url: url,
+    method: 'put',
+    data
+  })
+}
+
+// page FlarumPost page query
+module.exports.page = (data) => {
+  let url = '/api/flarum/posts/page?'
+  for (var key in data) {
+    url += key + '=' + encodeURIComponent(data[key]) + '&'
+  }
+  return axios({
+    url: url,
+    method: 'get'
+  })
+}
+
+// get Get flarum_posts info
+module.exports.get = (data) => {
+  let url = '/api/flarum/posts/get?'
+  for (var key in data) {
+    url += key + '=' + encodeURIComponent(data[key]) + '&'
+  }
+  return axios({
+    url: url,
+    method: 'get'
+  })
+}

+ 56 - 0
script/apis/flarum_users.js

@@ -0,0 +1,56 @@
+// Code generated by dol build. DO NOT EDIT.
+const axios = require('@/utils/request').default
+
+// add Add flarum_users
+module.exports.add = (data) => {
+  const url = '/api/flarum/users/add'
+  return axios({
+    url: url,
+    method: 'post',
+    data
+  })
+}
+
+// del Delete flarum_users
+module.exports.del = (data) => {
+  const url = '/api/flarum/users/del'
+  return axios({
+    url: url,
+    method: 'delete',
+    data
+  })
+}
+
+// update Update flarum_users
+module.exports.update = (data) => {
+  const url = '/api/flarum/users/update'
+  return axios({
+    url: url,
+    method: 'put',
+    data
+  })
+}
+
+// page FlarumUser page query
+module.exports.page = (data) => {
+  let url = '/api/flarum/users/page?'
+  for (var key in data) {
+    url += key + '=' + encodeURIComponent(data[key]) + '&'
+  }
+  return axios({
+    url: url,
+    method: 'get'
+  })
+}
+
+// get Get flarum_users info
+module.exports.get = (data) => {
+  let url = '/api/flarum/users/get?'
+  for (var key in data) {
+    url += key + '=' + encodeURIComponent(data[key]) + '&'
+  }
+  return axios({
+    url: url,
+    method: 'get'
+  })
+}

+ 5 - 0
script/apis/index.js

@@ -0,0 +1,5 @@
+// Code generated by dol build. DO NOT EDIT.
+// flarumPosts FlarumPosts controller
+module.exports.flarumPosts = require('./flarum_posts')
+// flarumUsers FlarumUser controller
+module.exports.flarumUsers = require('./flarum_users')

+ 11 - 0
script/axios.js

@@ -0,0 +1,11 @@
+// Code generated by dol build. DO NOT EDIT.
+// source: auto.go
+const axios = require('axios')
+
+const request = axios.create({
+  baseURL: '/',
+  timeout: 6000,
+  headers: { 'X-Custom-Header': 'xxx' }
+});
+
+module.exports = request

+ 14 - 0
sql/flarum_posts/flarum_posts_page_count.tpl

@@ -0,0 +1,14 @@
+-- Code generated by dol build. Only Generate by tools if not existed.
+-- 1. You must specify the appropriate field name, instead of the *, field can be referenced in sql/sqlmap/.xml.
+-- 2. You must load user information from the code level if you need, because the user information is present in another table.
+select
+    count(*) records
+from
+	flarum_posts
+where
+	flarum_posts.id {{.ne}} ""
+	and
+	flarum_posts.del_flag {{.ne}} 1
+{{if ne .role_rule ""}}
+	and {{.role_rule}}
+{{end}}

+ 15 - 0
sql/flarum_posts/flarum_posts_page_select.tpl

@@ -0,0 +1,15 @@
+-- Code generated by dol build. Only Generate by tools if not existed.
+-- 1. You must specify the appropriate field name, instead of the *, field can be referenced in sql/sqlmap/.xml.
+-- 2. You must load user information from the code level if you need, because the user information is present in another table.
+select
+    flarum_posts.id
+from
+	flarum_posts
+where
+	flarum_posts.id {{.ne}} ""
+	and
+	flarum_posts.del_flag {{.ne}} 1
+{{if ne .role_rule ""}}
+	and {{.role_rule}}
+{{end}}
+	LIMIT {{.size}} OFFSET {{.offset}}

+ 14 - 0
sql/flarum_users/flarum_users_page_count.tpl

@@ -0,0 +1,14 @@
+-- Code generated by dol build. Only Generate by tools if not existed.
+-- 1. You must specify the appropriate field name, instead of the *, field can be referenced in sql/sqlmap/.xml.
+-- 2. You must load user information from the code level if you need, because the user information is present in another table.
+select
+    count(*) records
+from
+	flarum_users
+where
+	flarum_users.id {{.ne}} ""
+	and
+	flarum_users.del_flag {{.ne}} 1
+{{if ne .role_rule ""}}
+	and {{.role_rule}}
+{{end}}

+ 15 - 0
sql/flarum_users/flarum_users_page_select.tpl

@@ -0,0 +1,15 @@
+-- Code generated by dol build. Only Generate by tools if not existed.
+-- 1. You must specify the appropriate field name, instead of the *, field can be referenced in sql/sqlmap/.xml.
+-- 2. You must load user information from the code level if you need, because the user information is present in another table.
+select
+    flarum_users.id
+from
+	flarum_users
+where
+	flarum_users.id {{.ne}} ""
+	and
+	flarum_users.del_flag {{.ne}} 1
+{{if ne .role_rule ""}}
+	and {{.role_rule}}
+{{end}}
+	LIMIT {{.size}} OFFSET {{.offset}}

+ 24 - 0
sql/sqlmap/flarum_access_tokens.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_access_tokens">
+        insert into flarum_access_tokens
+		(`token`,`user_id`,`last_activity_at`,`lifetime_seconds`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?token,?user_id,?last_activity_at,?lifetime_seconds,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_access_tokens">
+        update flarum_access_tokens set `token`=?token,`user_id`=?user_id,`last_activity_at`=?last_activity_at,`lifetime_seconds`=?lifetime_seconds,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_access_tokens">
+        delete from flarum_access_tokens
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_access_tokens">
+        select `token`,`user_id`,`last_activity_at`,`lifetime_seconds`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_access_tokens
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_access_tokens">
+        select `token`,`user_id`,`last_activity_at`,`lifetime_seconds`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_access_tokens
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_api_keys.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_api_keys">
+        insert into flarum_api_keys
+		(`key`,`id`,`allowed_ips`,`scopes`,`user_id`,`last_activity_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?key,?id,?allowed_ips,?scopes,?user_id,?last_activity_at,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_api_keys">
+        update flarum_api_keys set `key`=?key,`id`=?id,`allowed_ips`=?allowed_ips,`scopes`=?scopes,`user_id`=?user_id,`last_activity_at`=?last_activity_at,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_api_keys">
+        delete from flarum_api_keys
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_api_keys">
+        select `key`,`id`,`allowed_ips`,`scopes`,`user_id`,`last_activity_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_api_keys
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_api_keys">
+        select `key`,`id`,`allowed_ips`,`scopes`,`user_id`,`last_activity_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_api_keys
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_discussion_tag.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_discussion_tag">
+        insert into flarum_discussion_tag
+		(`discussion_id`,`tag_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?discussion_id,?tag_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_discussion_tag">
+        update flarum_discussion_tag set `discussion_id`=?discussion_id,`tag_id`=?tag_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_discussion_tag">
+        delete from flarum_discussion_tag
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_discussion_tag">
+        select `discussion_id`,`tag_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_discussion_tag
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_discussion_tag">
+        select `discussion_id`,`tag_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_discussion_tag
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_discussion_user.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_discussion_user">
+        insert into flarum_discussion_user
+		(`user_id`,`discussion_id`,`last_read_at`,`last_read_post_number`,`subscription`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?user_id,?discussion_id,?last_read_at,?last_read_post_number,?subscription,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_discussion_user">
+        update flarum_discussion_user set `user_id`=?user_id,`discussion_id`=?discussion_id,`last_read_at`=?last_read_at,`last_read_post_number`=?last_read_post_number,`subscription`=?subscription,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_discussion_user">
+        delete from flarum_discussion_user
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_discussion_user">
+        select `user_id`,`discussion_id`,`last_read_at`,`last_read_post_number`,`subscription`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_discussion_user
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_discussion_user">
+        select `user_id`,`discussion_id`,`last_read_at`,`last_read_post_number`,`subscription`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_discussion_user
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_discussions.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_discussions">
+        insert into flarum_discussions
+		(`id`,`title`,`comment_count`,`participant_count`,`post_number_index`,`user_id`,`first_post_id`,`last_posted_at`,`last_posted_user_id`,`last_post_id`,`last_post_number`,`hidden_at`,`hidden_user_id`,`slug`,`is_private`,`is_approved`,`is_locked`,`is_sticky`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?title,?comment_count,?participant_count,?post_number_index,?user_id,?first_post_id,?last_posted_at,?last_posted_user_id,?last_post_id,?last_post_number,?hidden_at,?hidden_user_id,?slug,?is_private,?is_approved,?is_locked,?is_sticky,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_discussions">
+        update flarum_discussions set `id`=?id,`title`=?title,`comment_count`=?comment_count,`participant_count`=?participant_count,`post_number_index`=?post_number_index,`user_id`=?user_id,`first_post_id`=?first_post_id,`last_posted_at`=?last_posted_at,`last_posted_user_id`=?last_posted_user_id,`last_post_id`=?last_post_id,`last_post_number`=?last_post_number,`hidden_at`=?hidden_at,`hidden_user_id`=?hidden_user_id,`slug`=?slug,`is_private`=?is_private,`is_approved`=?is_approved,`is_locked`=?is_locked,`is_sticky`=?is_sticky,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_discussions">
+        delete from flarum_discussions
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_discussions">
+        select `id`,`title`,`comment_count`,`participant_count`,`post_number_index`,`user_id`,`first_post_id`,`last_posted_at`,`last_posted_user_id`,`last_post_id`,`last_post_number`,`hidden_at`,`hidden_user_id`,`slug`,`is_private`,`is_approved`,`is_locked`,`is_sticky`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_discussions
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_discussions">
+        select `id`,`title`,`comment_count`,`participant_count`,`post_number_index`,`user_id`,`first_post_id`,`last_posted_at`,`last_posted_user_id`,`last_post_id`,`last_post_number`,`hidden_at`,`hidden_user_id`,`slug`,`is_private`,`is_approved`,`is_locked`,`is_sticky`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_discussions
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_email_tokens.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_email_tokens">
+        insert into flarum_email_tokens
+		(`token`,`email`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?token,?email,?user_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_email_tokens">
+        update flarum_email_tokens set `token`=?token,`email`=?email,`user_id`=?user_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_email_tokens">
+        delete from flarum_email_tokens
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_email_tokens">
+        select `token`,`email`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_email_tokens
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_email_tokens">
+        select `token`,`email`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_email_tokens
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_flags.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_flags">
+        insert into flarum_flags
+		(`id`,`post_id`,`type`,`user_id`,`reason`,`reason_detail`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?post_id,?type,?user_id,?reason,?reason_detail,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_flags">
+        update flarum_flags set `id`=?id,`post_id`=?post_id,`type`=?type,`user_id`=?user_id,`reason`=?reason,`reason_detail`=?reason_detail,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_flags">
+        delete from flarum_flags
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_flags">
+        select `id`,`post_id`,`type`,`user_id`,`reason`,`reason_detail`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_flags
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_flags">
+        select `id`,`post_id`,`type`,`user_id`,`reason`,`reason_detail`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_flags
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_group_permission.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_group_permission">
+        insert into flarum_group_permission
+		(`group_id`,`permission`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?group_id,?permission,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_group_permission">
+        update flarum_group_permission set `group_id`=?group_id,`permission`=?permission,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_group_permission">
+        delete from flarum_group_permission
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_group_permission">
+        select `group_id`,`permission`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_group_permission
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_group_permission">
+        select `group_id`,`permission`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_group_permission
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_group_user.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_group_user">
+        insert into flarum_group_user
+		(`user_id`,`group_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?user_id,?group_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_group_user">
+        update flarum_group_user set `user_id`=?user_id,`group_id`=?group_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_group_user">
+        delete from flarum_group_user
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_group_user">
+        select `user_id`,`group_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_group_user
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_group_user">
+        select `user_id`,`group_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_group_user
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_groups.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_groups">
+        insert into flarum_groups
+		(`id`,`name_singular`,`name_plural`,`color`,`icon`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?name_singular,?name_plural,?color,?icon,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_groups">
+        update flarum_groups set `id`=?id,`name_singular`=?name_singular,`name_plural`=?name_plural,`color`=?color,`icon`=?icon,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_groups">
+        delete from flarum_groups
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_groups">
+        select `id`,`name_singular`,`name_plural`,`color`,`icon`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_groups
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_groups">
+        select `id`,`name_singular`,`name_plural`,`color`,`icon`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_groups
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_login_providers.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_login_providers">
+        insert into flarum_login_providers
+		(`id`,`user_id`,`provider`,`identifier`,`last_login_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?user_id,?provider,?identifier,?last_login_at,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_login_providers">
+        update flarum_login_providers set `id`=?id,`user_id`=?user_id,`provider`=?provider,`identifier`=?identifier,`last_login_at`=?last_login_at,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_login_providers">
+        delete from flarum_login_providers
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_login_providers">
+        select `id`,`user_id`,`provider`,`identifier`,`last_login_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_login_providers
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_login_providers">
+        select `id`,`user_id`,`provider`,`identifier`,`last_login_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_login_providers
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_migrations.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_migrations">
+        insert into flarum_migrations
+		(`migration`,`extension`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?migration,?extension,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_migrations">
+        update flarum_migrations set `migration`=?migration,`extension`=?extension,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_migrations">
+        delete from flarum_migrations
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_migrations">
+        select `migration`,`extension`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_migrations
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_migrations">
+        select `migration`,`extension`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_migrations
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_notifications.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_notifications">
+        insert into flarum_notifications
+		(`id`,`user_id`,`from_user_id`,`type`,`subject_id`,`data`,`read_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?user_id,?from_user_id,?type,?subject_id,?data,?read_at,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_notifications">
+        update flarum_notifications set `id`=?id,`user_id`=?user_id,`from_user_id`=?from_user_id,`type`=?type,`subject_id`=?subject_id,`data`=?data,`read_at`=?read_at,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_notifications">
+        delete from flarum_notifications
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_notifications">
+        select `id`,`user_id`,`from_user_id`,`type`,`subject_id`,`data`,`read_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_notifications
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_notifications">
+        select `id`,`user_id`,`from_user_id`,`type`,`subject_id`,`data`,`read_at`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_notifications
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_password_tokens.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_password_tokens">
+        insert into flarum_password_tokens
+		(`token`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?token,?user_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_password_tokens">
+        update flarum_password_tokens set `token`=?token,`user_id`=?user_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_password_tokens">
+        delete from flarum_password_tokens
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_password_tokens">
+        select `token`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_password_tokens
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_password_tokens">
+        select `token`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_password_tokens
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_post_likes.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_post_likes">
+        insert into flarum_post_likes
+		(`post_id`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?post_id,?user_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_post_likes">
+        update flarum_post_likes set `post_id`=?post_id,`user_id`=?user_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_post_likes">
+        delete from flarum_post_likes
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_post_likes">
+        select `post_id`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_likes
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_post_likes">
+        select `post_id`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_likes
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_post_mentions_post.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_post_mentions_post">
+        insert into flarum_post_mentions_post
+		(`post_id`,`mentions_post_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?post_id,?mentions_post_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_post_mentions_post">
+        update flarum_post_mentions_post set `post_id`=?post_id,`mentions_post_id`=?mentions_post_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_post_mentions_post">
+        delete from flarum_post_mentions_post
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_post_mentions_post">
+        select `post_id`,`mentions_post_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_mentions_post
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_post_mentions_post">
+        select `post_id`,`mentions_post_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_mentions_post
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_post_mentions_user.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_post_mentions_user">
+        insert into flarum_post_mentions_user
+		(`post_id`,`mentions_user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?post_id,?mentions_user_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_post_mentions_user">
+        update flarum_post_mentions_user set `post_id`=?post_id,`mentions_user_id`=?mentions_user_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_post_mentions_user">
+        delete from flarum_post_mentions_user
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_post_mentions_user">
+        select `post_id`,`mentions_user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_mentions_user
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_post_mentions_user">
+        select `post_id`,`mentions_user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_mentions_user
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_post_user.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_post_user">
+        insert into flarum_post_user
+		(`post_id`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?post_id,?user_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_post_user">
+        update flarum_post_user set `post_id`=?post_id,`user_id`=?user_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_post_user">
+        delete from flarum_post_user
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_post_user">
+        select `post_id`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_user
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_post_user">
+        select `post_id`,`user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_post_user
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_posts.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_posts">
+        insert into flarum_posts
+		(`id`,`discussion_id`,`number`,`user_id`,`type`,`content`,`edited_at`,`edited_user_id`,`hidden_at`,`hidden_user_id`,`ip_address`,`is_private`,`is_approved`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?discussion_id,?number,?user_id,?type,?content,?edited_at,?edited_user_id,?hidden_at,?hidden_user_id,?ip_address,?is_private,?is_approved,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_posts">
+        update flarum_posts set `id`=?id,`discussion_id`=?discussion_id,`number`=?number,`user_id`=?user_id,`type`=?type,`content`=?content,`edited_at`=?edited_at,`edited_user_id`=?edited_user_id,`hidden_at`=?hidden_at,`hidden_user_id`=?hidden_user_id,`ip_address`=?ip_address,`is_private`=?is_private,`is_approved`=?is_approved,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_posts">
+        delete from flarum_posts
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_posts">
+        select `id`,`discussion_id`,`number`,`user_id`,`type`,`content`,`edited_at`,`edited_user_id`,`hidden_at`,`hidden_user_id`,`ip_address`,`is_private`,`is_approved`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_posts
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_posts">
+        select `id`,`discussion_id`,`number`,`user_id`,`type`,`content`,`edited_at`,`edited_user_id`,`hidden_at`,`hidden_user_id`,`ip_address`,`is_private`,`is_approved`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_posts
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_registration_tokens.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_registration_tokens">
+        insert into flarum_registration_tokens
+		(`token`,`payload`,`provider`,`identifier`,`user_attributes`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?token,?payload,?provider,?identifier,?user_attributes,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_registration_tokens">
+        update flarum_registration_tokens set `token`=?token,`payload`=?payload,`provider`=?provider,`identifier`=?identifier,`user_attributes`=?user_attributes,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_registration_tokens">
+        delete from flarum_registration_tokens
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_registration_tokens">
+        select `token`,`payload`,`provider`,`identifier`,`user_attributes`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_registration_tokens
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_registration_tokens">
+        select `token`,`payload`,`provider`,`identifier`,`user_attributes`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_registration_tokens
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_settings.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_settings">
+        insert into flarum_settings
+		(`key`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?key,?value,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_settings">
+        update flarum_settings set `key`=?key,`value`=?value,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_settings">
+        delete from flarum_settings
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_settings">
+        select `key`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_settings
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_settings">
+        select `key`,`value`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_settings
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_tag_user.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_tag_user">
+        insert into flarum_tag_user
+		(`user_id`,`tag_id`,`marked_as_read_at`,`is_hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?user_id,?tag_id,?marked_as_read_at,?is_hidden,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_tag_user">
+        update flarum_tag_user set `user_id`=?user_id,`tag_id`=?tag_id,`marked_as_read_at`=?marked_as_read_at,`is_hidden`=?is_hidden,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_tag_user">
+        delete from flarum_tag_user
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_tag_user">
+        select `user_id`,`tag_id`,`marked_as_read_at`,`is_hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_tag_user
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_tag_user">
+        select `user_id`,`tag_id`,`marked_as_read_at`,`is_hidden`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_tag_user
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_tags.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_tags">
+        insert into flarum_tags
+		(`id`,`name`,`slug`,`description`,`color`,`background_path`,`background_mode`,`position`,`parent_id`,`default_sort`,`is_restricted`,`is_hidden`,`discussion_count`,`last_posted_at`,`last_posted_discussion_id`,`last_posted_user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?name,?slug,?description,?color,?background_path,?background_mode,?position,?parent_id,?default_sort,?is_restricted,?is_hidden,?discussion_count,?last_posted_at,?last_posted_discussion_id,?last_posted_user_id,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_tags">
+        update flarum_tags set `id`=?id,`name`=?name,`slug`=?slug,`description`=?description,`color`=?color,`background_path`=?background_path,`background_mode`=?background_mode,`position`=?position,`parent_id`=?parent_id,`default_sort`=?default_sort,`is_restricted`=?is_restricted,`is_hidden`=?is_hidden,`discussion_count`=?discussion_count,`last_posted_at`=?last_posted_at,`last_posted_discussion_id`=?last_posted_discussion_id,`last_posted_user_id`=?last_posted_user_id,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_tags">
+        delete from flarum_tags
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_tags">
+        select `id`,`name`,`slug`,`description`,`color`,`background_path`,`background_mode`,`position`,`parent_id`,`default_sort`,`is_restricted`,`is_hidden`,`discussion_count`,`last_posted_at`,`last_posted_discussion_id`,`last_posted_user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_tags
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_tags">
+        select `id`,`name`,`slug`,`description`,`color`,`background_path`,`background_mode`,`position`,`parent_id`,`default_sort`,`is_restricted`,`is_hidden`,`discussion_count`,`last_posted_at`,`last_posted_discussion_id`,`last_posted_user_id`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_tags
+    </sql>
+</sqlMap>

+ 24 - 0
sql/sqlmap/flarum_users.xml

@@ -0,0 +1,24 @@
+<!-- Code generated by dol build. Only Generate by tools if not existed. -->
+<sqlMap>
+    <sql id="insert_flarum_users">
+        insert into flarum_users
+		(`id`,`username`,`email`,`is_email_confirmed`,`password`,`bio`,`avatar_url`,`preferences`,`joined_at`,`last_seen_at`,`marked_all_as_read_at`,`read_notifications_at`,`discussion_count`,`comment_count`,`read_flags_at`,`suspended_until`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark`)
+		values
+		(?id,?username,?email,?is_email_confirmed,?password,?bio,?avatar_url,?preferences,?joined_at,?last_seen_at,?marked_all_as_read_at,?read_notifications_at,?discussion_count,?comment_count,?read_flags_at,?suspended_until,?create_by,?create_time,?update_by,?update_time,?del_flag,?remark)
+    </sql>
+    <sql id="update_flarum_users">
+        update flarum_users set `id`=?id,`username`=?username,`email`=?email,`is_email_confirmed`=?is_email_confirmed,`password`=?password,`bio`=?bio,`avatar_url`=?avatar_url,`preferences`=?preferences,`joined_at`=?joined_at,`last_seen_at`=?last_seen_at,`marked_all_as_read_at`=?marked_all_as_read_at,`read_notifications_at`=?read_notifications_at,`discussion_count`=?discussion_count,`comment_count`=?comment_count,`read_flags_at`=?read_flags_at,`suspended_until`=?suspended_until,`create_by`=?create_by,`create_time`=?create_time,`update_by`=?update_by,`update_time`=?update_time,`del_flag`=?del_flag,`remark`=?remark
+		where  id =?id
+    </sql>
+    <sql id="delete_flarum_users">
+        delete from flarum_users
+		where id =?id
+    </sql>
+    <sql id="selectone_flarum_users">
+        select `id`,`username`,`email`,`is_email_confirmed`,`password`,`bio`,`avatar_url`,`preferences`,`joined_at`,`last_seen_at`,`marked_all_as_read_at`,`read_notifications_at`,`discussion_count`,`comment_count`,`read_flags_at`,`suspended_until`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_users
+		where  id =?id
+    </sql>
+    <sql id="selectall_flarum_users">
+        select `id`,`username`,`email`,`is_email_confirmed`,`password`,`bio`,`avatar_url`,`preferences`,`joined_at`,`last_seen_at`,`marked_all_as_read_at`,`read_notifications_at`,`discussion_count`,`comment_count`,`read_flags_at`,`suspended_until`,`create_by`,`create_time`,`update_by`,`update_time`,`del_flag`,`remark` from flarum_users
+    </sql>
+</sqlMap>

+ 16 - 0
srv/flarum_posts.go

@@ -0,0 +1,16 @@
+// Code generated by dol build. Only Generate by tools if not existed.
+// source: flarum_posts.go
+
+package srv
+
+import (
+	"errors"
+
+	"github.com/2637309949/dolphin/packages/gin"
+	"github.com/2637309949/dolphin/packages/xormplus/xorm"
+)
+
+// FlarumPostsAction defined srv
+func FlarumPostsAction(ctx *gin.Context, db *xorm.Engine, params struct{}) (interface{}, error) {
+	return nil, errors.New("No implementation found")
+}

+ 16 - 0
srv/flarum_users.go

@@ -0,0 +1,16 @@
+// Code generated by dol build. Only Generate by tools if not existed.
+// source: flarum_users.go
+
+package srv
+
+import (
+	"errors"
+
+	"github.com/2637309949/dolphin/packages/gin"
+	"github.com/2637309949/dolphin/packages/xormplus/xorm"
+)
+
+// FlarumUsersAction defined srv
+func FlarumUsersAction(ctx *gin.Context, db *xorm.Engine, params struct{}) (interface{}, error) {
+	return nil, errors.New("No implementation found")
+}

+ 177 - 0
static/web/affirm.html

@@ -0,0 +1,177 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+  <title>Auth</title>
+  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+  <meta http-equiv="Content-Language" content="zh-CN" />
+  <meta name="Author" content="网页作者" />
+  <meta name="Copyright" content="网站版权" />
+  <meta name="keywords" content="网站关键字" />
+  <meta name="description" content="网站描述" />
+  <style>
+    html,
+    body {
+      height: 100%;
+    }
+
+    html {
+      overflow-y: scroll;
+    }
+
+    body {
+      margin: 0;
+      font: 12px"\5B8B\4F53", sans-serif;
+      background: #f0f2f5;
+    }
+
+    div,
+    dl,
+    dt,
+    dd,
+    ul,
+    ol,
+    li,
+    h1,
+    h2,
+    h3,
+    h4,
+    h5,
+    h6,
+    pre,
+    form,
+    fieldset,
+    input,
+    textarea,
+    blockquote,
+    p {
+      padding: 0;
+      margin: 0;
+    }
+
+    table,
+    td,
+    tr,
+    th {
+      font-size: 12px;
+    }
+
+    li {
+      list-style-type: none;
+    }
+
+    img {
+      vertical-align: top;
+      border: 0;
+    }
+
+    ol,
+    ul {
+      list-style: none;
+    }
+
+    h1,
+    h2,
+    h3,
+    h4,
+    h5,
+    h6 {
+      font-size: 12px;
+      font-weight: normal;
+    }
+
+    address,
+    cite,
+    code,
+    em,
+    th {
+      font-weight: normal;
+      font-style: normal;
+    }
+
+    * {
+      margin: 0px;
+      padding: 0px;
+      box-sizing: border-box;
+    }
+    .container {
+            display: -webkit-flex;
+            display: flex;
+            flex-direction: column;
+            justify-content: center;
+            align-items: center;
+            height: 100%;
+    }
+    .auth-box{
+            width: 500px;
+            background: #fff;
+            border-radius: 10px;
+            overflow: hidden;
+            box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -moz-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -webkit-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -o-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -ms-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            padding-right: 55px;
+            padding-left: 55px;
+            padding-bottom: 50px;
+            padding-top: 65px;
+        }
+        .auth-box-title, .auth-box-subtitle {
+            display: block;
+            font-family: OpenSans-Regular;
+            color: #555555;
+            line-height: 1.2;
+            text-align: center;
+            padding-bottom: 28px;
+        }
+        .auth-box-title {
+          font-size: 30px;
+        }
+        .auth-box-subtitle {
+          font-size: 25px;
+        }
+        .btn-primary{
+          display: -webkit-box;
+            display: -webkit-flex;
+            display: -moz-box;
+            display: -ms-flexbox;
+            display: flex;
+            justify-content: center;
+            align-items: center;
+            padding: 0 20px;
+            width: 100%;
+            height: 60px;
+            background-color: #4272d7;
+            font-family: OpenSans-Regular;
+            font-size: 14px;
+            color: #fff;
+            line-height: 1.2;
+            text-transform: uppercase;
+            -webkit-transition: all 0.4s;
+            -o-transition: all 0.4s;
+            -moz-transition: all 0.4s;
+            transition: all 0.4s;
+            outline: none !important;
+            border: none;
+        }
+  </style>
+</head>
+
+<body>
+  <div class="container">
+    <div class="auth-box">
+      <form action="/api/sys/cas/affirm" method="POST">
+        <span class="auth-box-title">Authorize</span>
+        <span class="auth-box-subtitle">The client would like to perform actions on your behalf.</span>
+        <p>
+          <button type="submit" class="btn btn-primary btn-lg">
+            Allow
+          </button>
+        </p>
+      </form>
+    </div>
+  </div>
+</body>
+
+</html>

+ 209 - 0
static/web/login.html

@@ -0,0 +1,209 @@
+<!DOCTYPE html>
+<html lang="en">
+
+<head>
+    <title>Login</title>
+    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+    <meta http-equiv="Content-Language" content="zh-CN" />
+    <meta name="Author" content="网页作者" />
+    <meta name="Copyright" content="网站版权" />
+    <meta name="keywords" content="网站关键字" />
+    <meta name="description" content="网站描述" />
+    <style>
+        html,
+        body {
+            height: 100%;
+        }
+
+        html {
+            overflow-y: scroll;
+        }
+
+        body {
+            margin: 0;
+            font: 12px"\5B8B\4F53", sans-serif;
+            background: #f0f2f5;
+        }
+
+        div,
+        dl,
+        dt,
+        dd,
+        ul,
+        ol,
+        li,
+        h1,
+        h2,
+        h3,
+        h4,
+        h5,
+        h6,
+        pre,
+        form,
+        fieldset,
+        input,
+        textarea,
+        blockquote,
+        p {
+            padding: 0;
+            margin: 0;
+        }
+
+        table,
+        td,
+        tr,
+        th {
+            font-size: 12px;
+        }
+
+        li {
+            list-style-type: none;
+        }
+
+        img {
+            vertical-align: top;
+            border: 0;
+        }
+
+        ol,
+        ul {
+            list-style: none;
+        }
+
+        h1,
+        h2,
+        h3,
+        h4,
+        h5,
+        h6 {
+            font-size: 12px;
+            font-weight: normal;
+        }
+
+        address,
+        cite,
+        code,
+        em,
+        th {
+            font-weight: normal;
+            font-style: normal;
+        }
+
+        * {
+            margin: 0px;
+            padding: 0px;
+            box-sizing: border-box;
+        }
+
+        .container {
+            display: -webkit-flex;
+            display: flex;
+            flex-direction: column;
+            justify-content: center;
+            align-items: center;
+            height: 100%;
+        }
+
+        .login-box {
+            width: 500px;
+            background: #fff;
+            border-radius: 10px;
+            overflow: hidden;
+            box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -moz-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -webkit-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -o-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            -ms-box-shadow: 0 3px 20px 0px rgba(0, 0, 0, 0.1);
+            padding-right: 55px;
+            padding-left: 55px;
+            padding-bottom: 50px;
+            padding-top: 65px;
+        }
+
+        .form-group {
+            position: relative;
+            width: 100%;
+            position: relative;
+            background-color: #fff;
+            border: 1px solid #e6e6e6;
+        }
+
+        .form-control {
+            display: block;
+            width: 100%;
+            background: transparent;
+            font-family: OpenSans-Regular;
+            font-size: 15px;
+            color: #666666;
+            line-height: 1.2;
+            height: 50px;
+            padding: 0 20px 0 20px;
+            outline: none;
+            border: none;
+        }
+
+        .btn-success {
+            display: -webkit-box;
+            display: -webkit-flex;
+            display: -moz-box;
+            display: -ms-flexbox;
+            display: flex;
+            justify-content: center;
+            align-items: center;
+            padding: 0 20px;
+            width: 100%;
+            height: 60px;
+            background-color: #4272d7;
+            font-family: OpenSans-Regular;
+            font-size: 14px;
+            color: #fff;
+            line-height: 1.2;
+            text-transform: uppercase;
+            -webkit-transition: all 0.4s;
+            -o-transition: all 0.4s;
+            -moz-transition: all 0.4s;
+            transition: all 0.4s;
+            outline: none !important;
+            border: none;
+        }
+
+        .form-group-submit {
+            margin-top: 20px;
+        }
+
+        .login-box-title {
+            display: block;
+            font-family: OpenSans-Regular;
+            font-size: 30px;
+            color: #555555;
+            line-height: 1.2;
+            text-align: center;
+            padding-bottom: 28px;
+        }
+    </style>
+</head>
+
+<body>
+    <div class="container">
+        <div class="login-box">
+            <span class="login-box-title">Account Login</span>
+            <form action="/api/sys/cas/login" method="POST">
+                <div class="form-group">
+                    <input type="text" class="form-control" name="domain" placeholder="Please enter your domain">
+                </div>
+                <div class="form-group">
+                    <input type="text" class="form-control" name="username" placeholder="Please enter your user name">
+                </div>
+                <div class="form-group">
+                    <input type="password" class="form-control" name="password"
+                        placeholder="Please enter your password">
+                </div>
+                <div class="form-group form-group-submit">
+                    <button type="submit" class="btn btn-success">Sign in</button>
+                </div>
+            </form>
+        </div>
+    </div>
+</body>
+
+</html>

+ 31 - 0
util/tool.go

@@ -0,0 +1,31 @@
+// Code generated by dol build. Only Generate by tools if not existed.
+// source: app.go
+
+package util
+
+import "math/rand"
+
+// M defined
+type M map[string]interface{}
+
+var defaultLetters = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789")
+
+// RandString returns a random string with a fixed length
+func RandString(n int, allowedChars ...[]rune) string {
+	var letters []rune
+	if len(allowedChars) == 0 {
+		letters = defaultLetters
+	} else {
+		letters = allowedChars[0]
+	}
+	b := make([]rune, n)
+	for i := range b {
+		b[i] = letters[rand.Intn(len(letters))]
+	}
+	return string(b)
+}
+
+// RandInt generates a random int, based on a min and max values
+func RandInt(min, max int) int {
+	return min + rand.Intn(max-min)
+}

+ 2 - 0
xml/application.xml

@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="utf-8" ?>
+<application name="flarum" desc="dolphin boilerplate" packagename="flarum"/>

+ 4 - 0
xml/bean/flarum_posts_info.xml

@@ -0,0 +1,4 @@
+<bean name="flarum_posts_info" desc="FlarumPosts info" packages="github.com/2637309949/dolphin/packages/null" extends="$flarum_posts">
+    <prop name="content" desc="Content" type="null.String" />
+    <prop name="title" desc="Title" type="null.String" />
+</bean>

+ 38 - 0
xml/controller/flarum_posts.xml

@@ -0,0 +1,38 @@
+<controller name="flarum_posts" desc="FlarumPosts controller">
+    <api name="add" func="add" table="flarum_posts" desc="Add flarum_posts" method="post">
+        <param name="user" type="$flarum_posts" desc="FlarumPost info" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="del" func="delete" table="flarum_posts" desc="Delete flarum_posts" method="delete">
+        <param name="flarum_posts" type="$flarum_posts" desc="flarum_posts" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="update" func="update" table="flarum_posts" desc="Update flarum_posts" method="put">
+        <param name="user" type="$flarum_posts" desc="FlarumPost info" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="page" func="page" table="flarum_posts" desc="FlarumPost page query" method="get">
+        <param name="page" type="int" desc="Page number" value="1"/>
+        <param name="size" type="int" desc="Page size" value="15" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="get" desc="Get flarum_posts info" func="one" table="flarum_posts" method="get">
+        <param name="id" type="string" desc="FlarumPost id" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+</controller>

+ 38 - 0
xml/controller/flarum_users.xml

@@ -0,0 +1,38 @@
+<controller name="flarum_users" desc="FlarumUser controller">
+    <api name="add" func="add" table="flarum_users" desc="Add flarum_users" method="post">
+        <param name="user" type="$flarum_users" desc="FlarumUser info" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="del" func="delete" table="flarum_users" desc="Delete flarum_users" method="delete">
+        <param name="flarum_users" type="$flarum_users" desc="flarum_users" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="update" func="update" table="flarum_users" desc="Update flarum_users" method="put">
+        <param name="user" type="$flarum_users" desc="FlarumUser info" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="page" func="page" table="flarum_users" desc="FlarumUser page query" method="get">
+        <param name="page" type="int" desc="Page number" value="1"/>
+        <param name="size" type="int" desc="Page size" value="15" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+    <api name="get" desc="Get flarum_users info" func="one" table="flarum_users" method="get">
+        <param name="id" type="string" desc="FlarumUser id" />
+        <return>
+            <success type="$success"/>
+            <failure type="$fail"/>
+        </return>
+    </api>
+</controller>

+ 13 - 0
xml/table/flarum_access_tokens.xml

@@ -0,0 +1,13 @@
+<table name="flarum_access_tokens" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="token" desc="" type="null.String" xorm="varchar(40) pk notnull" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) notnull" />
+	<column name="last_activity_at" desc="" type="null.Time" xorm="datetime notnull" />
+	<column name="lifetime_seconds" desc="" type="null.Int" xorm="int(11) notnull" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 15 - 0
xml/table/flarum_api_keys.xml

@@ -0,0 +1,15 @@
+<table name="flarum_api_keys" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="key" desc="" type="null.String" xorm="varchar(100) notnull" />
+	<column name="id" desc="" type="null.Int" xorm="int(10) pk notnull autoincr" />
+	<column name="allowed_ips" desc="" type="null.String" xorm="varchar(255)" />
+	<column name="scopes" desc="" type="null.String" xorm="varchar(255)" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="last_activity_at" desc="" type="null.Time" xorm="datetime" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 11 - 0
xml/table/flarum_discussion_tag.xml

@@ -0,0 +1,11 @@
+<table name="flarum_discussion_tag" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="discussion_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+	<column name="tag_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 14 - 0
xml/table/flarum_discussion_user.xml

@@ -0,0 +1,14 @@
+<table name="flarum_discussion_user" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+	<column name="discussion_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+	<column name="last_read_at" desc="" type="null.Time" xorm="datetime" />
+	<column name="last_read_post_number" desc="" type="null.Int" xorm="int(10)" />
+	<column name="subscription" desc="" type="null.Int" xorm="int(10)" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 27 - 0
xml/table/flarum_discussions.xml

@@ -0,0 +1,27 @@
+<table name="flarum_discussions" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="id" desc="" type="null.Int" xorm="int(10) pk notnull autoincr" />
+	<column name="title" desc="" type="null.String" xorm="varchar(200) notnull" />
+	<column name="comment_count" desc="" type="null.Int" xorm="int(10) notnull default(0)" />
+	<column name="participant_count" desc="" type="null.Int" xorm="int(10) notnull default(0)" />
+	<column name="post_number_index" desc="" type="null.Int" xorm="int(10) notnull default(0)" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="first_post_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="last_posted_at" desc="" type="null.Time" xorm="datetime" />
+	<column name="last_posted_user_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="last_post_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="last_post_number" desc="" type="null.Int" xorm="int(10)" />
+	<column name="hidden_at" desc="" type="null.Time" xorm="datetime" />
+	<column name="hidden_user_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="slug" desc="" type="null.String" xorm="varchar(255) notnull" />
+	<column name="is_private" desc="" type="null.Int" xorm="int(10) notnull default(0)" />
+	<column name="is_approved" desc="" type="null.Int" xorm="int(10) notnull default(1)" />
+	<column name="is_locked" desc="" type="null.Int" xorm="int(10) notnull default(0)" />
+	<column name="is_sticky" desc="" type="null.Int" xorm="int(10) notnull default(0)" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 12 - 0
xml/table/flarum_email_tokens.xml

@@ -0,0 +1,12 @@
+<table name="flarum_email_tokens" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="token" desc="" type="null.String" xorm="varchar(100) pk notnull" />
+	<column name="email" desc="" type="null.String" xorm="varchar(150) notnull" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) notnull" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 15 - 0
xml/table/flarum_flags.xml

@@ -0,0 +1,15 @@
+<table name="flarum_flags" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="id" desc="" type="null.Int" xorm="int(10) pk notnull autoincr" />
+	<column name="post_id" desc="" type="null.Int" xorm="int(10) notnull" />
+	<column name="type" desc="" type="null.String" xorm="varchar(255) notnull" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="reason" desc="" type="null.String" xorm="varchar(255)" />
+	<column name="reason_detail" desc="" type="null.String" xorm="varchar(255)" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 11 - 0
xml/table/flarum_group_permission.xml

@@ -0,0 +1,11 @@
+<table name="flarum_group_permission" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="group_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+	<column name="permission" desc="" type="null.String" xorm="varchar(100) pk notnull" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 11 - 0
xml/table/flarum_group_user.xml

@@ -0,0 +1,11 @@
+<table name="flarum_group_user" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+	<column name="group_id" desc="" type="null.Int" xorm="int(10) pk notnull" />
+	
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 14 - 0
xml/table/flarum_groups.xml

@@ -0,0 +1,14 @@
+<table name="flarum_groups" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="id" desc="" type="null.Int" xorm="int(10) pk notnull autoincr" />
+	<column name="name_singular" desc="" type="null.String" xorm="varchar(100) notnull" />
+	<column name="name_plural" desc="" type="null.String" xorm="varchar(100) notnull" />
+	<column name="color" desc="" type="null.String" xorm="varchar(20)" />
+	<column name="icon" desc="" type="null.String" xorm="varchar(100)" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 14 - 0
xml/table/flarum_login_providers.xml

@@ -0,0 +1,14 @@
+<table name="flarum_login_providers" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="id" desc="" type="null.Int" xorm="int(10) pk notnull autoincr" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) notnull" />
+	<column name="provider" desc="" type="null.String" xorm="varchar(100) notnull" />
+	<column name="identifier" desc="" type="null.String" xorm="varchar(100) notnull" />
+	<column name="last_login_at" desc="" type="null.Time" xorm="datetime" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 11 - 0
xml/table/flarum_migrations.xml

@@ -0,0 +1,11 @@
+<table name="flarum_migrations" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="migration" desc="" type="null.String" xorm="varchar(255) notnull" />
+	<column name="extension" desc="" type="null.String" xorm="varchar(255)" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 16 - 0
xml/table/flarum_notifications.xml

@@ -0,0 +1,16 @@
+<table name="flarum_notifications" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="id" desc="" type="null.Int" xorm="int(10) pk notnull autoincr" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) notnull" />
+	<column name="from_user_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="type" desc="" type="null.String" xorm="varchar(100) notnull" />
+	<column name="subject_id" desc="" type="null.Int" xorm="int(10)" />
+	<column name="data" type="[]byte" xorm="blob" />
+	<column name="read_at" desc="" type="null.Time" xorm="datetime" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

+ 11 - 0
xml/table/flarum_password_tokens.xml

@@ -0,0 +1,11 @@
+<table name="flarum_password_tokens" desc="" packages="github.com/2637309949/dolphin/packages/null,github.com/2637309949/dolphin/packages/decimal">
+	<column name="token" desc="" type="null.String" xorm="varchar(100) pk notnull" />
+	<column name="user_id" desc="" type="null.Int" xorm="int(10) notnull" />
+
+	<column name="create_by" desc="Creator" type="null.String" xorm="varchar(36)" />
+    <column name="create_time" desc="Creation time" type="null.Time" xorm="datetime" />
+    <column name="update_by" desc="Last updated by" type="null.String" xorm="varchar(36)" />
+    <column name="update_time" desc="Last update time" type="null.Time" xorm="datetime" />
+    <column name="del_flag" desc="Delete tag" type="null.Int" xorm="notnull" />
+    <column name="remark" desc="Remark" type="null.String" xorm="varchar(200)" />
+</table>

Някои файлове не бяха показани, защото твърде много файлове са промени