@catladder/cli 1.164.0 → 1.165.1
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/dist/bundles/catci/index.js +2 -2
- package/dist/bundles/catenv/index.js +3 -3
- package/dist/bundles/cli/index.js +23 -18
- package/dist/cli/src/apps/catci/catci.js +19 -91
- package/dist/cli/src/apps/catci/catci.js.map +1 -1
- package/dist/cli/src/apps/catci/commands/security/auditDocument.js +73 -79
- package/dist/cli/src/apps/catci/commands/security/auditDocument.js.map +1 -1
- package/dist/cli/src/apps/catci/commands/security/commands.js +94 -169
- package/dist/cli/src/apps/catci/commands/security/commands.js.map +1 -1
- package/dist/cli/src/apps/catci/commands/security/createSecurityAuditMergeRequest.js +42 -102
- package/dist/cli/src/apps/catci/commands/security/createSecurityAuditMergeRequest.js.map +1 -1
- package/dist/cli/src/apps/catci/commands/security/evaluateSecurityAudit.js +19 -67
- package/dist/cli/src/apps/catci/commands/security/evaluateSecurityAudit.js.map +1 -1
- package/dist/cli/src/apps/catenv/catenv.js +18 -64
- package/dist/cli/src/apps/catenv/catenv.js.map +1 -1
- package/dist/cli/src/apps/catenv/printVariables.js +36 -123
- package/dist/cli/src/apps/catenv/printVariables.js.map +1 -1
- package/dist/cli/src/apps/catenv/utils.js +26 -112
- package/dist/cli/src/apps/catenv/utils.js.map +1 -1
- package/dist/cli/src/apps/catenv/writeDotEnvFiles.js +28 -132
- package/dist/cli/src/apps/catenv/writeDotEnvFiles.js.map +1 -1
- package/dist/cli/src/apps/catenv/writeEnvDTs.js +49 -150
- package/dist/cli/src/apps/catenv/writeEnvDTs.js.map +1 -1
- package/dist/cli/src/apps/cli/cli.js +31 -76
- package/dist/cli/src/apps/cli/cli.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/cloudSQL/commandRestoreDb.js +106 -180
- package/dist/cli/src/apps/cli/commands/cloudSQL/commandRestoreDb.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/cloudSQL/index.js +4 -43
- package/dist/cli/src/apps/cli/commands/cloudSQL/index.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/general/index.js +67 -191
- package/dist/cli/src/apps/cli/commands/general/index.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/general/namespaceAutoCompletion.js +4 -49
- package/dist/cli/src/apps/cli/commands/general/namespaceAutoCompletion.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/general/portForward.js +36 -93
- package/dist/cli/src/apps/cli/commands/general/portForward.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/mongodb/index.js +8 -47
- package/dist/cli/src/apps/cli/commands/mongodb/index.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/mongodb/projectMongoDestroyMember.js +86 -183
- package/dist/cli/src/apps/cli/commands/mongodb/projectMongoDestroyMember.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/mongodb/projectMongoGetShell.js +30 -90
- package/dist/cli/src/apps/cli/commands/mongodb/projectMongoGetShell.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/mongodb/projectMongoPortForward.js +50 -114
- package/dist/cli/src/apps/cli/commands/mongodb/projectMongoPortForward.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/mongodb/utils/index.js +58 -192
- package/dist/cli/src/apps/cli/commands/mongodb/utils/index.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/cloudSql/commandProjectRestoreDb.js +118 -197
- package/dist/cli/src/apps/cli/commands/project/cloudSql/commandProjectRestoreDb.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandCloudSqlProxy.js +81 -160
- package/dist/cli/src/apps/cli/commands/project/commandCloudSqlProxy.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandConfigSecrets.js +134 -397
- package/dist/cli/src/apps/cli/commands/project/commandConfigSecrets.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandDeletePods.js +40 -140
- package/dist/cli/src/apps/cli/commands/project/commandDeletePods.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandDeleteProject.js +23 -92
- package/dist/cli/src/apps/cli/commands/project/commandDeleteProject.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandEnvVars.js +10 -71
- package/dist/cli/src/apps/cli/commands/project/commandEnvVars.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandGetMyTotalWorktime.js +7 -54
- package/dist/cli/src/apps/cli/commands/project/commandGetMyTotalWorktime.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandGetShell.js +27 -89
- package/dist/cli/src/apps/cli/commands/project/commandGetShell.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandGitlabCi.js +65 -180
- package/dist/cli/src/apps/cli/commands/project/commandGitlabCi.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandListPods.js +13 -72
- package/dist/cli/src/apps/cli/commands/project/commandListPods.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandMigrateHelm3.js +38 -104
- package/dist/cli/src/apps/cli/commands/project/commandMigrateHelm3.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandNamespace.js +8 -67
- package/dist/cli/src/apps/cli/commands/project/commandNamespace.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenCostDashboard.js +16 -77
- package/dist/cli/src/apps/cli/commands/project/commandOpenCostDashboard.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenDashboard.js +18 -81
- package/dist/cli/src/apps/cli/commands/project/commandOpenDashboard.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenEnv.js +14 -74
- package/dist/cli/src/apps/cli/commands/project/commandOpenEnv.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenGit.js +6 -53
- package/dist/cli/src/apps/cli/commands/project/commandOpenGit.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenGrafana.js +16 -77
- package/dist/cli/src/apps/cli/commands/project/commandOpenGrafana.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenGrafanaPod.js +28 -93
- package/dist/cli/src/apps/cli/commands/project/commandOpenGrafanaPod.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandOpenLogs.js +11 -71
- package/dist/cli/src/apps/cli/commands/project/commandOpenLogs.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandPauseProject.js +23 -92
- package/dist/cli/src/apps/cli/commands/project/commandPauseProject.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandPortForward.js +71 -163
- package/dist/cli/src/apps/cli/commands/project/commandPortForward.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandRenewToken.js +6 -55
- package/dist/cli/src/apps/cli/commands/project/commandRenewToken.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandSecretsClearBackups.js +17 -112
- package/dist/cli/src/apps/cli/commands/project/commandSecretsClearBackups.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandSecurityEvaluate.js +15 -66
- package/dist/cli/src/apps/cli/commands/project/commandSecurityEvaluate.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandSetup.js +6 -55
- package/dist/cli/src/apps/cli/commands/project/commandSetup.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/commandTriggerCronjob.js +47 -135
- package/dist/cli/src/apps/cli/commands/project/commandTriggerCronjob.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/index.js +54 -93
- package/dist/cli/src/apps/cli/commands/project/index.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/setup/index.js +39 -127
- package/dist/cli/src/apps/cli/commands/project/setup/index.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/setup/setupAccessTokens.js +35 -100
- package/dist/cli/src/apps/cli/commands/project/setup/setupAccessTokens.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/setup/setupCloudRun.js +52 -129
- package/dist/cli/src/apps/cli/commands/project/setup/setupCloudRun.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/setup/setupContext.js +19 -68
- package/dist/cli/src/apps/cli/commands/project/setup/setupContext.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/setup/setupKubernetes.js +106 -147
- package/dist/cli/src/apps/cli/commands/project/setup/setupKubernetes.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/setup/setupTopic.js +7 -80
- package/dist/cli/src/apps/cli/commands/project/setup/setupTopic.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/utils/autocompletions.js +16 -105
- package/dist/cli/src/apps/cli/commands/project/utils/autocompletions.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/utils/ensureCluster.js +28 -79
- package/dist/cli/src/apps/cli/commands/project/utils/ensureCluster.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/utils/ensureNamespace.js +32 -89
- package/dist/cli/src/apps/cli/commands/project/utils/ensureNamespace.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/project/utils/showProjectBanner.js +9 -53
- package/dist/cli/src/apps/cli/commands/project/utils/showProjectBanner.js.map +1 -1
- package/dist/cli/src/apps/cli/commands/theStuffThatReallyMatters/index.js +26 -92
- package/dist/cli/src/apps/cli/commands/theStuffThatReallyMatters/index.js.map +1 -1
- package/dist/cli/src/apps/cli/utils/getGoogleAuthUserNumber.js +13 -62
- package/dist/cli/src/apps/cli/utils/getGoogleAuthUserNumber.js.map +1 -1
- package/dist/cli/src/apps/cli/verify/index.js +10 -62
- package/dist/cli/src/apps/cli/verify/index.js.map +1 -1
- package/dist/cli/src/catci.js +1 -1
- package/dist/cli/src/catci.js.map +1 -1
- package/dist/cli/src/catenv.js +8 -8
- package/dist/cli/src/catenv.js.map +1 -1
- package/dist/cli/src/cli.js +1 -1
- package/dist/cli/src/cli.js.map +1 -1
- package/dist/cli/src/config/getProjectConfig.js +118 -278
- package/dist/cli/src/config/getProjectConfig.js.map +1 -1
- package/dist/cli/src/config/parseChoice.js +3 -19
- package/dist/cli/src/config/parseChoice.js.map +1 -1
- package/dist/cli/src/gcloud/artifactsRegistry.js +10 -54
- package/dist/cli/src/gcloud/artifactsRegistry.js.map +1 -1
- package/dist/cli/src/gcloud/cloudRun/getCloudRunDomainSuffix.js +21 -60
- package/dist/cli/src/gcloud/cloudRun/getCloudRunDomainSuffix.js.map +1 -1
- package/dist/cli/src/gcloud/cloudRun/openCloudRunDashboards.js +12 -57
- package/dist/cli/src/gcloud/cloudRun/openCloudRunDashboards.js.map +1 -1
- package/dist/cli/src/gcloud/cloudSql/copyDb.js +30 -56
- package/dist/cli/src/gcloud/cloudSql/copyDb.js.map +1 -1
- package/dist/cli/src/gcloud/cloudSql/startProxy.js +41 -123
- package/dist/cli/src/gcloud/cloudSql/startProxy.js.map +1 -1
- package/dist/cli/src/gcloud/enableServices.js +6 -82
- package/dist/cli/src/gcloud/enableServices.js.map +1 -1
- package/dist/cli/src/gcloud/openDashboard.js +12 -95
- package/dist/cli/src/gcloud/openDashboard.js.map +1 -1
- package/dist/cli/src/gcloud/serviceAccounts.js +63 -186
- package/dist/cli/src/gcloud/serviceAccounts.js.map +1 -1
- package/dist/cli/src/k8sApi/index.js +9 -9
- package/dist/cli/src/k8sApi/index.js.map +1 -1
- package/dist/cli/src/kubernetes/index.js +20 -81
- package/dist/cli/src/kubernetes/index.js.map +1 -1
- package/dist/cli/src/kubernetes/openKubernetesDashboards.js +32 -86
- package/dist/cli/src/kubernetes/openKubernetesDashboards.js.map +1 -1
- package/dist/cli/src/kubernetes/portForward.js +5 -50
- package/dist/cli/src/kubernetes/portForward.js.map +1 -1
- package/dist/cli/src/packageInfos.js +2 -2
- package/dist/cli/src/packageInfos.js.map +1 -1
- package/dist/cli/src/utils/boxWithAscii.js +6 -6
- package/dist/cli/src/utils/boxWithAscii.js.map +1 -1
- package/dist/cli/src/utils/cluster.js +8 -61
- package/dist/cli/src/utils/cluster.js.map +1 -1
- package/dist/cli/src/utils/editAsFile.js +21 -75
- package/dist/cli/src/utils/editAsFile.js.map +1 -1
- package/dist/cli/src/utils/files.js +11 -57
- package/dist/cli/src/utils/files.js.map +1 -1
- package/dist/cli/src/utils/getEditor.js +15 -71
- package/dist/cli/src/utils/getEditor.js.map +1 -1
- package/dist/cli/src/utils/gitlab.js +176 -466
- package/dist/cli/src/utils/gitlab.js.map +1 -1
- package/dist/cli/src/utils/log.js +2 -2
- package/dist/cli/src/utils/log.js.map +1 -1
- package/dist/cli/src/utils/portForwards.js +32 -120
- package/dist/cli/src/utils/portForwards.js.map +1 -1
- package/dist/cli/src/utils/preferences/index.js +27 -108
- package/dist/cli/src/utils/preferences/index.js.map +1 -1
- package/dist/cli/src/utils/projects/index.js +28 -116
- package/dist/cli/src/utils/projects/index.js.map +1 -1
- package/dist/cli/src/utils/promise.js +4 -55
- package/dist/cli/src/utils/promise.js.map +1 -1
- package/dist/cli/src/utils/shell.js +19 -75
- package/dist/cli/src/utils/shell.js.map +1 -1
- package/dist/pipeline/src/bash/BashExpression.js +20 -52
- package/dist/pipeline/src/bash/BashExpression.js.map +1 -1
- package/dist/pipeline/src/bash/bashExpressionPerPipelineType.js +1 -1
- package/dist/pipeline/src/bash/bashExpressionPerPipelineType.js.map +1 -1
- package/dist/pipeline/src/bash/bashYaml.js +13 -10
- package/dist/pipeline/src/bash/bashYaml.js.map +1 -1
- package/dist/pipeline/src/bash/getInjectVarsScript.js +5 -27
- package/dist/pipeline/src/bash/getInjectVarsScript.js.map +1 -1
- package/dist/pipeline/src/bash/replaceAsync.js +29 -79
- package/dist/pipeline/src/bash/replaceAsync.js.map +1 -1
- package/dist/pipeline/src/build/artifacts/createBuildJobArtifact.js +29 -60
- package/dist/pipeline/src/build/artifacts/createBuildJobArtifact.js.map +1 -1
- package/dist/pipeline/src/build/base/createAppBuildJob.js +40 -72
- package/dist/pipeline/src/build/base/createAppBuildJob.js.map +1 -1
- package/dist/pipeline/src/build/base/createArtifactsConfig.js +11 -40
- package/dist/pipeline/src/build/base/createArtifactsConfig.js.map +1 -1
- package/dist/pipeline/src/build/base/index.js +36 -62
- package/dist/pipeline/src/build/base/index.js.map +1 -1
- package/dist/pipeline/src/build/base/writeBuildInfo.js +2 -2
- package/dist/pipeline/src/build/base/writeBuildInfo.js.map +1 -1
- package/dist/pipeline/src/build/base/writeDotEnv.js +13 -36
- package/dist/pipeline/src/build/base/writeDotEnv.js.map +1 -1
- package/dist/pipeline/src/build/custom/buildJob.js +8 -33
- package/dist/pipeline/src/build/custom/buildJob.js.map +1 -1
- package/dist/pipeline/src/build/custom/index.js +4 -29
- package/dist/pipeline/src/build/custom/index.js.map +1 -1
- package/dist/pipeline/src/build/custom/testJob.js +41 -50
- package/dist/pipeline/src/build/custom/testJob.js.map +1 -1
- package/dist/pipeline/src/build/docker.js +72 -104
- package/dist/pipeline/src/build/docker.js.map +1 -1
- package/dist/pipeline/src/build/index.js +17 -17
- package/dist/pipeline/src/build/index.js.map +1 -1
- package/dist/pipeline/src/build/node/buildJob.js +24 -45
- package/dist/pipeline/src/build/node/buildJob.js.map +1 -1
- package/dist/pipeline/src/build/node/cache.js +31 -54
- package/dist/pipeline/src/build/node/cache.js.map +1 -1
- package/dist/pipeline/src/build/node/index.js +9 -34
- package/dist/pipeline/src/build/node/index.js.map +1 -1
- package/dist/pipeline/src/build/node/meteor.js +17 -41
- package/dist/pipeline/src/build/node/meteor.js.map +1 -1
- package/dist/pipeline/src/build/node/testJob.js +69 -66
- package/dist/pipeline/src/build/node/testJob.js.map +1 -1
- package/dist/pipeline/src/build/node/yarn.js +35 -51
- package/dist/pipeline/src/build/node/yarn.js.map +1 -1
- package/dist/pipeline/src/build/rails/build.js +22 -57
- package/dist/pipeline/src/build/rails/build.js.map +1 -1
- package/dist/pipeline/src/build/rails/index.js +4 -29
- package/dist/pipeline/src/build/rails/index.js.map +1 -1
- package/dist/pipeline/src/build/rails/test.js +60 -66
- package/dist/pipeline/src/build/rails/test.js.map +1 -1
- package/dist/pipeline/src/build/sbom.js +12 -12
- package/dist/pipeline/src/build/sbom.js.map +1 -1
- package/dist/pipeline/src/build/types.js +2 -6
- package/dist/pipeline/src/build/types.js.map +1 -1
- package/dist/pipeline/src/config/configruedEnvs.js +18 -47
- package/dist/pipeline/src/config/configruedEnvs.js.map +1 -1
- package/dist/pipeline/src/config/readConfig.js +26 -101
- package/dist/pipeline/src/config/readConfig.js.map +1 -1
- package/dist/pipeline/src/context/createAllComponentsContext.js +16 -63
- package/dist/pipeline/src/context/createAllComponentsContext.js.map +1 -1
- package/dist/pipeline/src/context/createComponentContext.js +93 -170
- package/dist/pipeline/src/context/createComponentContext.js.map +1 -1
- package/dist/pipeline/src/context/createWorkspaceContext.js +30 -80
- package/dist/pipeline/src/context/createWorkspaceContext.js.map +1 -1
- package/dist/pipeline/src/context/getBuildInfoVariables.js +12 -31
- package/dist/pipeline/src/context/getBuildInfoVariables.js.map +1 -1
- package/dist/pipeline/src/context/getEnvConfig.js +4 -4
- package/dist/pipeline/src/context/getEnvConfig.js.map +1 -1
- package/dist/pipeline/src/context/getEnvType.js +2 -2
- package/dist/pipeline/src/context/getEnvType.js.map +1 -1
- package/dist/pipeline/src/context/getEnvironment.js +17 -64
- package/dist/pipeline/src/context/getEnvironment.js.map +1 -1
- package/dist/pipeline/src/context/getEnvironmentContext.js +21 -22
- package/dist/pipeline/src/context/getEnvironmentContext.js.map +1 -1
- package/dist/pipeline/src/context/getEnvironmentVariables.js +109 -169
- package/dist/pipeline/src/context/getEnvironmentVariables.js.map +1 -1
- package/dist/pipeline/src/context/getLabels.js +12 -15
- package/dist/pipeline/src/context/getLabels.js.map +1 -1
- package/dist/pipeline/src/context/getReviewSlug.js +7 -7
- package/dist/pipeline/src/context/getReviewSlug.js.map +1 -1
- package/dist/pipeline/src/context/resolveReferences.js +51 -172
- package/dist/pipeline/src/context/resolveReferences.js.map +1 -1
- package/dist/pipeline/src/context/transformJobOnlyVars.js +22 -69
- package/dist/pipeline/src/context/transformJobOnlyVars.js.map +1 -1
- package/dist/pipeline/src/context/utils/envVars.js +13 -39
- package/dist/pipeline/src/context/utils/envVars.js.map +1 -1
- package/dist/pipeline/src/deploy/base/deploy.js +60 -82
- package/dist/pipeline/src/deploy/base/deploy.js.map +1 -1
- package/dist/pipeline/src/deploy/base/index.js +11 -34
- package/dist/pipeline/src/deploy/base/index.js.map +1 -1
- package/dist/pipeline/src/deploy/base/rollback.js +11 -15
- package/dist/pipeline/src/deploy/base/rollback.js.map +1 -1
- package/dist/pipeline/src/deploy/base/stop.js +11 -15
- package/dist/pipeline/src/deploy/base/stop.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/artifactsRegistry.js +41 -64
- package/dist/pipeline/src/deploy/cloudRun/artifactsRegistry.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/cleanup.js +8 -33
- package/dist/pipeline/src/deploy/cloudRun/cleanup.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/cloudRunRevisions.js +25 -30
- package/dist/pipeline/src/deploy/cloudRun/cloudRunRevisions.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/cloudRunJobs.js +92 -136
- package/dist/pipeline/src/deploy/cloudRun/createJobs/cloudRunJobs.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/cloudRunServices.js +44 -61
- package/dist/pipeline/src/deploy/cloudRun/createJobs/cloudRunServices.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/common.js +25 -53
- package/dist/pipeline/src/deploy/cloudRun/createJobs/common.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/getCloudRunDeployScripts.js +36 -47
- package/dist/pipeline/src/deploy/cloudRun/createJobs/getCloudRunDeployScripts.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/getCloudRunStopScripts.js +22 -39
- package/dist/pipeline/src/deploy/cloudRun/createJobs/getCloudRunStopScripts.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/index.js +27 -33
- package/dist/pipeline/src/deploy/cloudRun/createJobs/index.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/createJobs/volumes.js +7 -34
- package/dist/pipeline/src/deploy/cloudRun/createJobs/volumes.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/index.js +38 -75
- package/dist/pipeline/src/deploy/cloudRun/index.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/createArgsString.js +14 -42
- package/dist/pipeline/src/deploy/cloudRun/utils/createArgsString.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/database.js +14 -30
- package/dist/pipeline/src/deploy/cloudRun/utils/database.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/gcloudServiceAccountLoginCommands.js +5 -5
- package/dist/pipeline/src/deploy/cloudRun/utils/gcloudServiceAccountLoginCommands.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/getServiceName.js +1 -3
- package/dist/pipeline/src/deploy/cloudRun/utils/getServiceName.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/jobName.js +1 -3
- package/dist/pipeline/src/deploy/cloudRun/utils/jobName.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/removeFirstLinesFromCommandOutput.js +1 -1
- package/dist/pipeline/src/deploy/cloudRun/utils/removeFirstLinesFromCommandOutput.js.map +1 -1
- package/dist/pipeline/src/deploy/cloudSql/utils.js +4 -4
- package/dist/pipeline/src/deploy/cloudSql/utils.js.map +1 -1
- package/dist/pipeline/src/deploy/custom/deployJob.js +18 -37
- package/dist/pipeline/src/deploy/custom/deployJob.js.map +1 -1
- package/dist/pipeline/src/deploy/custom/index.js +4 -4
- package/dist/pipeline/src/deploy/custom/index.js.map +1 -1
- package/dist/pipeline/src/deploy/dockerTag/deployJob.js +16 -48
- package/dist/pipeline/src/deploy/dockerTag/deployJob.js.map +1 -1
- package/dist/pipeline/src/deploy/dockerTag/index.js +4 -4
- package/dist/pipeline/src/deploy/dockerTag/index.js.map +1 -1
- package/dist/pipeline/src/deploy/index.js +4 -4
- package/dist/pipeline/src/deploy/index.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/additionalSecretKeys.js +6 -7
- package/dist/pipeline/src/deploy/kubernetes/additionalSecretKeys.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/cloudSql/index.js +13 -13
- package/dist/pipeline/src/deploy/kubernetes/cloudSql/index.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/deployJob.js +64 -72
- package/dist/pipeline/src/deploy/kubernetes/deployJob.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/index.js +21 -47
- package/dist/pipeline/src/deploy/kubernetes/index.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/kubeEnv.js +13 -36
- package/dist/pipeline/src/deploy/kubernetes/kubeEnv.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/kubeValues.js +23 -60
- package/dist/pipeline/src/deploy/kubernetes/kubeValues.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/mongodb.js +38 -48
- package/dist/pipeline/src/deploy/kubernetes/mongodb.js.map +1 -1
- package/dist/pipeline/src/deploy/kubernetes/processSecretsAsFiles.js +15 -17
- package/dist/pipeline/src/deploy/kubernetes/processSecretsAsFiles.js.map +1 -1
- package/dist/pipeline/src/deploy/sbom.js +9 -11
- package/dist/pipeline/src/deploy/sbom.js.map +1 -1
- package/dist/pipeline/src/deploy/types/index.js +1 -5
- package/dist/pipeline/src/deploy/types/index.js.map +1 -1
- package/dist/pipeline/src/deploy/utils.js +7 -7
- package/dist/pipeline/src/deploy/utils.js.map +1 -1
- package/dist/pipeline/src/packageInfos.js +2 -2
- package/dist/pipeline/src/packageInfos.js.map +1 -1
- package/dist/pipeline/src/pipeline/createAllJobs.js +39 -132
- package/dist/pipeline/src/pipeline/createAllJobs.js.map +1 -1
- package/dist/pipeline/src/pipeline/createChildPipeline.js +24 -71
- package/dist/pipeline/src/pipeline/createChildPipeline.js.map +1 -1
- package/dist/pipeline/src/pipeline/createJobsForComponent.js +18 -62
- package/dist/pipeline/src/pipeline/createJobsForComponent.js.map +1 -1
- package/dist/pipeline/src/pipeline/createJobsForWorkspace.js +3 -3
- package/dist/pipeline/src/pipeline/createJobsForWorkspace.js.map +1 -1
- package/dist/pipeline/src/pipeline/createMainPipeline.js +57 -141
- package/dist/pipeline/src/pipeline/createMainPipeline.js.map +1 -1
- package/dist/pipeline/src/pipeline/generatePipelineFiles.js +43 -137
- package/dist/pipeline/src/pipeline/generatePipelineFiles.js.map +1 -1
- package/dist/pipeline/src/pipeline/getPipelineStages.js +8 -31
- package/dist/pipeline/src/pipeline/getPipelineStages.js.map +1 -1
- package/dist/pipeline/src/pipeline/gitlab/createGitlabJobs.js +150 -216
- package/dist/pipeline/src/pipeline/gitlab/createGitlabJobs.js.map +1 -1
- package/dist/pipeline/src/pipeline/gitlab/createGitlabPipeline.js +14 -26
- package/dist/pipeline/src/pipeline/gitlab/createGitlabPipeline.js.map +1 -1
- package/dist/pipeline/src/pipeline/gitlab/getPipelineTriggerForGitlabChildPipeline.js +11 -11
- package/dist/pipeline/src/pipeline/gitlab/getPipelineTriggerForGitlabChildPipeline.js.map +1 -1
- package/dist/pipeline/src/pipeline/gitlab/gitlabReleaseJobs.js +8 -9
- package/dist/pipeline/src/pipeline/gitlab/gitlabReleaseJobs.js.map +1 -1
- package/dist/pipeline/src/pipeline/gitlab/sortGitLabJobDefProps.js +11 -20
- package/dist/pipeline/src/pipeline/gitlab/sortGitLabJobDefProps.js.map +1 -1
- package/dist/pipeline/src/pipeline/packageManager.js +59 -133
- package/dist/pipeline/src/pipeline/packageManager.js.map +1 -1
- package/dist/pipeline/src/pipeline/yarn/yarnUtils.js +30 -120
- package/dist/pipeline/src/pipeline/yarn/yarnUtils.js.map +1 -1
- package/dist/pipeline/src/runner/index.js +2 -4
- package/dist/pipeline/src/runner/index.js.map +1 -1
- package/dist/pipeline/src/types/config.js +4 -28
- package/dist/pipeline/src/types/config.js.map +1 -1
- package/dist/pipeline/src/types/context.js +2 -2
- package/dist/pipeline/src/types/context.js.map +1 -1
- package/dist/pipeline/src/utils/gitlab.js +19 -42
- package/dist/pipeline/src/utils/gitlab.js.map +1 -1
- package/dist/pipeline/src/utils/index.js +6 -34
- package/dist/pipeline/src/utils/index.js.map +1 -1
- package/dist/pipeline/src/utils/jsonParse.js +2 -2
- package/dist/pipeline/src/utils/jsonParse.js.map +1 -1
- package/dist/pipeline/src/utils/removeUndefined.js +1 -22
- package/dist/pipeline/src/utils/removeUndefined.js.map +1 -1
- package/dist/pipeline/src/utils/writeFiles.js +17 -68
- package/dist/pipeline/src/utils/writeFiles.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/tsconfig.json +2 -2
|
@@ -1,156 +1,115 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
-
function step(op) {
|
|
16
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
-
switch (op[0]) {
|
|
21
|
-
case 0: case 1: t = op; break;
|
|
22
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
-
default:
|
|
26
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
-
if (t[2]) _.ops.pop();
|
|
31
|
-
_.trys.pop(); continue;
|
|
32
|
-
}
|
|
33
|
-
op = body.call(thisArg, _);
|
|
34
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
2
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
39
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
40
4
|
};
|
|
41
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
42
6
|
exports.setupKubernetes = void 0;
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
var deployConfig, projectId, deploy_tokens, fullName, namespace, serviceAccountName, KUBE_URL, e_1, secretName, KUBE_CA_PEM, KUBE_TOKEN, vars, missing;
|
|
7
|
+
const pipeline_1 = require("../../../../../../../pipeline/src/index.js");
|
|
8
|
+
const child_process_promise_1 = require("child-process-promise");
|
|
9
|
+
const cluster_1 = require("../../../../../utils/cluster");
|
|
10
|
+
const gitlab_1 = require("../../../../../utils/gitlab");
|
|
11
|
+
const ensureNamespace_1 = __importDefault(require("../utils/ensureNamespace"));
|
|
12
|
+
const setupKubernetes = async (instance, context) => {
|
|
50
13
|
var _a;
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
return [2 /*return*/];
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
}); };
|
|
14
|
+
const deployConfig = (_a = context.deploy) === null || _a === void 0 ? void 0 : _a.config;
|
|
15
|
+
if (!(0, pipeline_1.isOfDeployType)(deployConfig, "kubernetes")) {
|
|
16
|
+
throw new Error("cannot run setupKubernetes on non-kubernetes deployments");
|
|
17
|
+
}
|
|
18
|
+
const { id: projectId } = await (0, gitlab_1.getProjectInfo)(instance);
|
|
19
|
+
const deploy_tokens = await (0, gitlab_1.doGitlabRequest)(instance, `projects/${projectId}/deploy_tokens`);
|
|
20
|
+
if (!deploy_tokens.find((v) => v.name === "gitlab-deploy-token")) {
|
|
21
|
+
instance.log("I will setup the 'GitLab Deploy Token', so Kubernetes can pull images from this project.");
|
|
22
|
+
await (0, gitlab_1.doGitlabRequest)(instance, `projects/${projectId}/deploy_tokens`, {
|
|
23
|
+
id: projectId,
|
|
24
|
+
name: "gitlab-deploy-token",
|
|
25
|
+
scopes: ["read_registry"],
|
|
26
|
+
}, "POST");
|
|
27
|
+
}
|
|
28
|
+
const fullName = (0, pipeline_1.getFullKubernetesClusterName)(deployConfig.cluster);
|
|
29
|
+
instance.log(`cluster: ${fullName}`);
|
|
30
|
+
await (0, cluster_1.connectToCluster)(fullName);
|
|
31
|
+
instance.log("");
|
|
32
|
+
instance.log("ensuring namespace ...");
|
|
33
|
+
const namespace = await (0, ensureNamespace_1.default)(context);
|
|
34
|
+
instance.log("Namespace " + namespace + " created / updated!");
|
|
35
|
+
instance.log("");
|
|
36
|
+
//$.verbose = true;
|
|
37
|
+
// we name the service account and the role and the role binding with the same name
|
|
38
|
+
// we currently create one per component to better separate them
|
|
39
|
+
instance.log("ensuring service accounts...");
|
|
40
|
+
const serviceAccountName = `cl-${context.name}-deploy`;
|
|
41
|
+
const KUBE_URL = await (0, child_process_promise_1.exec)(`TERM=dumb kubectl cluster-info | grep -E 'Kubernetes master|Kubernetes control plane' | awk '/http/ {print $NF}'`).then((s) => s.stdout.trim());
|
|
42
|
+
// first upsert service acount in the ns
|
|
43
|
+
try {
|
|
44
|
+
await (0, child_process_promise_1.exec)(`kubectl delete serviceaccount --namespace ${namespace} ${serviceAccountName}`);
|
|
45
|
+
await (0, child_process_promise_1.exec)(`kubectl delete rolebinding --namespace ${namespace} ${serviceAccountName}`);
|
|
46
|
+
await (0, child_process_promise_1.exec)(`kubectl delete role --namespace ${namespace} ${serviceAccountName}`);
|
|
47
|
+
}
|
|
48
|
+
catch (e) {
|
|
49
|
+
// ignore
|
|
50
|
+
}
|
|
51
|
+
await (0, child_process_promise_1.exec)(`kubectl create serviceaccount --namespace ${namespace} ${serviceAccountName}`);
|
|
52
|
+
// upsert role in the ns
|
|
53
|
+
await (0, child_process_promise_1.exec)(`cat <<EOF | kubectl apply -f -
|
|
54
|
+
kind: Role
|
|
55
|
+
apiVersion: rbac.authorization.k8s.io/v1
|
|
56
|
+
metadata:
|
|
57
|
+
namespace: ${namespace}
|
|
58
|
+
name: ${serviceAccountName}
|
|
59
|
+
rules:
|
|
60
|
+
- apiGroups: ["", "extensions", "apps", "networking.k8s.io", "batch", "autoscaling", "rbac.authorization.k8s.io","snapshot.storage.k8s.io"]
|
|
61
|
+
resources: ["deployments", "replicasets", "statefulsets", "pods", "secrets", "configmaps", "services", "ingresses", "serviceaccounts", "roles", "rolebindings", "jobs", "cronjobs", "horizontalpodautoscalers", "persistentvolumeclaims", "volumesnapshots"]
|
|
62
|
+
verbs: ["*"]
|
|
63
|
+
---
|
|
64
|
+
kind: RoleBinding
|
|
65
|
+
apiVersion: rbac.authorization.k8s.io/v1
|
|
66
|
+
metadata:
|
|
67
|
+
name: ${serviceAccountName}
|
|
68
|
+
namespace: ${namespace}
|
|
69
|
+
subjects:
|
|
70
|
+
- kind: ServiceAccount
|
|
71
|
+
name: ${serviceAccountName}
|
|
72
|
+
namespace: ${namespace}
|
|
73
|
+
roleRef:
|
|
74
|
+
kind: Role
|
|
75
|
+
name: ${serviceAccountName}
|
|
76
|
+
apiGroup: rbac.authorization.k8s.io
|
|
77
|
+
EOF
|
|
78
|
+
`);
|
|
79
|
+
const secretName = `${serviceAccountName}-secret`;
|
|
80
|
+
// create token for the service account
|
|
81
|
+
await (0, child_process_promise_1.exec)(`
|
|
82
|
+
kubectl apply -f - <<EOF
|
|
83
|
+
apiVersion: v1
|
|
84
|
+
kind: Secret
|
|
85
|
+
metadata:
|
|
86
|
+
name: ${secretName}
|
|
87
|
+
namespace: ${namespace}
|
|
88
|
+
annotations:
|
|
89
|
+
kubernetes.io/service-account.name: ${serviceAccountName}
|
|
90
|
+
type: kubernetes.io/service-account-token
|
|
91
|
+
EOF
|
|
92
|
+
`);
|
|
93
|
+
const KUBE_CA_PEM = await (0, child_process_promise_1.exec)(`kubectl get secret ${secretName} --namespace ${namespace} -o jsonpath="{['data']['ca\\.crt']}"`).then((c) => c.stdout.trim());
|
|
94
|
+
const KUBE_TOKEN = await (0, child_process_promise_1.exec)(`kubectl get secret ${secretName} --namespace ${namespace} -o jsonpath="{['data']['token']}" | base64 --decode`).then((c) => c.stdout.trim());
|
|
95
|
+
const vars = {
|
|
96
|
+
KUBE_TOKEN,
|
|
97
|
+
KUBE_CA_PEM,
|
|
98
|
+
KUBE_URL,
|
|
99
|
+
};
|
|
100
|
+
const missing = Object.entries(vars).filter((e) => !e[1]);
|
|
101
|
+
if (missing.length > 0) {
|
|
102
|
+
throw new Error("could not setup credentials. Missing vars: " +
|
|
103
|
+
missing.map((m) => m[0]).join(", ") +
|
|
104
|
+
". Check whether your local kubectl is still working for '" +
|
|
105
|
+
fullName +
|
|
106
|
+
"'");
|
|
107
|
+
}
|
|
108
|
+
instance.log("service accounts created / updated!");
|
|
109
|
+
instance.log("");
|
|
110
|
+
instance.log("pusing secrets to gitlab...");
|
|
111
|
+
await (0, gitlab_1.upsertAllVariables)(instance, vars, context.env, context.name, false);
|
|
112
|
+
instance.log("done!");
|
|
113
|
+
};
|
|
155
114
|
exports.setupKubernetes = setupKubernetes;
|
|
156
115
|
//# sourceMappingURL=setupKubernetes.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupKubernetes.js","sourceRoot":"","sources":["../../../../../../../../src/apps/cli/commands/project/setup/setupKubernetes.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"setupKubernetes.js","sourceRoot":"","sources":["../../../../../../../../src/apps/cli/commands/project/setup/setupKubernetes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,85 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
-
function step(op) {
|
|
16
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
-
switch (op[0]) {
|
|
21
|
-
case 0: case 1: t = op; break;
|
|
22
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
-
default:
|
|
26
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
-
if (t[2]) _.ops.pop();
|
|
31
|
-
_.trys.pop(); continue;
|
|
32
|
-
}
|
|
33
|
-
op = body.call(thisArg, _);
|
|
34
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
39
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
40
|
-
if (!m) return o;
|
|
41
|
-
var i = m.call(o), r, ar = [], e;
|
|
42
|
-
try {
|
|
43
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
44
|
-
}
|
|
45
|
-
catch (error) { e = { error: error }; }
|
|
46
|
-
finally {
|
|
47
|
-
try {
|
|
48
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
49
|
-
}
|
|
50
|
-
finally { if (e) throw e.error; }
|
|
51
|
-
}
|
|
52
|
-
return ar;
|
|
53
|
-
};
|
|
54
|
-
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
55
|
-
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
56
|
-
if (ar || !(i in from)) {
|
|
57
|
-
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
58
|
-
ar[i] = from[i];
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return to.concat(ar || Array.prototype.slice.call(from));
|
|
62
|
-
};
|
|
63
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
64
3
|
exports.setupTopic = void 0;
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
case 1:
|
|
73
|
-
projectId = (_a.sent()).id;
|
|
74
|
-
return [4 /*yield*/, (0, gitlab_1.doGitlabRequest)(instance, "projects/".concat(projectId))];
|
|
75
|
-
case 2:
|
|
76
|
-
topics = (_a.sent()).topics;
|
|
77
|
-
return [4 /*yield*/, (0, gitlab_1.doGitlabRequest)(instance, "projects/".concat(projectId), { topics: __spreadArray([catladderTopic], __read(topics), false) }, "PUT")];
|
|
78
|
-
case 3:
|
|
79
|
-
_a.sent();
|
|
80
|
-
return [2 /*return*/];
|
|
81
|
-
}
|
|
82
|
-
});
|
|
83
|
-
}); };
|
|
4
|
+
const gitlab_1 = require("../../../../../utils/gitlab");
|
|
5
|
+
const catladderTopic = "catladder";
|
|
6
|
+
const setupTopic = async (instance) => {
|
|
7
|
+
const { id: projectId } = await (0, gitlab_1.getProjectInfo)(instance);
|
|
8
|
+
const { topics } = await (0, gitlab_1.doGitlabRequest)(instance, `projects/${projectId}`);
|
|
9
|
+
await (0, gitlab_1.doGitlabRequest)(instance, `projects/${projectId}`, { topics: [catladderTopic, ...topics] }, "PUT");
|
|
10
|
+
};
|
|
84
11
|
exports.setupTopic = setupTopic;
|
|
85
12
|
//# sourceMappingURL=setupTopic.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupTopic.js","sourceRoot":"","sources":["../../../../../../../../src/apps/cli/commands/project/setup/setupTopic.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"setupTopic.js","sourceRoot":"","sources":["../../../../../../../../src/apps/cli/commands/project/setup/setupTopic.ts"],"names":[],"mappings":";;;AACA,wDAA8E;AAE9E,MAAM,cAAc,GAAG,WAAW,CAAC;AAE5B,MAAM,UAAU,GAAG,KAAK,EAAE,QAAyB,EAAE,EAAE;IAC5D,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,GAAG,MAAM,IAAA,uBAAc,EAAC,QAAQ,CAAC,CAAC;IAEzD,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,IAAA,wBAAe,EAAC,QAAQ,EAAE,YAAY,SAAS,EAAE,CAAC,CAAC;IAE5E,MAAM,IAAA,wBAAe,EACnB,QAAQ,EACR,YAAY,SAAS,EAAE,EACvB,EAAE,MAAM,EAAE,CAAC,cAAc,EAAE,GAAG,MAAM,CAAC,EAAE,EACvC,KAAK,CACN,CAAC;AACJ,CAAC,CAAC;AAXW,QAAA,UAAU,cAWrB"}
|
|
@@ -1,112 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
-
function step(op) {
|
|
16
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
-
switch (op[0]) {
|
|
21
|
-
case 0: case 1: t = op; break;
|
|
22
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
-
default:
|
|
26
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
-
if (t[2]) _.ops.pop();
|
|
31
|
-
_.trys.pop(); continue;
|
|
32
|
-
}
|
|
33
|
-
op = body.call(thisArg, _);
|
|
34
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
39
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
40
|
-
if (!m) return o;
|
|
41
|
-
var i = m.call(o), r, ar = [], e;
|
|
42
|
-
try {
|
|
43
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
44
|
-
}
|
|
45
|
-
catch (error) { e = { error: error }; }
|
|
46
|
-
finally {
|
|
47
|
-
try {
|
|
48
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
49
|
-
}
|
|
50
|
-
finally { if (e) throw e.error; }
|
|
51
|
-
}
|
|
52
|
-
return ar;
|
|
53
|
-
};
|
|
54
|
-
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
55
|
-
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
56
|
-
if (ar || !(i in from)) {
|
|
57
|
-
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
58
|
-
ar[i] = from[i];
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return to.concat(ar || Array.prototype.slice.call(from));
|
|
62
|
-
};
|
|
63
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
64
3
|
exports.allEnvsAndAllComponents = exports.envAndComponents = exports.allEnvs = void 0;
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
if (!config) {
|
|
75
|
-
return [2 /*return*/, []];
|
|
76
|
-
}
|
|
77
|
-
return [2 /*return*/, (0, pipeline_1.getAllEnvsInAllComponents)(config)];
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
}); };
|
|
4
|
+
const pipeline_1 = require("../../../../../../../pipeline/src/index.js");
|
|
5
|
+
const getProjectConfig_1 = require("../../../../../config/getProjectConfig");
|
|
6
|
+
const allEnvs = async () => {
|
|
7
|
+
const config = await (0, getProjectConfig_1.getProjectConfig)();
|
|
8
|
+
if (!config) {
|
|
9
|
+
return [];
|
|
10
|
+
}
|
|
11
|
+
return (0, pipeline_1.getAllEnvsInAllComponents)(config);
|
|
12
|
+
};
|
|
81
13
|
exports.allEnvs = allEnvs;
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
return
|
|
85
|
-
|
|
86
|
-
case 0: return [4 /*yield*/, (0, getProjectConfig_1.getAllComponentsWithAllEnvsFlat)()];
|
|
87
|
-
case 1:
|
|
88
|
-
allEnvAndcomponents = _a.sent();
|
|
89
|
-
return [2 /*return*/, allEnvAndcomponents.reduce(function (acc, _a) {
|
|
90
|
-
var env = _a.env, componentName = _a.componentName;
|
|
91
|
-
return __spreadArray(__spreadArray([], __read(acc), false), [env + ":" + componentName], false);
|
|
92
|
-
}, [])];
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
}); };
|
|
14
|
+
const envAndComponents = async () => {
|
|
15
|
+
const allEnvAndcomponents = await (0, getProjectConfig_1.getAllComponentsWithAllEnvsFlat)();
|
|
16
|
+
return allEnvAndcomponents.reduce((acc, { env, componentName }) => [...acc, env + ":" + componentName], []);
|
|
17
|
+
};
|
|
96
18
|
exports.envAndComponents = envAndComponents;
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
switch (_c.label) {
|
|
101
|
-
case 0:
|
|
102
|
-
_a = [[]];
|
|
103
|
-
return [4 /*yield*/, (0, exports.allEnvs)()];
|
|
104
|
-
case 1:
|
|
105
|
-
_b = [__spreadArray.apply(void 0, _a.concat([__read.apply(void 0, [(_c.sent())]), false]))];
|
|
106
|
-
return [4 /*yield*/, (0, exports.envAndComponents)()];
|
|
107
|
-
case 2: return [2 /*return*/, __spreadArray.apply(void 0, _b.concat([__read.apply(void 0, [(_c.sent())]), false]))];
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
}); };
|
|
19
|
+
const allEnvsAndAllComponents = async () => {
|
|
20
|
+
return [...(await (0, exports.allEnvs)()), ...(await (0, exports.envAndComponents)())];
|
|
21
|
+
};
|
|
111
22
|
exports.allEnvsAndAllComponents = allEnvsAndAllComponents;
|
|
112
23
|
//# sourceMappingURL=autocompletions.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"autocompletions.js","sourceRoot":"","sources":["../../../../../../../../src/apps/cli/commands/project/utils/autocompletions.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"autocompletions.js","sourceRoot":"","sources":["../../../../../../../../src/apps/cli/commands/project/utils/autocompletions.ts"],"names":[],"mappings":";;;AAAA,kDAA4E;AAC5E,6EAGgD;AAEzC,MAAM,OAAO,GAAG,KAAK,IAAI,EAAE;IAChC,MAAM,MAAM,GAAG,MAAM,IAAA,mCAAgB,GAAE,CAAC;IACxC,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,OAAO,IAAA,oCAAyB,EAAC,MAAM,CAAC,CAAC;AAC3C,CAAC,CAAC;AANW,QAAA,OAAO,WAMlB;AAEK,MAAM,gBAAgB,GAAG,KAAK,IAAI,EAAE;IACzC,MAAM,mBAAmB,GAAG,MAAM,IAAA,kDAA+B,GAAE,CAAC;IAEpE,OAAO,mBAAmB,CAAC,MAAM,CAC/B,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,GAAG,aAAa,CAAC,EACpE,EAAE,CACH,CAAC;AACJ,CAAC,CAAC;AAPW,QAAA,gBAAgB,oBAO3B;AAEK,MAAM,uBAAuB,GAAG,KAAK,IAAI,EAAE;IAChD,OAAO,CAAC,GAAG,CAAC,MAAM,IAAA,eAAO,GAAE,CAAC,EAAE,GAAG,CAAC,MAAM,IAAA,wBAAgB,GAAE,CAAC,CAAC,CAAC;AAC/D,CAAC,CAAC;AAFW,QAAA,uBAAuB,2BAElC"}
|