0001_initial.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. # Generated by Django 5.2.4 on 2025-07-14 03:50
  2. import django.contrib.postgres.search
  3. import django.db.models.deletion
  4. import knowledge.models.knowledge
  5. import mptt.fields
  6. import uuid_utils.compat
  7. from django.db import migrations, models
  8. from knowledge.models import KnowledgeFolder
  9. def insert_default_data(apps, schema_editor):
  10. # 创建一个根模块(没有父节点)
  11. KnowledgeFolder.objects.create(id='default', name='根目录', user_id='f0dd8f71-e4ee-11ee-8c84-a8a1595801ab', workspace_id='default')
  12. class Migration(migrations.Migration):
  13. initial = True
  14. dependencies = [
  15. ('models_provider', '0001_initial'),
  16. ('users', '0001_initial'),
  17. ]
  18. operations = [
  19. migrations.CreateModel(
  20. name='File',
  21. fields=[
  22. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  23. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  24. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  25. ('file_name', models.CharField(default='', max_length=256, verbose_name='文件名称')),
  26. ('file_size', models.IntegerField(default=0, verbose_name='文件大小')),
  27. ('sha256_hash', models.CharField(default='', verbose_name='文件sha256_hash标识')),
  28. ('source_type', models.CharField(choices=[('KNOWLEDGE', 'Knowledge'), ('APPLICATION', 'Application'), ('TOOL', 'Tool'), ('DOCUMENT', 'Document'), ('CHAT', 'Chat'), ('TEMPORARY_30_MINUTE', 'Temporary 30 Minute'), ('TEMPORARY_120_MINUTE', 'Temporary 120 Minute'), ('TEMPORARY_1_DAY', 'Temporary 1 Day')], db_index=True, default='TEMPORARY_120_MINUTE', verbose_name='资源类型')),
  29. ('source_id', models.CharField(db_index=True, default='TEMPORARY_120_MINUTE', verbose_name='资源id')),
  30. ('loid', models.IntegerField(verbose_name='loid')),
  31. ('meta', models.JSONField(default=dict, verbose_name='文件关联数据')),
  32. ],
  33. options={
  34. 'db_table': 'file',
  35. },
  36. ),
  37. migrations.CreateModel(
  38. name='Knowledge',
  39. fields=[
  40. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  41. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  42. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  43. ('name', models.CharField(db_index=True, max_length=150, verbose_name='知识库名称')),
  44. ('workspace_id', models.CharField(db_index=True, default='default', max_length=64, verbose_name='工作空间id')),
  45. ('desc', models.CharField(max_length=256, verbose_name='描述')),
  46. ('type', models.IntegerField(choices=[(0, '通用类型'), (1, 'web站点类型'), (2, '飞书类型'), (3, '语雀类型')], db_index=True, default=0, verbose_name='类型')),
  47. ('scope', models.CharField(choices=[('SHARED', '共享'), ('WORKSPACE', '工作空间可用')], db_index=True, default='WORKSPACE', max_length=20, verbose_name='可用范围')),
  48. ('file_size_limit', models.IntegerField(default=100, verbose_name='文件大小限制')),
  49. ('file_count_limit', models.IntegerField(default=50, verbose_name='文件数量限制')),
  50. ('meta', models.JSONField(default=dict, verbose_name='元数据')),
  51. ('embedding_model', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.SET_NULL, to='models_provider.model')),
  52. ('user', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.SET_NULL, to='users.user')),
  53. ],
  54. options={
  55. 'db_table': 'knowledge',
  56. },
  57. ),
  58. migrations.CreateModel(
  59. name='Document',
  60. fields=[
  61. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  62. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  63. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  64. ('name', models.CharField(db_index=True, max_length=150, verbose_name='文档名称')),
  65. ('char_length', models.IntegerField(verbose_name='文档字符数 冗余字段')),
  66. ('status', models.CharField(db_index=True, default=knowledge.models.knowledge.get_default_status, max_length=20, verbose_name='状态')),
  67. ('status_meta', models.JSONField(default=knowledge.models.knowledge.default_status_meta, verbose_name='状态统计数据')),
  68. ('is_active', models.BooleanField(db_index=True, default=True)),
  69. ('type', models.IntegerField(choices=[(0, '通用类型'), (1, 'web站点类型'), (2, '飞书类型'), (3, '语雀类型')], db_index=True, default=0, verbose_name='类型')),
  70. ('hit_handling_method', models.CharField(choices=[('optimization', '模型优化'), ('directly_return', '直接返回')], default='optimization', max_length=20, verbose_name='命中处理方式')),
  71. ('directly_return_similarity', models.FloatField(default=0.9, verbose_name='直接回答相似度')),
  72. ('meta', models.JSONField(default=dict, verbose_name='元数据')),
  73. ('knowledge', models.ForeignKey(on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.knowledge', verbose_name='知识库id')),
  74. ],
  75. options={
  76. 'db_table': 'document',
  77. },
  78. ),
  79. migrations.CreateModel(
  80. name='KnowledgeFolder',
  81. fields=[
  82. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  83. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  84. ('id', models.CharField(editable=False, max_length=64, primary_key=True, serialize=False, verbose_name='主键id')),
  85. ('name', models.CharField(db_index=True, max_length=64, verbose_name='文件夹名称')),
  86. ('desc', models.CharField(blank=True, max_length=200, null=True, verbose_name='描述')),
  87. ('workspace_id', models.CharField(db_index=True, default='default', max_length=64, verbose_name='工作空间id')),
  88. ('lft', models.PositiveIntegerField(editable=False)),
  89. ('rght', models.PositiveIntegerField(editable=False)),
  90. ('tree_id', models.PositiveIntegerField(db_index=True, editable=False)),
  91. ('level', models.PositiveIntegerField(editable=False)),
  92. ('parent', mptt.fields.TreeForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='children', to='knowledge.knowledgefolder')),
  93. ('user', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.SET_NULL, to='users.user')),
  94. ],
  95. options={
  96. 'db_table': 'knowledge_folder',
  97. },
  98. ),
  99. migrations.AddField(
  100. model_name='knowledge',
  101. name='folder',
  102. field=models.ForeignKey(default='default', on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.knowledgefolder', verbose_name='文件夹id'),
  103. ),
  104. migrations.CreateModel(
  105. name='Paragraph',
  106. fields=[
  107. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  108. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  109. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  110. ('content', models.CharField(max_length=102400, verbose_name='段落内容')),
  111. ('title', models.CharField(db_index=True, default='', max_length=256, verbose_name='标题')),
  112. ('status', models.CharField(db_index=True, default=knowledge.models.knowledge.get_default_status, max_length=20, verbose_name='状态')),
  113. ('status_meta', models.JSONField(default=knowledge.models.knowledge.default_status_meta, verbose_name='状态数据')),
  114. ('hit_num', models.IntegerField(default=0, verbose_name='命中次数')),
  115. ('is_active', models.BooleanField(db_index=True, default=True)),
  116. ('position', models.IntegerField(db_index=True, default=0, verbose_name='段落顺序')),
  117. ('document', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.document')),
  118. ('knowledge', models.ForeignKey(on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.knowledge')),
  119. ],
  120. options={
  121. 'db_table': 'paragraph',
  122. },
  123. ),
  124. migrations.CreateModel(
  125. name='Embedding',
  126. fields=[
  127. ('id', models.CharField(max_length=128, primary_key=True, serialize=False, verbose_name='主键id')),
  128. ('source_id', models.CharField(db_index=True, max_length=128, verbose_name='资源id')),
  129. ('source_type', models.CharField(choices=[(0, '问题'), (1, '段落'), (2, '标题')], db_index=True, default=0, max_length=5, verbose_name='资源类型')),
  130. ('is_active', models.BooleanField(default=True, max_length=1, verbose_name='是否可用')),
  131. ('embedding', knowledge.models.knowledge.VectorField(verbose_name='向量')),
  132. ('search_vector', django.contrib.postgres.search.SearchVectorField(default='', verbose_name='分词')),
  133. ('meta', models.JSONField(default=dict, verbose_name='元数据')),
  134. ('document', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.document', verbose_name='文档关联')),
  135. ('knowledge', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.knowledge', verbose_name='文档关联')),
  136. ('paragraph', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.paragraph', verbose_name='段落关联')),
  137. ],
  138. options={
  139. 'db_table': 'embedding',
  140. },
  141. ),
  142. migrations.CreateModel(
  143. name='Problem',
  144. fields=[
  145. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  146. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  147. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  148. ('content', models.CharField(db_index=True, max_length=256, verbose_name='问题内容')),
  149. ('hit_num', models.IntegerField(default=0, verbose_name='命中次数')),
  150. ('knowledge', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.knowledge')),
  151. ],
  152. options={
  153. 'db_table': 'problem',
  154. },
  155. ),
  156. migrations.CreateModel(
  157. name='ProblemParagraphMapping',
  158. fields=[
  159. ('create_time', models.DateTimeField(auto_now_add=True, db_index=True, verbose_name='创建时间')),
  160. ('update_time', models.DateTimeField(auto_now=True, db_index=True, verbose_name='修改时间')),
  161. ('id', models.UUIDField(default=uuid_utils.compat.uuid7, editable=False, primary_key=True, serialize=False, verbose_name='主键id')),
  162. ('document', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.document')),
  163. ('knowledge', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.knowledge')),
  164. ('paragraph', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.paragraph')),
  165. ('problem', models.ForeignKey(db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, to='knowledge.problem')),
  166. ],
  167. options={
  168. 'db_table': 'problem_paragraph_mapping',
  169. },
  170. ),
  171. migrations.RunPython(insert_default_data),
  172. ]