@factiii/stack 0.1.24 → 0.1.25
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 +81 -60
- package/bin/{factiii → stack} +12 -12
- package/dist/cli/check-config.js +1 -1
- package/dist/cli/check-config.js.map +1 -1
- package/dist/cli/deploy-secrets.d.ts.map +1 -1
- package/dist/cli/deploy-secrets.js +11 -11
- package/dist/cli/deploy-secrets.js.map +1 -1
- package/dist/cli/deploy.d.ts.map +1 -1
- package/dist/cli/deploy.js +19 -9
- package/dist/cli/deploy.js.map +1 -1
- package/dist/cli/dev-sync.d.ts.map +1 -1
- package/dist/cli/dev-sync.js +10 -9
- package/dist/cli/dev-sync.js.map +1 -1
- package/dist/cli/execute-plugin-command.d.ts.map +1 -1
- package/dist/cli/execute-plugin-command.js +7 -7
- package/dist/cli/execute-plugin-command.js.map +1 -1
- package/dist/cli/fix.d.ts.map +1 -1
- package/dist/cli/fix.js +24 -4
- package/dist/cli/fix.js.map +1 -1
- package/dist/cli/init.d.ts +3 -1
- package/dist/cli/init.d.ts.map +1 -1
- package/dist/cli/init.js +114 -71
- package/dist/cli/init.js.map +1 -1
- package/dist/cli/pr-check.d.ts.map +1 -1
- package/dist/cli/pr-check.js +5 -4
- package/dist/cli/pr-check.js.map +1 -1
- package/dist/cli/scan.d.ts +6 -6
- package/dist/cli/scan.d.ts.map +1 -1
- package/dist/cli/scan.js +20 -19
- package/dist/cli/scan.js.map +1 -1
- package/dist/cli/secrets.d.ts.map +1 -1
- package/dist/cli/secrets.js +17 -16
- package/dist/cli/secrets.js.map +1 -1
- package/dist/cli/undeploy.d.ts.map +1 -1
- package/dist/cli/undeploy.js +4 -4
- package/dist/cli/undeploy.js.map +1 -1
- package/dist/cli/upgrade.d.ts +1 -1
- package/dist/cli/upgrade.js +5 -5
- package/dist/cli/upgrade.js.map +1 -1
- package/dist/cli/validate.js +1 -1
- package/dist/cli/validate.js.map +1 -1
- package/dist/constants/config-files.d.ts +17 -0
- package/dist/constants/config-files.d.ts.map +1 -0
- package/dist/constants/config-files.js +73 -0
- package/dist/constants/config-files.js.map +1 -0
- package/dist/generators/{generate-factiii-auto.d.ts → generate-stack-auto.d.ts} +4 -4
- package/dist/generators/generate-stack-auto.d.ts.map +1 -0
- package/dist/generators/{generate-factiii-auto.js → generate-stack-auto.js} +15 -13
- package/dist/generators/generate-stack-auto.js.map +1 -0
- package/dist/generators/{generate-factiii-yml.d.ts → generate-stack-yml.d.ts} +5 -5
- package/dist/generators/generate-stack-yml.d.ts.map +1 -0
- package/dist/generators/{generate-factiii-yml.js → generate-stack-yml.js} +16 -15
- package/dist/generators/generate-stack-yml.js.map +1 -0
- package/dist/generators/index.d.ts +2 -2
- package/dist/generators/index.d.ts.map +1 -1
- package/dist/generators/index.js +5 -5
- package/dist/generators/index.js.map +1 -1
- package/dist/plugins/pipelines/aws/index.js +3 -3
- package/dist/plugins/pipelines/aws/index.js.map +1 -1
- package/dist/plugins/pipelines/aws/scanfix/credentials.d.ts.map +1 -1
- package/dist/plugins/pipelines/aws/scanfix/credentials.js +36 -44
- package/dist/plugins/pipelines/aws/scanfix/credentials.js.map +1 -1
- package/dist/plugins/pipelines/aws/scanfix/ec2.js +1 -1
- package/dist/plugins/pipelines/aws/scanfix/ec2.js.map +1 -1
- package/dist/plugins/pipelines/aws/scanfix/iam.js +2 -2
- package/dist/plugins/pipelines/aws/scanfix/iam.js.map +1 -1
- package/dist/plugins/pipelines/aws/scanfix/rds.js +2 -2
- package/dist/plugins/pipelines/aws/scanfix/rds.js.map +1 -1
- package/dist/plugins/pipelines/factiii/index.js +1 -1
- package/dist/plugins/pipelines/factiii/index.js.map +1 -1
- package/dist/plugins/pipelines/factiii/pr-check.d.ts +1 -1
- package/dist/plugins/pipelines/factiii/pr-check.js +1 -1
- package/dist/plugins/pipelines/factiii/prod.d.ts.map +1 -1
- package/dist/plugins/pipelines/factiii/prod.js +3 -3
- package/dist/plugins/pipelines/factiii/prod.js.map +1 -1
- package/dist/plugins/pipelines/factiii/scanfix/config.d.ts +1 -1
- package/dist/plugins/pipelines/factiii/scanfix/config.d.ts.map +1 -1
- package/dist/plugins/pipelines/factiii/scanfix/config.js +10 -11
- package/dist/plugins/pipelines/factiii/scanfix/config.js.map +1 -1
- package/dist/plugins/pipelines/factiii/scanfix/secrets.js +6 -6
- package/dist/plugins/pipelines/factiii/scanfix/secrets.js.map +1 -1
- package/dist/plugins/pipelines/factiii/scanfix/workflows.d.ts.map +1 -1
- package/dist/plugins/pipelines/factiii/scanfix/workflows.js +29 -25
- package/dist/plugins/pipelines/factiii/scanfix/workflows.js.map +1 -1
- package/dist/plugins/pipelines/factiii/staging.d.ts +1 -1
- package/dist/plugins/pipelines/factiii/staging.d.ts.map +1 -1
- package/dist/plugins/pipelines/factiii/staging.js +3 -2
- package/dist/plugins/pipelines/factiii/staging.js.map +1 -1
- package/dist/plugins/pipelines/factiii/utils/workflows.js +15 -15
- package/dist/plugins/pipelines/factiii/utils/workflows.js.map +1 -1
- package/dist/plugins/pipelines/factiii/workflows/factiii-cicd-prod.yml +11 -8
- package/dist/plugins/pipelines/factiii/workflows/factiii-cicd-staging.yml +11 -8
- package/dist/plugins/pipelines/factiii/workflows/factiii-command.yml +10 -8
- package/dist/plugins/pipelines/factiii/workflows/factiii-deploy.yml +17 -13
- package/dist/plugins/pipelines/factiii/workflows/factiii-dev-sync.yml +13 -11
- package/dist/plugins/pipelines/factiii/workflows/factiii-fix.yml +13 -11
- package/dist/plugins/pipelines/factiii/workflows/factiii-pr-check.yml +10 -7
- package/dist/plugins/pipelines/factiii/workflows/factiii-scan.yml +18 -11
- package/dist/plugins/pipelines/factiii/workflows/factiii-undeploy.yml +9 -8
- package/dist/plugins/pipelines/factiii/workflows/stack-cicd-prod.yml +115 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-cicd-staging.yml +120 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-command.yml +132 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-deploy.yml +202 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-dev-sync.yml +181 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-fix.yml +177 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-pr-check.yml +106 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-scan.yml +182 -0
- package/dist/plugins/pipelines/factiii/workflows/stack-undeploy.yml +96 -0
- package/dist/plugins/servers/mac/scanfix/containers.js +1 -1
- package/dist/plugins/servers/mac/scanfix/containers.js.map +1 -1
- package/dist/scanfix/fixes/pnpm.d.ts.map +1 -1
- package/dist/scanfix/fixes/pnpm.js +2 -2
- package/dist/scanfix/fixes/pnpm.js.map +1 -1
- package/dist/scripts/generate-all.d.ts.map +1 -1
- package/dist/scripts/generate-all.js +9 -8
- package/dist/scripts/generate-all.js.map +1 -1
- package/dist/scripts/get-repo-name.d.ts +1 -1
- package/dist/scripts/get-repo-name.js +5 -3
- package/dist/scripts/get-repo-name.js.map +1 -1
- package/dist/scripts/validate-env-files.js +7 -1
- package/dist/scripts/validate-env-files.js.map +1 -1
- package/dist/scripts/validate-example-values.d.ts +1 -1
- package/dist/scripts/validate-example-values.js +3 -2
- package/dist/scripts/validate-example-values.js.map +1 -1
- package/dist/scripts/validate-stack-yml.d.ts +6 -0
- package/dist/scripts/validate-stack-yml.d.ts.map +1 -0
- package/dist/scripts/{validate-factiii-yml.js → validate-stack-yml.js} +15 -11
- package/dist/scripts/validate-stack-yml.js.map +1 -0
- package/dist/utils/config-validator.d.ts +2 -2
- package/dist/utils/config-validator.d.ts.map +1 -1
- package/dist/utils/config-validator.js +7 -6
- package/dist/utils/config-validator.js.map +1 -1
- package/dist/utils/config-writer.d.ts +2 -2
- package/dist/utils/config-writer.d.ts.map +1 -1
- package/dist/utils/config-writer.js +6 -6
- package/dist/utils/config-writer.js.map +1 -1
- package/dist/utils/deployment-report.js +4 -4
- package/dist/utils/deployment-report.js.map +1 -1
- package/dist/utils/ssh-helper.js +6 -6
- package/dist/utils/ssh-helper.js.map +1 -1
- package/dist/utils/template-generator.js +1 -1
- package/dist/utils/version-check.d.ts +1 -1
- package/dist/utils/version-check.d.ts.map +1 -1
- package/dist/utils/version-check.js +9 -8
- package/dist/utils/version-check.js.map +1 -1
- package/package.json +8 -2
- package/dist/generators/generate-factiii-auto.d.ts.map +0 -1
- package/dist/generators/generate-factiii-auto.js.map +0 -1
- package/dist/generators/generate-factiii-yml.d.ts.map +0 -1
- package/dist/generators/generate-factiii-yml.js.map +0 -1
- package/dist/scripts/validate-factiii-yml.d.ts +0 -6
- package/dist/scripts/validate-factiii-yml.d.ts.map +0 -1
- package/dist/scripts/validate-factiii-yml.js.map +0 -1
|
@@ -51,13 +51,13 @@ exports.workflowFixes = [
|
|
|
51
51
|
description: 'GitHub workflows not generated',
|
|
52
52
|
scan: async (_config, rootDir) => {
|
|
53
53
|
const workflowsDir = path.join(rootDir, '.github', 'workflows');
|
|
54
|
-
return !fs.existsSync(path.join(workflowsDir, '
|
|
54
|
+
return !fs.existsSync(path.join(workflowsDir, 'stack-deploy.yml'));
|
|
55
55
|
},
|
|
56
56
|
fix: async (_config, rootDir) => {
|
|
57
57
|
await (0, workflows_js_1.generateWorkflows)(rootDir);
|
|
58
58
|
return true;
|
|
59
59
|
},
|
|
60
|
-
manualFix: 'Run: npx
|
|
60
|
+
manualFix: 'Run: npx stack fix (will generate workflow files)',
|
|
61
61
|
},
|
|
62
62
|
{
|
|
63
63
|
id: 'outdated-workflows',
|
|
@@ -65,7 +65,7 @@ exports.workflowFixes = [
|
|
|
65
65
|
severity: 'info',
|
|
66
66
|
description: 'GitHub workflows may be outdated',
|
|
67
67
|
scan: async (_config, rootDir) => {
|
|
68
|
-
const workflowPath = path.join(rootDir, '.github', 'workflows', '
|
|
68
|
+
const workflowPath = path.join(rootDir, '.github', 'workflows', 'stack-deploy.yml');
|
|
69
69
|
if (!fs.existsSync(workflowPath))
|
|
70
70
|
return false;
|
|
71
71
|
const content = fs.readFileSync(workflowPath, 'utf8');
|
|
@@ -84,7 +84,7 @@ exports.workflowFixes = [
|
|
|
84
84
|
await (0, workflows_js_1.generateWorkflows)(rootDir);
|
|
85
85
|
return true;
|
|
86
86
|
},
|
|
87
|
-
manualFix: 'Run: npx
|
|
87
|
+
manualFix: 'Run: npx stack fix (will regenerate thin workflows)',
|
|
88
88
|
},
|
|
89
89
|
{
|
|
90
90
|
id: 'orphaned-workflows',
|
|
@@ -97,35 +97,39 @@ exports.workflowFixes = [
|
|
|
97
97
|
return false;
|
|
98
98
|
// List of workflows we currently generate
|
|
99
99
|
const validWorkflows = [
|
|
100
|
-
'
|
|
101
|
-
'
|
|
102
|
-
'
|
|
103
|
-
'
|
|
104
|
-
'
|
|
105
|
-
'
|
|
106
|
-
'
|
|
100
|
+
'stack-deploy.yml',
|
|
101
|
+
'stack-fix.yml',
|
|
102
|
+
'stack-scan.yml',
|
|
103
|
+
'stack-undeploy.yml',
|
|
104
|
+
'stack-pr-check.yml',
|
|
105
|
+
'stack-command.yml',
|
|
106
|
+
'stack-cicd-staging.yml',
|
|
107
|
+
'stack-cicd-prod.yml',
|
|
108
|
+
'stack-dev-sync.yml', // Only in dev mode
|
|
107
109
|
];
|
|
108
|
-
// Find all
|
|
110
|
+
// Find all stack-*.yml files
|
|
109
111
|
const files = fs.readdirSync(workflowsDir);
|
|
110
|
-
const
|
|
112
|
+
const stackFiles = files.filter((f) => f.startsWith('stack-') && f.endsWith('.yml'));
|
|
111
113
|
// Check for orphaned files
|
|
112
|
-
const orphaned =
|
|
114
|
+
const orphaned = stackFiles.filter((f) => !validWorkflows.includes(f));
|
|
113
115
|
return orphaned.length > 0;
|
|
114
116
|
},
|
|
115
117
|
fix: async (_config, rootDir) => {
|
|
116
118
|
const workflowsDir = path.join(rootDir, '.github', 'workflows');
|
|
117
119
|
const validWorkflows = [
|
|
118
|
-
'
|
|
119
|
-
'
|
|
120
|
-
'
|
|
121
|
-
'
|
|
122
|
-
'
|
|
123
|
-
'
|
|
124
|
-
'
|
|
120
|
+
'stack-deploy.yml',
|
|
121
|
+
'stack-fix.yml',
|
|
122
|
+
'stack-scan.yml',
|
|
123
|
+
'stack-undeploy.yml',
|
|
124
|
+
'stack-pr-check.yml',
|
|
125
|
+
'stack-command.yml',
|
|
126
|
+
'stack-cicd-staging.yml',
|
|
127
|
+
'stack-cicd-prod.yml',
|
|
128
|
+
'stack-dev-sync.yml',
|
|
125
129
|
];
|
|
126
130
|
const files = fs.readdirSync(workflowsDir);
|
|
127
|
-
const
|
|
128
|
-
const orphaned =
|
|
131
|
+
const stackFiles = files.filter((f) => f.startsWith('stack-') && f.endsWith('.yml'));
|
|
132
|
+
const orphaned = stackFiles.filter((f) => !validWorkflows.includes(f));
|
|
129
133
|
for (const file of orphaned) {
|
|
130
134
|
const filePath = path.join(workflowsDir, file);
|
|
131
135
|
fs.unlinkSync(filePath);
|
|
@@ -133,7 +137,7 @@ exports.workflowFixes = [
|
|
|
133
137
|
}
|
|
134
138
|
return orphaned.length > 0;
|
|
135
139
|
},
|
|
136
|
-
manualFix: 'Run: npx
|
|
140
|
+
manualFix: 'Run: npx stack fix (will remove old workflow files)',
|
|
137
141
|
},
|
|
138
142
|
{
|
|
139
143
|
id: 'workflows-uncommitted',
|
|
@@ -162,7 +166,7 @@ exports.workflowFixes = [
|
|
|
162
166
|
fix: null, // Cannot auto-commit
|
|
163
167
|
manualFix: 'Commit and push workflow files to git:\n' +
|
|
164
168
|
' git add .github/workflows/\n' +
|
|
165
|
-
' git commit -m "Update
|
|
169
|
+
' git commit -m "Update stack workflows"\n' +
|
|
166
170
|
' git push',
|
|
167
171
|
},
|
|
168
172
|
];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflows.js","sourceRoot":"","sources":["../../../../../src/plugins/pipelines/factiii/scanfix/workflows.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,uCAAyB;AACzB,2CAA6B;AAC7B,iDAAyC;AAEzC,wDAAmF;AACnF,yEAAuE;AAE1D,QAAA,aAAa,GAAU;IAClC;QACE,EAAE,EAAE,mBAAmB;QACvB,KAAK,EAAE,KAAK;QACZ,QAAQ,EAAE,SAAS;QACnB,WAAW,EAAE,gCAAgC;QAC7C,IAAI,EAAE,KAAK,EAAE,OAAsB,EAAE,OAAe,EAAoB,EAAE;YACxE,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;YAChE,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,
|
|
1
|
+
{"version":3,"file":"workflows.js","sourceRoot":"","sources":["../../../../../src/plugins/pipelines/factiii/scanfix/workflows.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
*/
|
|
7
7
|
import type { FactiiiConfig, EnvironmentConfig, DeployResult } from '../../../types/index.js';
|
|
8
8
|
/**
|
|
9
|
-
* Get dockerfile path from factiiiAuto.yml or use default
|
|
9
|
+
* Get dockerfile path from stackAuto.yml (or legacy factiiiAuto.yml) or use default
|
|
10
10
|
*/
|
|
11
11
|
export declare function getDockerfilePath(repoDir: string): string;
|
|
12
12
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"staging.d.ts","sourceRoot":"","sources":["../../../../src/plugins/pipelines/factiii/staging.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"staging.d.ts","sourceRoot":"","sources":["../../../../src/plugins/pipelines/factiii/staging.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AASH,OAAO,KAAK,EACV,aAAa,EACb,iBAAiB,EACjB,YAAY,EACb,MAAM,yBAAyB,CAAC;AAEjC;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAgBzD;AAED;;;GAGG;AACH,wBAAsB,mBAAmB,CACvC,SAAS,EAAE,iBAAiB,EAC5B,UAAU,EAAE,OAAO,GAClB,OAAO,CAAC,IAAI,CAAC,CAuFf;AAED;;;;;;GAMG;AACH,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,aAAa,EACrB,SAAS,EAAE,iBAAiB,GAC3B,OAAO,CAAC,YAAY,CAAC,CA4DvB"}
|
|
@@ -49,12 +49,13 @@ const fs = __importStar(require("fs"));
|
|
|
49
49
|
const path = __importStar(require("path"));
|
|
50
50
|
const child_process_1 = require("child_process");
|
|
51
51
|
const js_yaml_1 = __importDefault(require("js-yaml"));
|
|
52
|
+
const config_files_js_1 = require("../../../constants/config-files.js");
|
|
52
53
|
const ssh_helper_js_1 = require("../../../utils/ssh-helper.js");
|
|
53
54
|
/**
|
|
54
|
-
* Get dockerfile path from factiiiAuto.yml or use default
|
|
55
|
+
* Get dockerfile path from stackAuto.yml (or legacy factiiiAuto.yml) or use default
|
|
55
56
|
*/
|
|
56
57
|
function getDockerfilePath(repoDir) {
|
|
57
|
-
const autoConfigPath =
|
|
58
|
+
const autoConfigPath = (0, config_files_js_1.getStackAutoPath)(repoDir);
|
|
58
59
|
if (fs.existsSync(autoConfigPath)) {
|
|
59
60
|
try {
|
|
60
61
|
const autoConfig = js_yaml_1.default.load(fs.readFileSync(autoConfigPath, 'utf8'));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"staging.js","sourceRoot":"","sources":["../../../../src/plugins/pipelines/factiii/staging.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"staging.js","sourceRoot":"","sources":["../../../../src/plugins/pipelines/factiii/staging.ts"],"names":[],"mappings":"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"}
|
|
@@ -62,26 +62,26 @@ async function generateWorkflows(rootDir) {
|
|
|
62
62
|
}
|
|
63
63
|
// Copy workflow files and inject version
|
|
64
64
|
// Infrastructure management (manual dispatch):
|
|
65
|
-
// -
|
|
66
|
-
// -
|
|
67
|
-
// -
|
|
68
|
-
// -
|
|
65
|
+
// - stack-deploy.yml: Manual deploy with --staging or --prod
|
|
66
|
+
// - stack-fix.yml: Manual fix with matrix for all configured envs
|
|
67
|
+
// - stack-scan.yml: Manual scan with matrix for all configured envs
|
|
68
|
+
// - stack-undeploy.yml: Manual cleanup
|
|
69
69
|
// CI/CD (auto on push):
|
|
70
|
-
// -
|
|
71
|
-
// -
|
|
70
|
+
// - stack-cicd-staging.yml: Auto-deploy on push to main
|
|
71
|
+
// - stack-cicd-prod.yml: Auto-deploy on push to prod
|
|
72
72
|
const workflows = [
|
|
73
|
-
'
|
|
74
|
-
'
|
|
75
|
-
'
|
|
76
|
-
'
|
|
77
|
-
'
|
|
78
|
-
'
|
|
79
|
-
'
|
|
80
|
-
'
|
|
73
|
+
'stack-deploy.yml',
|
|
74
|
+
'stack-fix.yml',
|
|
75
|
+
'stack-scan.yml',
|
|
76
|
+
'stack-undeploy.yml',
|
|
77
|
+
'stack-pr-check.yml',
|
|
78
|
+
'stack-cicd-staging.yml',
|
|
79
|
+
'stack-cicd-prod.yml',
|
|
80
|
+
'stack-command.yml',
|
|
81
81
|
];
|
|
82
82
|
// Only add dev-sync workflow in dev mode
|
|
83
83
|
if (process.env.DEV_MODE === 'true') {
|
|
84
|
-
workflows.push('
|
|
84
|
+
workflows.push('stack-dev-sync.yml');
|
|
85
85
|
}
|
|
86
86
|
for (const workflow of workflows) {
|
|
87
87
|
const sourcePath = path.join(sourceDir, workflow);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflows.js","sourceRoot":"","sources":["../../../../../src/plugins/pipelines/factiii/utils/workflows.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYH,8CAmDC;AAKD,0CAmCC;AArGD,uCAAyB;AACzB,2CAA6B;AAC7B,iDAAyC;AACzC,wCAAwC;AACxC,wEAAgE;AAChE,yEAAuE;AAEvE;;GAEG;AACI,KAAK,UAAU,iBAAiB,CAAC,OAAe;IACrD,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;IAChE,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;IAEvD,sBAAsB;IACtB,MAAM,OAAO,GAAG,IAAA,oCAAiB,GAAE,CAAC;IAEpC,+CAA+C;IAC/C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;QACjC,EAAE,CAAC,SAAS,CAAC,YAAY,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAClD,CAAC;IAED,yCAAyC;IACzC,+CAA+C;IAC/C,
|
|
1
|
+
{"version":3,"file":"workflows.js","sourceRoot":"","sources":["../../../../../src/plugins/pipelines/factiii/utils/workflows.ts"],"names":[],"mappings":"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"}
|
|
@@ -25,14 +25,16 @@ jobs:
|
|
|
25
25
|
- name: Read config
|
|
26
26
|
id: config
|
|
27
27
|
run: |
|
|
28
|
-
|
|
29
|
-
|
|
28
|
+
CONFIG_FILE="stack.yml"
|
|
29
|
+
if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
30
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
31
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
30
32
|
exit 1
|
|
31
33
|
fi
|
|
32
34
|
|
|
33
|
-
REPO_NAME=$(yq eval '.name'
|
|
34
|
-
HOST=$(yq eval '.prod.domain // ""'
|
|
35
|
-
SSH_USER=$(yq eval '.prod.ssh_user // "ubuntu"'
|
|
35
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
36
|
+
HOST=$(yq eval '.prod.domain // ""' "$CONFIG_FILE")
|
|
37
|
+
SSH_USER=$(yq eval '.prod.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
36
38
|
|
|
37
39
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
38
40
|
echo "host=$HOST" >> $GITHUB_OUTPUT
|
|
@@ -41,11 +43,12 @@ jobs:
|
|
|
41
43
|
- name: Check if prod configured
|
|
42
44
|
id: check_prod
|
|
43
45
|
run: |
|
|
44
|
-
|
|
46
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
47
|
+
HAS_PROD=$(yq eval '.prod != null' "$CONFIG_FILE")
|
|
45
48
|
echo "has_prod=$HAS_PROD" >> $GITHUB_OUTPUT
|
|
46
49
|
|
|
47
50
|
if [ "$HAS_PROD" != "true" ]; then
|
|
48
|
-
echo "⏭️ Prod
|
|
51
|
+
echo "⏭️ Prod not configured - skipping deployment"
|
|
49
52
|
exit 0
|
|
50
53
|
fi
|
|
51
54
|
|
|
@@ -75,7 +78,7 @@ jobs:
|
|
|
75
78
|
PROD_ENVS: ${{ secrets.PROD_ENVS }}
|
|
76
79
|
run: |
|
|
77
80
|
if [ -z "$HOST" ]; then
|
|
78
|
-
echo "❌ Missing domain in
|
|
81
|
+
echo "❌ Missing prod.domain in config"
|
|
79
82
|
exit 1
|
|
80
83
|
fi
|
|
81
84
|
|
|
@@ -25,14 +25,16 @@ jobs:
|
|
|
25
25
|
- name: Read config
|
|
26
26
|
id: config
|
|
27
27
|
run: |
|
|
28
|
-
|
|
29
|
-
|
|
28
|
+
CONFIG_FILE="stack.yml"
|
|
29
|
+
if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
30
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
31
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
30
32
|
exit 1
|
|
31
33
|
fi
|
|
32
34
|
|
|
33
|
-
REPO_NAME=$(yq eval '.name'
|
|
34
|
-
HOST=$(yq eval '.staging.domain // ""'
|
|
35
|
-
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"'
|
|
35
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
36
|
+
HOST=$(yq eval '.staging.domain // ""' "$CONFIG_FILE")
|
|
37
|
+
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
36
38
|
|
|
37
39
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
38
40
|
echo "host=$HOST" >> $GITHUB_OUTPUT
|
|
@@ -41,11 +43,12 @@ jobs:
|
|
|
41
43
|
- name: Check if staging configured
|
|
42
44
|
id: check_staging
|
|
43
45
|
run: |
|
|
44
|
-
|
|
46
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
47
|
+
HAS_STAGING=$(yq eval '.staging != null' "$CONFIG_FILE")
|
|
45
48
|
echo "has_staging=$HAS_STAGING" >> $GITHUB_OUTPUT
|
|
46
49
|
|
|
47
50
|
if [ "$HAS_STAGING" != "true" ]; then
|
|
48
|
-
echo "⏭️ Staging
|
|
51
|
+
echo "⏭️ Staging not configured - skipping deployment"
|
|
49
52
|
exit 0
|
|
50
53
|
fi
|
|
51
54
|
|
|
@@ -76,7 +79,7 @@ jobs:
|
|
|
76
79
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
77
80
|
run: |
|
|
78
81
|
if [ -z "$HOST" ]; then
|
|
79
|
-
echo "❌ Missing domain in
|
|
82
|
+
echo "❌ Missing staging.domain in config"
|
|
80
83
|
exit 1
|
|
81
84
|
fi
|
|
82
85
|
|
|
@@ -44,14 +44,15 @@ jobs:
|
|
|
44
44
|
env:
|
|
45
45
|
STAGE: ${{ inputs.stage }}
|
|
46
46
|
run: |
|
|
47
|
-
if [ ! -f "factiii.yml"
|
|
48
|
-
|
|
47
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
48
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
49
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
49
50
|
exit 1
|
|
50
51
|
fi
|
|
51
52
|
|
|
52
|
-
REPO_NAME=$(yq eval '.name'
|
|
53
|
-
HOST=$(yq eval ".$STAGE.domain // \"\""
|
|
54
|
-
SSH_USER=$(yq eval ".$STAGE.ssh_user // \"ubuntu\""
|
|
53
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
54
|
+
HOST=$(yq eval ".$STAGE.domain // \"\"" "$CONFIG_FILE")
|
|
55
|
+
SSH_USER=$(yq eval ".$STAGE.ssh_user // \"ubuntu\"" "$CONFIG_FILE")
|
|
55
56
|
|
|
56
57
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
57
58
|
echo "host=$HOST" >> $GITHUB_OUTPUT
|
|
@@ -61,9 +62,10 @@ jobs:
|
|
|
61
62
|
env:
|
|
62
63
|
STAGE: ${{ inputs.stage }}
|
|
63
64
|
run: |
|
|
64
|
-
|
|
65
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
66
|
+
HAS_ENV=$(yq eval ".$STAGE != null" "$CONFIG_FILE")
|
|
65
67
|
if [ "$HAS_ENV" != "true" ]; then
|
|
66
|
-
echo "$STAGE
|
|
68
|
+
echo "$STAGE not configured in config"
|
|
67
69
|
exit 1
|
|
68
70
|
fi
|
|
69
71
|
|
|
@@ -97,7 +99,7 @@ jobs:
|
|
|
97
99
|
STAGE: ${{ inputs.stage }}
|
|
98
100
|
run: |
|
|
99
101
|
if [ -z "$HOST" ]; then
|
|
100
|
-
echo "Missing domain in
|
|
102
|
+
echo "Missing domain in config: $STAGE.domain"
|
|
101
103
|
exit 1
|
|
102
104
|
fi
|
|
103
105
|
|
|
@@ -31,19 +31,21 @@ jobs:
|
|
|
31
31
|
- name: Read config
|
|
32
32
|
id: config
|
|
33
33
|
run: |
|
|
34
|
-
|
|
35
|
-
|
|
34
|
+
CONFIG_FILE="stack.yml"
|
|
35
|
+
if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
36
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
37
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
36
38
|
exit 1
|
|
37
39
|
fi
|
|
38
40
|
|
|
39
|
-
REPO_NAME=$(yq eval '.name'
|
|
41
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
40
42
|
|
|
41
43
|
if [ "${{ inputs.environment }}" == "staging" ]; then
|
|
42
|
-
HOST=$(yq eval '.staging.domain // ""'
|
|
43
|
-
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"'
|
|
44
|
+
HOST=$(yq eval '.staging.domain // ""' "$CONFIG_FILE")
|
|
45
|
+
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
44
46
|
else
|
|
45
|
-
HOST=$(yq eval '.prod.domain // ""'
|
|
46
|
-
SSH_USER=$(yq eval '.prod.ssh_user // "ubuntu"'
|
|
47
|
+
HOST=$(yq eval '.prod.domain // ""' "$CONFIG_FILE")
|
|
48
|
+
SSH_USER=$(yq eval '.prod.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
47
49
|
fi
|
|
48
50
|
|
|
49
51
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
@@ -53,16 +55,17 @@ jobs:
|
|
|
53
55
|
- name: Check if environment configured
|
|
54
56
|
id: check_env
|
|
55
57
|
run: |
|
|
58
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
56
59
|
if [ "${{ inputs.environment }}" == "staging" ]; then
|
|
57
|
-
HAS_ENV=$(yq eval '.staging != null'
|
|
60
|
+
HAS_ENV=$(yq eval '.staging != null' "$CONFIG_FILE")
|
|
58
61
|
else
|
|
59
|
-
HAS_ENV=$(yq eval '.prod != null'
|
|
62
|
+
HAS_ENV=$(yq eval '.prod != null' "$CONFIG_FILE")
|
|
60
63
|
fi
|
|
61
64
|
|
|
62
65
|
echo "has_env=$HAS_ENV" >> $GITHUB_OUTPUT
|
|
63
66
|
|
|
64
67
|
if [ "$HAS_ENV" != "true" ]; then
|
|
65
|
-
echo "⏭️ ${{ inputs.environment }}
|
|
68
|
+
echo "⏭️ ${{ inputs.environment }} not configured in config"
|
|
66
69
|
exit 1
|
|
67
70
|
fi
|
|
68
71
|
|
|
@@ -70,8 +73,9 @@ jobs:
|
|
|
70
73
|
if: steps.check_env.outputs.has_env == 'true' && inputs.environment == 'prod'
|
|
71
74
|
id: staging_config
|
|
72
75
|
run: |
|
|
73
|
-
|
|
74
|
-
|
|
76
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
77
|
+
STAGING_HOST=$(yq eval '.staging.domain // ""' "$CONFIG_FILE")
|
|
78
|
+
STAGING_SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
75
79
|
|
|
76
80
|
echo "staging_host=$STAGING_HOST" >> $GITHUB_OUTPUT
|
|
77
81
|
echo "staging_ssh_user=$STAGING_SSH_USER" >> $GITHUB_OUTPUT
|
|
@@ -152,7 +156,7 @@ jobs:
|
|
|
152
156
|
PROD_ENVS: ${{ inputs.environment == 'prod' && secrets.PROD_ENVS || '' }}
|
|
153
157
|
run: |
|
|
154
158
|
if [ -z "$HOST" ]; then
|
|
155
|
-
echo "❌ Missing domain in
|
|
159
|
+
echo "❌ Missing domain in config: $ENVIRONMENT.domain"
|
|
156
160
|
exit 1
|
|
157
161
|
fi
|
|
158
162
|
|
|
@@ -47,19 +47,20 @@ jobs:
|
|
|
47
47
|
- name: Read config
|
|
48
48
|
id: config
|
|
49
49
|
run: |
|
|
50
|
-
if [ ! -f "factiii.yml"
|
|
51
|
-
|
|
50
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
51
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
52
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
52
53
|
exit 1
|
|
53
54
|
fi
|
|
54
55
|
|
|
55
|
-
REPO_NAME=$(yq eval '.name'
|
|
56
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
56
57
|
|
|
57
58
|
if [ "${{ inputs.environment }}" == "staging" ]; then
|
|
58
|
-
HOST=$(yq eval '.
|
|
59
|
-
SSH_USER=$(yq eval '.
|
|
59
|
+
HOST=$(yq eval '.staging.domain // ""' "$CONFIG_FILE")
|
|
60
|
+
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
60
61
|
else
|
|
61
|
-
HOST=$(yq eval '.
|
|
62
|
-
SSH_USER=$(yq eval '.
|
|
62
|
+
HOST=$(yq eval '.prod.domain // ""' "$CONFIG_FILE")
|
|
63
|
+
SSH_USER=$(yq eval '.prod.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
63
64
|
fi
|
|
64
65
|
|
|
65
66
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
@@ -69,16 +70,17 @@ jobs:
|
|
|
69
70
|
- name: Check if environment configured
|
|
70
71
|
id: check_env
|
|
71
72
|
run: |
|
|
73
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
72
74
|
if [ "${{ inputs.environment }}" == "staging" ]; then
|
|
73
|
-
HAS_ENV=$(yq eval '.
|
|
75
|
+
HAS_ENV=$(yq eval '.staging != null' "$CONFIG_FILE")
|
|
74
76
|
else
|
|
75
|
-
HAS_ENV=$(yq eval '.
|
|
77
|
+
HAS_ENV=$(yq eval '.prod != null' "$CONFIG_FILE")
|
|
76
78
|
fi
|
|
77
79
|
|
|
78
80
|
echo "has_env=$HAS_ENV" >> $GITHUB_OUTPUT
|
|
79
81
|
|
|
80
82
|
if [ "$HAS_ENV" != "true" ]; then
|
|
81
|
-
echo "⏭️ ${{ inputs.environment }}
|
|
83
|
+
echo "⏭️ ${{ inputs.environment }} not configured in config"
|
|
82
84
|
exit 1
|
|
83
85
|
fi
|
|
84
86
|
|
|
@@ -137,7 +139,7 @@ jobs:
|
|
|
137
139
|
ENVIRONMENT: ${{ inputs.environment }}
|
|
138
140
|
run: |
|
|
139
141
|
if [ -z "$HOST" ]; then
|
|
140
|
-
echo "❌ Missing domain in
|
|
142
|
+
echo "❌ Missing domain in config: $ENVIRONMENT.domain"
|
|
141
143
|
exit 1
|
|
142
144
|
fi
|
|
143
145
|
|
|
@@ -37,10 +37,10 @@ jobs:
|
|
|
37
37
|
run: |
|
|
38
38
|
ENVS="[]"
|
|
39
39
|
|
|
40
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
40
41
|
if [ "${{ inputs.environment }}" == "all" ]; then
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
HAS_PROD=$(yq eval '.prod != null' factiii.yml)
|
|
42
|
+
HAS_STAGING=$(yq eval '.staging != null' "$CONFIG_FILE")
|
|
43
|
+
HAS_PROD=$(yq eval '.prod != null' "$CONFIG_FILE")
|
|
44
44
|
|
|
45
45
|
if [ "$HAS_STAGING" == "true" ] && [ "$HAS_PROD" == "true" ]; then
|
|
46
46
|
ENVS='["staging", "prod"]'
|
|
@@ -75,14 +75,15 @@ jobs:
|
|
|
75
75
|
env:
|
|
76
76
|
ENVIRONMENT: ${{ matrix.environment }}
|
|
77
77
|
run: |
|
|
78
|
-
if [ ! -f "factiii.yml"
|
|
79
|
-
|
|
78
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
79
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
80
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
80
81
|
exit 1
|
|
81
82
|
fi
|
|
82
83
|
|
|
83
|
-
REPO_NAME=$(yq eval '.name'
|
|
84
|
-
HOST=$(yq eval ".$ENVIRONMENT.domain // \"\""
|
|
85
|
-
SSH_USER=$(yq eval ".$ENVIRONMENT.ssh_user // \"ubuntu\""
|
|
84
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
85
|
+
HOST=$(yq eval ".$ENVIRONMENT.domain // \"\"" "$CONFIG_FILE")
|
|
86
|
+
SSH_USER=$(yq eval ".$ENVIRONMENT.ssh_user // \"ubuntu\"" "$CONFIG_FILE")
|
|
86
87
|
|
|
87
88
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
88
89
|
echo "host=$HOST" >> $GITHUB_OUTPUT
|
|
@@ -93,11 +94,12 @@ jobs:
|
|
|
93
94
|
env:
|
|
94
95
|
ENVIRONMENT: ${{ matrix.environment }}
|
|
95
96
|
run: |
|
|
96
|
-
|
|
97
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
98
|
+
HAS_ENV=$(yq eval ".$ENVIRONMENT != null" "$CONFIG_FILE")
|
|
97
99
|
echo "has_env=$HAS_ENV" >> $GITHUB_OUTPUT
|
|
98
100
|
|
|
99
101
|
if [ "$HAS_ENV" != "true" ]; then
|
|
100
|
-
echo "⏭️ $ENVIRONMENT
|
|
102
|
+
echo "⏭️ $ENVIRONMENT not configured"
|
|
101
103
|
exit 0
|
|
102
104
|
fi
|
|
103
105
|
|
|
@@ -153,7 +155,7 @@ jobs:
|
|
|
153
155
|
ENVIRONMENT: ${{ matrix.environment }}
|
|
154
156
|
run: |
|
|
155
157
|
if [ -z "$HOST" ]; then
|
|
156
|
-
echo "❌ Missing domain in
|
|
158
|
+
echo "❌ Missing domain in config: $ENVIRONMENT.domain"
|
|
157
159
|
exit 1
|
|
158
160
|
fi
|
|
159
161
|
|
|
@@ -24,14 +24,16 @@ jobs:
|
|
|
24
24
|
- name: Read config
|
|
25
25
|
id: config
|
|
26
26
|
run: |
|
|
27
|
-
|
|
28
|
-
|
|
27
|
+
CONFIG_FILE="stack.yml"
|
|
28
|
+
if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
29
|
+
if [ ! -f "$CONFIG_FILE" ]; then
|
|
30
|
+
echo "❌ stack.yml or factiii.yml not found"
|
|
29
31
|
exit 1
|
|
30
32
|
fi
|
|
31
33
|
|
|
32
|
-
REPO_NAME=$(yq eval '.name'
|
|
33
|
-
HOST=$(yq eval '.staging.domain // ""'
|
|
34
|
-
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"'
|
|
34
|
+
REPO_NAME=$(yq eval '.name' "$CONFIG_FILE")
|
|
35
|
+
HOST=$(yq eval '.staging.domain // ""' "$CONFIG_FILE")
|
|
36
|
+
SSH_USER=$(yq eval '.staging.ssh_user // "ubuntu"' "$CONFIG_FILE")
|
|
35
37
|
|
|
36
38
|
echo "repo_name=$REPO_NAME" >> $GITHUB_OUTPUT
|
|
37
39
|
echo "host=$HOST" >> $GITHUB_OUTPUT
|
|
@@ -40,7 +42,8 @@ jobs:
|
|
|
40
42
|
- name: Check if staging configured
|
|
41
43
|
id: check_staging
|
|
42
44
|
run: |
|
|
43
|
-
|
|
45
|
+
CONFIG_FILE="stack.yml"; if [ ! -f "$CONFIG_FILE" ]; then CONFIG_FILE="factiii.yml"; fi
|
|
46
|
+
HAS_STAGING=$(yq eval '.staging != null' "$CONFIG_FILE")
|
|
44
47
|
echo "has_staging=$HAS_STAGING" >> $GITHUB_OUTPUT
|
|
45
48
|
|
|
46
49
|
if [ "$HAS_STAGING" != "true" ]; then
|
|
@@ -74,7 +77,7 @@ jobs:
|
|
|
74
77
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
75
78
|
run: |
|
|
76
79
|
if [ -z "$HOST" ]; then
|
|
77
|
-
echo "❌ Missing staging.domain in
|
|
80
|
+
echo "❌ Missing staging.domain in config"
|
|
78
81
|
exit 1
|
|
79
82
|
fi
|
|
80
83
|
|