mirror of
https://github.com/1Panel-dev/MaxKB.git
synced 2025-12-27 12:12:57 +00:00
138 lines
8.8 KiB
Python
138 lines
8.8 KiB
Python
# Generated by Django 5.2.4 on 2025-07-14 03:50
|
|
|
|
import common.encoder.encoder
|
|
import django.contrib.postgres.fields
|
|
import django.db.models.deletion
|
|
import uuid_utils.compat
|
|
from django.db import migrations, models
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
|
|
initial = True
|
|
|
|
dependencies = [
|
|
('users', '0001_initial'),
|
|
]
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name='ChatUser',
|
|
fields=[
|
|
('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('email', models.EmailField(blank=True, db_index=True, max_length=254, null=True, verbose_name='邮箱')),
|
|
('phone', models.CharField(default='', max_length=20, verbose_name='电话')),
|
|
('nick_name', models.CharField(db_index=True, max_length=150, unique=True, verbose_name='昵称')),
|
|
('username', models.CharField(db_index=True, max_length=150, unique=True, verbose_name='用户名')),
|
|
('password', models.CharField(max_length=150, verbose_name='密码')),
|
|
('source', models.CharField(db_index=True, default='LOCAL', max_length=10, verbose_name='来源')),
|
|
('is_active', models.BooleanField(db_index=True, default=True)),
|
|
('create_time', models.DateTimeField(auto_now_add=True, db_index=True, null=True, verbose_name='创建时间')),
|
|
('update_time', models.DateTimeField(auto_now=True, db_index=True, null=True, verbose_name='修改时间')),
|
|
],
|
|
options={
|
|
'db_table': 'chat_user',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='Log',
|
|
fields=[
|
|
('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
|
|
('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
|
|
('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('menu', models.CharField(max_length=128, verbose_name='操作菜单')),
|
|
('operate', models.CharField(db_index=True, max_length=128, verbose_name='操作')),
|
|
('operation_object', models.JSONField(default=dict, encoder=common.encoder.encoder.SystemEncoder, verbose_name='操作对象')),
|
|
('user', models.JSONField(default=dict, verbose_name='用户信息')),
|
|
('status', models.IntegerField(db_index=True, verbose_name='状态')),
|
|
('ip_address', models.CharField(max_length=128, verbose_name='ip地址')),
|
|
('details', models.JSONField(default=dict, encoder=common.encoder.encoder.SystemEncoder, verbose_name='详情')),
|
|
('workspace_id', models.CharField(db_index=True, default='default', max_length=64, verbose_name='工作空间id')),
|
|
],
|
|
options={
|
|
'db_table': 'log',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='SystemSetting',
|
|
fields=[
|
|
('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
|
|
('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
|
|
('type', models.IntegerField(choices=[(0, '邮箱'), (1, '私钥秘钥')], default=0, primary_key=True, serialize=False, verbose_name='设置类型')),
|
|
('meta', models.JSONField(default=dict, verbose_name='配置数据')),
|
|
],
|
|
options={
|
|
'db_table': 'system_setting',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='UserGroup',
|
|
fields=[
|
|
('id', models.CharField(default=uuid_utils.compat.uuid7, editable=False, max_length=128, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('name', models.CharField(db_index=True, max_length=150, unique=True, verbose_name='名称')),
|
|
],
|
|
options={
|
|
'db_table': 'user_group',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='UserGroupRelation',
|
|
fields=[
|
|
('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.usergroup', verbose_name='用户组')),
|
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.chatuser', verbose_name='用户')),
|
|
],
|
|
options={
|
|
'db_table': 'user_group_relation',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='WorkspaceUserResourcePermission',
|
|
fields=[
|
|
('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('workspace_id', models.CharField(db_index=True, default='default', max_length=128, verbose_name='工作空间id')),
|
|
('auth_target_type', models.CharField(choices=[('KNOWLEDGE', '知识库'), ('APPLICATION', '应用'), ('TOOL', '工具'), ('MODEL', '模型')], db_index=True, default='KNOWLEDGE', max_length=128, verbose_name='授权目标')),
|
|
('target', models.UUIDField(db_index=True, verbose_name='知识库/应用id')),
|
|
('auth_type', models.CharField(choices=[('ROLE', 'Role'), ('RESOURCE_PERMISSION_GROUP', 'Resource Permission Group')], db_default='ROLE', db_index=True, default=False, verbose_name='授权类型')),
|
|
('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='权限列表')),
|
|
('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
|
|
('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
|
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='users.user', verbose_name='工作空间下的用户')),
|
|
],
|
|
options={
|
|
'db_table': 'workspace_user_resource_permission',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='ResourceChatUserGroupAuthorize',
|
|
fields=[
|
|
('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('workspace_id', models.CharField(db_index=True, default='default', max_length=64, null=True, verbose_name='工作空间id')),
|
|
('resource_id', models.UUIDField(db_index=True, verbose_name='资源id')),
|
|
('resource_type', models.CharField(choices=[('KNOWLEDGE', '知识库'), ('APPLICATION', '应用')], db_index=True, verbose_name='资源类型')),
|
|
('is_auth', models.BooleanField(verbose_name='是否授权')),
|
|
('user_group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.usergroup', verbose_name='用户组')),
|
|
],
|
|
options={
|
|
'db_table': 'resource_chat_user_group_authorize',
|
|
'unique_together': {('user_group_id', 'resource_type', 'resource_id')},
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='ResourceChatUserAuthorize',
|
|
fields=[
|
|
('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
|
|
('workspace_id', models.CharField(db_index=True, default='default', max_length=64, null=True, verbose_name='工作空间id')),
|
|
('resource_id', models.UUIDField(db_index=True, verbose_name='资源id')),
|
|
('resource_type', models.CharField(choices=[('KNOWLEDGE', '知识库'), ('APPLICATION', '应用')], db_index=True, verbose_name='资源类型')),
|
|
('is_auth', models.BooleanField(verbose_name='是否授权')),
|
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.chatuser', verbose_name='用户')),
|
|
('user_group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='system_manage.usergroup', verbose_name='用户组')),
|
|
],
|
|
options={
|
|
'db_table': 'resource_chat_user_authorize',
|
|
'unique_together': {('user_group_id', 'resource_type', 'resource_id', 'user_id')},
|
|
},
|
|
),
|
|
]
|