20260425_0001_init_skill_models.py 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. """init skill models
  2. Revision ID: 20260425_0001
  3. Revises:
  4. Create Date: 2026-04-25 15:10:00
  5. """
  6. from collections.abc import Sequence
  7. import sqlalchemy as sa
  8. from alembic import op
  9. revision: str = "20260425_0001"
  10. down_revision: str | None = None
  11. branch_labels: Sequence[str] | None = None
  12. depends_on: Sequence[str] | None = None
  13. def upgrade() -> None:
  14. op.create_table(
  15. "skill_definition",
  16. sa.Column("code", sa.String(length=64), nullable=False),
  17. sa.Column("name", sa.String(length=128), nullable=False),
  18. sa.Column("skill_type", sa.String(length=32), nullable=False),
  19. sa.Column("description", sa.Text(), nullable=True),
  20. sa.Column("status", sa.String(length=32), nullable=False),
  21. sa.Column("owner_user_id", sa.String(length=36), nullable=True),
  22. sa.Column("metadata_json", sa.JSON(), nullable=True),
  23. sa.Column("id", sa.String(length=36), nullable=False),
  24. sa.Column("created_by", sa.String(length=36), nullable=True),
  25. sa.Column("updated_by", sa.String(length=36), nullable=True),
  26. sa.Column("created_time", sa.DateTime(), nullable=False),
  27. sa.Column("updated_time", sa.DateTime(), nullable=False),
  28. sa.Column("deleted_time", sa.DateTime(), nullable=True),
  29. sa.Column("version", sa.Integer(), nullable=False),
  30. sa.PrimaryKeyConstraint("id"))
  31. op.create_index("ix_skill_definition_code", "skill_definition", ["code"], unique=False)
  32. op.create_index("ix_skill_definition_skill_type", "skill_definition", ["skill_type"], unique=False)
  33. op.create_index("ix_skill_definition_status", "skill_definition", ["status"], unique=False)
  34. op.create_table(
  35. "skill_version",
  36. sa.Column("skill_id", sa.String(length=36), nullable=False),
  37. sa.Column("version_no", sa.Integer(), nullable=False),
  38. sa.Column("status", sa.String(length=32), nullable=False),
  39. sa.Column("runtime_type", sa.String(length=32), nullable=False),
  40. sa.Column("entrypoint", sa.String(length=128), nullable=True),
  41. sa.Column("parameter_schema_json", sa.JSON(), nullable=False),
  42. sa.Column("output_schema_json", sa.JSON(), nullable=False),
  43. sa.Column("implementation_json", sa.JSON(), nullable=False),
  44. sa.Column("published_time", sa.DateTime(), nullable=True),
  45. sa.Column("id", sa.String(length=36), nullable=False),
  46. sa.Column("created_by", sa.String(length=36), nullable=True),
  47. sa.Column("updated_by", sa.String(length=36), nullable=True),
  48. sa.Column("created_time", sa.DateTime(), nullable=False),
  49. sa.Column("updated_time", sa.DateTime(), nullable=False),
  50. sa.Column("deleted_time", sa.DateTime(), nullable=True),
  51. sa.Column("version", sa.Integer(), nullable=False),
  52. sa.PrimaryKeyConstraint("id"))
  53. op.create_index("ix_skill_version_skill_id", "skill_version", ["skill_id"], unique=False)
  54. op.create_index("ix_skill_version_status", "skill_version", ["status"], unique=False)
  55. op.create_table(
  56. "skill_installation",
  57. sa.Column("skill_id", sa.String(length=36), nullable=False),
  58. sa.Column("skill_version_id", sa.String(length=36), nullable=False),
  59. sa.Column("install_scope", sa.String(length=32), nullable=False),
  60. sa.Column("scope_id", sa.String(length=64), nullable=False),
  61. sa.Column("status", sa.String(length=32), nullable=False),
  62. sa.Column("config_json", sa.JSON(), nullable=False),
  63. sa.Column("installed_by", sa.String(length=36), nullable=True),
  64. sa.Column("installed_time", sa.DateTime(), nullable=True),
  65. sa.Column("id", sa.String(length=36), nullable=False),
  66. sa.Column("created_by", sa.String(length=36), nullable=True),
  67. sa.Column("updated_by", sa.String(length=36), nullable=True),
  68. sa.Column("created_time", sa.DateTime(), nullable=False),
  69. sa.Column("updated_time", sa.DateTime(), nullable=False),
  70. sa.Column("deleted_time", sa.DateTime(), nullable=True),
  71. sa.Column("version", sa.Integer(), nullable=False),
  72. sa.PrimaryKeyConstraint("id"))
  73. op.create_index("ix_skill_installation_skill_id", "skill_installation", ["skill_id"], unique=False)
  74. op.create_index(
  75. "ix_skill_installation_skill_version_id",
  76. "skill_installation",
  77. ["skill_version_id"],
  78. unique=False)
  79. op.create_index(
  80. "ix_skill_installation_install_scope",
  81. "skill_installation",
  82. ["install_scope"],
  83. unique=False)
  84. op.create_index("ix_skill_installation_scope_id", "skill_installation", ["scope_id"], unique=False)
  85. op.create_index("ix_skill_installation_status", "skill_installation", ["status"], unique=False)
  86. op.create_table(
  87. "skill_run",
  88. sa.Column("skill_id", sa.String(length=36), nullable=False),
  89. sa.Column("skill_version_id", sa.String(length=36), nullable=False),
  90. sa.Column("installation_id", sa.String(length=36), nullable=True),
  91. sa.Column("status", sa.String(length=32), nullable=False),
  92. sa.Column("input_json", sa.JSON(), nullable=False),
  93. sa.Column("output_json", sa.JSON(), nullable=True),
  94. sa.Column("output_text", sa.Text(), nullable=True),
  95. sa.Column("worker_key", sa.String(length=128), nullable=True),
  96. sa.Column("started_time", sa.DateTime(), nullable=True),
  97. sa.Column("finished_time", sa.DateTime(), nullable=True),
  98. sa.Column("error_code", sa.String(length=64), nullable=True),
  99. sa.Column("error_message", sa.Text(), nullable=True),
  100. sa.Column("id", sa.String(length=36), nullable=False),
  101. sa.Column("created_by", sa.String(length=36), nullable=True),
  102. sa.Column("updated_by", sa.String(length=36), nullable=True),
  103. sa.Column("created_time", sa.DateTime(), nullable=False),
  104. sa.Column("updated_time", sa.DateTime(), nullable=False),
  105. sa.Column("deleted_time", sa.DateTime(), nullable=True),
  106. sa.Column("version", sa.Integer(), nullable=False),
  107. sa.PrimaryKeyConstraint("id"))
  108. op.create_index("ix_skill_run_skill_id", "skill_run", ["skill_id"], unique=False)
  109. op.create_index("ix_skill_run_skill_version_id", "skill_run", ["skill_version_id"], unique=False)
  110. op.create_index("ix_skill_run_installation_id", "skill_run", ["installation_id"], unique=False)
  111. op.create_index("ix_skill_run_status", "skill_run", ["status"], unique=False)
  112. def downgrade() -> None:
  113. op.drop_index("ix_skill_run_status", table_name="skill_run")
  114. op.drop_index("ix_skill_run_installation_id", table_name="skill_run")
  115. op.drop_index("ix_skill_run_skill_version_id", table_name="skill_run")
  116. op.drop_index("ix_skill_run_skill_id", table_name="skill_run")
  117. op.drop_table("skill_run")
  118. op.drop_index("ix_skill_installation_status", table_name="skill_installation")
  119. op.drop_index("ix_skill_installation_scope_id", table_name="skill_installation")
  120. op.drop_index("ix_skill_installation_install_scope", table_name="skill_installation")
  121. op.drop_index("ix_skill_installation_skill_version_id", table_name="skill_installation")
  122. op.drop_index("ix_skill_installation_skill_id", table_name="skill_installation")
  123. op.drop_table("skill_installation")
  124. op.drop_index("ix_skill_version_status", table_name="skill_version")
  125. op.drop_index("ix_skill_version_skill_id", table_name="skill_version")
  126. op.drop_table("skill_version")
  127. op.drop_index("ix_skill_definition_status", table_name="skill_definition")
  128. op.drop_index("ix_skill_definition_skill_type", table_name="skill_definition")
  129. op.drop_index("ix_skill_definition_code", table_name="skill_definition")
  130. op.drop_table("skill_definition")