Files
mayfly-go/server/sys/infrastructure/persistence/resource_repo.go

49 lines
1.5 KiB
Go
Raw Normal View History

package persistence
import (
"mayfly-go/base/biz"
"mayfly-go/base/model"
"mayfly-go/server/sys/domain/entity"
"mayfly-go/server/sys/domain/repository"
)
type resourceRepo struct{}
var ResourceDao repository.Resource = &resourceRepo{}
func (r *resourceRepo) GetResourceList(condition *entity.Resource, toEntity interface{}, orderBy ...string) {
model.ListByOrder(condition, toEntity, orderBy...)
}
func (r *resourceRepo) GetById(id uint64, cols ...string) *entity.Resource {
res := new(entity.Resource)
if err := model.GetById(res, id, cols...); err != nil {
return nil
}
return res
}
func (r *resourceRepo) GetByIdIn(ids []uint64, toEntity interface{}, orderBy ...string) {
model.GetByIdIn(new(entity.Resource), toEntity, ids, orderBy...)
}
func (r *resourceRepo) Delete(id uint64) {
biz.ErrIsNil(model.DeleteById(new(entity.Resource), id), "删除失败")
}
func (r *resourceRepo) GetByCondition(condition *entity.Resource, cols ...string) error {
return model.GetBy(condition, cols...)
}
func (r *resourceRepo) GetAccountResources(accountId uint64, toEntity interface{}) {
sql := "SELECT m.id, m.pid, m.weight, m.name, m.code, m.meta, m.type, m.status " +
"FROM t_resource m WHERE m.status = 1 AND " +
"m.id IN " +
"(SELECT DISTINCT(rmb.resource_id) " +
"FROM t_account_role p JOIN t_role r ON p.role_Id = r.id AND p.account_id = ? AND r.status = 1 " +
"JOIN t_role_resource rmb ON rmb.role_id = r.id)" +
"ORDER BY m.pid ASC, m.weight ASC"
model.GetListBySql2Model(sql, toEntity, accountId)
}