@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,146 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { afterEach, describe, expect, it } from "vitest";
|
|
5
|
+
import postgres from "postgres";
|
|
6
|
+
import { createBufferedTextFileWriter, runDatabaseBackup, runDatabaseRestore } from "./backup-lib.js";
|
|
7
|
+
import { ensurePostgresDatabase } from "./client.js";
|
|
8
|
+
import { getEmbeddedPostgresTestSupport, startEmbeddedPostgresTestDatabase, } from "./test-embedded-postgres.js";
|
|
9
|
+
const cleanups = [];
|
|
10
|
+
const embeddedPostgresSupport = await getEmbeddedPostgresTestSupport();
|
|
11
|
+
const describeEmbeddedPostgres = embeddedPostgresSupport.supported ? describe : describe.skip;
|
|
12
|
+
function createTempDir(prefix) {
|
|
13
|
+
const dir = fs.mkdtempSync(path.join(os.tmpdir(), prefix));
|
|
14
|
+
cleanups.push(() => {
|
|
15
|
+
fs.rmSync(dir, { recursive: true, force: true });
|
|
16
|
+
});
|
|
17
|
+
return dir;
|
|
18
|
+
}
|
|
19
|
+
async function createTempDatabase() {
|
|
20
|
+
const db = await startEmbeddedPostgresTestDatabase("zmeel-db-backup-");
|
|
21
|
+
cleanups.push(db.cleanup);
|
|
22
|
+
return db.connectionString;
|
|
23
|
+
}
|
|
24
|
+
async function createSiblingDatabase(connectionString, databaseName) {
|
|
25
|
+
const adminUrl = new URL(connectionString);
|
|
26
|
+
adminUrl.pathname = "/postgres";
|
|
27
|
+
await ensurePostgresDatabase(adminUrl.toString(), databaseName);
|
|
28
|
+
const targetUrl = new URL(connectionString);
|
|
29
|
+
targetUrl.pathname = `/${databaseName}`;
|
|
30
|
+
return targetUrl.toString();
|
|
31
|
+
}
|
|
32
|
+
afterEach(async () => {
|
|
33
|
+
while (cleanups.length > 0) {
|
|
34
|
+
const cleanup = cleanups.pop();
|
|
35
|
+
await cleanup?.();
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
if (!embeddedPostgresSupport.supported) {
|
|
39
|
+
console.warn(`Skipping embedded Postgres backup tests on this host: ${embeddedPostgresSupport.reason ?? "unsupported environment"}`);
|
|
40
|
+
}
|
|
41
|
+
describe("createBufferedTextFileWriter", () => {
|
|
42
|
+
it("preserves line boundaries across buffered flushes", async () => {
|
|
43
|
+
const tempDir = createTempDir("zmeel-buffered-writer-");
|
|
44
|
+
const outputPath = path.join(tempDir, "backup.sql");
|
|
45
|
+
const writer = createBufferedTextFileWriter(outputPath, 16);
|
|
46
|
+
const lines = [
|
|
47
|
+
"-- header",
|
|
48
|
+
"BEGIN;",
|
|
49
|
+
"",
|
|
50
|
+
"INSERT INTO test VALUES (1);",
|
|
51
|
+
"-- footer",
|
|
52
|
+
];
|
|
53
|
+
for (const line of lines) {
|
|
54
|
+
writer.emit(line);
|
|
55
|
+
}
|
|
56
|
+
await writer.close();
|
|
57
|
+
expect(fs.readFileSync(outputPath, "utf8")).toBe(lines.join("\n"));
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describeEmbeddedPostgres("runDatabaseBackup", () => {
|
|
61
|
+
it("backs up and restores large table payloads without materializing one giant string", async () => {
|
|
62
|
+
const sourceConnectionString = await createTempDatabase();
|
|
63
|
+
const restoreConnectionString = await createSiblingDatabase(sourceConnectionString, "zmeel_restore_target");
|
|
64
|
+
const backupDir = createTempDir("zmeel-db-backup-output-");
|
|
65
|
+
const sourceSql = postgres(sourceConnectionString, { max: 1, onnotice: () => { } });
|
|
66
|
+
const restoreSql = postgres(restoreConnectionString, { max: 1, onnotice: () => { } });
|
|
67
|
+
try {
|
|
68
|
+
await sourceSql.unsafe(`
|
|
69
|
+
CREATE TYPE "public"."backup_test_state" AS ENUM ('pending', 'done');
|
|
70
|
+
`);
|
|
71
|
+
await sourceSql.unsafe(`
|
|
72
|
+
CREATE TABLE "public"."backup_test_records" (
|
|
73
|
+
"id" serial PRIMARY KEY,
|
|
74
|
+
"title" text NOT NULL,
|
|
75
|
+
"payload" text NOT NULL,
|
|
76
|
+
"state" "public"."backup_test_state" NOT NULL,
|
|
77
|
+
"metadata" jsonb,
|
|
78
|
+
"created_at" timestamptz NOT NULL DEFAULT now()
|
|
79
|
+
);
|
|
80
|
+
`);
|
|
81
|
+
const payload = "x".repeat(8192);
|
|
82
|
+
for (let index = 0; index < 160; index += 1) {
|
|
83
|
+
const createdAt = new Date(Date.UTC(2026, 0, 1, 0, 0, index));
|
|
84
|
+
await sourceSql `
|
|
85
|
+
INSERT INTO "public"."backup_test_records" (
|
|
86
|
+
"title",
|
|
87
|
+
"payload",
|
|
88
|
+
"state",
|
|
89
|
+
"metadata",
|
|
90
|
+
"created_at"
|
|
91
|
+
)
|
|
92
|
+
VALUES (
|
|
93
|
+
${`row-${index}`},
|
|
94
|
+
${payload},
|
|
95
|
+
${index % 2 === 0 ? "pending" : "done"}::"public"."backup_test_state",
|
|
96
|
+
${JSON.stringify({ index, even: index % 2 === 0 })}::jsonb,
|
|
97
|
+
${createdAt}
|
|
98
|
+
)
|
|
99
|
+
`;
|
|
100
|
+
}
|
|
101
|
+
const result = await runDatabaseBackup({
|
|
102
|
+
connectionString: sourceConnectionString,
|
|
103
|
+
backupDir,
|
|
104
|
+
retentionDays: 7,
|
|
105
|
+
filenamePrefix: "zmeel-test",
|
|
106
|
+
});
|
|
107
|
+
expect(result.backupFile).toMatch(/zmeel-test-.*\.sql$/);
|
|
108
|
+
expect(result.sizeBytes).toBeGreaterThan(1024 * 1024);
|
|
109
|
+
expect(fs.existsSync(result.backupFile)).toBe(true);
|
|
110
|
+
await runDatabaseRestore({
|
|
111
|
+
connectionString: restoreConnectionString,
|
|
112
|
+
backupFile: result.backupFile,
|
|
113
|
+
});
|
|
114
|
+
const counts = await restoreSql.unsafe(`
|
|
115
|
+
SELECT count(*)::int AS count
|
|
116
|
+
FROM "public"."backup_test_records"
|
|
117
|
+
`);
|
|
118
|
+
expect(counts[0]?.count).toBe(160);
|
|
119
|
+
const sampleRows = await restoreSql.unsafe(`
|
|
120
|
+
SELECT "title", "payload", "state"::text AS "state", "metadata"
|
|
121
|
+
FROM "public"."backup_test_records"
|
|
122
|
+
WHERE "title" IN ('row-0', 'row-159')
|
|
123
|
+
ORDER BY "title"
|
|
124
|
+
`);
|
|
125
|
+
expect(sampleRows).toEqual([
|
|
126
|
+
{
|
|
127
|
+
title: "row-0",
|
|
128
|
+
payload,
|
|
129
|
+
state: "pending",
|
|
130
|
+
metadata: { index: 0, even: true },
|
|
131
|
+
},
|
|
132
|
+
{
|
|
133
|
+
title: "row-159",
|
|
134
|
+
payload,
|
|
135
|
+
state: "done",
|
|
136
|
+
metadata: { index: 159, even: false },
|
|
137
|
+
},
|
|
138
|
+
]);
|
|
139
|
+
}
|
|
140
|
+
finally {
|
|
141
|
+
await sourceSql.end();
|
|
142
|
+
await restoreSql.end();
|
|
143
|
+
}
|
|
144
|
+
}, 60_000);
|
|
145
|
+
});
|
|
146
|
+
//# sourceMappingURL=backup-lib.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backup-lib.test.js","sourceRoot":"","sources":["../src/backup-lib.test.ts"],"names":[],"mappings":"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"}
|
package/dist/backup.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backup.d.ts","sourceRoot":"","sources":["../src/backup.ts"],"names":[],"mappings":""}
|
package/dist/backup.js
ADDED
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { existsSync, readFileSync } from "node:fs";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { formatDatabaseBackupResult, runDatabaseBackup } from "./backup-lib.js";
|
|
5
|
+
function expandHomePrefix(value) {
|
|
6
|
+
if (value === "~")
|
|
7
|
+
return os.homedir();
|
|
8
|
+
if (value.startsWith("~/"))
|
|
9
|
+
return path.resolve(os.homedir(), value.slice(2));
|
|
10
|
+
return value;
|
|
11
|
+
}
|
|
12
|
+
function resolvezmeelHomeDir() {
|
|
13
|
+
const envHome = process.env.ZMEEL_HOME?.trim();
|
|
14
|
+
if (envHome)
|
|
15
|
+
return path.resolve(expandHomePrefix(envHome));
|
|
16
|
+
return path.resolve(os.homedir(), ".zmeel");
|
|
17
|
+
}
|
|
18
|
+
function resolvezmeelInstanceId() {
|
|
19
|
+
const raw = process.env.ZMEEL_INSTANCE_ID?.trim() || "default";
|
|
20
|
+
if (!/^[a-zA-Z0-9_-]+$/.test(raw)) {
|
|
21
|
+
throw new Error(`Invalid ZMEEL_INSTANCE_ID '${raw}'.`);
|
|
22
|
+
}
|
|
23
|
+
return raw;
|
|
24
|
+
}
|
|
25
|
+
function resolveDefaultConfigPath() {
|
|
26
|
+
return path.resolve(resolvezmeelHomeDir(), "instances", resolvezmeelInstanceId(), "config.json");
|
|
27
|
+
}
|
|
28
|
+
function readConfig(configPath) {
|
|
29
|
+
if (!existsSync(configPath))
|
|
30
|
+
return null;
|
|
31
|
+
try {
|
|
32
|
+
const parsed = JSON.parse(readFileSync(configPath, "utf8"));
|
|
33
|
+
return typeof parsed === "object" && parsed ? parsed : null;
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function asPositiveInt(value) {
|
|
40
|
+
if (typeof value !== "number" || !Number.isFinite(value))
|
|
41
|
+
return null;
|
|
42
|
+
const rounded = Math.trunc(value);
|
|
43
|
+
return rounded > 0 ? rounded : null;
|
|
44
|
+
}
|
|
45
|
+
function resolveEmbeddedPort(config) {
|
|
46
|
+
return asPositiveInt(config?.database?.embeddedPostgresPort) ?? 54329;
|
|
47
|
+
}
|
|
48
|
+
function resolveConnectionString(config) {
|
|
49
|
+
const envUrl = process.env.DATABASE_URL?.trim();
|
|
50
|
+
if (envUrl)
|
|
51
|
+
return envUrl;
|
|
52
|
+
if (config?.database?.mode === "postgres" && typeof config.database.connectionString === "string") {
|
|
53
|
+
const trimmed = config.database.connectionString.trim();
|
|
54
|
+
if (trimmed)
|
|
55
|
+
return trimmed;
|
|
56
|
+
}
|
|
57
|
+
const port = resolveEmbeddedPort(config);
|
|
58
|
+
return `postgres://zmeel:zmeel@127.0.0.1:${port}/zmeel`;
|
|
59
|
+
}
|
|
60
|
+
function resolveDefaultBackupDir() {
|
|
61
|
+
return path.resolve(resolvezmeelHomeDir(), "instances", resolvezmeelInstanceId(), "data", "backups");
|
|
62
|
+
}
|
|
63
|
+
function resolveBackupDir(config) {
|
|
64
|
+
const raw = config?.database?.backup?.dir;
|
|
65
|
+
if (typeof raw === "string" && raw.trim().length > 0) {
|
|
66
|
+
return path.resolve(expandHomePrefix(raw.trim()));
|
|
67
|
+
}
|
|
68
|
+
return resolveDefaultBackupDir();
|
|
69
|
+
}
|
|
70
|
+
function resolveRetentionDays(config) {
|
|
71
|
+
return asPositiveInt(config?.database?.backup?.retentionDays) ?? 30;
|
|
72
|
+
}
|
|
73
|
+
async function main() {
|
|
74
|
+
const configPath = resolveDefaultConfigPath();
|
|
75
|
+
const config = readConfig(configPath);
|
|
76
|
+
const connectionString = resolveConnectionString(config);
|
|
77
|
+
const backupDir = resolveBackupDir(config);
|
|
78
|
+
const retentionDays = resolveRetentionDays(config);
|
|
79
|
+
console.log(`Config path: ${configPath}`);
|
|
80
|
+
console.log(`Backing up database to: ${backupDir}`);
|
|
81
|
+
console.log(`Retention window: ${retentionDays} day(s)`);
|
|
82
|
+
try {
|
|
83
|
+
const result = await runDatabaseBackup({
|
|
84
|
+
connectionString,
|
|
85
|
+
backupDir,
|
|
86
|
+
retentionDays,
|
|
87
|
+
filenamePrefix: "zmeel",
|
|
88
|
+
});
|
|
89
|
+
console.log(`Backup saved: ${formatDatabaseBackupResult(result)}`);
|
|
90
|
+
}
|
|
91
|
+
catch (err) {
|
|
92
|
+
console.error("Backup failed.");
|
|
93
|
+
if (err instanceof Error) {
|
|
94
|
+
console.error(err.message);
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
console.error(String(err));
|
|
98
|
+
}
|
|
99
|
+
process.exit(1);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
await main();
|
|
103
|
+
//# sourceMappingURL=backup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backup.js","sourceRoot":"","sources":["../src/backup.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-migration-numbering.d.ts","sourceRoot":"","sources":["../src/check-migration-numbering.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { readdir, readFile } from "node:fs/promises";
|
|
2
|
+
import { fileURLToPath } from "node:url";
|
|
3
|
+
const migrationsDir = fileURLToPath(new URL("./migrations", import.meta.url));
|
|
4
|
+
const journalPath = fileURLToPath(new URL("./migrations/meta/_journal.json", import.meta.url));
|
|
5
|
+
function migrationNumber(value) {
|
|
6
|
+
const match = value.match(/^(\d{4})_/);
|
|
7
|
+
return match ? match[1] : null;
|
|
8
|
+
}
|
|
9
|
+
function ensureNoDuplicates(values, label) {
|
|
10
|
+
const seen = new Map();
|
|
11
|
+
for (const value of values) {
|
|
12
|
+
const number = migrationNumber(value);
|
|
13
|
+
if (!number) {
|
|
14
|
+
throw new Error(`${label} entry does not start with a 4-digit migration number: ${value}`);
|
|
15
|
+
}
|
|
16
|
+
const existing = seen.get(number);
|
|
17
|
+
if (existing) {
|
|
18
|
+
throw new Error(`Duplicate migration number ${number} in ${label}: ${existing}, ${value}`);
|
|
19
|
+
}
|
|
20
|
+
seen.set(number, value);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function ensureStrictlyOrdered(values, label) {
|
|
24
|
+
const sorted = [...values].sort();
|
|
25
|
+
for (let index = 0; index < values.length; index += 1) {
|
|
26
|
+
if (values[index] !== sorted[index]) {
|
|
27
|
+
throw new Error(`${label} are out of order at position ${index}: expected ${sorted[index]}, found ${values[index]}`);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
function ensureJournalMatchesFiles(migrationFiles, journalTags) {
|
|
32
|
+
const journalFiles = journalTags.map((tag) => `${tag}.sql`);
|
|
33
|
+
if (journalFiles.length !== migrationFiles.length) {
|
|
34
|
+
throw new Error(`Migration journal/file count mismatch: journal has ${journalFiles.length}, files have ${migrationFiles.length}`);
|
|
35
|
+
}
|
|
36
|
+
for (let index = 0; index < migrationFiles.length; index += 1) {
|
|
37
|
+
const migrationFile = migrationFiles[index];
|
|
38
|
+
const journalFile = journalFiles[index];
|
|
39
|
+
if (migrationFile !== journalFile) {
|
|
40
|
+
throw new Error(`Migration journal/file order mismatch at position ${index}: journal has ${journalFile}, files have ${migrationFile}`);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
async function main() {
|
|
45
|
+
const migrationFiles = (await readdir(migrationsDir))
|
|
46
|
+
.filter((entry) => entry.endsWith(".sql"))
|
|
47
|
+
.sort();
|
|
48
|
+
ensureNoDuplicates(migrationFiles, "migration files");
|
|
49
|
+
ensureStrictlyOrdered(migrationFiles, "migration files");
|
|
50
|
+
const rawJournal = await readFile(journalPath, "utf8");
|
|
51
|
+
const journal = JSON.parse(rawJournal);
|
|
52
|
+
const journalTags = (journal.entries ?? [])
|
|
53
|
+
.map((entry, index) => {
|
|
54
|
+
if (typeof entry.tag !== "string" || entry.tag.length === 0) {
|
|
55
|
+
throw new Error(`Migration journal entry ${index} is missing a tag`);
|
|
56
|
+
}
|
|
57
|
+
return entry.tag;
|
|
58
|
+
});
|
|
59
|
+
ensureNoDuplicates(journalTags, "migration journal");
|
|
60
|
+
ensureStrictlyOrdered(journalTags, "migration journal");
|
|
61
|
+
ensureJournalMatchesFiles(migrationFiles, journalTags);
|
|
62
|
+
}
|
|
63
|
+
await main();
|
|
64
|
+
//# sourceMappingURL=check-migration-numbering.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-migration-numbering.js","sourceRoot":"","sources":["../src/check-migration-numbering.ts"],"names":[],"mappings":"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"}
|
package/dist/client.d.ts
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import postgres from "postgres";
|
|
2
|
+
import * as schema from "./schema/index.js";
|
|
3
|
+
export type MigrationState = {
|
|
4
|
+
status: "upToDate";
|
|
5
|
+
tableCount: number;
|
|
6
|
+
availableMigrations: string[];
|
|
7
|
+
appliedMigrations: string[];
|
|
8
|
+
} | {
|
|
9
|
+
status: "needsMigrations";
|
|
10
|
+
tableCount: number;
|
|
11
|
+
availableMigrations: string[];
|
|
12
|
+
appliedMigrations: string[];
|
|
13
|
+
pendingMigrations: string[];
|
|
14
|
+
reason: "no-migration-journal-empty-db" | "no-migration-journal-non-empty-db" | "pending-migrations";
|
|
15
|
+
};
|
|
16
|
+
export declare function createDb(url: string): import("drizzle-orm/postgres-js").PostgresJsDatabase<typeof schema> & {
|
|
17
|
+
$client: postgres.Sql<{}>;
|
|
18
|
+
};
|
|
19
|
+
export declare function getPostgresDataDirectory(url: string): Promise<string | null>;
|
|
20
|
+
export type MigrationHistoryReconcileResult = {
|
|
21
|
+
repairedMigrations: string[];
|
|
22
|
+
remainingMigrations: string[];
|
|
23
|
+
};
|
|
24
|
+
export declare function reconcilePendingMigrationHistory(url: string): Promise<MigrationHistoryReconcileResult>;
|
|
25
|
+
export declare function inspectMigrations(url: string): Promise<MigrationState>;
|
|
26
|
+
export declare function applyPendingMigrations(url: string): Promise<void>;
|
|
27
|
+
export type MigrationBootstrapResult = {
|
|
28
|
+
migrated: true;
|
|
29
|
+
reason: "migrated-empty-db";
|
|
30
|
+
tableCount: 0;
|
|
31
|
+
} | {
|
|
32
|
+
migrated: false;
|
|
33
|
+
reason: "already-migrated";
|
|
34
|
+
tableCount: number;
|
|
35
|
+
} | {
|
|
36
|
+
migrated: false;
|
|
37
|
+
reason: "not-empty-no-migration-journal";
|
|
38
|
+
tableCount: number;
|
|
39
|
+
};
|
|
40
|
+
export declare function migratePostgresIfEmpty(url: string): Promise<MigrationBootstrapResult>;
|
|
41
|
+
export declare function ensurePostgresDatabase(url: string, databaseName: string): Promise<"created" | "exists">;
|
|
42
|
+
export type Db = ReturnType<typeof createDb>;
|
|
43
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAKA,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,KAAK,MAAM,MAAM,mBAAmB,CAAC;AA8B5C,MAAM,MAAM,cAAc,GACtB;IAAE,MAAM,EAAE,UAAU,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAAC,iBAAiB,EAAE,MAAM,EAAE,CAAA;CAAE,GACtG;IACE,MAAM,EAAE,iBAAiB,CAAC;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAC9B,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,MAAM,EAAE,+BAA+B,GAAG,mCAAmC,GAAG,oBAAoB,CAAC;CACtG,CAAC;AAEN,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM;;EAGnC;AAED,wBAAsB,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAalF;AA+ZD,MAAM,MAAM,+BAA+B,GAAG;IAC5C,kBAAkB,EAAE,MAAM,EAAE,CAAC;IAC7B,mBAAmB,EAAE,MAAM,EAAE,CAAC;CAC/B,CAAC;AAEF,wBAAsB,gCAAgC,CACpD,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,+BAA+B,CAAC,CA2F1C;AAqBD,wBAAsB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CA0D5E;AAED,wBAAsB,sBAAsB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CA0DvE;AAED,MAAM,MAAM,wBAAwB,GAChC;IAAE,QAAQ,EAAE,IAAI,CAAC;IAAC,MAAM,EAAE,mBAAmB,CAAC;IAAC,UAAU,EAAE,CAAC,CAAA;CAAE,GAC9D;IAAE,QAAQ,EAAE,KAAK,CAAC;IAAC,MAAM,EAAE,kBAAkB,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,GACnE;IAAE,QAAQ,EAAE,KAAK,CAAC;IAAC,MAAM,EAAE,gCAAgC,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC;AAEtF,wBAAsB,sBAAsB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,wBAAwB,CAAC,CA8B3F;AAED,wBAAsB,sBAAsB,CAC1C,GAAG,EAAE,MAAM,EACX,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,SAAS,GAAG,QAAQ,CAAC,CAiB/B;AAED,MAAM,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC"}
|