123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- package system
- import (
- "errors"
- "fmt"
- "lcfns/global"
- "lcfns/model/common/request"
- "lcfns/model/system"
- "gorm.io/gorm"
- )
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: CreateApi
- //@description: 新增基础api
- //@param: api model.SysApi
- //@return: err error
- type ApiService struct{}
- var ApiServiceApp = new(ApiService)
- func (apiService *ApiService) CreateApi(api system.SysApi) (err error) {
- if !errors.Is(global.Db.Where("path = ? AND method = ?", api.Path, api.Method).First(&system.SysApi{}).Error, gorm.ErrRecordNotFound) {
- return errors.New("存在相同api")
- }
- return global.Db.Create(&api).Error
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: DeleteApi
- //@description: 删除基础api
- //@param: api model.SysApi
- //@return: err error
- func (apiService *ApiService) DeleteApi(api system.SysApi) (err error) {
- var entity system.SysApi
- err = global.Db.Where("id = ?", api.ID).First(&entity).Error // 根据id查询api记录
- if errors.Is(err, gorm.ErrRecordNotFound) { // api记录不存在
- return err
- }
- err = global.Db.Delete(&entity).Error
- if err != nil {
- return err
- }
- CasbinServiceApp.ClearCasbin(1, entity.Path, entity.Method)
- e := CasbinServiceApp.Casbin()
- err = e.InvalidateCache()
- if err != nil {
- return err
- }
- return nil
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: GetAPIInfoList
- //@description: 分页获取数据,
- //@param: api model.SysApi, info request.PageInfo, order string, desc bool
- //@return: list interface{}, total int64, err error
- func (apiService *ApiService) GetAPIInfoList(api system.SysApi, info request.PageInfo, order string, desc bool) (list interface{}, total int64, err error) {
- limit := info.PageSize
- offset := info.PageSize * (info.Page - 1)
- db := global.Db.Model(&system.SysApi{})
- var apiList []system.SysApi
- if api.Path != "" {
- db = db.Where("path LIKE ?", "%"+api.Path+"%")
- }
- if api.Description != "" {
- db = db.Where("description LIKE ?", "%"+api.Description+"%")
- }
- if api.Method != "" {
- db = db.Where("method = ?", api.Method)
- }
- if api.ApiGroup != "" {
- db = db.Where("api_group = ?", api.ApiGroup)
- }
- err = db.Count(&total).Error
- if err != nil {
- return apiList, total, err
- } else {
- db = db.Limit(limit).Offset(offset)
- if order != "" {
- var OrderStr string
- // 设置有效排序key 防止sql注入
- // 感谢 Tom4t0 提交漏洞信息
- orderMap := make(map[string]bool, 5)
- orderMap["id"] = true
- orderMap["path"] = true
- orderMap["api_group"] = true
- orderMap["description"] = true
- orderMap["method"] = true
- if orderMap[order] {
- if desc {
- OrderStr = order + " desc"
- } else {
- OrderStr = order
- }
- } else { // didn't matched any order key in `orderMap`
- err = fmt.Errorf("非法的排序字段: %v", order)
- return apiList, total, err
- }
- err = db.Order(OrderStr).Find(&apiList).Error
- } else {
- err = db.Order("api_group").Find(&apiList).Error
- }
- }
- return apiList, total, err
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: GetAllApis
- //@description: 获取所有的api
- //@return: apis []model.SysApi, err error
- func (apiService *ApiService) GetAllApis() (apis []system.SysApi, err error) {
- err = global.Db.Find(&apis).Error
- return
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: GetApiById
- //@description: 根据id获取api
- //@param: id float64
- //@return: api model.SysApi, err error
- func (apiService *ApiService) GetApiById(id int) (api system.SysApi, err error) {
- err = global.Db.Where("id = ?", id).First(&api).Error
- return
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: UpdateApi
- //@description: 根据id更新api
- //@param: api model.SysApi
- //@return: err error
- func (apiService *ApiService) UpdateApi(api system.SysApi) (err error) {
- var oldA system.SysApi
- err = global.Db.Where("id = ?", api.ID).First(&oldA).Error
- if oldA.Path != api.Path || oldA.Method != api.Method {
- if !errors.Is(global.Db.Where("path = ? AND method = ?", api.Path, api.Method).First(&system.SysApi{}).Error, gorm.ErrRecordNotFound) {
- return errors.New("存在相同api路径")
- }
- }
- if err != nil {
- return err
- } else {
- err = CasbinServiceApp.UpdateCasbinApi(oldA.Path, api.Path, oldA.Method, api.Method)
- if err != nil {
- return err
- } else {
- err = global.Db.Omit("created_at").Save(&api).Error
- }
- }
- return err
- }
- //@author: [piexlmax](https://github.com/piexlmax)
- //@function: DeleteApis
- //@description: 删除选中API
- //@param: apis []model.SysApi
- //@return: err error
- func (apiService *ApiService) DeleteApisByIds(ids request.IdsReq) (err error) {
- var apis []system.SysApi
- err = global.Db.Find(&apis, "id in ?", ids.Ids).Delete(&apis).Error
- if err != nil {
- return err
- } else {
- for _, sysApi := range apis {
- CasbinServiceApp.ClearCasbin(1, sysApi.Path, sysApi.Method)
- }
- e := CasbinServiceApp.Casbin()
- err = e.InvalidateCache()
- if err != nil {
- return err
- }
- }
- return err
- }
- func (apiService *ApiService) FreshCasbin() (err error) {
- e := CasbinServiceApp.Casbin()
- err = e.LoadPolicy()
- return err
- }
|