2025-04-16 12:09:00 +00:00
|
|
|
|
# coding=utf-8
|
|
|
|
|
|
"""
|
|
|
|
|
|
@project: MaxKB
|
|
|
|
|
|
@Author:虎虎
|
|
|
|
|
|
@file: workspace_permission.py
|
|
|
|
|
|
@date:2025/4/16 18:25
|
|
|
|
|
|
@desc:
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
import uuid_utils.compat as uuid
|
2025-04-27 10:14:50 +00:00
|
|
|
|
from django.contrib.postgres.fields import ArrayField
|
2025-04-16 12:09:00 +00:00
|
|
|
|
from django.db import models
|
|
|
|
|
|
|
2025-04-27 10:14:50 +00:00
|
|
|
|
from common.constants.permission_constants import Group, ResourcePermissionGroup, ResourceAuthType, \
|
|
|
|
|
|
ResourcePermissionRole
|
2025-04-16 12:09:00 +00:00
|
|
|
|
from users.models import User
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AuthTargetType(models.TextChoices):
|
|
|
|
|
|
"""授权目标"""
|
|
|
|
|
|
KNOWLEDGE = Group.KNOWLEDGE.value, '知识库'
|
|
|
|
|
|
APPLICATION = Group.APPLICATION.value, '应用'
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-04-27 10:14:50 +00:00
|
|
|
|
class WorkspaceUserResourcePermission(models.Model):
|
2025-04-16 12:09:00 +00:00
|
|
|
|
"""
|
|
|
|
|
|
工作空间用户资源权限表
|
|
|
|
|
|
用于管理当前工作空间是否有权限操作 某一个应用或者知识库
|
|
|
|
|
|
"""
|
|
|
|
|
|
id = models.UUIDField(primary_key=True, max_length=128, default=uuid.uuid7, editable=False, verbose_name="主键id")
|
|
|
|
|
|
|
|
|
|
|
|
workspace_id = models.CharField(max_length=128, verbose_name="工作空间id", default="default")
|
|
|
|
|
|
|
2025-06-24 10:46:20 +00:00
|
|
|
|
user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="工作空间下的用户")
|
2025-04-16 12:09:00 +00:00
|
|
|
|
|
|
|
|
|
|
auth_target_type = models.CharField(verbose_name='授权目标', max_length=128, choices=AuthTargetType.choices,
|
|
|
|
|
|
default=AuthTargetType.KNOWLEDGE)
|
|
|
|
|
|
# 授权的知识库或者应用的id
|
|
|
|
|
|
target = models.UUIDField(max_length=128, verbose_name="知识库/应用id")
|
|
|
|
|
|
|
2025-04-27 10:14:50 +00:00
|
|
|
|
# 授权类型 如果是Role那么就是角色的权限 如果是PERMISSION
|
|
|
|
|
|
auth_type = models.CharField(default=False, verbose_name="授权类型", choices=ResourceAuthType.choices,
|
|
|
|
|
|
db_default=ResourceAuthType.ROLE)
|
|
|
|
|
|
# 资源权限列表
|
|
|
|
|
|
permission_list = ArrayField(verbose_name="权限列表",
|
|
|
|
|
|
default=list,
|
|
|
|
|
|
base_field=models.CharField(max_length=256,
|
|
|
|
|
|
blank=True,
|
|
|
|
|
|
choices=ResourcePermissionGroup.choices + ResourcePermissionRole.choices,
|
|
|
|
|
|
default=ResourcePermissionGroup.VIEW))
|
2025-04-16 12:09:00 +00:00
|
|
|
|
|
|
|
|
|
|
create_time = models.DateTimeField(verbose_name="创建时间", auto_now_add=True)
|
|
|
|
|
|
|
|
|
|
|
|
update_time = models.DateTimeField(verbose_name="修改时间", auto_now=True)
|
|
|
|
|
|
|
|
|
|
|
|
class Meta:
|
2025-04-27 10:14:50 +00:00
|
|
|
|
db_table = "workspace_user_resource_permission"
|