0001_initial.py 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. # Generated by Django 5.2.4 on 2025-07-14 03:50
  2. import common.encoder.encoder
  3. import django.contrib.postgres.fields
  4. import django.db.models.deletion
  5. import uuid_utils.compat
  6. from django.db import migrations, models
  7. class Migration(migrations.Migration):
  8. initial = True
  9. dependencies = [
  10. ('users', '0001_initial'),
  11. ]
  12. operations = [
  13. migrations.CreateModel(
  14. name='ChatUser',
  15. fields=[
  16. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  17. ('email', models.EmailField(blank=True, db_index=True, max_length=254, null=True, verbose_name='邮箱')),
  18. ('phone', models.CharField(default='', max_length=20, verbose_name='电话')),
  19. ('nick_name', models.CharField(db_index=True, max_length=150, unique=True, verbose_name='昵称')),
  20. ('username', models.CharField(db_index=True, max_length=150, unique=True, verbose_name='用户名')),
  21. ('password', models.CharField(max_length=150, verbose_name='密码')),
  22. ('source', models.CharField(db_index=True, default='LOCAL', max_length=10, verbose_name='来源')),
  23. ('is_active', models.BooleanField(db_index=True, default=True)),
  24. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, null=True, verbose_name='创建时间')),
  25. ('update_time', models.DateTimeField(auto_now=True, db_index=True, null=True, verbose_name='修改时间')),
  26. ],
  27. options={
  28. 'db_table': 'chat_user',
  29. },
  30. ),
  31. migrations.CreateModel(
  32. name='Log',
  33. fields=[
  34. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  35. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  36. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  37. ('menu', models.CharField(max_length=128, verbose_name='操作菜单')),
  38. ('operate', models.CharField(db_index=True, max_length=128, verbose_name='操作')),
  39. ('operation_object', models.JSONField(default=dict, encoder=common.encoder.encoder.SystemEncoder, verbose_name='操作对象')),
  40. ('user', models.JSONField(default=dict, verbose_name='用户信息')),
  41. ('status', models.IntegerField(db_index=True, verbose_name='状态')),
  42. ('ip_address', models.CharField(max_length=128, verbose_name='ip地址')),
  43. ('details', models.JSONField(default=dict, encoder=common.encoder.encoder.SystemEncoder, verbose_name='详情')),
  44. ('workspace_id', models.CharField(db_index=True, default='default', max_length=64, verbose_name='工作空间id')),
  45. ],
  46. options={
  47. 'db_table': 'log',
  48. },
  49. ),
  50. migrations.CreateModel(
  51. name='SystemSetting',
  52. fields=[
  53. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  54. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  55. ('type', models.IntegerField(choices=[(0, '邮箱'), (1, '私钥秘钥')], default=0, primary_key=True, serialize=False, verbose_name='设置类型')),
  56. ('meta', models.JSONField(default=dict, verbose_name='配置数据')),
  57. ],
  58. options={
  59. 'db_table': 'system_setting',
  60. },
  61. ),
  62. migrations.CreateModel(
  63. name='UserGroup',
  64. fields=[
  65. ('id', models.CharField(default=uuid_utils.compat.uuid7, editable=False, max_length=128, primary_key=True, serialize=False, verbose_name='主键id')),
  66. ('name', models.CharField(db_index=True, max_length=150, unique=True, verbose_name='名称')),
  67. ],
  68. options={
  69. 'db_table': 'user_group',
  70. },
  71. ),
  72. migrations.CreateModel(
  73. name='UserGroupRelation',
  74. fields=[
  75. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  76. ('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.usergroup', verbose_name='用户组')),
  77. ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.chatuser', verbose_name='用户')),
  78. ],
  79. options={
  80. 'db_table': 'user_group_relation',
  81. },
  82. ),
  83. migrations.CreateModel(
  84. name='WorkspaceUserResourcePermission',
  85. fields=[
  86. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  87. ('workspace_id', models.CharField(db_index=True, default='default', max_length=128, verbose_name='工作空间id')),
  88. ('auth_target_type', models.CharField(choices=[('KNOWLEDGE', '知识库'), ('APPLICATION', '应用'), ('TOOL', '工具'), ('MODEL', '模型')], db_index=True, default='KNOWLEDGE', max_length=128, verbose_name='授权目标')),
  89. ('target', models.UUIDField(db_index=True, verbose_name='知识库/应用id')),
  90. ('auth_type', models.CharField(choices=[('ROLE', 'Role'), ('RESOURCE_PERMISSION_GROUP', 'Resource Permission Group')], db_default='ROLE', db_index=True, default=False, verbose_name='授权类型')),
  91. ('permission_list', django.contrib.postgres.fields.ArrayField(base_field=models.CharField(blank=True, choices=[('VIEW', 'View'), ('MANAGE', 'Manage'), ('ROLE', 'Role')], default='VIEW', max_length=256), default=list, size=None, verbose_name='权限列表')),
  92. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  93. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  94. ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='users.user', verbose_name='工作空间下的用户')),
  95. ],
  96. options={
  97. 'db_table': 'workspace_user_resource_permission',
  98. },
  99. ),
  100. migrations.CreateModel(
  101. name='ResourceChatUserGroupAuthorize',
  102. fields=[
  103. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  104. ('workspace_id', models.CharField(db_index=True, default='default', max_length=64, null=True, verbose_name='工作空间id')),
  105. ('resource_id', models.UUIDField(db_index=True, verbose_name='资源id')),
  106. ('resource_type', models.CharField(choices=[('KNOWLEDGE', '知识库'), ('APPLICATION', '应用')], db_index=True, verbose_name='资源类型')),
  107. ('is_auth', models.BooleanField(verbose_name='是否授权')),
  108. ('user_group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.usergroup', verbose_name='用户组')),
  109. ],
  110. options={
  111. 'db_table': 'resource_chat_user_group_authorize',
  112. 'unique_together': {('user_group_id', 'resource_type', 'resource_id')},
  113. },
  114. ),
  115. migrations.CreateModel(
  116. name='ResourceChatUserAuthorize',
  117. fields=[
  118. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  119. ('workspace_id', models.CharField(db_index=True, default='default', max_length=64, null=True, verbose_name='工作空间id')),
  120. ('resource_id', models.UUIDField(db_index=True, verbose_name='资源id')),
  121. ('resource_type', models.CharField(choices=[('KNOWLEDGE', '知识库'), ('APPLICATION', '应用')], db_index=True, verbose_name='资源类型')),
  122. ('is_auth', models.BooleanField(verbose_name='是否授权')),
  123. ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.chatuser', verbose_name='用户')),
  124. ('user_group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.usergroup', verbose_name='用户组')),
  125. ],
  126. options={
  127. 'db_table': 'resource_chat_user_authorize',
  128. 'unique_together': {('user_group_id', 'resource_type', 'resource_id', 'user_id')},
  129. },
  130. ),
  131. ]