heroku 9.0.0-dev.0 → 9.1.0-beta.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/README.md +6 -11
- package/lib/commands/access/add.d.ts +14 -0
- package/lib/commands/access/add.js +55 -0
- package/lib/commands/access/index.d.ts +11 -0
- package/lib/commands/access/index.js +86 -0
- package/lib/commands/access/remove.d.ts +12 -0
- package/lib/commands/access/remove.js +25 -0
- package/lib/commands/access/update.d.ts +14 -0
- package/lib/commands/access/update.js +39 -0
- package/lib/commands/addons/attach.d.ts +16 -0
- package/lib/commands/addons/attach.js +51 -0
- package/lib/commands/addons/create.d.ts +20 -0
- package/lib/commands/addons/create.js +96 -0
- package/lib/commands/addons/destroy.d.ts +19 -0
- package/lib/commands/addons/destroy.js +61 -0
- package/lib/commands/addons/detach.d.ts +13 -0
- package/lib/commands/addons/detach.js +31 -0
- package/lib/commands/addons/docs.d.ts +14 -0
- package/lib/commands/addons/docs.js +36 -0
- package/lib/commands/addons/index.d.ts +16 -0
- package/lib/commands/addons/index.js +246 -0
- package/lib/commands/addons/info.d.ts +14 -0
- package/lib/commands/addons/info.js +44 -0
- package/lib/commands/addons/open.d.ts +75 -0
- package/lib/commands/addons/open.js +87 -0
- package/lib/commands/addons/plans.d.ts +12 -0
- package/lib/commands/addons/plans.js +47 -0
- package/lib/commands/addons/rename.d.ts +10 -0
- package/lib/commands/addons/rename.js +20 -0
- package/lib/commands/addons/services.d.ts +9 -0
- package/lib/commands/addons/services.js +34 -0
- package/lib/commands/addons/upgrade.d.ts +28 -0
- package/lib/commands/addons/upgrade.js +145 -0
- package/lib/commands/addons/wait.d.ts +14 -0
- package/lib/commands/addons/wait.js +70 -0
- package/lib/commands/apps/create.d.ts +28 -0
- package/lib/commands/apps/create.js +201 -0
- package/lib/commands/apps/destroy.d.ts +15 -0
- package/lib/commands/apps/destroy.js +47 -0
- package/lib/commands/apps/errors.d.ts +13 -0
- package/lib/commands/apps/errors.js +120 -0
- package/lib/commands/apps/favorites/add.d.ts +2 -1
- package/lib/commands/apps/favorites/add.js +1 -0
- package/lib/commands/apps/favorites/remove.d.ts +2 -1
- package/lib/commands/apps/favorites/remove.js +1 -0
- package/lib/commands/apps/index.d.ts +16 -0
- package/lib/commands/apps/index.js +119 -0
- package/lib/commands/apps/info.d.ts +19 -0
- package/lib/commands/apps/info.js +162 -0
- package/lib/commands/apps/join.d.ts +11 -0
- package/lib/commands/apps/join.js +25 -0
- package/lib/commands/apps/leave.d.ts +12 -0
- package/lib/commands/apps/leave.js +25 -0
- package/lib/commands/apps/lock.d.ts +11 -0
- package/lib/commands/apps/lock.js +30 -0
- package/lib/commands/apps/open.d.ts +15 -0
- package/lib/commands/apps/open.js +30 -0
- package/lib/commands/apps/rename.d.ts +16 -0
- package/lib/commands/apps/rename.js +51 -0
- package/lib/commands/apps/stacks/index.d.ts +3 -2
- package/lib/commands/apps/stacks/index.js +2 -1
- package/lib/commands/apps/stacks/set.d.ts +4 -4
- package/lib/commands/apps/stacks/set.js +1 -1
- package/lib/commands/apps/transfer.d.ts +17 -0
- package/lib/commands/apps/transfer.js +91 -0
- package/lib/commands/apps/unlock.d.ts +11 -0
- package/lib/commands/apps/unlock.js +30 -0
- package/lib/commands/auth/token.js +2 -1
- package/lib/commands/authorizations/create.d.ts +3 -3
- package/lib/commands/authorizations/create.js +5 -1
- package/lib/commands/authorizations/info.d.ts +1 -1
- package/lib/commands/authorizations/info.js +5 -1
- package/lib/commands/authorizations/revoke.d.ts +1 -1
- package/lib/commands/authorizations/revoke.js +5 -1
- package/lib/commands/authorizations/rotate.d.ts +1 -1
- package/lib/commands/authorizations/rotate.js +5 -1
- package/lib/commands/authorizations/update.d.ts +4 -4
- package/lib/commands/authorizations/update.js +5 -1
- package/lib/commands/autocomplete/doctor.js +2 -2
- package/lib/commands/autocomplete/options.d.ts +2 -2
- package/lib/commands/autocomplete/options.js +2 -2
- package/lib/commands/autocomplete/script.d.ts +1 -1
- package/lib/commands/buildpacks/add.d.ts +4 -4
- package/lib/commands/buildpacks/clear.d.ts +2 -2
- package/lib/commands/buildpacks/index.d.ts +2 -2
- package/lib/commands/buildpacks/info.d.ts +1 -1
- package/lib/commands/buildpacks/remove.d.ts +4 -4
- package/lib/commands/buildpacks/search.d.ts +4 -4
- package/lib/commands/buildpacks/set.d.ts +4 -4
- package/lib/commands/buildpacks/versions.d.ts +1 -1
- package/lib/commands/certs/add.d.ts +16 -0
- package/lib/commands/certs/add.js +98 -0
- package/lib/commands/certs/auto/disable.d.ts +11 -0
- package/lib/commands/certs/auto/disable.js +34 -0
- package/lib/commands/certs/auto/enable.d.ts +11 -0
- package/lib/commands/certs/auto/enable.js +51 -0
- package/lib/commands/certs/auto/index.d.ts +12 -0
- package/lib/commands/certs/auto/index.js +94 -0
- package/lib/commands/certs/auto/refresh.d.ts +10 -0
- package/lib/commands/certs/auto/refresh.js +19 -0
- package/lib/commands/certs/generate.d.ts +26 -0
- package/lib/commands/certs/generate.js +111 -0
- package/lib/commands/certs/index.d.ts +10 -0
- package/lib/commands/certs/index.js +26 -0
- package/lib/commands/certs/info.d.ts +13 -0
- package/lib/commands/certs/info.js +43 -0
- package/lib/commands/certs/remove.d.ts +13 -0
- package/lib/commands/certs/remove.js +32 -0
- package/lib/commands/certs/update.d.ts +18 -0
- package/lib/commands/certs/update.js +54 -0
- package/lib/commands/ci/config/get.d.ts +4 -3
- package/lib/commands/ci/config/get.js +3 -2
- package/lib/commands/ci/config/index.d.ts +3 -2
- package/lib/commands/ci/config/index.js +3 -2
- package/lib/commands/ci/config/set.d.ts +3 -2
- package/lib/commands/ci/config/set.js +2 -1
- package/lib/commands/ci/config/unset.d.ts +3 -3
- package/lib/commands/ci/config/unset.js +3 -3
- package/lib/commands/ci/debug.d.ts +2 -2
- package/lib/commands/ci/index.d.ts +3 -2
- package/lib/commands/ci/index.js +1 -0
- package/lib/commands/ci/info.d.ts +5 -4
- package/lib/commands/ci/info.js +1 -0
- package/lib/commands/ci/last.d.ts +4 -3
- package/lib/commands/ci/last.js +1 -0
- package/lib/commands/ci/open.d.ts +3 -2
- package/lib/commands/ci/open.js +1 -0
- package/lib/commands/ci/rerun.d.ts +4 -3
- package/lib/commands/ci/rerun.js +1 -0
- package/lib/commands/ci/run.d.ts +2 -2
- package/lib/commands/clients/create.d.ts +2 -2
- package/lib/commands/clients/destroy.d.ts +1 -1
- package/lib/commands/clients/info.d.ts +1 -1
- package/lib/commands/clients/rotate.d.ts +1 -1
- package/lib/commands/clients/update.d.ts +3 -3
- package/lib/commands/config/edit.d.ts +3 -3
- package/lib/commands/config/get.d.ts +3 -3
- package/lib/commands/config/index.d.ts +2 -2
- package/lib/commands/config/set.d.ts +12 -0
- package/lib/commands/config/set.js +60 -0
- package/lib/commands/config/unset.d.ts +2 -2
- package/lib/commands/console.d.ts +4 -4
- package/lib/commands/container/index.d.ts +6 -0
- package/lib/commands/container/index.js +13 -0
- package/lib/commands/container/login.d.ts +9 -0
- package/lib/commands/container/login.js +57 -0
- package/lib/commands/container/logout.d.ts +9 -0
- package/lib/commands/container/logout.js +37 -0
- package/lib/commands/container/pull.d.ts +14 -0
- package/lib/commands/container/pull.js +43 -0
- package/lib/commands/container/push.d.ts +16 -0
- package/lib/commands/container/push.js +103 -0
- package/lib/commands/container/release.d.ts +14 -0
- package/lib/commands/container/release.js +91 -0
- package/lib/commands/container/rm.d.ts +13 -0
- package/lib/commands/container/rm.js +39 -0
- package/lib/commands/container/run.d.ts +15 -0
- package/lib/commands/container/run.js +66 -0
- package/lib/commands/dashboard.d.ts +7 -0
- package/lib/commands/dashboard.js +164 -0
- package/lib/commands/domains/add.d.ts +4 -4
- package/lib/commands/domains/clear.d.ts +2 -2
- package/lib/commands/domains/index.d.ts +14 -10
- package/lib/commands/domains/index.js +47 -3
- package/lib/commands/domains/info.d.ts +3 -3
- package/lib/commands/domains/remove.d.ts +3 -3
- package/lib/commands/domains/update.d.ts +4 -4
- package/lib/commands/domains/wait.d.ts +3 -3
- package/lib/commands/drains/add.d.ts +12 -0
- package/lib/commands/drains/add.js +23 -0
- package/lib/commands/drains/index.d.ts +11 -0
- package/lib/commands/drains/index.js +50 -0
- package/lib/commands/drains/remove.d.ts +13 -0
- package/lib/commands/drains/remove.js +22 -0
- package/lib/commands/features/disable.d.ts +12 -0
- package/lib/commands/features/disable.js +30 -0
- package/lib/commands/features/enable.d.ts +12 -0
- package/lib/commands/features/enable.js +29 -0
- package/lib/commands/features/index.d.ts +10 -0
- package/lib/commands/features/index.js +37 -0
- package/lib/commands/features/info.d.ts +13 -0
- package/lib/commands/features/info.js +33 -0
- package/lib/commands/git/clone.d.ts +3 -3
- package/lib/commands/git/credentials.d.ts +1 -1
- package/lib/commands/git/remote.d.ts +2 -2
- package/lib/commands/keys/add.d.ts +14 -0
- package/lib/commands/keys/add.js +101 -0
- package/lib/commands/keys/clear.d.ts +5 -0
- package/lib/commands/keys/clear.js +17 -0
- package/lib/commands/keys/index.d.ts +9 -0
- package/lib/commands/keys/index.js +36 -0
- package/lib/commands/keys/remove.d.ts +9 -0
- package/lib/commands/keys/remove.js +29 -0
- package/lib/commands/labs/enable.d.ts +13 -0
- package/lib/commands/labs/enable.js +47 -0
- package/lib/commands/labs/index.d.ts +11 -0
- package/lib/commands/labs/index.js +71 -0
- package/lib/commands/labs/info.d.ts +14 -0
- package/lib/commands/labs/info.js +49 -0
- package/lib/commands/local/index.d.ts +5 -5
- package/lib/commands/local/index.js +8 -3
- package/lib/commands/local/run.d.ts +2 -2
- package/lib/commands/local/run.js +8 -3
- package/lib/commands/logs.d.ts +6 -6
- package/lib/commands/maintenance/index.d.ts +10 -0
- package/lib/commands/maintenance/index.js +19 -0
- package/lib/commands/maintenance/off.d.ts +10 -0
- package/lib/commands/maintenance/off.js +20 -0
- package/lib/commands/maintenance/on.d.ts +10 -0
- package/lib/commands/maintenance/on.js +20 -0
- package/lib/commands/members/add.d.ts +13 -0
- package/lib/commands/members/add.js +33 -0
- package/lib/commands/members/index.d.ts +12 -0
- package/lib/commands/members/index.js +76 -0
- package/lib/commands/members/remove.d.ts +10 -0
- package/lib/commands/members/remove.js +58 -0
- package/lib/commands/members/set.d.ts +11 -0
- package/lib/commands/members/set.js +21 -0
- package/lib/commands/notifications/index.d.ts +13 -0
- package/lib/commands/notifications/index.js +62 -0
- package/lib/commands/orgs/index.d.ts +11 -0
- package/lib/commands/orgs/index.js +27 -0
- package/lib/commands/orgs/open.d.ts +10 -0
- package/lib/commands/orgs/open.js +24 -0
- package/lib/commands/pg/backups/cancel.d.ts +15 -0
- package/lib/commands/pg/backups/cancel.js +49 -0
- package/lib/commands/pg/backups/capture.d.ts +15 -0
- package/lib/commands/pg/backups/capture.js +65 -0
- package/lib/commands/pg/backups/delete.d.ts +15 -0
- package/lib/commands/pg/backups/delete.js +38 -0
- package/lib/commands/pg/backups/download.d.ts +14 -0
- package/lib/commands/pg/backups/download.js +58 -0
- package/lib/commands/pg/backups/index.d.ts +20 -0
- package/lib/commands/pg/backups/index.js +129 -0
- package/lib/commands/pg/backups/info.d.ts +17 -0
- package/lib/commands/pg/backups/info.js +92 -0
- package/lib/commands/pg/backups/restore.d.ts +19 -0
- package/lib/commands/pg/backups/restore.js +107 -0
- package/lib/commands/pg/backups/schedule.d.ts +21 -0
- package/lib/commands/pg/backups/schedule.js +82 -0
- package/lib/commands/pg/backups/schedules.d.ts +10 -0
- package/lib/commands/pg/backups/schedules.js +31 -0
- package/lib/commands/pg/backups/unschedule.d.ts +13 -0
- package/lib/commands/pg/backups/unschedule.js +44 -0
- package/lib/commands/pg/backups/url.d.ts +13 -0
- package/lib/commands/pg/backups/url.js +41 -0
- package/lib/commands/pg/bloat.d.ts +13 -0
- package/lib/commands/pg/bloat.js +87 -0
- package/lib/commands/pg/blocking.d.ts +13 -0
- package/lib/commands/pg/blocking.js +42 -0
- package/lib/commands/pg/connection-pooling/attach.d.ts +15 -0
- package/lib/commands/pg/connection-pooling/attach.js +41 -0
- package/lib/commands/pg/copy.d.ts +18 -0
- package/lib/commands/pg/copy.js +86 -0
- package/lib/commands/pg/credentials/create.d.ts +14 -0
- package/lib/commands/pg/credentials/create.js +40 -0
- package/lib/commands/pg/credentials/destroy.d.ts +16 -0
- package/lib/commands/pg/credentials/destroy.js +48 -0
- package/lib/commands/pg/credentials/repair-default.d.ts +15 -0
- package/lib/commands/pg/credentials/repair-default.js +39 -0
- package/lib/commands/pg/credentials/rotate.d.ts +16 -0
- package/lib/commands/pg/credentials/rotate.js +82 -0
- package/lib/commands/pg/credentials/url.d.ts +14 -0
- package/lib/commands/pg/credentials/url.js +64 -0
- package/lib/commands/pg/credentials.d.ts +16 -0
- package/lib/commands/pg/credentials.js +61 -0
- package/lib/commands/pg/diagnose.d.ts +18 -0
- package/lib/commands/pg/diagnose.js +109 -0
- package/lib/commands/pg/info.d.ts +14 -0
- package/lib/commands/pg/info.js +92 -0
- package/lib/commands/pg/kill.d.ts +15 -0
- package/lib/commands/pg/kill.js +32 -0
- package/lib/commands/pg/killall.d.ts +13 -0
- package/lib/commands/pg/killall.js +26 -0
- package/lib/commands/pg/links/create.d.ts +15 -0
- package/lib/commands/pg/links/create.js +58 -0
- package/lib/commands/pg/links/destroy.d.ts +16 -0
- package/lib/commands/pg/links/destroy.js +42 -0
- package/lib/commands/pg/links/index.d.ts +13 -0
- package/lib/commands/pg/links/index.js +59 -0
- package/lib/commands/pg/locks.d.ts +15 -0
- package/lib/commands/pg/locks.js +53 -0
- package/lib/commands/pg/maintenance/index.d.ts +13 -0
- package/lib/commands/pg/maintenance/index.js +29 -0
- package/lib/commands/pg/maintenance/run.d.ts +14 -0
- package/lib/commands/pg/maintenance/run.js +37 -0
- package/lib/commands/pg/maintenance/window.d.ts +15 -0
- package/lib/commands/pg/maintenance/window.js +41 -0
- package/lib/commands/pg/outliers.d.ts +19 -0
- package/lib/commands/pg/outliers.js +97 -0
- package/lib/commands/pg/promote.d.ts +14 -0
- package/lib/commands/pg/promote.js +169 -0
- package/lib/commands/pg/ps.d.ts +14 -0
- package/lib/commands/pg/ps.js +52 -0
- package/lib/commands/pg/psql.d.ts +16 -0
- package/lib/commands/pg/psql.js +49 -0
- package/lib/commands/pg/pull.d.ts +18 -0
- package/lib/commands/pg/pull.js +87 -0
- package/lib/commands/pg/push.d.ts +18 -0
- package/lib/commands/pg/push.js +84 -0
- package/lib/commands/pg/reset.d.ts +15 -0
- package/lib/commands/pg/reset.js +44 -0
- package/lib/commands/pg/settings/auto-explain/log-analyze.d.ts +13 -0
- package/lib/commands/pg/settings/auto-explain/log-analyze.js +32 -0
- package/lib/commands/pg/settings/auto-explain/log-buffers.d.ts +13 -0
- package/lib/commands/pg/settings/auto-explain/log-buffers.js +30 -0
- package/lib/commands/pg/settings/auto-explain/log-min-duration.d.ts +16 -0
- package/lib/commands/pg/settings/auto-explain/log-min-duration.js +33 -0
- package/lib/commands/pg/settings/auto-explain/log-nested-statements.d.ts +12 -0
- package/lib/commands/pg/settings/auto-explain/log-nested-statements.js +25 -0
- package/lib/commands/pg/settings/auto-explain/log-triggers.d.ts +13 -0
- package/lib/commands/pg/settings/auto-explain/log-triggers.js +30 -0
- package/lib/commands/pg/settings/auto-explain/log-verbose.d.ts +17 -0
- package/lib/commands/pg/settings/auto-explain/log-verbose.js +33 -0
- package/lib/commands/pg/settings/auto-explain.d.ts +18 -0
- package/lib/commands/pg/settings/auto-explain.js +38 -0
- package/lib/commands/pg/settings/index.d.ts +13 -0
- package/lib/commands/pg/settings/index.js +34 -0
- package/lib/commands/pg/settings/log-connections.d.ts +17 -0
- package/lib/commands/pg/settings/log-connections.js +34 -0
- package/lib/commands/pg/settings/log-lock-waits.d.ts +13 -0
- package/lib/commands/pg/settings/log-lock-waits.js +31 -0
- package/lib/commands/pg/settings/log-min-duration-statement.d.ts +15 -0
- package/lib/commands/pg/settings/log-min-duration-statement.js +33 -0
- package/lib/commands/pg/settings/log-statement.d.ts +12 -0
- package/lib/commands/pg/settings/log-statement.js +30 -0
- package/lib/commands/pg/settings/track-functions.d.ts +12 -0
- package/lib/commands/pg/settings/track-functions.js +29 -0
- package/lib/commands/pg/unfollow.d.ts +14 -0
- package/lib/commands/pg/unfollow.js +40 -0
- package/lib/commands/pg/upgrade.d.ts +15 -0
- package/lib/commands/pg/upgrade.js +58 -0
- package/lib/commands/pg/vacuum-stats.d.ts +13 -0
- package/lib/commands/pg/vacuum-stats.js +65 -0
- package/lib/commands/pg/wait.d.ts +15 -0
- package/lib/commands/pg/wait.js +79 -0
- package/lib/commands/pipelines/add.d.ts +4 -4
- package/lib/commands/pipelines/connect.d.ts +2 -2
- package/lib/commands/pipelines/connect.js +1 -1
- package/lib/commands/pipelines/create.d.ts +5 -5
- package/lib/commands/pipelines/destroy.d.ts +1 -1
- package/lib/commands/pipelines/diff.d.ts +2 -2
- package/lib/commands/pipelines/diff.js +1 -1
- package/lib/commands/pipelines/info.d.ts +1 -1
- package/lib/commands/pipelines/open.d.ts +1 -1
- package/lib/commands/pipelines/promote.d.ts +3 -3
- package/lib/commands/pipelines/remove.d.ts +2 -2
- package/lib/commands/pipelines/rename.d.ts +2 -2
- package/lib/commands/pipelines/setup.d.ts +3 -3
- package/lib/commands/pipelines/transfer.d.ts +3 -3
- package/lib/commands/pipelines/update.d.ts +3 -3
- package/lib/commands/ps/autoscale/disable.d.ts +2 -2
- package/lib/commands/ps/autoscale/enable.d.ts +5 -5
- package/lib/commands/ps/index.d.ts +15 -0
- package/lib/commands/ps/index.js +195 -0
- package/lib/commands/ps/restart.d.ts +17 -0
- package/lib/commands/ps/restart.js +38 -0
- package/lib/commands/ps/scale.d.ts +13 -0
- package/lib/commands/ps/scale.js +108 -0
- package/lib/commands/ps/stop.d.ts +17 -0
- package/lib/commands/ps/stop.js +33 -0
- package/lib/commands/ps/type.d.ts +12 -0
- package/lib/commands/ps/type.js +163 -0
- package/lib/commands/ps/wait.d.ts +4 -4
- package/lib/commands/rake.d.ts +4 -4
- package/lib/commands/redis/cli.d.ts +15 -0
- package/lib/commands/redis/cli.js +204 -0
- package/lib/commands/redis/credentials.d.ts +14 -0
- package/lib/commands/redis/credentials.js +32 -0
- package/lib/commands/redis/info.d.ts +15 -0
- package/lib/commands/redis/info.js +25 -0
- package/lib/commands/redis/keyspace-notifications.d.ts +14 -0
- package/lib/commands/redis/keyspace-notifications.js +47 -0
- package/lib/commands/redis/maintenance.d.ts +16 -0
- package/lib/commands/redis/maintenance.js +63 -0
- package/lib/commands/redis/maxmemory.d.ts +14 -0
- package/lib/commands/redis/maxmemory.js +40 -0
- package/lib/commands/redis/promote.d.ts +13 -0
- package/lib/commands/redis/promote.js +39 -0
- package/lib/commands/redis/stats-reset.d.ts +14 -0
- package/lib/commands/redis/stats-reset.js +36 -0
- package/lib/commands/redis/timeout.d.ts +14 -0
- package/lib/commands/redis/timeout.js +35 -0
- package/lib/commands/redis/upgrade.d.ts +15 -0
- package/lib/commands/redis/upgrade.js +37 -0
- package/lib/commands/redis/wait.d.ts +14 -0
- package/lib/commands/redis/wait.js +60 -0
- package/lib/commands/releases/index.d.ts +14 -0
- package/lib/commands/releases/index.js +124 -0
- package/lib/commands/releases/info.d.ts +15 -0
- package/lib/commands/releases/info.js +56 -0
- package/lib/commands/releases/output.d.ts +13 -0
- package/lib/commands/releases/output.js +37 -0
- package/lib/commands/releases/rollback.d.ts +14 -0
- package/lib/commands/releases/rollback.js +48 -0
- package/lib/commands/reviewapps/disable.d.ts +3 -3
- package/lib/commands/reviewapps/enable.d.ts +3 -3
- package/lib/commands/run/detached.d.ts +7 -8
- package/lib/commands/run/detached.js +16 -20
- package/lib/commands/run/index.d.ts +10 -11
- package/lib/commands/run/index.js +16 -17
- package/lib/commands/run/inside.d.ts +5 -7
- package/lib/commands/run/inside.js +10 -14
- package/lib/commands/sessions/destroy.d.ts +1 -1
- package/lib/commands/spaces/create.d.ts +22 -0
- package/lib/commands/spaces/create.js +73 -0
- package/lib/commands/spaces/destroy.d.ts +14 -0
- package/lib/commands/spaces/destroy.js +49 -0
- package/lib/commands/spaces/drains/get.d.ts +12 -0
- package/lib/commands/spaces/drains/get.js +27 -0
- package/lib/commands/spaces/drains/set.d.ts +14 -0
- package/lib/commands/spaces/drains/set.js +29 -0
- package/lib/commands/spaces/hosts.d.ts +14 -0
- package/lib/commands/spaces/hosts.js +37 -0
- package/lib/commands/spaces/index.d.ts +16 -0
- package/lib/commands/spaces/index.js +55 -0
- package/lib/commands/spaces/info.d.ts +14 -0
- package/lib/commands/spaces/info.js +47 -0
- package/lib/commands/spaces/peerings/accept.d.ts +15 -0
- package/lib/commands/spaces/peerings/accept.js +36 -0
- package/lib/commands/spaces/peerings/destroy.d.ts +15 -0
- package/lib/commands/spaces/peerings/destroy.js +45 -0
- package/lib/commands/spaces/peerings/index.d.ts +13 -0
- package/lib/commands/spaces/peerings/index.js +33 -0
- package/lib/commands/spaces/peerings/info.d.ts +15 -0
- package/lib/commands/spaces/peerings/info.js +59 -0
- package/lib/commands/spaces/ps.d.ts +15 -0
- package/lib/commands/spaces/ps.js +82 -0
- package/lib/commands/spaces/rename.d.ts +11 -0
- package/lib/commands/spaces/rename.js +26 -0
- package/lib/commands/spaces/topology.d.ts +32 -0
- package/lib/commands/spaces/topology.js +89 -0
- package/lib/commands/spaces/transfer.d.ts +11 -0
- package/lib/commands/spaces/transfer.js +35 -0
- package/lib/commands/spaces/trusted-ips/add.d.ts +16 -0
- package/lib/commands/spaces/trusted-ips/add.js +43 -0
- package/lib/commands/spaces/trusted-ips/index.d.ts +15 -0
- package/lib/commands/spaces/trusted-ips/index.js +52 -0
- package/lib/commands/spaces/trusted-ips/remove.d.ts +15 -0
- package/lib/commands/spaces/trusted-ips/remove.js +44 -0
- package/lib/commands/spaces/vpn/config.d.ts +14 -0
- package/lib/commands/spaces/vpn/config.js +54 -0
- package/lib/commands/spaces/vpn/connect.d.ts +15 -0
- package/lib/commands/spaces/vpn/connect.js +48 -0
- package/lib/commands/spaces/vpn/connections.d.ts +17 -0
- package/lib/commands/spaces/vpn/connections.js +57 -0
- package/lib/commands/spaces/vpn/destroy.d.ts +14 -0
- package/lib/commands/spaces/vpn/destroy.js +38 -0
- package/lib/commands/spaces/vpn/info.d.ts +16 -0
- package/lib/commands/spaces/vpn/info.js +82 -0
- package/lib/commands/spaces/vpn/update.d.ts +14 -0
- package/lib/commands/spaces/vpn/update.js +39 -0
- package/lib/commands/spaces/vpn/wait.d.ts +16 -0
- package/lib/commands/spaces/vpn/wait.js +70 -0
- package/lib/commands/spaces/wait.d.ts +17 -0
- package/lib/commands/spaces/wait.js +89 -0
- package/lib/commands/status.js +4 -4
- package/lib/commands/teams/index.d.ts +9 -0
- package/lib/commands/teams/index.js +29 -0
- package/lib/commands/webhooks/add.d.ts +8 -8
- package/lib/commands/webhooks/deliveries/index.d.ts +4 -4
- package/lib/commands/webhooks/deliveries/info.d.ts +4 -4
- package/lib/commands/webhooks/events/index.d.ts +3 -3
- package/lib/commands/webhooks/events/info.d.ts +4 -4
- package/lib/commands/webhooks/index.d.ts +3 -3
- package/lib/commands/webhooks/info.d.ts +4 -4
- package/lib/commands/webhooks/remove.d.ts +4 -4
- package/lib/commands/webhooks/update.d.ts +9 -9
- package/lib/global_telemetry.js +10 -4
- package/lib/hooks/postrun/performance_analytics.js +5 -4
- package/lib/hooks/prerun/analytics.js +3 -0
- package/lib/lib/addons/addons_wait.d.ts +78 -0
- package/lib/lib/addons/addons_wait.js +56 -0
- package/lib/lib/addons/create_addon.d.ts +7 -0
- package/lib/lib/addons/create_addon.js +59 -0
- package/lib/lib/addons/destroy_addon.d.ts +3 -0
- package/lib/lib/addons/destroy_addon.js +48 -0
- package/lib/lib/addons/resolve.d.ts +39 -0
- package/lib/lib/addons/resolve.js +180 -0
- package/lib/lib/addons/util.d.ts +9 -0
- package/lib/lib/addons/util.js +72 -0
- package/lib/lib/apps/app-transfer.d.ts +10 -0
- package/lib/lib/apps/app-transfer.js +35 -0
- package/lib/lib/apps/error_info.d.ts +7 -0
- package/lib/lib/apps/error_info.js +185 -0
- package/lib/lib/autocomplete/base.d.ts +1 -1
- package/lib/lib/autocomplete/completions.d.ts +5 -1
- package/lib/lib/autocomplete/completions.js +6 -1
- package/lib/lib/certs/certificate_details.d.ts +2 -0
- package/lib/lib/certs/certificate_details.js +37 -0
- package/lib/lib/certs/display_table.d.ts +2 -0
- package/lib/lib/certs/display_table.js +51 -0
- package/lib/lib/certs/domains.d.ts +3 -0
- package/lib/lib/certs/domains.js +45 -0
- package/lib/lib/certs/flags.d.ts +7 -0
- package/lib/lib/certs/flags.js +42 -0
- package/lib/lib/certs/format_date.d.ts +1 -0
- package/lib/lib/certs/format_date.js +11 -0
- package/lib/lib/certs/get_cert_and_key.d.ts +9 -0
- package/lib/lib/certs/get_cert_and_key.js +11 -0
- package/lib/lib/ci/git.d.ts +7 -1
- package/lib/lib/ci/git.js +44 -1
- package/lib/lib/ci/interfaces/kolkrabbi.d.ts +1 -1
- package/lib/lib/ci/source.js +3 -3
- package/lib/lib/ci/test-run.js +2 -2
- package/lib/lib/config/quote.js +1 -1
- package/lib/lib/confirmCommand.d.ts +1 -0
- package/lib/lib/confirmCommand.js +23 -0
- package/lib/lib/container/debug.d.ts +2 -0
- package/lib/lib/container/debug.js +5 -0
- package/lib/lib/container/docker_helper.d.ts +24 -0
- package/lib/lib/container/docker_helper.js +168 -0
- package/lib/lib/container/helpers.d.ts +8 -0
- package/lib/lib/container/helpers.js +29 -0
- package/lib/lib/container/streamer.d.ts +1 -0
- package/lib/lib/container/streamer.js +31 -0
- package/lib/lib/domains/domains.d.ts +6 -0
- package/lib/lib/domains/domains.js +104 -0
- package/lib/lib/git/git.d.ts +3 -0
- package/lib/lib/git/git.js +22 -3
- package/lib/lib/local/run-foreman.d.ts +1 -0
- package/lib/lib/local/run-foreman.js +229 -1
- package/lib/lib/members/util.d.ts +3 -0
- package/lib/lib/members/util.js +25 -0
- package/lib/lib/members/utils.d.ts +2 -0
- package/lib/lib/members/utils.js +14 -0
- package/lib/lib/notify.d.ts +1 -0
- package/lib/lib/notify.js +23 -0
- package/lib/lib/orgs/utils.d.ts +5 -0
- package/lib/lib/orgs/utils.js +24 -0
- package/lib/lib/pg/backups.d.ts +17 -0
- package/lib/lib/pg/backups.js +164 -0
- package/lib/lib/pg/bastion.d.ts +29 -0
- package/lib/lib/pg/bastion.js +121 -0
- package/lib/lib/pg/config.d.ts +2 -0
- package/lib/lib/pg/config.js +13 -0
- package/lib/lib/pg/download.d.ts +5 -0
- package/lib/lib/pg/download.js +34 -0
- package/lib/lib/pg/fetcher.d.ts +39 -0
- package/lib/lib/pg/fetcher.js +137 -0
- package/lib/lib/pg/host.d.ts +1 -0
- package/lib/lib/pg/host.js +7 -0
- package/lib/lib/pg/psql.d.ts +48 -0
- package/lib/lib/pg/psql.js +252 -0
- package/lib/lib/pg/push_pull.d.ts +13 -0
- package/lib/lib/pg/push_pull.js +118 -0
- package/lib/lib/pg/setter.d.ts +16 -0
- package/lib/lib/pg/setter.js +65 -0
- package/lib/lib/pg/types.d.ts +230 -0
- package/lib/lib/pg/types.js +2 -0
- package/lib/lib/pg/util.d.ts +36 -0
- package/lib/lib/pg/util.js +183 -0
- package/lib/lib/redis/api.d.ts +65 -0
- package/lib/lib/redis/api.js +122 -0
- package/lib/lib/releases/output.d.ts +1 -0
- package/lib/lib/releases/output.js +14 -0
- package/lib/lib/releases/releases.d.ts +6 -0
- package/lib/lib/releases/releases.js +32 -0
- package/lib/lib/releases/status_helper.d.ts +5 -0
- package/lib/lib/releases/status_helper.js +25 -0
- package/lib/lib/run/dyno.js +2 -2
- package/lib/lib/run/log-displayer.d.ts +1 -1
- package/lib/lib/spaces/format.d.ts +4 -0
- package/lib/lib/spaces/format.js +60 -0
- package/lib/lib/spaces/hosts.d.ts +9 -0
- package/lib/lib/spaces/hosts.js +34 -0
- package/lib/lib/spaces/outbound-rules.d.ts +4 -0
- package/lib/lib/spaces/outbound-rules.js +78 -0
- package/lib/lib/spaces/parsers.d.ts +8 -0
- package/lib/lib/spaces/parsers.js +17 -0
- package/lib/lib/spaces/peering.d.ts +4 -0
- package/lib/lib/spaces/peering.js +53 -0
- package/lib/lib/spaces/spaces.d.ts +4 -0
- package/lib/lib/spaces/spaces.js +37 -0
- package/lib/lib/spaces/vpn-connections.d.ts +2 -0
- package/lib/lib/spaces/vpn-connections.js +22 -0
- package/lib/lib/teamUtils.d.ts +3 -0
- package/lib/lib/teamUtils.js +18 -0
- package/lib/lib/time.d.ts +2 -0
- package/lib/lib/time.js +29 -0
- package/lib/lib/types/app_errors.d.ts +6 -0
- package/lib/lib/types/app_errors.js +2 -0
- package/lib/lib/types/domain.d.ts +61 -0
- package/lib/lib/types/domain.js +5 -0
- package/lib/lib/types/notifications.d.ts +20 -0
- package/lib/lib/types/notifications.js +2 -0
- package/lib/lib/utils/keyValueParser.d.ts +4 -0
- package/lib/lib/utils/keyValueParser.js +9 -0
- package/lib/lib/utils/multisort.d.ts +32 -0
- package/lib/lib/utils/multisort.js +66 -0
- package/lib/lib/utils/paginator.d.ts +2 -0
- package/lib/lib/utils/paginator.js +29 -0
- package/lib/lib/utils/uuid-validate.d.ts +1 -0
- package/lib/lib/utils/uuid-validate.js +7 -0
- package/lib/user-config.js +2 -2
- package/oclif.manifest.json +12684 -2674
- package/package.json +116 -65
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const color_1 = require("@heroku-cli/color");
|
|
4
|
+
const command_1 = require("@heroku-cli/command");
|
|
5
|
+
const core_1 = require("@oclif/core");
|
|
6
|
+
const util_1 = require("../../../lib/pg/util");
|
|
7
|
+
const fetcher_1 = require("../../../lib/pg/fetcher");
|
|
8
|
+
const host_1 = require("../../../lib/pg/host");
|
|
9
|
+
const confirmCommand_1 = require("../../../lib/confirmCommand");
|
|
10
|
+
class Destroy extends command_1.Command {
|
|
11
|
+
async run() {
|
|
12
|
+
const { flags, args } = await this.parse(Destroy);
|
|
13
|
+
const { database } = args;
|
|
14
|
+
const { app, name, confirm } = flags;
|
|
15
|
+
if (name === 'default') {
|
|
16
|
+
throw new Error('Default credential cannot be destroyed.');
|
|
17
|
+
}
|
|
18
|
+
const db = await (0, fetcher_1.getAddon)(this.heroku, app, database);
|
|
19
|
+
if ((0, util_1.essentialPlan)(db)) {
|
|
20
|
+
throw new Error("You can't destroy the default credential on Essential-tier databases.");
|
|
21
|
+
}
|
|
22
|
+
const { body: attachments } = await this.heroku.get(`/addons/${db.name}/addon-attachments`);
|
|
23
|
+
const credAttachments = attachments.filter(a => a.namespace === `credential:${name}`);
|
|
24
|
+
const credAttachmentApps = Array.from(new Set(credAttachments.map(a => { var _a; return (_a = a.app) === null || _a === void 0 ? void 0 : _a.name; })));
|
|
25
|
+
if (credAttachmentApps.length > 0)
|
|
26
|
+
throw new Error(`Credential ${name} must be detached from the app${credAttachmentApps.length > 1 ? 's' : ''} ${credAttachmentApps.map(appName => color_1.default.app(appName || ''))
|
|
27
|
+
.join(', ')} before destroying.`);
|
|
28
|
+
await (0, confirmCommand_1.default)(app, confirm);
|
|
29
|
+
core_1.ux.action.start(`Destroying credential ${color_1.default.cyan.bold(name)}`);
|
|
30
|
+
await this.heroku.delete(`/postgres/v0/databases/${db.name}/credentials/${encodeURIComponent(name)}`, { hostname: (0, host_1.default)() });
|
|
31
|
+
core_1.ux.action.stop();
|
|
32
|
+
core_1.ux.log(`The credential has been destroyed within ${db.name}.`);
|
|
33
|
+
core_1.ux.log(`Database objects owned by ${name} will be assigned to the default credential.`);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.default = Destroy;
|
|
37
|
+
Destroy.topic = 'pg';
|
|
38
|
+
Destroy.description = 'destroy credential within database';
|
|
39
|
+
Destroy.example = '$ heroku pg:credentials:destroy postgresql-transparent-56874 --name cred-name -a woodstock-production';
|
|
40
|
+
Destroy.flags = {
|
|
41
|
+
name: command_1.flags.string({ char: 'n', required: true, description: 'unique identifier for the credential' }),
|
|
42
|
+
confirm: command_1.flags.string({ char: 'c' }),
|
|
43
|
+
app: command_1.flags.app({ required: true }),
|
|
44
|
+
remote: command_1.flags.remote(),
|
|
45
|
+
};
|
|
46
|
+
Destroy.args = {
|
|
47
|
+
database: core_1.Args.string(),
|
|
48
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
export default class RepairDefault extends Command {
|
|
3
|
+
static topic: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static example: string;
|
|
6
|
+
static flags: {
|
|
7
|
+
confirm: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
8
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
9
|
+
remote: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
10
|
+
};
|
|
11
|
+
static args: {
|
|
12
|
+
database: import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const command_1 = require("@heroku-cli/command");
|
|
4
|
+
const core_1 = require("@oclif/core");
|
|
5
|
+
const fetcher_1 = require("../../../lib/pg/fetcher");
|
|
6
|
+
const util_1 = require("../../../lib/pg/util");
|
|
7
|
+
const confirmCommand_1 = require("../../../lib/confirmCommand");
|
|
8
|
+
const tsheredoc_1 = require("tsheredoc");
|
|
9
|
+
const host_1 = require("../../../lib/pg/host");
|
|
10
|
+
class RepairDefault extends command_1.Command {
|
|
11
|
+
async run() {
|
|
12
|
+
const { flags, args } = await this.parse(RepairDefault);
|
|
13
|
+
const { app, confirm } = flags;
|
|
14
|
+
const { database } = args;
|
|
15
|
+
const db = await (0, fetcher_1.getAddon)(this.heroku, app, database);
|
|
16
|
+
if ((0, util_1.essentialPlan)(db))
|
|
17
|
+
throw new Error("You can't perform this operation on Essential-tier databases.");
|
|
18
|
+
await (0, confirmCommand_1.default)(app, confirm, (0, tsheredoc_1.default)(`
|
|
19
|
+
Destructive Action
|
|
20
|
+
Ownership of all database objects owned by additional credentials will be transferred to the default credential.
|
|
21
|
+
This command will also grant the default credential admin option for all additional credentials.
|
|
22
|
+
`));
|
|
23
|
+
core_1.ux.action.start('Resetting permissions and object ownership for default role to factory settings');
|
|
24
|
+
await this.heroku.post(`/postgres/v0/databases/${db.name}/repair-default`, { hostname: (0, host_1.default)() });
|
|
25
|
+
core_1.ux.action.stop();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
exports.default = RepairDefault;
|
|
29
|
+
RepairDefault.topic = 'pg';
|
|
30
|
+
RepairDefault.description = 'repair the permissions of the default credential within database';
|
|
31
|
+
RepairDefault.example = '$ heroku pg:credentials:repair-default postgresql-something-12345';
|
|
32
|
+
RepairDefault.flags = {
|
|
33
|
+
confirm: command_1.flags.string({ char: 'c' }),
|
|
34
|
+
app: command_1.flags.app({ required: true }),
|
|
35
|
+
remote: command_1.flags.remote(),
|
|
36
|
+
};
|
|
37
|
+
RepairDefault.args = {
|
|
38
|
+
database: core_1.Args.string(),
|
|
39
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
export default class Rotate extends Command {
|
|
3
|
+
static topic: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static flags: {
|
|
6
|
+
name: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
7
|
+
all: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
8
|
+
confirm: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
9
|
+
force: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
10
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
11
|
+
};
|
|
12
|
+
static args: {
|
|
13
|
+
database: import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const color_1 = require("@heroku-cli/color");
|
|
4
|
+
const command_1 = require("@heroku-cli/command");
|
|
5
|
+
const core_1 = require("@oclif/core");
|
|
6
|
+
const confirmCommand_1 = require("../../../lib/confirmCommand");
|
|
7
|
+
const fetcher_1 = require("../../../lib/pg/fetcher");
|
|
8
|
+
const host_1 = require("../../../lib/pg/host");
|
|
9
|
+
const util_1 = require("../../../lib/pg/util");
|
|
10
|
+
class Rotate extends command_1.Command {
|
|
11
|
+
async run() {
|
|
12
|
+
const { flags, args } = await this.parse(Rotate);
|
|
13
|
+
const { app, all, confirm, name, force } = flags;
|
|
14
|
+
const { addon: db } = await (0, fetcher_1.getAttachment)(this.heroku, app, args.database);
|
|
15
|
+
const warnings = [];
|
|
16
|
+
const cred = name || 'default';
|
|
17
|
+
if (all && name !== undefined) {
|
|
18
|
+
throw new Error('cannot pass both --all and --name');
|
|
19
|
+
}
|
|
20
|
+
if ((0, util_1.legacyEssentialPlan)(db) && cred !== 'default') {
|
|
21
|
+
throw new Error('Legacy Essential-tier databases do not support named credentials.');
|
|
22
|
+
}
|
|
23
|
+
if (all && force) {
|
|
24
|
+
warnings.push('This forces rotation on all credentials including the default credential.');
|
|
25
|
+
}
|
|
26
|
+
let { body: attachments } = await this.heroku.get(`/addons/${db.name}/addon-attachments`);
|
|
27
|
+
if (name) {
|
|
28
|
+
attachments = attachments.filter(a => a.namespace === `credential:${cred}`);
|
|
29
|
+
}
|
|
30
|
+
if (!all) {
|
|
31
|
+
warnings.push(`The password for the ${cred} credential will rotate.`);
|
|
32
|
+
}
|
|
33
|
+
if (all || force || cred === 'default') {
|
|
34
|
+
warnings.push('Connections will be reset and applications will be restarted.');
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
warnings.push('Connections older than 30 minutes will be reset, and a temporary rotation username will be used during the process.');
|
|
38
|
+
}
|
|
39
|
+
if (force) {
|
|
40
|
+
warnings.push(`Any followers lagging in replication (see ${color_1.default.cyan.bold('heroku pg:info')}) will be inaccessible until caught up.`);
|
|
41
|
+
}
|
|
42
|
+
if (attachments.length > 0) {
|
|
43
|
+
const uniqueAttachments = [...new Set(attachments.map(attachment => color_1.default.app(attachment.app.name || '')))]
|
|
44
|
+
.sort()
|
|
45
|
+
.join(', ');
|
|
46
|
+
warnings.push(`This command will affect the app${(attachments.length > 1) ? 's' : ''} ${uniqueAttachments}.`);
|
|
47
|
+
}
|
|
48
|
+
await (0, confirmCommand_1.default)(app, confirm, `Destructive Action\n${warnings.join('\n')}`);
|
|
49
|
+
const options = {
|
|
50
|
+
hostname: (0, host_1.default)(),
|
|
51
|
+
body: { forced: force !== null && force !== void 0 ? force : undefined },
|
|
52
|
+
headers: {
|
|
53
|
+
Authorization: `Basic ${Buffer.from(`:${this.heroku.auth}`).toString('base64')}`,
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
if (all) {
|
|
57
|
+
core_1.ux.action.start(`Rotating all credentials on ${color_1.default.yellow(db.name)}`);
|
|
58
|
+
await this.heroku.post(`/postgres/v0/databases/${db.name}/credentials_rotation`, options);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
core_1.ux.action.start(`Rotating ${cred} on ${color_1.default.yellow(db.name)}`);
|
|
62
|
+
await this.heroku.post(`/postgres/v0/databases/${db.name}/credentials/${encodeURIComponent(cred)}/credentials_rotation`, options);
|
|
63
|
+
}
|
|
64
|
+
core_1.ux.action.stop();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.default = Rotate;
|
|
68
|
+
Rotate.topic = 'pg';
|
|
69
|
+
Rotate.description = 'rotate the database credentials';
|
|
70
|
+
Rotate.flags = {
|
|
71
|
+
name: command_1.flags.string({
|
|
72
|
+
char: 'n',
|
|
73
|
+
description: 'which credential to rotate (default credentials if not specified and --all is not used)',
|
|
74
|
+
}),
|
|
75
|
+
all: command_1.flags.boolean({ description: 'rotate all credentials', exclusive: ['name'] }),
|
|
76
|
+
confirm: command_1.flags.string({ char: 'c' }),
|
|
77
|
+
force: command_1.flags.boolean({ description: 'forces rotating the targeted credentials' }),
|
|
78
|
+
app: command_1.flags.app({ required: true }),
|
|
79
|
+
};
|
|
80
|
+
Rotate.args = {
|
|
81
|
+
database: core_1.Args.string(),
|
|
82
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
export default class Url extends Command {
|
|
3
|
+
static topic: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static flags: {
|
|
6
|
+
name: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
7
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
8
|
+
remote: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
database: import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const color_1 = require("@heroku-cli/color");
|
|
4
|
+
const command_1 = require("@heroku-cli/command");
|
|
5
|
+
const core_1 = require("@oclif/core");
|
|
6
|
+
const util_1 = require("../../../lib/pg/util");
|
|
7
|
+
const fetcher_1 = require("../../../lib/pg/fetcher");
|
|
8
|
+
const host_1 = require("../../../lib/pg/host");
|
|
9
|
+
const url_1 = require("url");
|
|
10
|
+
const tsheredoc_1 = require("tsheredoc");
|
|
11
|
+
class Url extends command_1.Command {
|
|
12
|
+
async run() {
|
|
13
|
+
const { flags, args } = await this.parse(Url);
|
|
14
|
+
const { app, name } = flags;
|
|
15
|
+
const { database } = args;
|
|
16
|
+
const db = await (0, fetcher_1.getAddon)(this.heroku, app, database);
|
|
17
|
+
if ((0, util_1.legacyEssentialPlan)(db) && name !== 'default') {
|
|
18
|
+
core_1.ux.error('Legacy Essential-tier databases do not support named credentials.');
|
|
19
|
+
}
|
|
20
|
+
const { body: credInfo } = await this.heroku.get(`/postgres/v0/databases/${db.name}/credentials/${encodeURIComponent(name)}`, {
|
|
21
|
+
hostname: (0, host_1.default)(),
|
|
22
|
+
headers: {
|
|
23
|
+
Authorization: `Basic ${Buffer.from(`:${this.heroku.auth}`).toString('base64')}`,
|
|
24
|
+
},
|
|
25
|
+
});
|
|
26
|
+
const activeCreds = credInfo.credentials.find(c => c.state === 'active');
|
|
27
|
+
if (!activeCreds) {
|
|
28
|
+
core_1.ux.error(`Could not find any active credentials for ${name}`, { exit: 1 });
|
|
29
|
+
}
|
|
30
|
+
const creds = Object.assign({}, db, {
|
|
31
|
+
database: credInfo.database, host: credInfo.host, port: credInfo.port,
|
|
32
|
+
}, {
|
|
33
|
+
user: activeCreds === null || activeCreds === void 0 ? void 0 : activeCreds.user, password: activeCreds === null || activeCreds === void 0 ? void 0 : activeCreds.password,
|
|
34
|
+
});
|
|
35
|
+
const connUrl = new url_1.URL(`postgres://${creds.host}/${creds.database}`);
|
|
36
|
+
connUrl.port = creds.port.toString();
|
|
37
|
+
if (creds.user && creds.password) {
|
|
38
|
+
connUrl.username = creds.user;
|
|
39
|
+
connUrl.password = creds.password;
|
|
40
|
+
}
|
|
41
|
+
core_1.ux.log((0, tsheredoc_1.default)(`
|
|
42
|
+
Connection information for ${color_1.default.yellow(name)} credential.
|
|
43
|
+
Connection info string:
|
|
44
|
+
"dbname=${creds.database} host=${creds.host} port=${creds.port} user=${creds.user} password=${creds.password} sslmode=require"
|
|
45
|
+
Connection URL:
|
|
46
|
+
${connUrl}
|
|
47
|
+
`));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.default = Url;
|
|
51
|
+
Url.topic = 'pg';
|
|
52
|
+
Url.description = 'show information on a database credential';
|
|
53
|
+
Url.flags = {
|
|
54
|
+
name: command_1.flags.string({
|
|
55
|
+
char: 'n',
|
|
56
|
+
description: 'which credential to show (default credentials if not specified)',
|
|
57
|
+
default: 'default',
|
|
58
|
+
}),
|
|
59
|
+
app: command_1.flags.app({ required: true }),
|
|
60
|
+
remote: command_1.flags.remote(),
|
|
61
|
+
};
|
|
62
|
+
Url.args = {
|
|
63
|
+
database: core_1.Args.string(),
|
|
64
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
import { CredentialInfo, CredentialsInfo } from '../../lib/pg/types';
|
|
3
|
+
export default class Credentials extends Command {
|
|
4
|
+
static topic: string;
|
|
5
|
+
static description: string;
|
|
6
|
+
static flags: {
|
|
7
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
8
|
+
remote: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
database: import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
protected sortByDefaultAndName(credentials: CredentialsInfo): CredentialsInfo;
|
|
15
|
+
protected isDefaultCredential(cred: CredentialInfo): boolean;
|
|
16
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const command_1 = require("@heroku-cli/command");
|
|
4
|
+
const core_1 = require("@oclif/core");
|
|
5
|
+
const host_1 = require("../../lib/pg/host");
|
|
6
|
+
const fetcher_1 = require("../../lib/pg/fetcher");
|
|
7
|
+
const util_1 = require("../../lib/pg/util");
|
|
8
|
+
class Credentials extends command_1.Command {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(Credentials);
|
|
11
|
+
const { app } = flags;
|
|
12
|
+
const { database } = args;
|
|
13
|
+
const addon = await (0, fetcher_1.getAddon)(this.heroku, app, database);
|
|
14
|
+
const { body: credentials } = await this.heroku.get(`/postgres/v0/databases/${addon.id}/credentials`, {
|
|
15
|
+
hostname: (0, host_1.default)(),
|
|
16
|
+
headers: {
|
|
17
|
+
Authorization: `Basic ${Buffer.from(`:${this.heroku.auth}`).toString('base64')}`,
|
|
18
|
+
},
|
|
19
|
+
});
|
|
20
|
+
const sortedCredentials = this.sortByDefaultAndName(credentials);
|
|
21
|
+
const { body: attachments } = await this.heroku.get(`/addons/${addon.id}/addon-attachments`);
|
|
22
|
+
const presentCredential = (cred) => {
|
|
23
|
+
let credAttachments = [];
|
|
24
|
+
if (cred.name === 'default') {
|
|
25
|
+
credAttachments = attachments.filter(a => a.namespace === null);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
credAttachments = attachments.filter(a => a.namespace === `credential:${cred.name}`);
|
|
29
|
+
}
|
|
30
|
+
return (0, util_1.presentCredentialAttachments)(app, credAttachments, sortedCredentials, cred.name);
|
|
31
|
+
};
|
|
32
|
+
core_1.ux.table(credentials, {
|
|
33
|
+
Credential: {
|
|
34
|
+
get: presentCredential,
|
|
35
|
+
},
|
|
36
|
+
State: {
|
|
37
|
+
get: cred => cred.state,
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
sortByDefaultAndName(credentials) {
|
|
42
|
+
return credentials.sort((a, b) => {
|
|
43
|
+
const isDefaultA = this.isDefaultCredential(a);
|
|
44
|
+
const isDefaultB = this.isDefaultCredential(b);
|
|
45
|
+
return isDefaultB < isDefaultA ? -1 : (isDefaultA < isDefaultB ? 1 : a.name.localeCompare(b.name));
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
isDefaultCredential(cred) {
|
|
49
|
+
return cred.name === 'default';
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
exports.default = Credentials;
|
|
53
|
+
Credentials.topic = 'pg';
|
|
54
|
+
Credentials.description = 'show information on credentials in the database';
|
|
55
|
+
Credentials.flags = {
|
|
56
|
+
app: command_1.flags.app({ required: true }),
|
|
57
|
+
remote: command_1.flags.remote(),
|
|
58
|
+
};
|
|
59
|
+
Credentials.args = {
|
|
60
|
+
database: core_1.Args.string(),
|
|
61
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
export default class Diagnose extends Command {
|
|
3
|
+
static topic: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static flags: {
|
|
6
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
8
|
+
remote: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
'DATABASE|REPORT_ID': import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
private displayReport;
|
|
15
|
+
private display;
|
|
16
|
+
private generateParams;
|
|
17
|
+
private generateReport;
|
|
18
|
+
}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const command_1 = require("@heroku-cli/command");
|
|
4
|
+
const core_1 = require("@oclif/core");
|
|
5
|
+
const util_1 = require("@oclif/core/lib/util");
|
|
6
|
+
const tsheredoc_1 = require("tsheredoc");
|
|
7
|
+
const fetcher_1 = require("../../lib/pg/fetcher");
|
|
8
|
+
const host_1 = require("../../lib/pg/host");
|
|
9
|
+
const util_2 = require("../../lib/pg/util");
|
|
10
|
+
const color_1 = require("@heroku-cli/color");
|
|
11
|
+
const uuid_validate_1 = require("../../lib/utils/uuid-validate");
|
|
12
|
+
const PGDIAGNOSE_HOST = process.env.PGDIAGNOSE_URL || 'pgdiagnose.herokai.com';
|
|
13
|
+
class Diagnose extends command_1.Command {
|
|
14
|
+
async run() {
|
|
15
|
+
const { flags, args } = await this.parse(Diagnose);
|
|
16
|
+
const id = args['DATABASE|REPORT_ID'];
|
|
17
|
+
let report;
|
|
18
|
+
if (id && (0, uuid_validate_1.uuidValidate)(id)) {
|
|
19
|
+
({ body: report } = await this.heroku.get(`/reports/${encodeURIComponent(id)}`, { hostname: PGDIAGNOSE_HOST }));
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
report = await this.generateReport(id, flags.app);
|
|
23
|
+
}
|
|
24
|
+
this.displayReport(report, flags.json);
|
|
25
|
+
}
|
|
26
|
+
displayReport(report, json) {
|
|
27
|
+
if (json) {
|
|
28
|
+
core_1.ux.styledJSON(report);
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
core_1.ux.log(`Report ${report.id} for ${report.app}::${report.database}\navailable for one month after creation on ${report.created_at}\n`);
|
|
32
|
+
this.display(report.checks.filter(c => c.status === 'red'));
|
|
33
|
+
this.display(report.checks.filter(c => c.status === 'yellow'));
|
|
34
|
+
this.display(report.checks.filter(c => c.status === 'green'));
|
|
35
|
+
this.display(report.checks.filter(c => !['red', 'yellow', 'green'].includes(c.status)));
|
|
36
|
+
}
|
|
37
|
+
display(checks) {
|
|
38
|
+
checks.forEach(check => {
|
|
39
|
+
var _a;
|
|
40
|
+
const colorFn = color_1.default[check.status] || ((txt) => txt);
|
|
41
|
+
core_1.ux.log(colorFn(`${check.status.toUpperCase()}: ${check.name}`));
|
|
42
|
+
const isNonEmptyArray = Array.isArray(check.results) && check.results.length > 0;
|
|
43
|
+
const resultsKeys = Object.keys((_a = check.results) !== null && _a !== void 0 ? _a : {});
|
|
44
|
+
if (check.status === 'green' || (!isNonEmptyArray && resultsKeys.length === 0)) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
if (isNonEmptyArray) {
|
|
48
|
+
const keys = Object.keys(check.results[0]);
|
|
49
|
+
const cols = {};
|
|
50
|
+
keys.forEach(key => {
|
|
51
|
+
cols[(0, util_1.capitalize)(key)] = {
|
|
52
|
+
get: (row) => row[key],
|
|
53
|
+
};
|
|
54
|
+
});
|
|
55
|
+
core_1.ux.table(check.results, cols);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
const [key] = resultsKeys;
|
|
59
|
+
core_1.ux.log(`${key.split('_')
|
|
60
|
+
.map(s => (0, util_1.capitalize)(s))
|
|
61
|
+
.join(' ')} ${check.results[key]}`);
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
async generateParams(url, db, dbName) {
|
|
66
|
+
const base_params = {
|
|
67
|
+
url,
|
|
68
|
+
plan: db.plan.name.split(':')[1],
|
|
69
|
+
app: db.app.name,
|
|
70
|
+
database: dbName,
|
|
71
|
+
};
|
|
72
|
+
if (!(0, util_2.essentialPlan)(db)) {
|
|
73
|
+
const { body: metrics } = await this.heroku.get(`/client/v11/databases/${db.id}/metrics`, { hostname: (0, host_1.default)() });
|
|
74
|
+
base_params.metrics = metrics;
|
|
75
|
+
const { body: burstData } = await this.heroku.get(`/client/v11/databases/${db.id}/burst_status`, { hostname: (0, host_1.default)() });
|
|
76
|
+
if (burstData && Object.keys(burstData).length > 0) {
|
|
77
|
+
base_params.burst_data_present = true;
|
|
78
|
+
base_params.burst_status = burstData.burst_status;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return base_params;
|
|
82
|
+
}
|
|
83
|
+
async generateReport(database, app) {
|
|
84
|
+
const attachment = await (0, fetcher_1.getAttachment)(this.heroku, app, database);
|
|
85
|
+
const { addon: db } = attachment;
|
|
86
|
+
const { body: config } = await this.heroku.get(`/apps/${app}/config-vars`);
|
|
87
|
+
const { url } = (0, util_2.getConnectionDetails)(attachment, config);
|
|
88
|
+
const dbName = (0, util_2.getConfigVarNameFromAttachment)(attachment, config);
|
|
89
|
+
const body = await this.generateParams(url, db, dbName);
|
|
90
|
+
const { body: report } = await this.heroku.post('/reports', { hostname: PGDIAGNOSE_HOST, body });
|
|
91
|
+
return report;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
exports.default = Diagnose;
|
|
95
|
+
Diagnose.topic = 'pg';
|
|
96
|
+
Diagnose.description = (0, tsheredoc_1.default)(`
|
|
97
|
+
run or view diagnostics report
|
|
98
|
+
defaults to DATABASE_URL database if no DATABASE is specified
|
|
99
|
+
if REPORT_ID is specified instead, a previous report is displayed
|
|
100
|
+
|
|
101
|
+
`);
|
|
102
|
+
Diagnose.flags = {
|
|
103
|
+
json: command_1.flags.boolean({ description: 'format output as JSON' }),
|
|
104
|
+
app: command_1.flags.app({ required: true }),
|
|
105
|
+
remote: command_1.flags.remote(),
|
|
106
|
+
};
|
|
107
|
+
Diagnose.args = {
|
|
108
|
+
'DATABASE|REPORT_ID': core_1.Args.string(),
|
|
109
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
export default class Info extends Command {
|
|
3
|
+
static topic: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static flags: {
|
|
6
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
7
|
+
remote: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
8
|
+
};
|
|
9
|
+
static args: {
|
|
10
|
+
database: import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
11
|
+
};
|
|
12
|
+
static aliases: string[];
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const color_1 = require("@heroku-cli/color");
|
|
4
|
+
const command_1 = require("@heroku-cli/command");
|
|
5
|
+
const core_1 = require("@oclif/core");
|
|
6
|
+
const host_1 = require("../../lib/pg/host");
|
|
7
|
+
const fetcher_1 = require("../../lib/pg/fetcher");
|
|
8
|
+
const util_1 = require("../../lib/pg/util");
|
|
9
|
+
function displayDB(db, app) {
|
|
10
|
+
var _a, _b, _c, _d, _e;
|
|
11
|
+
if (db.addon.attachment_names) {
|
|
12
|
+
core_1.ux.styledHeader(db.addon.attachment_names.map((c) => color_1.default.green(c + '_URL'))
|
|
13
|
+
.join(', '));
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
core_1.ux.styledHeader(((_a = db.configVars) === null || _a === void 0 ? void 0 : _a.map(c => color_1.default.green(c)).join(', ')) || '');
|
|
17
|
+
}
|
|
18
|
+
if (db.addon.app.name && db.addon.app.name !== app) {
|
|
19
|
+
(_b = db.dbInfo) === null || _b === void 0 ? void 0 : _b.info.push({ name: 'Billing App', values: [color_1.default.cyan(db.addon.app.name)] });
|
|
20
|
+
}
|
|
21
|
+
(_c = db.dbInfo) === null || _c === void 0 ? void 0 : _c.info.push({ name: 'Add-on', values: [color_1.default.yellow(db.addon.name)] });
|
|
22
|
+
const info = {};
|
|
23
|
+
(_d = db.dbInfo) === null || _d === void 0 ? void 0 : _d.info.forEach(infoObject => {
|
|
24
|
+
if (infoObject.values.length > 0) {
|
|
25
|
+
let valuesArray;
|
|
26
|
+
if (infoObject.resolve_db_name) {
|
|
27
|
+
valuesArray = infoObject.values.map(v => (0, util_1.databaseNameFromUrl)(v, db.config));
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
valuesArray = infoObject.values;
|
|
31
|
+
}
|
|
32
|
+
info[infoObject.name] = valuesArray.join(', ');
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
const keys = (_e = db.dbInfo) === null || _e === void 0 ? void 0 : _e.info.map(i => i.name);
|
|
36
|
+
core_1.ux.styledObject(info, keys);
|
|
37
|
+
core_1.ux.log();
|
|
38
|
+
}
|
|
39
|
+
class Info extends command_1.Command {
|
|
40
|
+
async run() {
|
|
41
|
+
const { flags, args } = await this.parse(Info);
|
|
42
|
+
const { app } = flags;
|
|
43
|
+
const { sortBy } = require('lodash');
|
|
44
|
+
const { database: db } = args;
|
|
45
|
+
let addons;
|
|
46
|
+
const { body: config } = await this.heroku.get(`/apps/${app}/config-vars`);
|
|
47
|
+
if (db) {
|
|
48
|
+
addons = await Promise.all([(0, fetcher_1.getAddon)(this.heroku, app, db)]);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
addons = await (0, fetcher_1.all)(this.heroku, app);
|
|
52
|
+
if (addons.length === 0) {
|
|
53
|
+
core_1.ux.log(`${color_1.default.magenta(app)} has no heroku-postgresql databases.`);
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
let dbs = await Promise.all(addons.map(async (addon) => {
|
|
58
|
+
const pgResponse = await this.heroku.get(`/client/v11/databases/${addon.id}`, {
|
|
59
|
+
hostname: (0, host_1.default)(),
|
|
60
|
+
})
|
|
61
|
+
.catch(error => {
|
|
62
|
+
if (error.statusCode !== 404)
|
|
63
|
+
throw error;
|
|
64
|
+
core_1.ux.warn(`${color_1.default.yellow(addon.name)} is not yet provisioned.\nRun ${color_1.default.cyan.bold('heroku addons:wait')} to wait until the db is provisioned.`);
|
|
65
|
+
});
|
|
66
|
+
const { body: dbInfo } = pgResponse || { body: null };
|
|
67
|
+
return {
|
|
68
|
+
addon,
|
|
69
|
+
config,
|
|
70
|
+
dbInfo,
|
|
71
|
+
};
|
|
72
|
+
}));
|
|
73
|
+
dbs = dbs.filter(db => db.dbInfo);
|
|
74
|
+
dbs.forEach(db => {
|
|
75
|
+
var _a;
|
|
76
|
+
db.configVars = (0, util_1.configVarNamesFromValue)(db.config, ((_a = db.dbInfo) === null || _a === void 0 ? void 0 : _a.resource_url) || '');
|
|
77
|
+
});
|
|
78
|
+
dbs = sortBy(dbs, (db) => db.configVars && db.configVars[0] !== 'DATABASE_URL', 'configVars[0]');
|
|
79
|
+
dbs.forEach(db => displayDB(db, app));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
exports.default = Info;
|
|
83
|
+
Info.topic = 'pg';
|
|
84
|
+
Info.description = 'show database information';
|
|
85
|
+
Info.flags = {
|
|
86
|
+
app: command_1.flags.app({ required: true }),
|
|
87
|
+
remote: command_1.flags.remote(),
|
|
88
|
+
};
|
|
89
|
+
Info.args = {
|
|
90
|
+
database: core_1.Args.string(),
|
|
91
|
+
};
|
|
92
|
+
Info.aliases = ['pg'];
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Command } from '@heroku-cli/command';
|
|
2
|
+
export default class Kill extends Command {
|
|
3
|
+
static topic: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static flags: {
|
|
6
|
+
force: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
7
|
+
app: import("@oclif/core/lib/interfaces").OptionFlag<string, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
8
|
+
remote: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces/parser").CustomOptions>;
|
|
9
|
+
};
|
|
10
|
+
static args: {
|
|
11
|
+
pid: import("@oclif/core/lib/interfaces/parser").Arg<string, Record<string, unknown>>;
|
|
12
|
+
database: import("@oclif/core/lib/interfaces/parser").Arg<string | undefined, Record<string, unknown>>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const command_1 = require("@heroku-cli/command");
|
|
4
|
+
const core_1 = require("@oclif/core");
|
|
5
|
+
const fetcher_1 = require("../../lib/pg/fetcher");
|
|
6
|
+
const psql_1 = require("../../lib/pg/psql");
|
|
7
|
+
const tsheredoc_1 = require("tsheredoc");
|
|
8
|
+
class Kill extends command_1.Command {
|
|
9
|
+
async run() {
|
|
10
|
+
const { flags, args } = await this.parse(Kill);
|
|
11
|
+
const { app, force } = flags;
|
|
12
|
+
const { pid } = args;
|
|
13
|
+
const db = await (0, fetcher_1.database)(this.heroku, app, args.database);
|
|
14
|
+
const query = (0, tsheredoc_1.default) `
|
|
15
|
+
SELECT ${force ? 'pg_terminate_backend' : 'pg_cancel_backend'}(${Number.parseInt(pid, 10)});
|
|
16
|
+
`;
|
|
17
|
+
const output = await (0, psql_1.exec)(db, query);
|
|
18
|
+
core_1.ux.log(output);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.default = Kill;
|
|
22
|
+
Kill.topic = 'pg';
|
|
23
|
+
Kill.description = 'kill a query';
|
|
24
|
+
Kill.flags = {
|
|
25
|
+
force: command_1.flags.boolean({ char: 'f' }),
|
|
26
|
+
app: command_1.flags.app({ required: true }),
|
|
27
|
+
remote: command_1.flags.remote(),
|
|
28
|
+
};
|
|
29
|
+
Kill.args = {
|
|
30
|
+
pid: core_1.Args.string({ required: true }),
|
|
31
|
+
database: core_1.Args.string(),
|
|
32
|
+
};
|