feat:完善项目信息
This commit is contained in:
154
app/common/migrate/instance.go
Normal file
154
app/common/migrate/instance.go
Normal file
@ -0,0 +1,154 @@
|
||||
package migrate
|
||||
|
||||
import (
|
||||
config2 "SciencesServer/app/basic/config"
|
||||
"SciencesServer/app/common/model"
|
||||
"SciencesServer/utils"
|
||||
"gorm.io/gorm"
|
||||
)
|
||||
|
||||
type Instance struct {
|
||||
gormDB *gorm.DB
|
||||
}
|
||||
|
||||
type Option func(instance *Instance)
|
||||
|
||||
type synchronized struct {
|
||||
iModel model.IModel
|
||||
iValues func() interface{}
|
||||
Catch func() interface{}
|
||||
}
|
||||
|
||||
func (this *Instance) Handle() {
|
||||
db := this.gormDB
|
||||
|
||||
function := func(synchronized ...*synchronized) {
|
||||
for _, v := range synchronized {
|
||||
if !db.Migrator().HasTable(v.iModel) {
|
||||
err := db.Migrator().CreateTable(v.iModel)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
if v.iValues != nil && v.iValues() != nil {
|
||||
db.Table(v.iModel.TableName()).Create(v.iValues())
|
||||
}
|
||||
} else if v.Catch != nil && v.Catch() != nil {
|
||||
v.Catch()
|
||||
}
|
||||
}
|
||||
}
|
||||
function(
|
||||
&synchronized{iModel: model.NewSysTenant()}, &synchronized{iModel: model.NewSysTenantMenu()},
|
||||
&synchronized{iModel: model.NewSysConfig()},
|
||||
&synchronized{iModel: model.NewSysMenu()}, &synchronized{iModel: model.NewSysAuth()},
|
||||
&synchronized{iModel: model.NewSysUser(), iValues: func() interface{} {
|
||||
return &model.SysUser{Account: "admin", Name: "商挈智能", Mobile: "13888888888", Password: utils.Md5String("123456"),
|
||||
IsAdmin: model.SysUserAdministratorForAdmin, Remark: "超级管理员"}
|
||||
}},
|
||||
&synchronized{iModel: model.NewSysUserRole()}, &synchronized{iModel: model.NewSysUserTenant()},
|
||||
&synchronized{iModel: model.NewSysDepartment()},
|
||||
&synchronized{iModel: model.NewSysRole()}, &synchronized{iModel: model.NewSysRoleMenu()}, &synchronized{iModel: model.NewSysRoleAuth()},
|
||||
// 配置管理
|
||||
&synchronized{iModel: model.NewSysConfig(), iValues: func() interface{} {
|
||||
return nil
|
||||
}},
|
||||
&synchronized{iModel: model.NewSysPatent(), iValues: func() interface{} {
|
||||
return nil
|
||||
}},
|
||||
&synchronized{iModel: model.NewSysPatentClassify()},
|
||||
&synchronized{iModel: model.NewSysIdentity(), iValues: func() interface{} {
|
||||
out := make([]*model.SysIdentity, 0)
|
||||
|
||||
for k, v := range config2.TenantUserIdentityData {
|
||||
registerCount := 1
|
||||
|
||||
if k == config2.TenantUserIdentityForCompany {
|
||||
registerCount = -1
|
||||
}
|
||||
out = append(out, &model.SysIdentity{
|
||||
Identity: k,
|
||||
Name: v,
|
||||
RegisterCount: registerCount,
|
||||
IsExamine: 1,
|
||||
})
|
||||
}
|
||||
return out
|
||||
}},
|
||||
&synchronized{iModel: model.NewSysIndustry(), iValues: func() interface{} {
|
||||
file := "./file/sys_industry.json"
|
||||
src := make([]*config2.MemoryForIndustry, 0)
|
||||
utils.LoadConfig(file, &src)
|
||||
out := make([]*model.SysIndustry, 0)
|
||||
|
||||
var id uint64 = 1
|
||||
|
||||
for _, v := range src {
|
||||
var parentID uint64 = 0
|
||||
|
||||
data := &model.SysIndustry{
|
||||
Model: model.Model{
|
||||
ID: id,
|
||||
},
|
||||
ParentID: parentID,
|
||||
Name: v.Name,
|
||||
}
|
||||
out = append(out, data)
|
||||
|
||||
if v.Children != nil && len(v.Children) > 0 {
|
||||
parentID = id
|
||||
for _, val := range v.Children {
|
||||
id++
|
||||
data = &model.SysIndustry{
|
||||
Model: model.Model{
|
||||
ID: id,
|
||||
},
|
||||
ParentID: parentID,
|
||||
Name: val.Name,
|
||||
}
|
||||
out = append(out, data)
|
||||
}
|
||||
}
|
||||
}
|
||||
return out
|
||||
}},
|
||||
&synchronized{iModel: model.NewSysPlatform()}, &synchronized{iModel: model.NewSysNavigation()},
|
||||
&synchronized{iModel: model.NewSysAbout()},
|
||||
// 日志管理
|
||||
&synchronized{iModel: model.NewSysLog()}, &synchronized{iModel: model.NewSysUserLoginLog()},
|
||||
// 用户管理
|
||||
&synchronized{iModel: model.NewUserInstance()}, &synchronized{iModel: model.NewUserIdentity()},
|
||||
&synchronized{iModel: model.NewUserAssets()},
|
||||
&synchronized{iModel: model.NewUserPatent()}, &synchronized{iModel: model.NewUserBank()},
|
||||
&synchronized{iModel: model.NewUserCompany()}, &synchronized{iModel: model.NewUserExpert()},
|
||||
&synchronized{iModel: model.NewUserLaboratory()}, &synchronized{iModel: model.NewUserResearch()},
|
||||
&synchronized{iModel: model.NewUserAgent()},
|
||||
// 数据管理
|
||||
&synchronized{iModel: model.NewManageCompany()}, &synchronized{iModel: model.NewManageExpert()},
|
||||
&synchronized{iModel: model.NewManageLaboratory()}, &synchronized{iModel: model.NewManageResearch()},
|
||||
&synchronized{iModel: model.NewManageAgent()},
|
||||
&synchronized{iModel: model.NewTechnologyAchievement()}, &synchronized{iModel: model.NewTechnologyDemand()},
|
||||
&synchronized{iModel: model.NewTechnologyPaper()}, &synchronized{iModel: model.NewTechnologyProduct()},
|
||||
&synchronized{iModel: model.NewTechnologyProject()}, &synchronized{iModel: model.NewTechnologyTopic()},
|
||||
&synchronized{iModel: model.NewServiceDocking()}, &synchronized{iModel: model.NewServiceMessage()},
|
||||
&synchronized{iModel: model.NewServiceSolutionCase()}, &synchronized{iModel: model.NewServiceSolutionCaseDetail()},
|
||||
&synchronized{iModel: model.NewServiceInnovate()}, &synchronized{iModel: model.NewServiceInnovateKind()},
|
||||
// 活动管理
|
||||
&synchronized{iModel: model.NewActivityInstance()}, &synchronized{iModel: model.NewActivityApply()},
|
||||
&synchronized{iModel: model.NewActivityExamine()}, &synchronized{iModel: model.NewActivityJoin()},
|
||||
)
|
||||
}
|
||||
|
||||
func WithGormDBOption(db *gorm.DB) Option {
|
||||
return func(instance *Instance) {
|
||||
instance.gormDB = db
|
||||
}
|
||||
}
|
||||
|
||||
func NewInstance(options ...Option) *Instance {
|
||||
out := new(Instance)
|
||||
|
||||
for _, v := range options {
|
||||
v(out)
|
||||
}
|
||||
return out
|
||||
}
|
Reference in New Issue
Block a user