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) }