@zmeel/db 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/backup-lib.d.ts +29 -0
- package/dist/backup-lib.d.ts.map +1 -0
- package/dist/backup-lib.js +553 -0
- package/dist/backup-lib.js.map +1 -0
- package/dist/backup-lib.test.d.ts +2 -0
- package/dist/backup-lib.test.d.ts.map +1 -0
- package/dist/backup-lib.test.js +146 -0
- package/dist/backup-lib.test.js.map +1 -0
- package/dist/backup.d.ts +2 -0
- package/dist/backup.d.ts.map +1 -0
- package/dist/backup.js +103 -0
- package/dist/backup.js.map +1 -0
- package/dist/check-migration-numbering.d.ts +2 -0
- package/dist/check-migration-numbering.d.ts.map +1 -0
- package/dist/check-migration-numbering.js +64 -0
- package/dist/check-migration-numbering.js.map +1 -0
- package/dist/client.d.ts +43 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +586 -0
- package/dist/client.js.map +1 -0
- package/dist/client.test.d.ts +2 -0
- package/dist/client.test.d.ts.map +1 -0
- package/dist/client.test.js +298 -0
- package/dist/client.test.js.map +1 -0
- package/dist/embedded-postgres-error.d.ts +9 -0
- package/dist/embedded-postgres-error.d.ts.map +1 -0
- package/dist/embedded-postgres-error.js +73 -0
- package/dist/embedded-postgres-error.js.map +1 -0
- package/dist/embedded-postgres-error.test.d.ts +2 -0
- package/dist/embedded-postgres-error.test.d.ts.map +1 -0
- package/dist/embedded-postgres-error.test.js +25 -0
- package/dist/embedded-postgres-error.test.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/migrate.d.ts +2 -0
- package/dist/migrate.d.ts.map +1 -0
- package/dist/migrate.js +25 -0
- package/dist/migrate.js.map +1 -0
- package/dist/migration-runtime.d.ts +7 -0
- package/dist/migration-runtime.d.ts.map +1 -0
- package/dist/migration-runtime.js +158 -0
- package/dist/migration-runtime.js.map +1 -0
- package/dist/migration-status.d.ts +2 -0
- package/dist/migration-status.d.ts.map +1 -0
- package/dist/migration-status.js +55 -0
- package/dist/migration-status.js.map +1 -0
- package/dist/migrations/0000_mature_masked_marvel.sql +208 -0
- package/dist/migrations/0001_fast_northstar.sql +87 -0
- package/dist/migrations/0002_big_zaladane.sql +1 -0
- package/dist/migrations/0003_shallow_quentin_quire.sql +5 -0
- package/dist/migrations/0004_issue_identifiers.sql +28 -0
- package/dist/migrations/0005_chief_luke_cage.sql +19 -0
- package/dist/migrations/0006_overjoyed_mister_sinister.sql +36 -0
- package/dist/migrations/0007_new_quentin_quire.sql +20 -0
- package/dist/migrations/0008_amused_zzzax.sql +1 -0
- package/dist/migrations/0009_fast_jackal.sql +36 -0
- package/dist/migrations/0010_stale_justin_hammer.sql +37 -0
- package/dist/migrations/0011_windy_corsair.sql +18 -0
- package/dist/migrations/0012_perpetual_ser_duncan.sql +2 -0
- package/dist/migrations/0013_dashing_wasp.sql +4 -0
- package/dist/migrations/0014_many_mikhail_rasputin.sql +135 -0
- package/dist/migrations/0015_project_color_archived.sql +2 -0
- package/dist/migrations/0016_agent_icon.sql +1 -0
- package/dist/migrations/0017_tiresome_gabe_jones.sql +51 -0
- package/dist/migrations/0018_flat_sleepwalker.sql +26 -0
- package/dist/migrations/0019_public_victor_mancha.sql +18 -0
- package/dist/migrations/0020_white_anita_blake.sql +1 -0
- package/dist/migrations/0021_chief_vindicator.sql +1 -0
- package/dist/migrations/0022_company_brand_color.sql +1 -0
- package/dist/migrations/0023_fair_lethal_legion.sql +3 -0
- package/dist/migrations/0024_far_beast.sql +2 -0
- package/dist/migrations/0025_nasty_salo.sql +15 -0
- package/dist/migrations/0026_lying_pete_wisdom.sql +39 -0
- package/dist/migrations/0027_tranquil_tenebrous.sql +2 -0
- package/dist/migrations/0028_harsh_goliath.sql +54 -0
- package/dist/migrations/0029_plugin_tables.sql +177 -0
- package/dist/migrations/0030_rich_magneto.sql +12 -0
- package/dist/migrations/0031_zippy_magma.sql +51 -0
- package/dist/migrations/0032_pretty_doctor_octopus.sql +102 -0
- package/dist/migrations/0033_shiny_black_tarantula.sql +2 -0
- package/dist/migrations/0034_fat_dormammu.sql +2 -0
- package/dist/migrations/0035_marvelous_satana.sql +91 -0
- package/dist/migrations/0036_cheerful_nitro.sql +9 -0
- package/dist/migrations/0037_friendly_eddie_brock.sql +29 -0
- package/dist/migrations/0038_careless_iron_monger.sql +5 -0
- package/dist/migrations/0039_fat_magneto.sql +161 -0
- package/dist/migrations/0040_eager_shotgun.sql +5 -0
- package/dist/migrations/0041_curly_maria_hill.sql +1 -0
- package/dist/migrations/0042_spotty_the_renegades.sql +26 -0
- package/dist/migrations/0043_reflective_captain_universe.sql +6 -0
- package/dist/migrations/0044_illegal_toad.sql +56 -0
- package/dist/migrations/0045_workable_shockwave.sql +17 -0
- package/dist/migrations/0046_smooth_sentinels.sql +11 -0
- package/dist/migrations/0047_overjoyed_groot.sql +102 -0
- package/dist/migrations/0048_flashy_marrow.sql +1 -0
- package/dist/migrations/meta/0000_snapshot.json +1743 -0
- package/dist/migrations/meta/0001_snapshot.json +2441 -0
- package/dist/migrations/meta/0002_snapshot.json +2454 -0
- package/dist/migrations/meta/0003_snapshot.json +2502 -0
- package/dist/migrations/meta/0005_snapshot.json +2719 -0
- package/dist/migrations/meta/0006_snapshot.json +3048 -0
- package/dist/migrations/meta/0007_snapshot.json +3258 -0
- package/dist/migrations/meta/0008_snapshot.json +3264 -0
- package/dist/migrations/meta/0009_snapshot.json +3587 -0
- package/dist/migrations/meta/0010_snapshot.json +3929 -0
- package/dist/migrations/meta/0011_snapshot.json +4068 -0
- package/dist/migrations/meta/0012_snapshot.json +4087 -0
- package/dist/migrations/meta/0013_snapshot.json +4118 -0
- package/dist/migrations/meta/0014_snapshot.json +5187 -0
- package/dist/migrations/meta/0017_snapshot.json +5215 -0
- package/dist/migrations/meta/0018_snapshot.json +5450 -0
- package/dist/migrations/meta/0019_snapshot.json +5603 -0
- package/dist/migrations/meta/0020_snapshot.json +5603 -0
- package/dist/migrations/meta/0021_snapshot.json +5609 -0
- package/dist/migrations/meta/0023_snapshot.json +5633 -0
- package/dist/migrations/meta/0024_snapshot.json +5693 -0
- package/dist/migrations/meta/0025_snapshot.json +5849 -0
- package/dist/migrations/meta/0027_snapshot.json +6205 -0
- package/dist/migrations/meta/0028_snapshot.json +6710 -0
- package/dist/migrations/meta/0029_snapshot.json +7899 -0
- package/dist/migrations/meta/0030_snapshot.json +8003 -0
- package/dist/migrations/meta/0031_snapshot.json +7242 -0
- package/dist/migrations/meta/0032_snapshot.json +7733 -0
- package/dist/migrations/meta/0033_snapshot.json +9038 -0
- package/dist/migrations/meta/0034_snapshot.json +9039 -0
- package/dist/migrations/meta/0035_snapshot.json +9959 -0
- package/dist/migrations/meta/0036_snapshot.json +10023 -0
- package/dist/migrations/meta/0037_snapshot.json +10263 -0
- package/dist/migrations/meta/0038_snapshot.json +11350 -0
- package/dist/migrations/meta/0039_snapshot.json +10308 -0
- package/dist/migrations/meta/0040_snapshot.json +10481 -0
- package/dist/migrations/meta/0041_snapshot.json +11393 -0
- package/dist/migrations/meta/0044_snapshot.json +11701 -0
- package/dist/migrations/meta/0045_snapshot.json +11857 -0
- package/dist/migrations/meta/0046_snapshot.json +11870 -0
- package/dist/migrations/meta/0047_snapshot.json +12539 -0
- package/dist/migrations/meta/0048_snapshot.json +12546 -0
- package/dist/migrations/meta/_journal.json +349 -0
- package/dist/migrations/migrations/0000_mature_masked_marvel.sql +208 -0
- package/dist/migrations/migrations/0001_fast_northstar.sql +87 -0
- package/dist/migrations/migrations/0002_big_zaladane.sql +1 -0
- package/dist/migrations/migrations/0003_shallow_quentin_quire.sql +5 -0
- package/dist/migrations/migrations/0004_issue_identifiers.sql +28 -0
- package/dist/migrations/migrations/0005_chief_luke_cage.sql +19 -0
- package/dist/migrations/migrations/0006_overjoyed_mister_sinister.sql +36 -0
- package/dist/migrations/migrations/0007_new_quentin_quire.sql +20 -0
- package/dist/migrations/migrations/0008_amused_zzzax.sql +1 -0
- package/dist/migrations/migrations/0009_fast_jackal.sql +36 -0
- package/dist/migrations/migrations/0010_stale_justin_hammer.sql +37 -0
- package/dist/migrations/migrations/0011_windy_corsair.sql +18 -0
- package/dist/migrations/migrations/0012_perpetual_ser_duncan.sql +2 -0
- package/dist/migrations/migrations/0013_dashing_wasp.sql +4 -0
- package/dist/migrations/migrations/0014_many_mikhail_rasputin.sql +135 -0
- package/dist/migrations/migrations/0015_project_color_archived.sql +2 -0
- package/dist/migrations/migrations/0016_agent_icon.sql +1 -0
- package/dist/migrations/migrations/0017_tiresome_gabe_jones.sql +51 -0
- package/dist/migrations/migrations/0018_flat_sleepwalker.sql +26 -0
- package/dist/migrations/migrations/0019_public_victor_mancha.sql +18 -0
- package/dist/migrations/migrations/0020_white_anita_blake.sql +1 -0
- package/dist/migrations/migrations/0021_chief_vindicator.sql +1 -0
- package/dist/migrations/migrations/0022_company_brand_color.sql +1 -0
- package/dist/migrations/migrations/0023_fair_lethal_legion.sql +3 -0
- package/dist/migrations/migrations/0024_far_beast.sql +2 -0
- package/dist/migrations/migrations/0025_nasty_salo.sql +15 -0
- package/dist/migrations/migrations/0026_lying_pete_wisdom.sql +39 -0
- package/dist/migrations/migrations/0027_tranquil_tenebrous.sql +2 -0
- package/dist/migrations/migrations/0028_harsh_goliath.sql +54 -0
- package/dist/migrations/migrations/0029_plugin_tables.sql +177 -0
- package/dist/migrations/migrations/0030_rich_magneto.sql +12 -0
- package/dist/migrations/migrations/0031_zippy_magma.sql +51 -0
- package/dist/migrations/migrations/0032_pretty_doctor_octopus.sql +102 -0
- package/dist/migrations/migrations/0033_shiny_black_tarantula.sql +2 -0
- package/dist/migrations/migrations/0034_fat_dormammu.sql +2 -0
- package/dist/migrations/migrations/0035_marvelous_satana.sql +91 -0
- package/dist/migrations/migrations/0036_cheerful_nitro.sql +9 -0
- package/dist/migrations/migrations/0037_friendly_eddie_brock.sql +29 -0
- package/dist/migrations/migrations/0038_careless_iron_monger.sql +5 -0
- package/dist/migrations/migrations/0039_fat_magneto.sql +161 -0
- package/dist/migrations/migrations/0040_eager_shotgun.sql +5 -0
- package/dist/migrations/migrations/0041_curly_maria_hill.sql +1 -0
- package/dist/migrations/migrations/0042_spotty_the_renegades.sql +26 -0
- package/dist/migrations/migrations/0043_reflective_captain_universe.sql +6 -0
- package/dist/migrations/migrations/0044_illegal_toad.sql +56 -0
- package/dist/migrations/migrations/0045_workable_shockwave.sql +17 -0
- package/dist/migrations/migrations/0046_smooth_sentinels.sql +11 -0
- package/dist/migrations/migrations/0047_overjoyed_groot.sql +102 -0
- package/dist/migrations/migrations/0048_flashy_marrow.sql +1 -0
- package/dist/migrations/migrations/meta/0000_snapshot.json +1743 -0
- package/dist/migrations/migrations/meta/0001_snapshot.json +2441 -0
- package/dist/migrations/migrations/meta/0002_snapshot.json +2454 -0
- package/dist/migrations/migrations/meta/0003_snapshot.json +2502 -0
- package/dist/migrations/migrations/meta/0005_snapshot.json +2719 -0
- package/dist/migrations/migrations/meta/0006_snapshot.json +3048 -0
- package/dist/migrations/migrations/meta/0007_snapshot.json +3258 -0
- package/dist/migrations/migrations/meta/0008_snapshot.json +3264 -0
- package/dist/migrations/migrations/meta/0009_snapshot.json +3587 -0
- package/dist/migrations/migrations/meta/0010_snapshot.json +3929 -0
- package/dist/migrations/migrations/meta/0011_snapshot.json +4068 -0
- package/dist/migrations/migrations/meta/0012_snapshot.json +4087 -0
- package/dist/migrations/migrations/meta/0013_snapshot.json +4118 -0
- package/dist/migrations/migrations/meta/0014_snapshot.json +5187 -0
- package/dist/migrations/migrations/meta/0017_snapshot.json +5215 -0
- package/dist/migrations/migrations/meta/0018_snapshot.json +5450 -0
- package/dist/migrations/migrations/meta/0019_snapshot.json +5603 -0
- package/dist/migrations/migrations/meta/0020_snapshot.json +5603 -0
- package/dist/migrations/migrations/meta/0021_snapshot.json +5609 -0
- package/dist/migrations/migrations/meta/0023_snapshot.json +5633 -0
- package/dist/migrations/migrations/meta/0024_snapshot.json +5693 -0
- package/dist/migrations/migrations/meta/0025_snapshot.json +5849 -0
- package/dist/migrations/migrations/meta/0027_snapshot.json +6205 -0
- package/dist/migrations/migrations/meta/0028_snapshot.json +6710 -0
- package/dist/migrations/migrations/meta/0029_snapshot.json +7899 -0
- package/dist/migrations/migrations/meta/0030_snapshot.json +8003 -0
- package/dist/migrations/migrations/meta/0031_snapshot.json +7242 -0
- package/dist/migrations/migrations/meta/0032_snapshot.json +7733 -0
- package/dist/migrations/migrations/meta/0033_snapshot.json +9038 -0
- package/dist/migrations/migrations/meta/0034_snapshot.json +9039 -0
- package/dist/migrations/migrations/meta/0035_snapshot.json +9959 -0
- package/dist/migrations/migrations/meta/0036_snapshot.json +10023 -0
- package/dist/migrations/migrations/meta/0037_snapshot.json +10263 -0
- package/dist/migrations/migrations/meta/0038_snapshot.json +11350 -0
- package/dist/migrations/migrations/meta/0039_snapshot.json +10308 -0
- package/dist/migrations/migrations/meta/0040_snapshot.json +10481 -0
- package/dist/migrations/migrations/meta/0041_snapshot.json +11393 -0
- package/dist/migrations/migrations/meta/0044_snapshot.json +11701 -0
- package/dist/migrations/migrations/meta/0045_snapshot.json +11857 -0
- package/dist/migrations/migrations/meta/0046_snapshot.json +11870 -0
- package/dist/migrations/migrations/meta/0047_snapshot.json +12539 -0
- package/dist/migrations/migrations/meta/0048_snapshot.json +12546 -0
- package/dist/migrations/migrations/meta/_journal.json +349 -0
- package/dist/runtime-config.d.ts +16 -0
- package/dist/runtime-config.d.ts.map +1 -0
- package/dist/runtime-config.js +197 -0
- package/dist/runtime-config.js.map +1 -0
- package/dist/runtime-config.test.d.ts +2 -0
- package/dist/runtime-config.test.d.ts.map +1 -0
- package/dist/runtime-config.test.js +93 -0
- package/dist/runtime-config.test.js.map +1 -0
- package/dist/schema/activity_log.d.ts +197 -0
- package/dist/schema/activity_log.d.ts.map +1 -0
- package/dist/schema/activity_log.js +22 -0
- package/dist/schema/activity_log.js.map +1 -0
- package/dist/schema/agent_api_keys.d.ts +144 -0
- package/dist/schema/agent_api_keys.d.ts.map +1 -0
- package/dist/schema/agent_api_keys.js +17 -0
- package/dist/schema/agent_api_keys.js.map +1 -0
- package/dist/schema/agent_config_revisions.d.ts +201 -0
- package/dist/schema/agent_config_revisions.d.ts.map +1 -0
- package/dist/schema/agent_config_revisions.js +20 -0
- package/dist/schema/agent_config_revisions.js.map +1 -0
- package/dist/schema/agent_runtime_state.d.ts +248 -0
- package/dist/schema/agent_runtime_state.d.ts.map +1 -0
- package/dist/schema/agent_runtime_state.js +23 -0
- package/dist/schema/agent_runtime_state.js.map +1 -0
- package/dist/schema/agent_task_sessions.d.ts +197 -0
- package/dist/schema/agent_task_sessions.d.ts.map +1 -0
- package/dist/schema/agent_task_sessions.js +22 -0
- package/dist/schema/agent_task_sessions.js.map +1 -0
- package/dist/schema/agent_wakeup_requests.d.ts +333 -0
- package/dist/schema/agent_wakeup_requests.d.ts.map +1 -0
- package/dist/schema/agent_wakeup_requests.js +29 -0
- package/dist/schema/agent_wakeup_requests.js.map +1 -0
- package/dist/schema/agents.d.ts +373 -0
- package/dist/schema/agents.d.ts.map +1 -0
- package/dist/schema/agents.js +29 -0
- package/dist/schema/agents.js.map +1 -0
- package/dist/schema/approval_comments.d.ts +144 -0
- package/dist/schema/approval_comments.d.ts.map +1 -0
- package/dist/schema/approval_comments.js +19 -0
- package/dist/schema/approval_comments.js.map +1 -0
- package/dist/schema/approvals.d.ts +214 -0
- package/dist/schema/approvals.d.ts.map +1 -0
- package/dist/schema/approvals.js +20 -0
- package/dist/schema/approvals.js.map +1 -0
- package/dist/schema/assets.d.ts +212 -0
- package/dist/schema/assets.d.ts.map +1 -0
- package/dist/schema/assets.js +22 -0
- package/dist/schema/assets.js.map +1 -0
- package/dist/schema/auth.d.ts +607 -0
- package/dist/schema/auth.d.ts.map +1 -0
- package/dist/schema/auth.js +44 -0
- package/dist/schema/auth.js.map +1 -0
- package/dist/schema/board_api_keys.d.ts +144 -0
- package/dist/schema/board_api_keys.d.ts.map +1 -0
- package/dist/schema/board_api_keys.js +16 -0
- package/dist/schema/board_api_keys.js.map +1 -0
- package/dist/schema/budget_incidents.d.ts +297 -0
- package/dist/schema/budget_incidents.d.ts.map +1 -0
- package/dist/schema/budget_incidents.js +29 -0
- package/dist/schema/budget_incidents.js.map +1 -0
- package/dist/schema/budget_policies.d.ts +263 -0
- package/dist/schema/budget_policies.d.ts.map +1 -0
- package/dist/schema/budget_policies.js +24 -0
- package/dist/schema/budget_policies.js.map +1 -0
- package/dist/schema/cli_auth_challenges.d.ts +263 -0
- package/dist/schema/cli_auth_challenges.d.ts.map +1 -0
- package/dist/schema/cli_auth_challenges.js +26 -0
- package/dist/schema/cli_auth_challenges.js.map +1 -0
- package/dist/schema/companies.d.ts +314 -0
- package/dist/schema/companies.d.ts.map +1 -0
- package/dist/schema/companies.js +28 -0
- package/dist/schema/companies.js.map +1 -0
- package/dist/schema/company_logos.d.ts +93 -0
- package/dist/schema/company_logos.d.ts.map +1 -0
- package/dist/schema/company_logos.js +14 -0
- package/dist/schema/company_logos.js.map +1 -0
- package/dist/schema/company_memberships.d.ts +144 -0
- package/dist/schema/company_memberships.d.ts.map +1 -0
- package/dist/schema/company_memberships.js +17 -0
- package/dist/schema/company_memberships.js.map +1 -0
- package/dist/schema/company_secret_versions.d.ts +163 -0
- package/dist/schema/company_secret_versions.d.ts.map +1 -0
- package/dist/schema/company_secret_versions.js +19 -0
- package/dist/schema/company_secret_versions.js.map +1 -0
- package/dist/schema/company_secrets.d.ts +195 -0
- package/dist/schema/company_secrets.d.ts.map +1 -0
- package/dist/schema/company_secrets.js +21 -0
- package/dist/schema/company_secrets.js.map +1 -0
- package/dist/schema/company_skills.d.ts +284 -0
- package/dist/schema/company_skills.d.ts.map +1 -0
- package/dist/schema/company_skills.js +24 -0
- package/dist/schema/company_skills.js.map +1 -0
- package/dist/schema/cost_events.d.ts +314 -0
- package/dist/schema/cost_events.d.ts.map +1 -0
- package/dist/schema/cost_events.js +34 -0
- package/dist/schema/cost_events.js.map +1 -0
- package/dist/schema/document_revisions.d.ts +212 -0
- package/dist/schema/document_revisions.d.ts.map +1 -0
- package/dist/schema/document_revisions.js +23 -0
- package/dist/schema/document_revisions.js.map +1 -0
- package/dist/schema/documents.d.ts +229 -0
- package/dist/schema/documents.d.ts.map +1 -0
- package/dist/schema/documents.js +22 -0
- package/dist/schema/documents.js.map +1 -0
- package/dist/schema/execution_workspaces.d.ts +418 -0
- package/dist/schema/execution_workspaces.d.ts.map +1 -0
- package/dist/schema/execution_workspaces.js +39 -0
- package/dist/schema/execution_workspaces.js.map +1 -0
- package/dist/schema/feedback_exports.d.ts +450 -0
- package/dist/schema/feedback_exports.d.ts.map +1 -0
- package/dist/schema/feedback_exports.js +41 -0
- package/dist/schema/feedback_exports.js.map +1 -0
- package/dist/schema/feedback_votes.d.ts +246 -0
- package/dist/schema/feedback_votes.d.ts.map +1 -0
- package/dist/schema/feedback_votes.js +25 -0
- package/dist/schema/feedback_votes.js.map +1 -0
- package/dist/schema/finance_events.d.ts +469 -0
- package/dist/schema/finance_events.d.ts.map +1 -0
- package/dist/schema/finance_events.js +45 -0
- package/dist/schema/finance_events.js.map +1 -0
- package/dist/schema/goals.d.ts +178 -0
- package/dist/schema/goals.d.ts.map +1 -0
- package/dist/schema/goals.js +18 -0
- package/dist/schema/goals.js.map +1 -0
- package/dist/schema/heartbeat_run_events.d.ts +214 -0
- package/dist/schema/heartbeat_run_events.d.ts.map +1 -0
- package/dist/schema/heartbeat_run_events.js +23 -0
- package/dist/schema/heartbeat_run_events.js.map +1 -0
- package/dist/schema/heartbeat_runs.d.ts +558 -0
- package/dist/schema/heartbeat_runs.d.ts.map +1 -0
- package/dist/schema/heartbeat_runs.js +43 -0
- package/dist/schema/heartbeat_runs.js.map +1 -0
- package/dist/schema/index.d.ts +61 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +61 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/instance_settings.d.ts +114 -0
- package/dist/schema/instance_settings.d.ts.map +1 -0
- package/dist/schema/instance_settings.js +12 -0
- package/dist/schema/instance_settings.js.map +1 -0
- package/dist/schema/instance_user_roles.d.ts +93 -0
- package/dist/schema/instance_user_roles.d.ts.map +1 -0
- package/dist/schema/instance_user_roles.js +12 -0
- package/dist/schema/instance_user_roles.js.map +1 -0
- package/dist/schema/invites.d.ts +214 -0
- package/dist/schema/invites.d.ts.map +1 -0
- package/dist/schema/invites.js +20 -0
- package/dist/schema/invites.js.map +1 -0
- package/dist/schema/issue_approvals.d.ts +110 -0
- package/dist/schema/issue_approvals.d.ts.map +1 -0
- package/dist/schema/issue_approvals.js +19 -0
- package/dist/schema/issue_approvals.js.map +1 -0
- package/dist/schema/issue_attachments.d.ts +127 -0
- package/dist/schema/issue_attachments.d.ts.map +1 -0
- package/dist/schema/issue_attachments.js +19 -0
- package/dist/schema/issue_attachments.js.map +1 -0
- package/dist/schema/issue_comments.d.ts +161 -0
- package/dist/schema/issue_comments.d.ts.map +1 -0
- package/dist/schema/issue_comments.js +22 -0
- package/dist/schema/issue_comments.js.map +1 -0
- package/dist/schema/issue_documents.d.ts +127 -0
- package/dist/schema/issue_documents.d.ts.map +1 -0
- package/dist/schema/issue_documents.js +18 -0
- package/dist/schema/issue_documents.js.map +1 -0
- package/dist/schema/issue_inbox_archives.d.ts +127 -0
- package/dist/schema/issue_inbox_archives.d.ts.map +1 -0
- package/dist/schema/issue_inbox_archives.js +17 -0
- package/dist/schema/issue_inbox_archives.js.map +1 -0
- package/dist/schema/issue_labels.d.ts +76 -0
- package/dist/schema/issue_labels.d.ts.map +1 -0
- package/dist/schema/issue_labels.js +16 -0
- package/dist/schema/issue_labels.js.map +1 -0
- package/dist/schema/issue_read_states.d.ts +127 -0
- package/dist/schema/issue_read_states.d.ts.map +1 -0
- package/dist/schema/issue_read_states.js +17 -0
- package/dist/schema/issue_read_states.js.map +1 -0
- package/dist/schema/issue_work_products.d.ts +350 -0
- package/dist/schema/issue_work_products.d.ts.map +1 -0
- package/dist/schema/issue_work_products.js +37 -0
- package/dist/schema/issue_work_products.js.map +1 -0
- package/dist/schema/issues.d.ts +607 -0
- package/dist/schema/issues.d.ts.map +1 -0
- package/dist/schema/issues.js +65 -0
- package/dist/schema/issues.js.map +1 -0
- package/dist/schema/join_requests.d.ts +384 -0
- package/dist/schema/join_requests.d.ts.map +1 -0
- package/dist/schema/join_requests.js +32 -0
- package/dist/schema/join_requests.js.map +1 -0
- package/dist/schema/labels.d.ts +110 -0
- package/dist/schema/labels.d.ts.map +1 -0
- package/dist/schema/labels.js +14 -0
- package/dist/schema/labels.js.map +1 -0
- package/dist/schema/plugin_company_settings.d.ts +158 -0
- package/dist/schema/plugin_company_settings.d.ts.map +1 -0
- package/dist/schema/plugin_company_settings.js +34 -0
- package/dist/schema/plugin_company_settings.js.map +1 -0
- package/dist/schema/plugin_config.d.ts +123 -0
- package/dist/schema/plugin_config.d.ts.map +1 -0
- package/dist/schema/plugin_config.js +26 -0
- package/dist/schema/plugin_config.js.map +1 -0
- package/dist/schema/plugin_entities.d.ts +213 -0
- package/dist/schema/plugin_entities.d.ts.map +1 -0
- package/dist/schema/plugin_entities.js +37 -0
- package/dist/schema/plugin_entities.js.map +1 -0
- package/dist/schema/plugin_jobs.d.ts +392 -0
- package/dist/schema/plugin_jobs.d.ts.map +1 -0
- package/dist/schema/plugin_jobs.js +83 -0
- package/dist/schema/plugin_jobs.js.map +1 -0
- package/dist/schema/plugin_logs.d.ts +125 -0
- package/dist/schema/plugin_logs.d.ts.map +1 -0
- package/dist/schema/plugin_logs.js +29 -0
- package/dist/schema/plugin_logs.js.map +1 -0
- package/dist/schema/plugin_state.d.ts +169 -0
- package/dist/schema/plugin_state.d.ts.map +1 -0
- package/dist/schema/plugin_state.js +68 -0
- package/dist/schema/plugin_state.js.map +1 -0
- package/dist/schema/plugin_webhooks.d.ts +239 -0
- package/dist/schema/plugin_webhooks.d.ts.map +1 -0
- package/dist/schema/plugin_webhooks.js +52 -0
- package/dist/schema/plugin_webhooks.js.map +1 -0
- package/dist/schema/plugins.d.ts +246 -0
- package/dist/schema/plugins.d.ts.map +1 -0
- package/dist/schema/plugins.js +31 -0
- package/dist/schema/plugins.js.map +1 -0
- package/dist/schema/principal_permission_grants.d.ts +163 -0
- package/dist/schema/principal_permission_grants.d.ts.map +1 -0
- package/dist/schema/principal_permission_grants.js +17 -0
- package/dist/schema/principal_permission_grants.js.map +1 -0
- package/dist/schema/project_goals.d.ts +93 -0
- package/dist/schema/project_goals.d.ts.map +1 -0
- package/dist/schema/project_goals.js +17 -0
- package/dist/schema/project_goals.js.map +1 -0
- package/dist/schema/project_workspaces.d.ts +333 -0
- package/dist/schema/project_workspaces.d.ts.map +1 -0
- package/dist/schema/project_workspaces.js +32 -0
- package/dist/schema/project_workspaces.js.map +1 -0
- package/dist/schema/projects.d.ts +265 -0
- package/dist/schema/projects.d.ts.map +1 -0
- package/dist/schema/projects.js +24 -0
- package/dist/schema/projects.js.map +1 -0
- package/dist/schema/routines.d.ts +1013 -0
- package/dist/schema/routines.d.ts.map +1 -0
- package/dist/schema/routines.js +87 -0
- package/dist/schema/routines.js.map +1 -0
- package/dist/schema/workspace_operations.d.ts +367 -0
- package/dist/schema/workspace_operations.d.ts.map +1 -0
- package/dist/schema/workspace_operations.js +35 -0
- package/dist/schema/workspace_operations.js.map +1 -0
- package/dist/schema/workspace_runtime_services.d.ts +469 -0
- package/dist/schema/workspace_runtime_services.d.ts.map +1 -0
- package/dist/schema/workspace_runtime_services.js +44 -0
- package/dist/schema/workspace_runtime_services.js.map +1 -0
- package/dist/seed.d.ts +2 -0
- package/dist/seed.d.ts.map +1 -0
- package/dist/seed.js +91 -0
- package/dist/seed.js.map +1 -0
- package/dist/test-embedded-postgres.d.ts +11 -0
- package/dist/test-embedded-postgres.d.ts.map +1 -0
- package/dist/test-embedded-postgres.js +111 -0
- package/dist/test-embedded-postgres.js.map +1 -0
- package/package.json +54 -0
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { existsSync, readFileSync, rmSync } from "node:fs";
|
|
2
|
+
import { createServer } from "node:net";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { ensurePostgresDatabase, getPostgresDataDirectory } from "./client.js";
|
|
5
|
+
import { createEmbeddedPostgresLogBuffer, formatEmbeddedPostgresError } from "./embedded-postgres-error.js";
|
|
6
|
+
import { resolveDatabaseTarget } from "./runtime-config.js";
|
|
7
|
+
function readRunningPostmasterPid(postmasterPidFile) {
|
|
8
|
+
if (!existsSync(postmasterPidFile))
|
|
9
|
+
return null;
|
|
10
|
+
try {
|
|
11
|
+
const pid = Number(readFileSync(postmasterPidFile, "utf8").split("\n")[0]?.trim());
|
|
12
|
+
if (!Number.isInteger(pid) || pid <= 0)
|
|
13
|
+
return null;
|
|
14
|
+
process.kill(pid, 0);
|
|
15
|
+
return pid;
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function readPidFilePort(postmasterPidFile) {
|
|
22
|
+
if (!existsSync(postmasterPidFile))
|
|
23
|
+
return null;
|
|
24
|
+
try {
|
|
25
|
+
const lines = readFileSync(postmasterPidFile, "utf8").split("\n");
|
|
26
|
+
const port = Number(lines[3]?.trim());
|
|
27
|
+
return Number.isInteger(port) && port > 0 ? port : null;
|
|
28
|
+
}
|
|
29
|
+
catch {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async function isPortInUse(port) {
|
|
34
|
+
return await new Promise((resolve) => {
|
|
35
|
+
const server = createServer();
|
|
36
|
+
server.unref();
|
|
37
|
+
server.once("error", (error) => {
|
|
38
|
+
resolve(error.code === "EADDRINUSE");
|
|
39
|
+
});
|
|
40
|
+
server.listen(port, "127.0.0.1", () => {
|
|
41
|
+
server.close();
|
|
42
|
+
resolve(false);
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
async function findAvailablePort(startPort) {
|
|
47
|
+
const maxLookahead = 20;
|
|
48
|
+
let port = startPort;
|
|
49
|
+
for (let i = 0; i < maxLookahead; i += 1, port += 1) {
|
|
50
|
+
if (!(await isPortInUse(port)))
|
|
51
|
+
return port;
|
|
52
|
+
}
|
|
53
|
+
throw new Error(`Embedded PostgreSQL could not find a free port from ${startPort} to ${startPort + maxLookahead - 1}`);
|
|
54
|
+
}
|
|
55
|
+
async function loadEmbeddedPostgresCtor() {
|
|
56
|
+
try {
|
|
57
|
+
const moduleName = "embedded-postgres";
|
|
58
|
+
const mod = await import(moduleName);
|
|
59
|
+
return mod.default;
|
|
60
|
+
}
|
|
61
|
+
catch {
|
|
62
|
+
throw new Error("Embedded PostgreSQL support requires dependency `embedded-postgres`. Reinstall dependencies and try again.");
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
async function ensureEmbeddedPostgresConnection(dataDir, preferredPort) {
|
|
66
|
+
const EmbeddedPostgres = await loadEmbeddedPostgresCtor();
|
|
67
|
+
const selectedPort = await findAvailablePort(preferredPort);
|
|
68
|
+
const postmasterPidFile = path.resolve(dataDir, "postmaster.pid");
|
|
69
|
+
const pgVersionFile = path.resolve(dataDir, "PG_VERSION");
|
|
70
|
+
const runningPid = readRunningPostmasterPid(postmasterPidFile);
|
|
71
|
+
const runningPort = readPidFilePort(postmasterPidFile);
|
|
72
|
+
const preferredAdminConnectionString = `postgres://zmeel:zmeel@127.0.0.1:${preferredPort}/postgres`;
|
|
73
|
+
const logBuffer = createEmbeddedPostgresLogBuffer();
|
|
74
|
+
if (!runningPid && existsSync(pgVersionFile)) {
|
|
75
|
+
try {
|
|
76
|
+
const actualDataDir = await getPostgresDataDirectory(preferredAdminConnectionString);
|
|
77
|
+
const matchesDataDir = typeof actualDataDir === "string" &&
|
|
78
|
+
path.resolve(actualDataDir) === path.resolve(dataDir);
|
|
79
|
+
if (!matchesDataDir) {
|
|
80
|
+
throw new Error("reachable postgres does not use the expected embedded data directory");
|
|
81
|
+
}
|
|
82
|
+
await ensurePostgresDatabase(preferredAdminConnectionString, "zmeel");
|
|
83
|
+
process.emitWarning(`Adopting an existing PostgreSQL instance on port ${preferredPort} for embedded data dir ${dataDir} because postmaster.pid is missing.`);
|
|
84
|
+
return {
|
|
85
|
+
connectionString: `postgres://zmeel:zmeel@127.0.0.1:${preferredPort}/zmeel`,
|
|
86
|
+
source: `embedded-postgres@${preferredPort}`,
|
|
87
|
+
stop: async () => { },
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
catch {
|
|
91
|
+
// Fall through and attempt to start the configured embedded cluster.
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
if (runningPid) {
|
|
95
|
+
const port = runningPort ?? preferredPort;
|
|
96
|
+
const adminConnectionString = `postgres://zmeel:zmeel@127.0.0.1:${port}/postgres`;
|
|
97
|
+
await ensurePostgresDatabase(adminConnectionString, "zmeel");
|
|
98
|
+
return {
|
|
99
|
+
connectionString: `postgres://zmeel:zmeel@127.0.0.1:${port}/zmeel`,
|
|
100
|
+
source: `embedded-postgres@${port}`,
|
|
101
|
+
stop: async () => { },
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
const instance = new EmbeddedPostgres({
|
|
105
|
+
databaseDir: dataDir,
|
|
106
|
+
user: "zmeel",
|
|
107
|
+
password: "zmeel",
|
|
108
|
+
port: selectedPort,
|
|
109
|
+
persistent: true,
|
|
110
|
+
initdbFlags: ["--encoding=UTF8", "--locale=C", "--lc-messages=C"],
|
|
111
|
+
onLog: logBuffer.append,
|
|
112
|
+
onError: logBuffer.append,
|
|
113
|
+
});
|
|
114
|
+
if (!existsSync(path.resolve(dataDir, "PG_VERSION"))) {
|
|
115
|
+
try {
|
|
116
|
+
await instance.initialise();
|
|
117
|
+
}
|
|
118
|
+
catch (error) {
|
|
119
|
+
throw formatEmbeddedPostgresError(error, {
|
|
120
|
+
fallbackMessage: `Failed to initialize embedded PostgreSQL cluster in ${dataDir} on port ${selectedPort}`,
|
|
121
|
+
recentLogs: logBuffer.getRecentLogs(),
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
if (existsSync(postmasterPidFile)) {
|
|
126
|
+
rmSync(postmasterPidFile, { force: true });
|
|
127
|
+
}
|
|
128
|
+
try {
|
|
129
|
+
await instance.start();
|
|
130
|
+
}
|
|
131
|
+
catch (error) {
|
|
132
|
+
throw formatEmbeddedPostgresError(error, {
|
|
133
|
+
fallbackMessage: `Failed to start embedded PostgreSQL on port ${selectedPort}`,
|
|
134
|
+
recentLogs: logBuffer.getRecentLogs(),
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
const adminConnectionString = `postgres://zmeel:zmeel@127.0.0.1:${selectedPort}/postgres`;
|
|
138
|
+
await ensurePostgresDatabase(adminConnectionString, "zmeel");
|
|
139
|
+
return {
|
|
140
|
+
connectionString: `postgres://zmeel:zmeel@127.0.0.1:${selectedPort}/zmeel`,
|
|
141
|
+
source: `embedded-postgres@${selectedPort}`,
|
|
142
|
+
stop: async () => {
|
|
143
|
+
await instance.stop();
|
|
144
|
+
},
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
export async function resolveMigrationConnection() {
|
|
148
|
+
const target = resolveDatabaseTarget();
|
|
149
|
+
if (target.mode === "postgres") {
|
|
150
|
+
return {
|
|
151
|
+
connectionString: target.connectionString,
|
|
152
|
+
source: target.source,
|
|
153
|
+
stop: async () => { },
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
return ensureEmbeddedPostgresConnection(target.dataDir, target.port);
|
|
157
|
+
}
|
|
158
|
+
//# sourceMappingURL=migration-runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-runtime.js","sourceRoot":"","sources":["../src/migration-runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-status.d.ts","sourceRoot":"","sources":["../src/migration-status.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { inspectMigrations } from "./client.js";
|
|
2
|
+
import { resolveMigrationConnection } from "./migration-runtime.js";
|
|
3
|
+
const jsonMode = process.argv.includes("--json");
|
|
4
|
+
function toError(error, context = "Migration status check failed") {
|
|
5
|
+
if (error instanceof Error)
|
|
6
|
+
return error;
|
|
7
|
+
if (error === undefined)
|
|
8
|
+
return new Error(context);
|
|
9
|
+
if (typeof error === "string")
|
|
10
|
+
return new Error(`${context}: ${error}`);
|
|
11
|
+
try {
|
|
12
|
+
return new Error(`${context}: ${JSON.stringify(error)}`);
|
|
13
|
+
}
|
|
14
|
+
catch {
|
|
15
|
+
return new Error(`${context}: ${String(error)}`);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
async function main() {
|
|
19
|
+
const connection = await resolveMigrationConnection();
|
|
20
|
+
try {
|
|
21
|
+
const state = await inspectMigrations(connection.connectionString);
|
|
22
|
+
const payload = state.status === "upToDate"
|
|
23
|
+
? {
|
|
24
|
+
source: connection.source,
|
|
25
|
+
status: "upToDate",
|
|
26
|
+
tableCount: state.tableCount,
|
|
27
|
+
pendingMigrations: [],
|
|
28
|
+
}
|
|
29
|
+
: {
|
|
30
|
+
source: connection.source,
|
|
31
|
+
status: "needsMigrations",
|
|
32
|
+
tableCount: state.tableCount,
|
|
33
|
+
pendingMigrations: state.pendingMigrations,
|
|
34
|
+
reason: state.reason,
|
|
35
|
+
};
|
|
36
|
+
if (jsonMode) {
|
|
37
|
+
console.log(JSON.stringify(payload));
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (payload.status === "upToDate") {
|
|
41
|
+
console.log(`Database is up to date via ${payload.source}`);
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
console.log(`Pending migrations via ${payload.source}: ${payload.pendingMigrations.join(", ")}`);
|
|
45
|
+
}
|
|
46
|
+
finally {
|
|
47
|
+
await connection.stop();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
main().catch((error) => {
|
|
51
|
+
const err = toError(error, "Migration status check failed");
|
|
52
|
+
process.stderr.write(`${err.stack ?? err.message}\n`);
|
|
53
|
+
process.exit(1);
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=migration-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-status.js","sourceRoot":"","sources":["../src/migration-status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AAEpE,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAEjD,SAAS,OAAO,CAAC,KAAc,EAAE,OAAO,GAAG,+BAA+B;IACxE,IAAI,KAAK,YAAY,KAAK;QAAE,OAAO,KAAK,CAAC;IACzC,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;IACnD,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,IAAI,KAAK,CAAC,GAAG,OAAO,KAAK,KAAK,EAAE,CAAC,CAAC;IAExE,IAAI,CAAC;QACH,OAAO,IAAI,KAAK,CAAC,GAAG,OAAO,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAC3D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,KAAK,CAAC,GAAG,OAAO,KAAK,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACnD,CAAC;AACH,CAAC;AAED,KAAK,UAAU,IAAI;IACjB,MAAM,UAAU,GAAG,MAAM,0BAA0B,EAAE,CAAC;IAEtD,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,iBAAiB,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;QACnE,MAAM,OAAO,GACX,KAAK,CAAC,MAAM,KAAK,UAAU;YACzB,CAAC,CAAC;gBACE,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,MAAM,EAAE,UAAmB;gBAC3B,UAAU,EAAE,KAAK,CAAC,UAAU;gBAC5B,iBAAiB,EAAE,EAAc;aAClC;YACH,CAAC,CAAC;gBACE,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,MAAM,EAAE,iBAA0B;gBAClC,UAAU,EAAE,KAAK,CAAC,UAAU;gBAC5B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;gBAC1C,MAAM,EAAE,KAAK,CAAC,MAAM;aACrB,CAAC;QAER,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;YACrC,OAAO;QACT,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,UAAU,EAAE,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,8BAA8B,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;YAC5D,OAAO;QACT,CAAC;QAED,OAAO,CAAC,GAAG,CACT,0BAA0B,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACpF,CAAC;IACJ,CAAC;YAAS,CAAC;QACT,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;AACH,CAAC;AAED,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;IACrB,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,+BAA+B,CAAC,CAAC;IAC5D,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC,OAAO,IAAI,CAAC,CAAC;IACtD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
CREATE TABLE "activity_log" (
|
|
2
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
3
|
+
"company_id" uuid NOT NULL,
|
|
4
|
+
"actor_type" text DEFAULT 'system' NOT NULL,
|
|
5
|
+
"actor_id" text NOT NULL,
|
|
6
|
+
"action" text NOT NULL,
|
|
7
|
+
"entity_type" text NOT NULL,
|
|
8
|
+
"entity_id" text NOT NULL,
|
|
9
|
+
"agent_id" uuid,
|
|
10
|
+
"details" jsonb,
|
|
11
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
12
|
+
);
|
|
13
|
+
--> statement-breakpoint
|
|
14
|
+
CREATE TABLE "agent_api_keys" (
|
|
15
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
16
|
+
"agent_id" uuid NOT NULL,
|
|
17
|
+
"company_id" uuid NOT NULL,
|
|
18
|
+
"name" text NOT NULL,
|
|
19
|
+
"key_hash" text NOT NULL,
|
|
20
|
+
"last_used_at" timestamp with time zone,
|
|
21
|
+
"revoked_at" timestamp with time zone,
|
|
22
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
23
|
+
);
|
|
24
|
+
--> statement-breakpoint
|
|
25
|
+
CREATE TABLE "agents" (
|
|
26
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
27
|
+
"company_id" uuid NOT NULL,
|
|
28
|
+
"name" text NOT NULL,
|
|
29
|
+
"role" text DEFAULT 'general' NOT NULL,
|
|
30
|
+
"title" text,
|
|
31
|
+
"status" text DEFAULT 'idle' NOT NULL,
|
|
32
|
+
"reports_to" uuid,
|
|
33
|
+
"capabilities" text,
|
|
34
|
+
"adapter_type" text DEFAULT 'process' NOT NULL,
|
|
35
|
+
"adapter_config" jsonb DEFAULT '{}'::jsonb NOT NULL,
|
|
36
|
+
"context_mode" text DEFAULT 'thin' NOT NULL,
|
|
37
|
+
"budget_monthly_cents" integer DEFAULT 0 NOT NULL,
|
|
38
|
+
"spent_monthly_cents" integer DEFAULT 0 NOT NULL,
|
|
39
|
+
"last_heartbeat_at" timestamp with time zone,
|
|
40
|
+
"metadata" jsonb,
|
|
41
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
42
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
43
|
+
);
|
|
44
|
+
--> statement-breakpoint
|
|
45
|
+
CREATE TABLE "approvals" (
|
|
46
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
47
|
+
"company_id" uuid NOT NULL,
|
|
48
|
+
"type" text NOT NULL,
|
|
49
|
+
"requested_by_agent_id" uuid,
|
|
50
|
+
"requested_by_user_id" text,
|
|
51
|
+
"status" text DEFAULT 'pending' NOT NULL,
|
|
52
|
+
"payload" jsonb NOT NULL,
|
|
53
|
+
"decision_note" text,
|
|
54
|
+
"decided_by_user_id" text,
|
|
55
|
+
"decided_at" timestamp with time zone,
|
|
56
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
57
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
58
|
+
);
|
|
59
|
+
--> statement-breakpoint
|
|
60
|
+
CREATE TABLE "companies" (
|
|
61
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
62
|
+
"name" text NOT NULL,
|
|
63
|
+
"description" text,
|
|
64
|
+
"status" text DEFAULT 'active' NOT NULL,
|
|
65
|
+
"budget_monthly_cents" integer DEFAULT 0 NOT NULL,
|
|
66
|
+
"spent_monthly_cents" integer DEFAULT 0 NOT NULL,
|
|
67
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
68
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
69
|
+
);
|
|
70
|
+
--> statement-breakpoint
|
|
71
|
+
CREATE TABLE "cost_events" (
|
|
72
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
73
|
+
"company_id" uuid NOT NULL,
|
|
74
|
+
"agent_id" uuid NOT NULL,
|
|
75
|
+
"issue_id" uuid,
|
|
76
|
+
"project_id" uuid,
|
|
77
|
+
"goal_id" uuid,
|
|
78
|
+
"billing_code" text,
|
|
79
|
+
"provider" text NOT NULL,
|
|
80
|
+
"model" text NOT NULL,
|
|
81
|
+
"input_tokens" integer DEFAULT 0 NOT NULL,
|
|
82
|
+
"output_tokens" integer DEFAULT 0 NOT NULL,
|
|
83
|
+
"cost_cents" integer NOT NULL,
|
|
84
|
+
"occurred_at" timestamp with time zone NOT NULL,
|
|
85
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
86
|
+
);
|
|
87
|
+
--> statement-breakpoint
|
|
88
|
+
CREATE TABLE "goals" (
|
|
89
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
90
|
+
"company_id" uuid NOT NULL,
|
|
91
|
+
"title" text NOT NULL,
|
|
92
|
+
"description" text,
|
|
93
|
+
"level" text DEFAULT 'task' NOT NULL,
|
|
94
|
+
"status" text DEFAULT 'planned' NOT NULL,
|
|
95
|
+
"parent_id" uuid,
|
|
96
|
+
"owner_agent_id" uuid,
|
|
97
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
98
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
99
|
+
);
|
|
100
|
+
--> statement-breakpoint
|
|
101
|
+
CREATE TABLE "heartbeat_runs" (
|
|
102
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
103
|
+
"company_id" uuid NOT NULL,
|
|
104
|
+
"agent_id" uuid NOT NULL,
|
|
105
|
+
"invocation_source" text DEFAULT 'manual' NOT NULL,
|
|
106
|
+
"status" text DEFAULT 'queued' NOT NULL,
|
|
107
|
+
"started_at" timestamp with time zone,
|
|
108
|
+
"finished_at" timestamp with time zone,
|
|
109
|
+
"error" text,
|
|
110
|
+
"external_run_id" text,
|
|
111
|
+
"context_snapshot" jsonb,
|
|
112
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
113
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
114
|
+
);
|
|
115
|
+
--> statement-breakpoint
|
|
116
|
+
CREATE TABLE "issue_comments" (
|
|
117
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
118
|
+
"company_id" uuid NOT NULL,
|
|
119
|
+
"issue_id" uuid NOT NULL,
|
|
120
|
+
"author_agent_id" uuid,
|
|
121
|
+
"author_user_id" text,
|
|
122
|
+
"body" text NOT NULL,
|
|
123
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
124
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
125
|
+
);
|
|
126
|
+
--> statement-breakpoint
|
|
127
|
+
CREATE TABLE "issues" (
|
|
128
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
129
|
+
"company_id" uuid NOT NULL,
|
|
130
|
+
"project_id" uuid,
|
|
131
|
+
"goal_id" uuid,
|
|
132
|
+
"parent_id" uuid,
|
|
133
|
+
"title" text NOT NULL,
|
|
134
|
+
"description" text,
|
|
135
|
+
"status" text DEFAULT 'backlog' NOT NULL,
|
|
136
|
+
"priority" text DEFAULT 'medium' NOT NULL,
|
|
137
|
+
"assignee_agent_id" uuid,
|
|
138
|
+
"created_by_agent_id" uuid,
|
|
139
|
+
"created_by_user_id" text,
|
|
140
|
+
"request_depth" integer DEFAULT 0 NOT NULL,
|
|
141
|
+
"billing_code" text,
|
|
142
|
+
"started_at" timestamp with time zone,
|
|
143
|
+
"completed_at" timestamp with time zone,
|
|
144
|
+
"cancelled_at" timestamp with time zone,
|
|
145
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
146
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
147
|
+
);
|
|
148
|
+
--> statement-breakpoint
|
|
149
|
+
CREATE TABLE "projects" (
|
|
150
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
151
|
+
"company_id" uuid NOT NULL,
|
|
152
|
+
"goal_id" uuid,
|
|
153
|
+
"name" text NOT NULL,
|
|
154
|
+
"description" text,
|
|
155
|
+
"status" text DEFAULT 'backlog' NOT NULL,
|
|
156
|
+
"lead_agent_id" uuid,
|
|
157
|
+
"target_date" date,
|
|
158
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
159
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
160
|
+
);
|
|
161
|
+
--> statement-breakpoint
|
|
162
|
+
ALTER TABLE "activity_log" ADD CONSTRAINT "activity_log_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
163
|
+
ALTER TABLE "activity_log" ADD CONSTRAINT "activity_log_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
164
|
+
ALTER TABLE "agent_api_keys" ADD CONSTRAINT "agent_api_keys_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
165
|
+
ALTER TABLE "agent_api_keys" ADD CONSTRAINT "agent_api_keys_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
166
|
+
ALTER TABLE "agents" ADD CONSTRAINT "agents_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
167
|
+
ALTER TABLE "agents" ADD CONSTRAINT "agents_reports_to_agents_id_fk" FOREIGN KEY ("reports_to") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
168
|
+
ALTER TABLE "approvals" ADD CONSTRAINT "approvals_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
169
|
+
ALTER TABLE "approvals" ADD CONSTRAINT "approvals_requested_by_agent_id_agents_id_fk" FOREIGN KEY ("requested_by_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
170
|
+
ALTER TABLE "cost_events" ADD CONSTRAINT "cost_events_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
171
|
+
ALTER TABLE "cost_events" ADD CONSTRAINT "cost_events_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
172
|
+
ALTER TABLE "cost_events" ADD CONSTRAINT "cost_events_issue_id_issues_id_fk" FOREIGN KEY ("issue_id") REFERENCES "public"."issues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
173
|
+
ALTER TABLE "cost_events" ADD CONSTRAINT "cost_events_project_id_projects_id_fk" FOREIGN KEY ("project_id") REFERENCES "public"."projects"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
174
|
+
ALTER TABLE "cost_events" ADD CONSTRAINT "cost_events_goal_id_goals_id_fk" FOREIGN KEY ("goal_id") REFERENCES "public"."goals"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
175
|
+
ALTER TABLE "goals" ADD CONSTRAINT "goals_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
176
|
+
ALTER TABLE "goals" ADD CONSTRAINT "goals_parent_id_goals_id_fk" FOREIGN KEY ("parent_id") REFERENCES "public"."goals"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
177
|
+
ALTER TABLE "goals" ADD CONSTRAINT "goals_owner_agent_id_agents_id_fk" FOREIGN KEY ("owner_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
178
|
+
ALTER TABLE "heartbeat_runs" ADD CONSTRAINT "heartbeat_runs_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
179
|
+
ALTER TABLE "heartbeat_runs" ADD CONSTRAINT "heartbeat_runs_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
180
|
+
ALTER TABLE "issue_comments" ADD CONSTRAINT "issue_comments_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
181
|
+
ALTER TABLE "issue_comments" ADD CONSTRAINT "issue_comments_issue_id_issues_id_fk" FOREIGN KEY ("issue_id") REFERENCES "public"."issues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
182
|
+
ALTER TABLE "issue_comments" ADD CONSTRAINT "issue_comments_author_agent_id_agents_id_fk" FOREIGN KEY ("author_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
183
|
+
ALTER TABLE "issues" ADD CONSTRAINT "issues_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
184
|
+
ALTER TABLE "issues" ADD CONSTRAINT "issues_project_id_projects_id_fk" FOREIGN KEY ("project_id") REFERENCES "public"."projects"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
185
|
+
ALTER TABLE "issues" ADD CONSTRAINT "issues_goal_id_goals_id_fk" FOREIGN KEY ("goal_id") REFERENCES "public"."goals"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
186
|
+
ALTER TABLE "issues" ADD CONSTRAINT "issues_parent_id_issues_id_fk" FOREIGN KEY ("parent_id") REFERENCES "public"."issues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
187
|
+
ALTER TABLE "issues" ADD CONSTRAINT "issues_assignee_agent_id_agents_id_fk" FOREIGN KEY ("assignee_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
188
|
+
ALTER TABLE "issues" ADD CONSTRAINT "issues_created_by_agent_id_agents_id_fk" FOREIGN KEY ("created_by_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
189
|
+
ALTER TABLE "projects" ADD CONSTRAINT "projects_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
190
|
+
ALTER TABLE "projects" ADD CONSTRAINT "projects_goal_id_goals_id_fk" FOREIGN KEY ("goal_id") REFERENCES "public"."goals"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
191
|
+
ALTER TABLE "projects" ADD CONSTRAINT "projects_lead_agent_id_agents_id_fk" FOREIGN KEY ("lead_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
192
|
+
CREATE INDEX "activity_log_company_created_idx" ON "activity_log" USING btree ("company_id","created_at");--> statement-breakpoint
|
|
193
|
+
CREATE INDEX "agent_api_keys_key_hash_idx" ON "agent_api_keys" USING btree ("key_hash");--> statement-breakpoint
|
|
194
|
+
CREATE INDEX "agent_api_keys_company_agent_idx" ON "agent_api_keys" USING btree ("company_id","agent_id");--> statement-breakpoint
|
|
195
|
+
CREATE INDEX "agents_company_status_idx" ON "agents" USING btree ("company_id","status");--> statement-breakpoint
|
|
196
|
+
CREATE INDEX "agents_company_reports_to_idx" ON "agents" USING btree ("company_id","reports_to");--> statement-breakpoint
|
|
197
|
+
CREATE INDEX "approvals_company_status_type_idx" ON "approvals" USING btree ("company_id","status","type");--> statement-breakpoint
|
|
198
|
+
CREATE INDEX "cost_events_company_occurred_idx" ON "cost_events" USING btree ("company_id","occurred_at");--> statement-breakpoint
|
|
199
|
+
CREATE INDEX "cost_events_company_agent_occurred_idx" ON "cost_events" USING btree ("company_id","agent_id","occurred_at");--> statement-breakpoint
|
|
200
|
+
CREATE INDEX "goals_company_idx" ON "goals" USING btree ("company_id");--> statement-breakpoint
|
|
201
|
+
CREATE INDEX "heartbeat_runs_company_agent_started_idx" ON "heartbeat_runs" USING btree ("company_id","agent_id","started_at");--> statement-breakpoint
|
|
202
|
+
CREATE INDEX "issue_comments_issue_idx" ON "issue_comments" USING btree ("issue_id");--> statement-breakpoint
|
|
203
|
+
CREATE INDEX "issue_comments_company_idx" ON "issue_comments" USING btree ("company_id");--> statement-breakpoint
|
|
204
|
+
CREATE INDEX "issues_company_status_idx" ON "issues" USING btree ("company_id","status");--> statement-breakpoint
|
|
205
|
+
CREATE INDEX "issues_company_assignee_status_idx" ON "issues" USING btree ("company_id","assignee_agent_id","status");--> statement-breakpoint
|
|
206
|
+
CREATE INDEX "issues_company_parent_idx" ON "issues" USING btree ("company_id","parent_id");--> statement-breakpoint
|
|
207
|
+
CREATE INDEX "issues_company_project_idx" ON "issues" USING btree ("company_id","project_id");--> statement-breakpoint
|
|
208
|
+
CREATE INDEX "projects_company_idx" ON "projects" USING btree ("company_id");
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
CREATE TABLE "agent_runtime_state" (
|
|
2
|
+
"agent_id" uuid PRIMARY KEY NOT NULL,
|
|
3
|
+
"company_id" uuid NOT NULL,
|
|
4
|
+
"adapter_type" text NOT NULL,
|
|
5
|
+
"session_id" text,
|
|
6
|
+
"state_json" jsonb DEFAULT '{}'::jsonb NOT NULL,
|
|
7
|
+
"last_run_id" uuid,
|
|
8
|
+
"last_run_status" text,
|
|
9
|
+
"total_input_tokens" bigint DEFAULT 0 NOT NULL,
|
|
10
|
+
"total_output_tokens" bigint DEFAULT 0 NOT NULL,
|
|
11
|
+
"total_cached_input_tokens" bigint DEFAULT 0 NOT NULL,
|
|
12
|
+
"total_cost_cents" bigint DEFAULT 0 NOT NULL,
|
|
13
|
+
"last_error" text,
|
|
14
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
15
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
16
|
+
);
|
|
17
|
+
--> statement-breakpoint
|
|
18
|
+
CREATE TABLE "agent_wakeup_requests" (
|
|
19
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
20
|
+
"company_id" uuid NOT NULL,
|
|
21
|
+
"agent_id" uuid NOT NULL,
|
|
22
|
+
"source" text NOT NULL,
|
|
23
|
+
"trigger_detail" text,
|
|
24
|
+
"reason" text,
|
|
25
|
+
"payload" jsonb,
|
|
26
|
+
"status" text DEFAULT 'queued' NOT NULL,
|
|
27
|
+
"coalesced_count" integer DEFAULT 0 NOT NULL,
|
|
28
|
+
"requested_by_actor_type" text,
|
|
29
|
+
"requested_by_actor_id" text,
|
|
30
|
+
"idempotency_key" text,
|
|
31
|
+
"run_id" uuid,
|
|
32
|
+
"requested_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
33
|
+
"claimed_at" timestamp with time zone,
|
|
34
|
+
"finished_at" timestamp with time zone,
|
|
35
|
+
"error" text,
|
|
36
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
37
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
38
|
+
);
|
|
39
|
+
--> statement-breakpoint
|
|
40
|
+
CREATE TABLE "heartbeat_run_events" (
|
|
41
|
+
"id" bigserial PRIMARY KEY NOT NULL,
|
|
42
|
+
"company_id" uuid NOT NULL,
|
|
43
|
+
"run_id" uuid NOT NULL,
|
|
44
|
+
"agent_id" uuid NOT NULL,
|
|
45
|
+
"seq" integer NOT NULL,
|
|
46
|
+
"event_type" text NOT NULL,
|
|
47
|
+
"stream" text,
|
|
48
|
+
"level" text,
|
|
49
|
+
"color" text,
|
|
50
|
+
"message" text,
|
|
51
|
+
"payload" jsonb,
|
|
52
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
53
|
+
);
|
|
54
|
+
--> statement-breakpoint
|
|
55
|
+
ALTER TABLE "heartbeat_runs" ALTER COLUMN "invocation_source" SET DEFAULT 'on_demand';--> statement-breakpoint
|
|
56
|
+
ALTER TABLE "agents" ADD COLUMN "runtime_config" jsonb DEFAULT '{}'::jsonb NOT NULL;--> statement-breakpoint
|
|
57
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "trigger_detail" text;--> statement-breakpoint
|
|
58
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "wakeup_request_id" uuid;--> statement-breakpoint
|
|
59
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "exit_code" integer;--> statement-breakpoint
|
|
60
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "signal" text;--> statement-breakpoint
|
|
61
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "usage_json" jsonb;--> statement-breakpoint
|
|
62
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "result_json" jsonb;--> statement-breakpoint
|
|
63
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "session_id_before" text;--> statement-breakpoint
|
|
64
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "session_id_after" text;--> statement-breakpoint
|
|
65
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "log_store" text;--> statement-breakpoint
|
|
66
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "log_ref" text;--> statement-breakpoint
|
|
67
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "log_bytes" bigint;--> statement-breakpoint
|
|
68
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "log_sha256" text;--> statement-breakpoint
|
|
69
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "log_compressed" boolean DEFAULT false NOT NULL;--> statement-breakpoint
|
|
70
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "stdout_excerpt" text;--> statement-breakpoint
|
|
71
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "stderr_excerpt" text;--> statement-breakpoint
|
|
72
|
+
ALTER TABLE "heartbeat_runs" ADD COLUMN "error_code" text;--> statement-breakpoint
|
|
73
|
+
ALTER TABLE "agent_runtime_state" ADD CONSTRAINT "agent_runtime_state_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
74
|
+
ALTER TABLE "agent_runtime_state" ADD CONSTRAINT "agent_runtime_state_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
75
|
+
ALTER TABLE "agent_wakeup_requests" ADD CONSTRAINT "agent_wakeup_requests_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
76
|
+
ALTER TABLE "agent_wakeup_requests" ADD CONSTRAINT "agent_wakeup_requests_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
77
|
+
ALTER TABLE "heartbeat_run_events" ADD CONSTRAINT "heartbeat_run_events_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
78
|
+
ALTER TABLE "heartbeat_run_events" ADD CONSTRAINT "heartbeat_run_events_run_id_heartbeat_runs_id_fk" FOREIGN KEY ("run_id") REFERENCES "public"."heartbeat_runs"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
79
|
+
ALTER TABLE "heartbeat_run_events" ADD CONSTRAINT "heartbeat_run_events_agent_id_agents_id_fk" FOREIGN KEY ("agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
80
|
+
CREATE INDEX "agent_runtime_state_company_agent_idx" ON "agent_runtime_state" USING btree ("company_id","agent_id");--> statement-breakpoint
|
|
81
|
+
CREATE INDEX "agent_runtime_state_company_updated_idx" ON "agent_runtime_state" USING btree ("company_id","updated_at");--> statement-breakpoint
|
|
82
|
+
CREATE INDEX "agent_wakeup_requests_company_agent_status_idx" ON "agent_wakeup_requests" USING btree ("company_id","agent_id","status");--> statement-breakpoint
|
|
83
|
+
CREATE INDEX "agent_wakeup_requests_company_requested_idx" ON "agent_wakeup_requests" USING btree ("company_id","requested_at");--> statement-breakpoint
|
|
84
|
+
CREATE INDEX "agent_wakeup_requests_agent_requested_idx" ON "agent_wakeup_requests" USING btree ("agent_id","requested_at");--> statement-breakpoint
|
|
85
|
+
CREATE INDEX "heartbeat_run_events_run_seq_idx" ON "heartbeat_run_events" USING btree ("run_id","seq");--> statement-breakpoint
|
|
86
|
+
CREATE INDEX "heartbeat_run_events_company_run_idx" ON "heartbeat_run_events" USING btree ("company_id","run_id");--> statement-breakpoint
|
|
87
|
+
CREATE INDEX "heartbeat_run_events_company_created_idx" ON "heartbeat_run_events" USING btree ("company_id","created_at");
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
ALTER TABLE "heartbeat_runs" ADD CONSTRAINT "heartbeat_runs_wakeup_request_id_agent_wakeup_requests_id_fk" FOREIGN KEY ("wakeup_request_id") REFERENCES "public"."agent_wakeup_requests"("id") ON DELETE no action ON UPDATE no action;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
ALTER TABLE "activity_log" ADD COLUMN "run_id" uuid;--> statement-breakpoint
|
|
2
|
+
ALTER TABLE "activity_log" ADD CONSTRAINT "activity_log_run_id_heartbeat_runs_id_fk" FOREIGN KEY ("run_id") REFERENCES "public"."heartbeat_runs"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
3
|
+
CREATE INDEX "activity_log_run_id_idx" ON "activity_log" USING btree ("run_id");--> statement-breakpoint
|
|
4
|
+
CREATE INDEX "activity_log_entity_type_id_idx" ON "activity_log" USING btree ("entity_type","entity_id");--> statement-breakpoint
|
|
5
|
+
ALTER TABLE "agents" DROP COLUMN "context_mode";
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
-- Add issue identifier columns to companies
|
|
2
|
+
ALTER TABLE "companies" ADD COLUMN "issue_prefix" text NOT NULL DEFAULT 'PAP';--> statement-breakpoint
|
|
3
|
+
ALTER TABLE "companies" ADD COLUMN "issue_counter" integer NOT NULL DEFAULT 0;--> statement-breakpoint
|
|
4
|
+
|
|
5
|
+
-- Add issue identifier columns to issues
|
|
6
|
+
ALTER TABLE "issues" ADD COLUMN "issue_number" integer;--> statement-breakpoint
|
|
7
|
+
ALTER TABLE "issues" ADD COLUMN "identifier" text;--> statement-breakpoint
|
|
8
|
+
|
|
9
|
+
-- Backfill existing issues: assign sequential issue_number per company ordered by created_at
|
|
10
|
+
WITH numbered AS (
|
|
11
|
+
SELECT id, company_id, ROW_NUMBER() OVER (PARTITION BY company_id ORDER BY created_at ASC) AS rn
|
|
12
|
+
FROM issues
|
|
13
|
+
)
|
|
14
|
+
UPDATE issues
|
|
15
|
+
SET issue_number = numbered.rn,
|
|
16
|
+
identifier = (SELECT issue_prefix FROM companies WHERE companies.id = issues.company_id) || '-' || numbered.rn
|
|
17
|
+
FROM numbered
|
|
18
|
+
WHERE issues.id = numbered.id;--> statement-breakpoint
|
|
19
|
+
|
|
20
|
+
-- Sync each company's issue_counter to the max assigned number
|
|
21
|
+
UPDATE companies
|
|
22
|
+
SET issue_counter = COALESCE(
|
|
23
|
+
(SELECT MAX(issue_number) FROM issues WHERE issues.company_id = companies.id),
|
|
24
|
+
0
|
|
25
|
+
);--> statement-breakpoint
|
|
26
|
+
|
|
27
|
+
-- Create unique index on (company_id, identifier)
|
|
28
|
+
CREATE UNIQUE INDEX "issues_company_identifier_idx" ON "issues" USING btree ("company_id","identifier");
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
CREATE TABLE "approval_comments" (
|
|
2
|
+
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
3
|
+
"company_id" uuid NOT NULL,
|
|
4
|
+
"approval_id" uuid NOT NULL,
|
|
5
|
+
"author_agent_id" uuid,
|
|
6
|
+
"author_user_id" text,
|
|
7
|
+
"body" text NOT NULL,
|
|
8
|
+
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
9
|
+
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
10
|
+
);
|
|
11
|
+
--> statement-breakpoint
|
|
12
|
+
ALTER TABLE "agents" ADD COLUMN "permissions" jsonb DEFAULT '{}'::jsonb NOT NULL;--> statement-breakpoint
|
|
13
|
+
ALTER TABLE "companies" ADD COLUMN "require_board_approval_for_new_agents" boolean DEFAULT true NOT NULL;--> statement-breakpoint
|
|
14
|
+
ALTER TABLE "approval_comments" ADD CONSTRAINT "approval_comments_company_id_companies_id_fk" FOREIGN KEY ("company_id") REFERENCES "public"."companies"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
15
|
+
ALTER TABLE "approval_comments" ADD CONSTRAINT "approval_comments_approval_id_approvals_id_fk" FOREIGN KEY ("approval_id") REFERENCES "public"."approvals"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
16
|
+
ALTER TABLE "approval_comments" ADD CONSTRAINT "approval_comments_author_agent_id_agents_id_fk" FOREIGN KEY ("author_agent_id") REFERENCES "public"."agents"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
|
|
17
|
+
CREATE INDEX "approval_comments_company_idx" ON "approval_comments" USING btree ("company_id");--> statement-breakpoint
|
|
18
|
+
CREATE INDEX "approval_comments_approval_idx" ON "approval_comments" USING btree ("approval_id");--> statement-breakpoint
|
|
19
|
+
CREATE INDEX "approval_comments_approval_created_idx" ON "approval_comments" USING btree ("approval_id","created_at");--> statement-breakpoint
|