feat: add permission

This commit is contained in:
王性驊 2025-10-07 17:39:54 +08:00
parent d31b44d434
commit 25075f3d7a
2 changed files with 52 additions and 13 deletions

View File

@ -7,14 +7,14 @@ import (
// PermissionRepository 權限 Repository 介面
type PermissionRepository interface {
// Get 取得單一權限
// FindOne 取得單一權限
FindOne(ctx context.Context, id string) (*entity.Permission, error)
// GetByName 根據名稱取得權限
GetByName(ctx context.Context, name string) (*entity.Permission, error)
// FindByName 根據名稱取得權限
FindByName(ctx context.Context, name string) (*entity.Permission, error)
// GetByNames 批量根據名稱取得權限
GetByNames(ctx context.Context, names []string) ([]*entity.Permission, error)
// GetByHTTP 根據 HTTP Path 和 Method 取得權限
GetByHTTP(ctx context.Context, path, method string) (*entity.Permission, error)
// FindByHTTP 根據 HTTP Path 和 Method 取得權限
FindByHTTP(ctx context.Context, path, method string) (*entity.Permission, error)
// List 列出所有權限
List(ctx context.Context, filter PermissionFilter) ([]*entity.Permission, error)
// ListActive 列出所有啟用的權限 (常用,可快取)

View File

@ -10,6 +10,7 @@ import (
"github.com/zeromicro/go-zero/core/stores/cache"
"github.com/zeromicro/go-zero/core/stores/mon"
"go.mongodb.org/mongo-driver/v2/bson"
"strings"
)
type PermissionRepositoryParam struct {
@ -61,19 +62,57 @@ func (repo *PermissionRepository) FindOne(ctx context.Context, id string) (*enti
}
}
func (repo *PermissionRepository) GetByName(ctx context.Context, name string) (*entity.Permission, error) {
//TODO implement me
panic("implement me")
func (repo *PermissionRepository) FindByName(ctx context.Context, name string) (*entity.Permission, error) {
var data entity.Permission
rk := domain.GetPermissionNameRedisKey(name)
err := repo.DB.FindOne(ctx, rk, &data, bson.M{"name": name})
switch {
case err == nil:
return &data, nil
case errors.Is(err, mon.ErrNotFound):
return nil, ErrNotFound
default:
return nil, err
}
}
func (repo *PermissionRepository) GetByNames(ctx context.Context, names []string) ([]*entity.Permission, error) {
//TODO implement me
panic("implement me")
var data []*entity.Permission
filter := bson.M{
"name": bson.M{"$in": names},
}
func (repo *PermissionRepository) GetByHTTP(ctx context.Context, path, method string) (*entity.Permission, error) {
//TODO implement me
panic("implement me")
err := repo.DB.GetClient().Find(ctx, &data, filter)
if err != nil {
if errors.Is(err, mon.ErrNotFound) {
return nil, ErrNotFound
}
return nil, err
}
return data, nil
}
func (repo *PermissionRepository) FindByHTTP(ctx context.Context, path, method string) (*entity.Permission, error) {
var perm entity.Permission
filter := bson.M{
"path": path,
"method": strings.ToUpper(method), // 確保大小寫一致
}
err := repo.DB.GetClient().FindOne(ctx, &perm, filter)
switch {
case err == nil:
return &perm, nil
case errors.Is(err, mon.ErrNotFound):
return nil, ErrNotFound
default:
return nil, err
}
}
func (repo *PermissionRepository) List(ctx context.Context, filter repository.PermissionFilter) ([]*entity.Permission, error) {