|
|
|
|
package role
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/veypi/vbase/cfg"
|
|
|
|
|
"github.com/veypi/vbase/models"
|
|
|
|
|
"github.com/veypi/vigo"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type ListReq struct {
|
|
|
|
|
Page int `json:"page" src:"query" default:"1"`
|
|
|
|
|
PageSize int `json:"page_size" src:"query" default:"20"`
|
refactor: Remove multi-tenant org system and simplify auth
- Delete org API endpoints (add_member, create, del, get, list, member, patch, tree)
- Delete models/org.go and remove Org/OrgMember models
- Delete org-related test files (org_crud, org_load_middleware, org_permission, multi_tenant)
- Delete org test scripts (03_org_permission.sh, 04_org_load_middleware.sh)
- Simplify auth/auth.go by removing org context and role loading logic
- Remove org claims from JWT tokens and login/register responses
- Redesign Permission model with hierarchical level-based access control
- Add auth/design.md with new permission system specification
- Update user and role APIs to work without org context
5 days ago
|
|
|
Scope string `json:"scope" src:"query" desc:"Scope"`
|
|
|
|
|
Keyword *string `json:"keyword" src:"query" desc:"Search Keyword"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type ListResp struct {
|
|
|
|
|
Items []models.Role `json:"items"`
|
|
|
|
|
Total int64 `json:"total"`
|
|
|
|
|
Page int `json:"page"`
|
|
|
|
|
PageSize int `json:"page_size"`
|
|
|
|
|
TotalPages int `json:"total_pages"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func list(x *vigo.X, req *ListReq) (*ListResp, error) {
|
|
|
|
|
db := cfg.DB().Model(&models.Role{})
|
|
|
|
|
|
refactor: Remove multi-tenant org system and simplify auth
- Delete org API endpoints (add_member, create, del, get, list, member, patch, tree)
- Delete models/org.go and remove Org/OrgMember models
- Delete org-related test files (org_crud, org_load_middleware, org_permission, multi_tenant)
- Delete org test scripts (03_org_permission.sh, 04_org_load_middleware.sh)
- Simplify auth/auth.go by removing org context and role loading logic
- Remove org claims from JWT tokens and login/register responses
- Redesign Permission model with hierarchical level-based access control
- Add auth/design.md with new permission system specification
- Update user and role APIs to work without org context
5 days ago
|
|
|
if req.Scope != "" {
|
|
|
|
|
db = db.Where("scope = ?", req.Scope)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if req.Keyword != nil && *req.Keyword != "" {
|
|
|
|
|
db = db.Where("name LIKE ? OR code LIKE ?", "%"+*req.Keyword+"%", "%"+*req.Keyword+"%")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var total int64
|
|
|
|
|
if err := db.Count(&total).Error; err != nil {
|
|
|
|
|
return nil, vigo.ErrInternalServer.WithError(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var roles []models.Role
|
|
|
|
|
offset := (req.Page - 1) * req.PageSize
|
|
|
|
|
if err := db.Order("created_at DESC").Offset(offset).Limit(req.PageSize).Find(&roles).Error; err != nil {
|
|
|
|
|
return nil, vigo.ErrInternalServer.WithError(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
totalPages := int(total) / req.PageSize
|
|
|
|
|
if int(total)%req.PageSize > 0 {
|
|
|
|
|
totalPages++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return &ListResp{
|
|
|
|
|
Items: roles,
|
|
|
|
|
Total: total,
|
|
|
|
|
Page: req.Page,
|
|
|
|
|
PageSize: req.PageSize,
|
|
|
|
|
TotalPages: totalPages,
|
|
|
|
|
}, nil
|
|
|
|
|
}
|