修改info 获取权限及菜单
This commit is contained in:
@@ -274,3 +274,7 @@ class User(AbstractUser, CoreModel):
|
|||||||
verbose_name = '用户数据'
|
verbose_name = '用户数据'
|
||||||
verbose_name_plural = verbose_name
|
verbose_name_plural = verbose_name
|
||||||
db_table = 'system_users'
|
db_table = 'system_users'
|
||||||
|
|
||||||
|
@property
|
||||||
|
def get_role_name(self):
|
||||||
|
return [role.name for role in self.role.all()]
|
||||||
@@ -69,7 +69,7 @@ class MenuMetaViewSet(viewsets.ModelViewSet):
|
|||||||
|
|
||||||
class MenuViewSet(CustomModelViewSet):
|
class MenuViewSet(CustomModelViewSet):
|
||||||
"""菜单管理视图集"""
|
"""菜单管理视图集"""
|
||||||
queryset = Menu.objects.filter(pid__isnull=True).order_by('id', 'status')
|
queryset = Menu.objects.filter(pid__isnull=True).order_by('sort', 'id', 'status')
|
||||||
serializer_class = MenuSerializer
|
serializer_class = MenuSerializer
|
||||||
filter_backends = [DjangoFilterBackend, SearchFilter, OrderingFilter]
|
filter_backends = [DjangoFilterBackend, SearchFilter, OrderingFilter]
|
||||||
filterset_fields = ['status', 'type', 'pid', 'name']
|
filterset_fields = ['status', 'type', 'pid', 'name']
|
||||||
@@ -91,7 +91,10 @@ class MenuViewSet(CustomModelViewSet):
|
|||||||
def name_search(self, request):
|
def name_search(self, request):
|
||||||
name = request.GET.get('name')
|
name = request.GET.get('name')
|
||||||
pk = request.GET.get('id', None)
|
pk = request.GET.get('id', None)
|
||||||
|
pid = request.GET.get('pid', None)
|
||||||
queryset = Menu.objects.all()
|
queryset = Menu.objects.all()
|
||||||
|
if pid:
|
||||||
|
queryset = queryset.filter(pid=pid)
|
||||||
if pk:
|
if pk:
|
||||||
queryset = queryset.exclude(pk=pk)
|
queryset = queryset.exclude(pk=pk)
|
||||||
if name:
|
if name:
|
||||||
|
|||||||
@@ -6,7 +6,8 @@ from rest_framework.response import Response
|
|||||||
from rest_framework.views import APIView
|
from rest_framework.views import APIView
|
||||||
from django.contrib.auth.hashers import make_password
|
from django.contrib.auth.hashers import make_password
|
||||||
|
|
||||||
from system.models import User
|
from system.models import User, Menu
|
||||||
|
from system.views.menu import MenuSerializer
|
||||||
|
|
||||||
from utils.serializers import CustomModelSerializer
|
from utils.serializers import CustomModelSerializer
|
||||||
from utils.custom_model_viewSet import CustomModelViewSet
|
from utils.custom_model_viewSet import CustomModelViewSet
|
||||||
@@ -68,10 +69,22 @@ class UserInfo(APIView):
|
|||||||
user = self.request.user
|
user = self.request.user
|
||||||
user_data = UserSerializer(user).data
|
user_data = UserSerializer(user).data
|
||||||
if user.is_superuser:
|
if user.is_superuser:
|
||||||
user_data['roles'] = ['admin']
|
roles = ['admin']
|
||||||
|
menus = Menu.objects.filter(pid__isnull=True).order_by('sort')
|
||||||
|
permissions = Menu.objects.filter(type='button').order_by('sort').values_list('auth_code', flat=True)
|
||||||
|
else:
|
||||||
|
roles = user.get_role_name
|
||||||
|
menus = Menu.objects.filter(pid__isnull=True, role__users=user).order_by('sort').distinct()
|
||||||
|
permissions = Menu.objects.filter(type='button', role__users=user).order_by('sort').distinct().values_list('auth_code', flat=True)
|
||||||
|
menus_data = MenuSerializer(menus, many=True).data
|
||||||
return Response({
|
return Response({
|
||||||
"code": 0,
|
"code": 0,
|
||||||
"data": user_data,
|
"data": {
|
||||||
|
"menus": menus_data,
|
||||||
|
"permissions": permissions,
|
||||||
|
"roles": roles,
|
||||||
|
"user": user_data,
|
||||||
|
},
|
||||||
"error": None,
|
"error": None,
|
||||||
"message": "ok"
|
"message": "ok"
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -25,7 +25,7 @@ export namespace SystemMenuApi {
|
|||||||
export interface SystemMenu {
|
export interface SystemMenu {
|
||||||
[key: string]: any;
|
[key: string]: any;
|
||||||
/** 后端权限标识 */
|
/** 后端权限标识 */
|
||||||
authCode: string;
|
auth_code: string;
|
||||||
/** 子级 */
|
/** 子级 */
|
||||||
children?: SystemMenu[];
|
children?: SystemMenu[];
|
||||||
/** 组件 */
|
/** 组件 */
|
||||||
@@ -110,9 +110,10 @@ async function isMenuNameExists(
|
|||||||
async function isMenuSearchExists(
|
async function isMenuSearchExists(
|
||||||
name: string,
|
name: string,
|
||||||
id?: SystemMenuApi.SystemMenu['id'],
|
id?: SystemMenuApi.SystemMenu['id'],
|
||||||
|
pid?: SystemMenuApi.SystemMenu['pid'],
|
||||||
) {
|
) {
|
||||||
return requestClient.get<boolean>('/system/menu/name-search', {
|
return requestClient.get<boolean>('/system/menu/name-search', {
|
||||||
params: { name, id },
|
params: { name, id, pid },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -29,7 +29,7 @@
|
|||||||
"component": "Component",
|
"component": "Component",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"sort": "sort",
|
"sort": "sort",
|
||||||
"authCode": "Permission Code",
|
"auth_code": "Permission Code",
|
||||||
"badge": "Badge",
|
"badge": "Badge",
|
||||||
"operation": "Actions",
|
"operation": "Actions",
|
||||||
"linkSrc": "Link URL",
|
"linkSrc": "Link URL",
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
"activePathMustExist": "该路径未能找到有效的菜单",
|
"activePathMustExist": "该路径未能找到有效的菜单",
|
||||||
"advancedSettings": "其它设置",
|
"advancedSettings": "其它设置",
|
||||||
"affixTab": "固定在标签",
|
"affixTab": "固定在标签",
|
||||||
"authCode": "权限标识",
|
"auth_code": "权限标识",
|
||||||
"badge": "徽章内容",
|
"badge": "徽章内容",
|
||||||
"badgeVariants": "徽标样式",
|
"badgeVariants": "徽标样式",
|
||||||
"badgeType": {
|
"badgeType": {
|
||||||
|
|||||||
@@ -56,7 +56,11 @@ const schema: VbenFormSchema[] = [
|
|||||||
.max(30, $t('ui.formRules.maxLength', [$t('system.menu.menuName'), 30]))
|
.max(30, $t('ui.formRules.maxLength', [$t('system.menu.menuName'), 30]))
|
||||||
.refine(
|
.refine(
|
||||||
async (value: string) => {
|
async (value: string) => {
|
||||||
return !(await isMenuSearchExists(value, formData.value?.id));
|
return !(await isMenuSearchExists(
|
||||||
|
value,
|
||||||
|
formData.value?.id,
|
||||||
|
formData.value?.pid,
|
||||||
|
));
|
||||||
},
|
},
|
||||||
(value) => ({
|
(value) => ({
|
||||||
message: $t('ui.formRules.alreadyExists', [
|
message: $t('ui.formRules.alreadyExists', [
|
||||||
@@ -252,7 +256,7 @@ const schema: VbenFormSchema[] = [
|
|||||||
triggerFields: ['type'],
|
triggerFields: ['type'],
|
||||||
},
|
},
|
||||||
fieldName: 'auth_code',
|
fieldName: 'auth_code',
|
||||||
label: $t('system.menu.authCode'),
|
label: $t('system.menu.auth_code'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
component: 'InputNumber',
|
component: 'InputNumber',
|
||||||
|
|||||||
Reference in New Issue
Block a user