feat:完善项目信息

This commit is contained in:
henry
2022-01-10 10:00:04 +08:00
parent 119857bfdb
commit 4b5acca5c3
14 changed files with 126 additions and 103 deletions

View File

@ -32,7 +32,7 @@ func (*Role) Select(c *gin.Context) {
func (*Role) Add(c *gin.Context) {
form := &struct {
Name string `json:"name" form:"name" binding:"required"`
Remark string `json:"remark" form:"remark" binding:"required"`
Remark string `json:"remark" form:"remark"`
Sort int `json:"sort" form:"sort"`
}{}
if err := api.Bind(form)(c); err != nil {
@ -47,7 +47,7 @@ func (*Role) Edit(c *gin.Context) {
form := &struct {
api.IDStringForm
Name string `json:"name" form:"name" binding:"required"`
Remark string `json:"remark" form:"remark" binding:"required"`
Remark string `json:"remark" form:"remark"`
Sort int `json:"sort" form:"sort"`
}{}
if err := api.Bind(form)(c); err != nil {

View File

@ -92,11 +92,14 @@ func (c *Auth) Bind(roleID uint64, authIDs []uint64) error {
if err = model2.Creates(mSysRoleAuth.SysRoleAuth, data); err != nil {
return err
}
if len(request) > 0 {
permission.AddRequest(request)
_, err = permission.AddPolicies()
if _, err = permission.AddPolicies(); err != nil {
return err
}
}
return nil
})
}

View File

@ -85,11 +85,14 @@ func (c *Menu) Bind(roleID uint64, menuIDs []uint64) error {
if err = model2.Creates(mSysRoleMenu.SysRoleMenu, data, tx); err != nil {
return err
}
if len(request) > 0 {
permission.AddRequest(request)
_, err = permission.AddPolicies()
if _, err = permission.AddPolicies(); err != nil {
return err
}
}
return nil
})
}

View File

@ -8,8 +8,12 @@ import (
"SciencesServer/app/service"
"SciencesServer/app/session"
config2 "SciencesServer/config"
"SciencesServer/serve/logger"
"SciencesServer/serve/orm"
"SciencesServer/utils"
"errors"
"fmt"
"gorm.io/gorm"
)
type Instance struct {
@ -115,9 +119,20 @@ func (c *Instance) Delete(id uint64) error {
} else if !isExist {
return errors.New("操作错误,平台信息不存在或已被删除")
}
if err = orm.GetDB().Transaction(func(tx *gorm.DB) error {
if err = model2.Delete(mSysTenant.SysTenant); err != nil {
return err
}
if _, err = service.NewPermission(
service.WithAuthTenant(fmt.Sprintf("%d", id)),
).RemoveFilteredGroupingPolicy(); err != nil {
logger.ErrorF("Casbin 删除租户【%d】下权限信息错误%v", id, err)
return err
}
return nil
}); err != nil {
return nil
}
service.Publish(config2.EventForRedisHashDestroy, config2.RedisKeyForTenant, mSysTenant.Domain)
return nil
}

View File

@ -8,6 +8,18 @@ import (
type Config struct{}
func (*Config) Index(c *gin.Context) {
form := &struct {
Kind int `json:"kind" form:"kind" binding:"required"`
}{}
if err := api.Bind(form)(c); err != nil {
api.APIFailure(err.(error))(c)
return
}
data, err := controller.NewConfig()(nil).Instance(form.Kind)
api.APIResponse(err, data)(c)
}
func (*Config) Area(c *gin.Context) {
form := &struct {
Code string `json:"code" form:"code"`

View File

@ -1,7 +1,9 @@
package controller
import (
"SciencesServer/app/api/admin/model"
"SciencesServer/app/basic/config"
model2 "SciencesServer/app/common/model"
"SciencesServer/app/session"
config2 "SciencesServer/config"
)
@ -10,8 +12,25 @@ type Config struct{ *session.Admin }
type ConfigHandle func(session *session.Admin) *Config
func (c *Config) Basic() {
type (
ConfigInfo struct {
Kind int `json:"kind"`
Name string `json:"name"`
Key string `json:"key"`
Value string `json:"value"`
}
)
func (c *Config) Instance(kind int) ([]*ConfigInfo, error) {
mSysConfig := model.NewSysConfig()
out := make([]*ConfigInfo, 0)
if err := model2.ScanFields(mSysConfig.SysConfig, &out, []string{"kind", "name", "`key`", "`value`"},
&model2.ModelWhereOrder{Where: model2.NewWhere("kind", kind)}); err != nil {
return nil, err
}
return out, nil
}
// Area 区域信息

View File

@ -2,7 +2,8 @@ package controller
import (
"SciencesServer/app/api/website/model"
model2 "SciencesServer/app/common/model"
"SciencesServer/app/basic/config"
config2 "SciencesServer/config"
)
type Platform struct{}
@ -10,36 +11,44 @@ type Platform struct{}
type PlatformHandle func() *Platform
type PlatformInfo struct {
Title string `json:"title"`
Link string `json:"link"`
Name string `json:"name"`
Code string `json:"code"`
Domain string `json:"domain"`
Children []*PlatformInfo `json:"children"`
}
// tree 树状
func (c *Platform) tree(src []*model2.SysPlatform, parentID uint64) []*PlatformInfo {
out := make([]*PlatformInfo, 0)
for _, v := range src {
if v.ParentID == parentID {
out = append(out, &PlatformInfo{
Title: v.Title,
Link: v.Link,
Children: c.tree(src, v.ID),
})
}
}
return out
}
// Instance 平台信息
func (c *Platform) Instance() ([]*PlatformInfo, error) {
mSysPlatform := model.NewSysPlatform()
out, err := mSysPlatform.Platform()
func (c *Platform) Instance() (map[string]*PlatformInfo, error) {
mSysPlatform := model.NewSysTenant()
out, err := mSysPlatform.Tenant()
if err != nil {
return nil, err
}
return c.tree(out, 0), nil
ret := make(map[string]*PlatformInfo, 0)
for _, v := range out {
if _, has := ret[v.Province]; !has {
ret[v.Province] = &PlatformInfo{
Name: config.MemoryForAreaInfo[config2.DefaultChinaAreaCode][v.Province],
Code: v.Province,
Domain: "",
Children: []*PlatformInfo{&PlatformInfo{
Name: config.MemoryForAreaInfo[v.Province][v.City],
Code: v.City,
Domain: v.Domain,
Children: nil,
}},
}
continue
}
ret[v.Province].Children = append(ret[v.Province].Children, &PlatformInfo{
Name: config.MemoryForAreaInfo[v.Province][v.City],
Domain: v.Domain,
Children: nil,
})
}
return ret, nil
}
func NewPlatform() PlatformHandle {

View File

@ -1,27 +0,0 @@
package model
import (
"SciencesServer/app/common/model"
"SciencesServer/serve/orm"
)
type SysPlatform struct {
*model.SysPlatform
}
// Platform 平台信息
func (m *SysPlatform) Platform() ([]*model.SysPlatform, error) {
out := make([]*model.SysPlatform, 0)
err := orm.GetDB().Table(m.TableName()).
Select("id", "parent_id", "`key`", "`code`", "title", "link").
Where("is_deleted = ?", model.DeleteStatusForNot).
Order("sort " + model.OrderModeToDesc).
Scan(&out).Error
return out, err
}
func NewSysPlatform() *SysPlatform {
return &SysPlatform{model.NewSysPlatform()}
}

View File

@ -0,0 +1,27 @@
package model
import (
"SciencesServer/app/common/model"
"SciencesServer/serve/orm"
)
type SysTenant struct {
*model.SysTenant
}
// Tenant 租户平台信息
func (m *SysTenant) Tenant() ([]*model.SysTenant, error) {
out := make([]*model.SysTenant, 0)
err := orm.GetDB().Table(m.TableName()).
Select("id", "`key`", "name", "domain", "province", "city").
Where("is_deleted = ?", model.DeleteStatusForNot).
Order("province " + model.OrderModeToAsc).Order("city " + model.OrderModeToAsc).
Scan(&out).Error
return out, err
}
func NewSysTenant() *SysTenant {
return &SysTenant{model.NewSysTenant()}
}

View File

@ -16,8 +16,6 @@ var (
MemoryForAreaInfo map[string]map[string]string = make(map[string]map[string]string, 0)
// MemoryForIndustryInfo 行业信息
MemoryForIndustryInfo map[string]string = make(map[string]string, 0)
// MemoryForPlatformInfo 平台信息
MemoryForPlatformInfo map[string]string = make(map[string]string, 0)
)
// GetIndustryInfo 获取行业信息

View File

@ -118,7 +118,7 @@ func (this *Instance) Handle() {
}
return out
}},
&synchronized{iModel: model.NewSysPlatform()}, &synchronized{iModel: model.NewSysNavigation()},
&synchronized{iModel: model.NewSysNavigation()},
&synchronized{iModel: model.NewSysAbout()},
// 日志管理
&synchronized{iModel: model.NewSysLog()}, &synchronized{iModel: model.NewSysUserLoginLog()},

View File

@ -1,22 +0,0 @@
package model
// SysPlatform 平台配置数据模型
type SysPlatform struct {
Model
ParentID uint64 `gorm:"column:parent_id;type:int;default:0;comment:父级ID" json:"parent_id"`
Key string `gorm:"column:key;uniqueIndex:idx_sys_platform_key;type:varchar(15);default:'';comment:唯一标识" json:"key"`
Code string `gorm:"column:code;type:varchar(10);default:'';comment:区域编码" json:"code"`
Title string `gorm:"column:title;type:varchar(10);default:'';comment:区域名称" json:"title"`
Link string `gorm:"column:link;type:varchar(255);default:'';comment:访问地址" json:"link"`
Sort int `gorm:"column:sort;type:tinyint(3);default:0;comment:排序,从大到小" json:"-"`
ModelDeleted
ModelAt
}
func (m *SysPlatform) TableName() string {
return "sys_platform"
}
func NewSysPlatform() *SysPlatform {
return &SysPlatform{}
}

View File

@ -57,21 +57,6 @@ func (this *Cache) Init() {
}
}},
)
function(
&caches{iModel: model.NewSysPlatform(), iValues: func() interface{} {
out := make([]*model.SysPlatform, 0)
_ = model.ScanFields(model.NewSysPlatform(), &out, []string{"id", "key", "link"})
return out
}, toCache: func(values interface{}) {
out := values.([]*model.SysPlatform)
for _, v := range out {
if v.Link == "" {
continue
}
config2.MemoryForPlatformInfo[v.Link] = v.Key
}
}},
)
}
func NewCache() CacheHandle {

View File

@ -38,6 +38,7 @@ func registerAPI(app *gin.Engine) {
configV1 := v1.Group("/config")
{
_api := new(api2.Config)
configV1.GET("", _api.Index)
configV1.POST("/area", _api.Area)
}
// User 用户信息管理