[feat] add GetResRelationResource

This commit is contained in:
what 2023-04-21 23:27:13 +08:00
parent 1a7863e941
commit e2ace7f2d3
2 changed files with 72 additions and 17 deletions

View File

@ -22,6 +22,9 @@ type GetResRelations func(categoryUuid string) []ResRelation
type GetOrmJoinsByResRelations func(root string, items []ResRelation) []contracts.Join type GetOrmJoinsByResRelations func(root string, items []ResRelation) []contracts.Join
// 获取被关联对象的资源
type GetResRelationResource func(r ResRelation) Resource
// 资源关联依赖 // 资源关联依赖
func GetJoinResDependencies(root string, items []ResRelation) (dependencies []string) { func GetJoinResDependencies(root string, items []ResRelation) (dependencies []string) {
dependencies = []string{root} dependencies = []string{root}

View File

@ -2,6 +2,7 @@ package base
import ( import (
"database/sql" "database/sql"
"fmt"
"log" "log"
"reflect" "reflect"
"unicode" "unicode"
@ -10,6 +11,7 @@ import (
"github.com/samber/lo" "github.com/samber/lo"
"git.fsdpf.net/go/contracts" "git.fsdpf.net/go/contracts"
"git.fsdpf.net/go/contracts/helper"
"git.fsdpf.net/go/contracts/res_type" "git.fsdpf.net/go/contracts/res_type"
"git.fsdpf.net/go/db" "git.fsdpf.net/go/db"
) )
@ -142,7 +144,7 @@ func (this Resource) GetDBDriver() string {
} }
func (this Resource) GetAuthDBTable(u contracts.User, params ...any) *db.Builder { func (this Resource) GetAuthDBTable(u contracts.User, params ...any) *db.Builder {
this.GetRolesCondition(u) fmt.Println(this.GetRolesCondition(u).ToSql())
return this.GetDBTable(append(params, u)...) return this.GetDBTable(append(params, u)...)
} }
@ -205,30 +207,80 @@ func (this Resource) WithRolesCondition(b *db.Builder, roles ...string) {
} }
// 获取鉴权条件 // 获取鉴权条件
func (this Resource) GetRolesCondition(u contracts.User) { func (this Resource) GetRolesCondition(u contracts.User) *db.Builder {
// isFullRight := false isFullRight := false
// isFullNot := false isFullNot := false
// roles := do.MustInvoke[GetResRoles](this.container)(this.GetUuid()) NewOrmConditionByRes := do.MustInvoke[helper.NewOrmConditionByRes](this.container)
// GetResRelations := do.MustInvoke[GetResRelations](this.container) NewOrmJoin := do.MustInvoke[helper.NewOrmJoin](this.container)
GetResRelations := do.MustInvoke[GetResRelations](this.container)
GetResource := do.MustInvoke[contracts.GetResource](this.container)
GetResConditions := do.MustInvoke[GetResConditions](this.container)
// subTables := lo.Reduce(roles, func(carry *db.Builder, item ResRole, _ int) *db.Builder { roles := do.MustInvoke[GetResRoles](this.container)(this.GetUuid())
// db := this.GetDB().Table(string(this.GetTable()), this.GetCode()).Select("`" + this.GetCode() + "`.*")
// joins := lo.Filter(GetResRelations(item.Uuid), func(item ResRelation, _ int) bool { subTables := lo.Reduce(roles, func(carry string, item ResRole, _ int) string {
// return item.Type == "inner" || item.Type == "left" || item.Type == "right" db := this.GetDB().Table(string(this.GetTable()), this.GetCode()).Select(db.Raw("`" + this.GetCode() + "`.*"))
// })
// join := orm.NewJoin(contracts.RelationType(item.Type), item.Code, oResource, item.RelationResource, item.RelationField, item.RelationForeignKey) joins := lo.Filter(GetResRelations(item.Uuid), func(item ResRelation, _ int) bool {
return item.Type == "inner" || item.Type == "left" || item.Type == "right"
})
// // 关联扩展条件 conditions := NewOrmConditionByRes(GetResConditions(item.Uuid))
// join.SetCondition(orm.NewConditionByRes(GetResConditions(item.Uuid)))
// return carry for i := 0; i < len(joins); i++ {
// }, nil) oResource, ok := GetResource(joins[i].ResourceCode)
if !ok {
continue
}
join := NewOrmJoin(contracts.RelationType(joins[i].Type), oResource, joins[i].Code, joins[i].RelationResource, joins[i].RelationField, joins[i].RelationForeignKey)
// 关联扩展条件
join.SetCondition(NewOrmConditionByRes(GetResConditions(joins[i].Uuid)))
join.Inject(db, nil)
}
// fmt.Println(subTables.ToSql()) if len(joins) == 0 && conditions.IsEmpty() {
// 无权限, 直接跳过这个 unoin 语句
if carry != "" {
return carry
}
// 第一个无权限除外, 避免所有用户所属角色都是无权限
db.WhereRaw("false")
isFullNot = true
} else if len(joins) == 0 && conditions.IsNotEmpty() && conditions.IsRight() /* 1=1 的这种条件*/ {
// 只要有1个满权限, 直接返回单条语句
isFullRight = true
return db.ToSql()
} else if conditions.IsNotEmpty() {
db.WhereRaw(string(conditions.ToSql(nil)))
// 如果前面是无权限的sql查看, 这直接返回本次查询
if isFullNot {
isFullNot = false
return db.ToSql()
}
}
if carry != "" {
carry += " union "
}
carry += db.ToSql()
return carry
}, "")
// @todo this.GetCode 要换成 alias
if isFullRight {
this.GetDB().Table(string(this.GetTable()), this.GetCode())
} else if isFullNot {
this.GetDB().Table(string(this.GetTable()), this.GetCode()).WhereRaw("false")
} else if subTables != "" {
this.GetDB().Table(subTables, this.GetCode())
}
return this.GetDB().Table(string(this.GetTable()), this.GetCode())
} }
// 格式化保存数据 // 格式化保存数据