@keywaysh/cli 0.1.15 → 0.1.16
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/cli.js +46 -4
- package/package.json +1 -1
package/dist/cli.js
CHANGED
|
@@ -140,7 +140,7 @@ var INTERNAL_POSTHOG_HOST = "https://eu.i.posthog.com";
|
|
|
140
140
|
// package.json
|
|
141
141
|
var package_default = {
|
|
142
142
|
name: "@keywaysh/cli",
|
|
143
|
-
version: "0.1.
|
|
143
|
+
version: "0.1.16",
|
|
144
144
|
description: "One link to all your secrets",
|
|
145
145
|
type: "module",
|
|
146
146
|
bin: {
|
|
@@ -2497,7 +2497,38 @@ function projectMatchesRepo(project, repoFullName) {
|
|
|
2497
2497
|
}
|
|
2498
2498
|
return false;
|
|
2499
2499
|
}
|
|
2500
|
-
async function
|
|
2500
|
+
async function selectProjectWithConnectOption(accessToken, provider, providerDisplayName, repoFullName, initialProjects) {
|
|
2501
|
+
let projects = initialProjects;
|
|
2502
|
+
while (true) {
|
|
2503
|
+
const result = await promptProjectSelection(projects, repoFullName, providerDisplayName);
|
|
2504
|
+
if (result === "connect_new") {
|
|
2505
|
+
console.log("");
|
|
2506
|
+
await connectCommand(provider, { loginPrompt: false });
|
|
2507
|
+
console.log("");
|
|
2508
|
+
const { projects: allProjects } = await getAllProviderProjects(accessToken, provider.toLowerCase());
|
|
2509
|
+
projects = allProjects.map((p) => ({
|
|
2510
|
+
id: p.id,
|
|
2511
|
+
name: p.name,
|
|
2512
|
+
serviceId: p.serviceId,
|
|
2513
|
+
serviceName: p.serviceName,
|
|
2514
|
+
linkedRepo: p.linkedRepo,
|
|
2515
|
+
environments: p.environments,
|
|
2516
|
+
connectionId: p.connectionId,
|
|
2517
|
+
teamId: p.teamId,
|
|
2518
|
+
teamName: p.teamName
|
|
2519
|
+
}));
|
|
2520
|
+
if (projects.length === 0) {
|
|
2521
|
+
console.error(pc12.red(`No projects found after connecting.`));
|
|
2522
|
+
process.exit(1);
|
|
2523
|
+
}
|
|
2524
|
+
console.log(pc12.green(`Found ${projects.length} projects. Select one:
|
|
2525
|
+
`));
|
|
2526
|
+
continue;
|
|
2527
|
+
}
|
|
2528
|
+
return { project: result, projects };
|
|
2529
|
+
}
|
|
2530
|
+
}
|
|
2531
|
+
async function promptProjectSelection(projects, repoFullName, providerDisplayName) {
|
|
2501
2532
|
const repoName = repoFullName.split("/")[1]?.toLowerCase() || "";
|
|
2502
2533
|
const uniqueTeams = new Set(projects.map((p) => p.teamId || "personal"));
|
|
2503
2534
|
const hasMultipleAccounts = uniqueTeams.size > 1;
|
|
@@ -2527,6 +2558,10 @@ async function promptProjectSelection(projects, repoFullName) {
|
|
|
2527
2558
|
}
|
|
2528
2559
|
return { title, value: p.id };
|
|
2529
2560
|
});
|
|
2561
|
+
choices.push({
|
|
2562
|
+
title: pc12.blue(`+ Connect another ${providerDisplayName} account`),
|
|
2563
|
+
value: "__connect_new__"
|
|
2564
|
+
});
|
|
2530
2565
|
const { projectChoice } = await prompts10({
|
|
2531
2566
|
type: "select",
|
|
2532
2567
|
name: "projectChoice",
|
|
@@ -2537,6 +2572,9 @@ async function promptProjectSelection(projects, repoFullName) {
|
|
|
2537
2572
|
console.log(pc12.gray("Cancelled."));
|
|
2538
2573
|
process.exit(0);
|
|
2539
2574
|
}
|
|
2575
|
+
if (projectChoice === "__connect_new__") {
|
|
2576
|
+
return "connect_new";
|
|
2577
|
+
}
|
|
2540
2578
|
return projects.find((p) => p.id === projectChoice);
|
|
2541
2579
|
}
|
|
2542
2580
|
async function syncCommand(provider, options = {}) {
|
|
@@ -2697,7 +2735,9 @@ Connection to ${providerDisplayName} failed.`));
|
|
|
2697
2735
|
if (useDetected) {
|
|
2698
2736
|
selectedProject = autoMatch.project;
|
|
2699
2737
|
} else {
|
|
2700
|
-
|
|
2738
|
+
const result = await selectProjectWithConnectOption(accessToken, provider, providerDisplayName, repoFullName, projects);
|
|
2739
|
+
selectedProject = result.project;
|
|
2740
|
+
projects = result.projects;
|
|
2701
2741
|
}
|
|
2702
2742
|
} else if (projects.length === 1) {
|
|
2703
2743
|
selectedProject = projects[0];
|
|
@@ -2727,7 +2767,9 @@ Connection to ${providerDisplayName} failed.`));
|
|
|
2727
2767
|
console.log(pc12.yellow(`
|
|
2728
2768
|
\u26A0\uFE0F No matching project found for ${repoFullName}`));
|
|
2729
2769
|
console.log(pc12.gray("Select a project manually:\n"));
|
|
2730
|
-
|
|
2770
|
+
const result = await selectProjectWithConnectOption(accessToken, provider, providerDisplayName, repoFullName, projects);
|
|
2771
|
+
selectedProject = result.project;
|
|
2772
|
+
projects = result.projects;
|
|
2731
2773
|
}
|
|
2732
2774
|
}
|
|
2733
2775
|
if (!options.project && !projectMatchesRepo(selectedProject, repoFullName)) {
|