climaybe 1.4.0 → 1.4.3
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/bin/cli.js +12 -3
- package/bin/version.txt +1 -0
- package/package.json +3 -2
- package/src/commands/init.js +13 -10
- package/src/index.js +6 -4
- package/src/workflows/preview/pr-update.yml +8 -1
package/bin/cli.js
CHANGED
|
@@ -1,13 +1,22 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
|
|
3
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
3
4
|
import { createRequire } from 'node:module';
|
|
4
5
|
import { dirname, join } from 'node:path';
|
|
5
6
|
import { fileURLToPath } from 'node:url';
|
|
6
7
|
import { run } from '../src/index.js';
|
|
7
8
|
|
|
8
|
-
// Resolve version from package.json next to this bin (works with npm link / global install)
|
|
9
9
|
const require = createRequire(import.meta.url);
|
|
10
10
|
const binDir = dirname(fileURLToPath(import.meta.url));
|
|
11
|
-
const
|
|
11
|
+
const packageDir = join(binDir, '..');
|
|
12
12
|
|
|
13
|
-
|
|
13
|
+
// Prefer version baked at publish (bin/version.txt) so the running binary always reports its own version
|
|
14
|
+
const versionFile = join(binDir, 'version.txt');
|
|
15
|
+
let version;
|
|
16
|
+
if (existsSync(versionFile)) {
|
|
17
|
+
version = readFileSync(versionFile, 'utf8').trim();
|
|
18
|
+
} else {
|
|
19
|
+
version = require(join(packageDir, 'package.json')).version;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
run(process.argv, version, packageDir);
|
package/bin/version.txt
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
1.4.3
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "climaybe",
|
|
3
|
-
"version": "1.4.
|
|
3
|
+
"version": "1.4.3",
|
|
4
4
|
"description": "Shopify CI/CD CLI — scaffolds workflows, branch strategy, and store config for single-store and multi-store theme repos",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -31,7 +31,8 @@
|
|
|
31
31
|
"homepage": "https://github.com/electricmaybe/climaybe#readme",
|
|
32
32
|
"scripts": {
|
|
33
33
|
"test": "node scripts/run-tests.js 2>&1 | tee test.log",
|
|
34
|
-
"prepare": "husky"
|
|
34
|
+
"prepare": "husky",
|
|
35
|
+
"prepublishOnly": "node -e \"require('fs').writeFileSync('bin/version.txt', require('./package.json').version)\""
|
|
35
36
|
},
|
|
36
37
|
"release": {
|
|
37
38
|
"branches": [
|
package/src/commands/init.js
CHANGED
|
@@ -140,12 +140,12 @@ async function runInitFlow() {
|
|
|
140
140
|
const existingNames =
|
|
141
141
|
ciHost === 'github' ? listGitHubSecrets() : listGitLabVariables();
|
|
142
142
|
const namesWeWillPrompt = new Set(secretsToPrompt.map((s) => s.name));
|
|
143
|
-
const alreadySet = existingNames.filter((n) => namesWeWillPrompt.has(n));
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
143
|
+
const alreadySet = new Set(existingNames.filter((n) => namesWeWillPrompt.has(n)));
|
|
144
|
+
let doUpdateExisting = true;
|
|
145
|
+
if (alreadySet.size > 0) {
|
|
146
|
+
doUpdateExisting = await promptUpdateExistingSecrets([...alreadySet]);
|
|
147
|
+
if (!doUpdateExisting) {
|
|
148
|
+
console.log(pc.dim('\n Skipping only the secret(s) already set; will still prompt for the rest.\n'));
|
|
149
149
|
}
|
|
150
150
|
}
|
|
151
151
|
|
|
@@ -159,6 +159,7 @@ async function runInitFlow() {
|
|
|
159
159
|
stores,
|
|
160
160
|
});
|
|
161
161
|
for (const { name, value } of storeUrlSecrets) {
|
|
162
|
+
if (alreadySet.has(name) && !doUpdateExisting) continue;
|
|
162
163
|
try {
|
|
163
164
|
await setter.set(name, value);
|
|
164
165
|
console.log(pc.green(` Set ${name} (from store config).`));
|
|
@@ -168,10 +169,12 @@ async function runInitFlow() {
|
|
|
168
169
|
}
|
|
169
170
|
}
|
|
170
171
|
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
172
|
+
const toPrompt = secretsToPrompt.filter((s) => !alreadySet.has(s.name) || doUpdateExisting);
|
|
173
|
+
const totalToPrompt = toPrompt.length;
|
|
174
|
+
console.log(pc.cyan(`\n Configure ${totalToPrompt} ${setter.name} secret(s)/variable(s). Leave optional ones blank to skip.\n`));
|
|
175
|
+
for (let i = 0; i < toPrompt.length; i++) {
|
|
176
|
+
const secret = toPrompt[i];
|
|
177
|
+
const value = await promptSecretValue(secret, i, totalToPrompt);
|
|
175
178
|
if (!value) continue;
|
|
176
179
|
|
|
177
180
|
const isThemeToken =
|
package/src/index.js
CHANGED
|
@@ -8,14 +8,16 @@ import { updateWorkflowsCommand } from './commands/update-workflows.js';
|
|
|
8
8
|
/**
|
|
9
9
|
* Create the CLI program (for testing and for run).
|
|
10
10
|
* @param {string} [version] - Version string (from bin/cli.js when run as CLI; from package.json in tests).
|
|
11
|
+
* @param {string} [packageDir] - Package root dir (shown with --version so user can see which install is running).
|
|
11
12
|
*/
|
|
12
|
-
export function createProgram(version = '0.0.0') {
|
|
13
|
+
export function createProgram(version = '0.0.0', packageDir = '') {
|
|
13
14
|
const program = new Command();
|
|
15
|
+
const versionDisplay = packageDir ? `${version}\n from: ${packageDir}` : version;
|
|
14
16
|
|
|
15
17
|
program
|
|
16
18
|
.name('climaybe')
|
|
17
19
|
.description('Shopify CI/CD CLI — scaffolds workflows, branch strategy, and store config')
|
|
18
|
-
.version(
|
|
20
|
+
.version(versionDisplay);
|
|
19
21
|
|
|
20
22
|
program
|
|
21
23
|
.command('init')
|
|
@@ -52,6 +54,6 @@ export function createProgram(version = '0.0.0') {
|
|
|
52
54
|
return program;
|
|
53
55
|
}
|
|
54
56
|
|
|
55
|
-
export function run(argv, version) {
|
|
56
|
-
createProgram(version).parse(argv);
|
|
57
|
+
export function run(argv, version, packageDir = '') {
|
|
58
|
+
createProgram(version, packageDir).parse(argv);
|
|
57
59
|
}
|
|
@@ -86,8 +86,15 @@ jobs:
|
|
|
86
86
|
fi
|
|
87
87
|
echo "Shopify credentials are configured for alias: ${{ steps.resolve.outputs.alias }}"
|
|
88
88
|
|
|
89
|
+
cleanup-themes:
|
|
90
|
+
needs: extract-pr-number
|
|
91
|
+
uses: ./.github/workflows/reusable-cleanup-themes.yml
|
|
92
|
+
with:
|
|
93
|
+
pr_number: ${{ needs.extract-pr-number.outputs.pr_number }}
|
|
94
|
+
secrets: inherit
|
|
95
|
+
|
|
89
96
|
share-theme:
|
|
90
|
-
needs: [validate-environment, extract-pr-number]
|
|
97
|
+
needs: [validate-environment, extract-pr-number, cleanup-themes]
|
|
91
98
|
uses: ./.github/workflows/reusable-share-theme.yml
|
|
92
99
|
with:
|
|
93
100
|
pr_number: ${{ needs.extract-pr-number.outputs.pr_number }}
|