
* refactor(server): 重构服务器启动和重载逻辑 将服务器启动和重载逻辑进行重构,提取初始化系统为单独函数,优化代码结构。删除冗余的服务器初始化文件,统一使用新的 `server_run.go` 实现优雅关闭和重载功能。同时,将“重启服务”改为“重载服务”以更准确地描述功能。 * refactor: 重构系统事件处理、JWT和Casbin相关逻辑 - 将系统重载逻辑提取到独立的`system_events.go`文件中,并引入全局事件管理器 - 将JWT相关操作从`service`层移动到`utils`层,减少服务层依赖 - 将Casbin实例管理逻辑提取到`utils`层,统一管理Casbin实例的初始化和获取 - 删除冗余的`CreateSysOperationRecord`方法,优化操作记录中间件逻辑 * refactor(server): 重构服务初始化和关闭逻辑 将 `RunServer` 函数重命名为 `initServer`,并调整其调用方式以简化代码。同时,在系统初始化时添加 `SetupHandlers` 函数以注册全局处理函数,提升代码可维护性。 * fix: 修复自动化代码enum查询条件的bug * fix: 修复组合模式下,顶部菜单重复bug * refactor: 修改名称 RunWindowsServer ==> RunServer * 新增mcp * feat: 支持mcp服务 * feat:调整mcp结构,增加客户端和测试用例 * feat:更换mcp基础包和结构 * feat:提交客户端工具测试用例 * feat: 增加自动创建 mcp Tool模板 功能 * fix: 增加默认值属性 * feat: 调整初始化menu的逻辑 * feat: 调整初始config.yaml * feat: 增加全局GVA_MCP_SERVER属性,方便灵活化开发。 * feat: 优化自动化mcp逻辑和成功展示 * feat: 优化mcp tool nickname工具 * feat: 发布2.8.2 Beta版本 --------- Co-authored-by: piexlMax(奇淼 <qimiaojiangjizhao@gmail.com> Co-authored-by: Gor-c <creup@outlook.com> Co-authored-by: QIN xiansheng <sjjlnaps@163.com>
174 lines
4.9 KiB
Go
174 lines
4.9 KiB
Go
package system
|
|
|
|
import (
|
|
"errors"
|
|
"strconv"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
gormadapter "github.com/casbin/gorm-adapter/v3"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/global"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/utils"
|
|
_ "github.com/go-sql-driver/mysql"
|
|
)
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: UpdateCasbin
|
|
//@description: 更新casbin权限
|
|
//@param: authorityId string, casbinInfos []request.CasbinInfo
|
|
//@return: error
|
|
|
|
type CasbinService struct{}
|
|
|
|
var CasbinServiceApp = new(CasbinService)
|
|
|
|
func (casbinService *CasbinService) UpdateCasbin(adminAuthorityID, AuthorityID uint, casbinInfos []request.CasbinInfo) error {
|
|
|
|
err := AuthorityServiceApp.CheckAuthorityIDAuth(adminAuthorityID, AuthorityID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if global.GVA_CONFIG.System.UseStrictAuth {
|
|
apis, e := ApiServiceApp.GetAllApis(adminAuthorityID)
|
|
if e != nil {
|
|
return e
|
|
}
|
|
|
|
for i := range casbinInfos {
|
|
hasApi := false
|
|
for j := range apis {
|
|
if apis[j].Path == casbinInfos[i].Path && apis[j].Method == casbinInfos[i].Method {
|
|
hasApi = true
|
|
break
|
|
}
|
|
}
|
|
if !hasApi {
|
|
return errors.New("存在api不在权限列表中")
|
|
}
|
|
}
|
|
}
|
|
|
|
authorityId := strconv.Itoa(int(AuthorityID))
|
|
casbinService.ClearCasbin(0, authorityId)
|
|
rules := [][]string{}
|
|
//做权限去重处理
|
|
deduplicateMap := make(map[string]bool)
|
|
for _, v := range casbinInfos {
|
|
key := authorityId + v.Path + v.Method
|
|
if _, ok := deduplicateMap[key]; !ok {
|
|
deduplicateMap[key] = true
|
|
rules = append(rules, []string{authorityId, v.Path, v.Method})
|
|
}
|
|
}
|
|
if len(rules) == 0 {
|
|
return nil
|
|
} // 设置空权限无需调用 AddPolicies 方法
|
|
e := utils.GetCasbin()
|
|
success, _ := e.AddPolicies(rules)
|
|
if !success {
|
|
return errors.New("存在相同api,添加失败,请联系管理员")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: UpdateCasbinApi
|
|
//@description: API更新随动
|
|
//@param: oldPath string, newPath string, oldMethod string, newMethod string
|
|
//@return: error
|
|
|
|
func (casbinService *CasbinService) UpdateCasbinApi(oldPath string, newPath string, oldMethod string, newMethod string) error {
|
|
err := global.GVA_DB.Model(&gormadapter.CasbinRule{}).Where("v1 = ? AND v2 = ?", oldPath, oldMethod).Updates(map[string]interface{}{
|
|
"v1": newPath,
|
|
"v2": newMethod,
|
|
}).Error
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
e := utils.GetCasbin()
|
|
return e.LoadPolicy()
|
|
}
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: GetPolicyPathByAuthorityId
|
|
//@description: 获取权限列表
|
|
//@param: authorityId string
|
|
//@return: pathMaps []request.CasbinInfo
|
|
|
|
func (casbinService *CasbinService) GetPolicyPathByAuthorityId(AuthorityID uint) (pathMaps []request.CasbinInfo) {
|
|
e := utils.GetCasbin()
|
|
authorityId := strconv.Itoa(int(AuthorityID))
|
|
list, _ := e.GetFilteredPolicy(0, authorityId)
|
|
for _, v := range list {
|
|
pathMaps = append(pathMaps, request.CasbinInfo{
|
|
Path: v[1],
|
|
Method: v[2],
|
|
})
|
|
}
|
|
return pathMaps
|
|
}
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: ClearCasbin
|
|
//@description: 清除匹配的权限
|
|
//@param: v int, p ...string
|
|
//@return: bool
|
|
|
|
func (casbinService *CasbinService) ClearCasbin(v int, p ...string) bool {
|
|
e := utils.GetCasbin()
|
|
success, _ := e.RemoveFilteredPolicy(v, p...)
|
|
return success
|
|
}
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: RemoveFilteredPolicy
|
|
//@description: 使用数据库方法清理筛选的politicy 此方法需要调用FreshCasbin方法才可以在系统中即刻生效
|
|
//@param: db *gorm.DB, authorityId string
|
|
//@return: error
|
|
|
|
func (casbinService *CasbinService) RemoveFilteredPolicy(db *gorm.DB, authorityId string) error {
|
|
return db.Delete(&gormadapter.CasbinRule{}, "v0 = ?", authorityId).Error
|
|
}
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: SyncPolicy
|
|
//@description: 同步目前数据库的policy 此方法需要调用FreshCasbin方法才可以在系统中即刻生效
|
|
//@param: db *gorm.DB, authorityId string, rules [][]string
|
|
//@return: error
|
|
|
|
func (casbinService *CasbinService) SyncPolicy(db *gorm.DB, authorityId string, rules [][]string) error {
|
|
err := casbinService.RemoveFilteredPolicy(db, authorityId)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return casbinService.AddPolicies(db, rules)
|
|
}
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
//@function: AddPolicies
|
|
//@description: 添加匹配的权限
|
|
//@param: v int, p ...string
|
|
//@return: bool
|
|
|
|
func (casbinService *CasbinService) AddPolicies(db *gorm.DB, rules [][]string) error {
|
|
var casbinRules []gormadapter.CasbinRule
|
|
for i := range rules {
|
|
casbinRules = append(casbinRules, gormadapter.CasbinRule{
|
|
Ptype: "p",
|
|
V0: rules[i][0],
|
|
V1: rules[i][1],
|
|
V2: rules[i][2],
|
|
})
|
|
}
|
|
return db.Create(&casbinRules).Error
|
|
}
|
|
|
|
func (casbinService *CasbinService) FreshCasbin() (err error) {
|
|
e := utils.GetCasbin()
|
|
err = e.LoadPolicy()
|
|
return err
|
|
}
|