workspace_user_permission.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. # coding=utf-8
  2. """
  3. @project: MaxKB
  4. @Author:虎虎
  5. @file: workspace_permission.py
  6. @date:2025/4/16 18:25
  7. @desc:
  8. """
  9. import uuid_utils.compat as uuid
  10. from django.contrib.postgres.fields import ArrayField
  11. from django.db import models
  12. from common.constants.permission_constants import Group, ResourcePermissionGroup, ResourceAuthType, \
  13. ResourcePermissionRole, ResourcePermission
  14. from users.models import User
  15. class AuthTargetType(models.TextChoices):
  16. """授权目标"""
  17. KNOWLEDGE = Group.KNOWLEDGE.value, '知识库'
  18. APPLICATION = Group.APPLICATION.value, '应用'
  19. TOOL = Group.TOOL.value, '工具'
  20. MODEL = Group.MODEL.value, '模型'
  21. class WorkspaceUserResourcePermission(models.Model):
  22. """
  23. 工作空间用户资源权限表
  24. 用于管理当前工作空间是否有权限操作 某一个应用或者知识库
  25. """
  26. id = models.UUIDField(primary_key=True, max_length=128, default=uuid.uuid7, editable=False, verbose_name="主键id")
  27. workspace_id = models.CharField(max_length=128, verbose_name="工作空间id", default="default", db_index=True)
  28. user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="工作空间下的用户")
  29. auth_target_type = models.CharField(verbose_name='授权目标', max_length=128, choices=AuthTargetType.choices,
  30. default=AuthTargetType.KNOWLEDGE, db_index=True)
  31. # 授权的知识库或者应用的id
  32. target = models.CharField(max_length=128, verbose_name="知识库/应用id", db_index=True)
  33. # 授权类型 如果是Role那么就是角色的权限 如果是PERMISSION
  34. auth_type = models.CharField(default=False, verbose_name="授权类型", choices=ResourceAuthType.choices,
  35. db_default=ResourceAuthType.ROLE, db_index=True)
  36. # 资源权限列表
  37. permission_list = ArrayField(verbose_name="权限列表",
  38. default=list,
  39. base_field=models.CharField(max_length=256,
  40. blank=True,
  41. choices=ResourcePermission.choices + ResourcePermissionRole.choices,
  42. default=ResourcePermission.VIEW))
  43. create_time = models.DateTimeField(verbose_name="创建时间", auto_now_add=True, db_index=True)
  44. update_time = models.DateTimeField(verbose_name="修改时间", auto_now=True, db_index=True)
  45. class Meta:
  46. db_table = "workspace_user_resource_permission"
  47. unique_together = ('workspace_id', 'user', 'auth_target_type', 'target')