@base44-preview/cli 0.0.15-pr.97.dfea5ba → 0.0.15-pr.97.e4e104f
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 +23 -1
- package/dist/cli/index.js +124 -107
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -43,9 +43,31 @@ base44 deploy
|
|
|
43
43
|
| Command | Description |
|
|
44
44
|
|---------|-------------|
|
|
45
45
|
| `base44 create` | Create a new Base44 project from a template |
|
|
46
|
-
| `base44 link` | Link
|
|
46
|
+
| `base44 link` | Link a local project to Base44 (create new or link existing) |
|
|
47
47
|
| `base44 dashboard` | Open the app dashboard in your browser |
|
|
48
48
|
|
|
49
|
+
#### Link Command Options
|
|
50
|
+
|
|
51
|
+
The `link` command supports both creating new projects and linking to existing ones:
|
|
52
|
+
|
|
53
|
+
```bash
|
|
54
|
+
# Interactive mode - choose to create new or link existing
|
|
55
|
+
base44 link
|
|
56
|
+
|
|
57
|
+
# Create a new project (non-interactive)
|
|
58
|
+
base44 link --create --name "my-app" --description "My app description"
|
|
59
|
+
|
|
60
|
+
# Link to an existing project by ID (non-interactive)
|
|
61
|
+
base44 link --existing <app-id>
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
| Option | Description |
|
|
65
|
+
|--------|-------------|
|
|
66
|
+
| `-c, --create` | Create a new project (skip selection prompt) |
|
|
67
|
+
| `-e, --existing <id>` | Link to an existing project by ID |
|
|
68
|
+
| `-n, --name <name>` | Project name (required with --create) |
|
|
69
|
+
| `-d, --description <desc>` | Project description (optional) |
|
|
70
|
+
|
|
49
71
|
### Deployment
|
|
50
72
|
|
|
51
73
|
| Command | Description |
|
package/dist/cli/index.js
CHANGED
|
@@ -4,7 +4,7 @@ import { EventEmitter, addAbortListener, on, once, setMaxListeners } from "node:
|
|
|
4
4
|
import childProcess, { ChildProcess, execFile, spawn, spawnSync } from "node:child_process";
|
|
5
5
|
import path, { basename, dirname, join, posix, resolve, win32 } from "node:path";
|
|
6
6
|
import fs, { appendFileSync, createReadStream, createWriteStream, readFileSync, statSync, writeFileSync } from "node:fs";
|
|
7
|
-
import
|
|
7
|
+
import process$1, { execArgv, execPath, hrtime, platform, stdin, stdout } from "node:process";
|
|
8
8
|
import { aborted, callbackify, debuglog, inspect, promisify, stripVTControlCharacters } from "node:util";
|
|
9
9
|
import * as g from "node:readline";
|
|
10
10
|
import O from "node:readline";
|
|
@@ -894,7 +894,7 @@ var require_command = /* @__PURE__ */ __commonJSMin(((exports) => {
|
|
|
894
894
|
const childProcess$1 = __require("node:child_process");
|
|
895
895
|
const path$15 = __require("node:path");
|
|
896
896
|
const fs$10 = __require("node:fs");
|
|
897
|
-
const process$
|
|
897
|
+
const process$4 = __require("node:process");
|
|
898
898
|
const { Argument, humanReadableArgName } = require_argument();
|
|
899
899
|
const { CommanderError } = require_error$1();
|
|
900
900
|
const { Help } = require_help();
|
|
@@ -945,10 +945,10 @@ var require_command = /* @__PURE__ */ __commonJSMin(((exports) => {
|
|
|
945
945
|
this._showHelpAfterError = false;
|
|
946
946
|
this._showSuggestionAfterError = true;
|
|
947
947
|
this._outputConfiguration = {
|
|
948
|
-
writeOut: (str) => process$
|
|
949
|
-
writeErr: (str) => process$
|
|
950
|
-
getOutHelpWidth: () => process$
|
|
951
|
-
getErrHelpWidth: () => process$
|
|
948
|
+
writeOut: (str) => process$4.stdout.write(str),
|
|
949
|
+
writeErr: (str) => process$4.stderr.write(str),
|
|
950
|
+
getOutHelpWidth: () => process$4.stdout.isTTY ? process$4.stdout.columns : void 0,
|
|
951
|
+
getErrHelpWidth: () => process$4.stderr.isTTY ? process$4.stderr.columns : void 0,
|
|
952
952
|
outputError: (str, write) => write(str)
|
|
953
953
|
};
|
|
954
954
|
this._hidden = false;
|
|
@@ -1302,7 +1302,7 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
1302
1302
|
*/
|
|
1303
1303
|
_exit(exitCode, code$1, message) {
|
|
1304
1304
|
if (this._exitCallback) this._exitCallback(new CommanderError(exitCode, code$1, message));
|
|
1305
|
-
process$
|
|
1305
|
+
process$4.exit(exitCode);
|
|
1306
1306
|
}
|
|
1307
1307
|
/**
|
|
1308
1308
|
* Register callback `fn` for the command.
|
|
@@ -1641,11 +1641,11 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
1641
1641
|
if (argv !== void 0 && !Array.isArray(argv)) throw new Error("first parameter to parse must be array or undefined");
|
|
1642
1642
|
parseOptions = parseOptions || {};
|
|
1643
1643
|
if (argv === void 0 && parseOptions.from === void 0) {
|
|
1644
|
-
if (process$
|
|
1645
|
-
const execArgv$1 = process$
|
|
1644
|
+
if (process$4.versions?.electron) parseOptions.from = "electron";
|
|
1645
|
+
const execArgv$1 = process$4.execArgv ?? [];
|
|
1646
1646
|
if (execArgv$1.includes("-e") || execArgv$1.includes("--eval") || execArgv$1.includes("-p") || execArgv$1.includes("--print")) parseOptions.from = "eval";
|
|
1647
1647
|
}
|
|
1648
|
-
if (argv === void 0) argv = process$
|
|
1648
|
+
if (argv === void 0) argv = process$4.argv;
|
|
1649
1649
|
this.rawArgs = argv.slice();
|
|
1650
1650
|
let userArgs;
|
|
1651
1651
|
switch (parseOptions.from) {
|
|
@@ -1655,7 +1655,7 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
1655
1655
|
userArgs = argv.slice(2);
|
|
1656
1656
|
break;
|
|
1657
1657
|
case "electron":
|
|
1658
|
-
if (process$
|
|
1658
|
+
if (process$4.defaultApp) {
|
|
1659
1659
|
this._scriptPath = argv[1];
|
|
1660
1660
|
userArgs = argv.slice(2);
|
|
1661
1661
|
} else userArgs = argv.slice(1);
|
|
@@ -1769,15 +1769,15 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
1769
1769
|
}
|
|
1770
1770
|
launchWithNode = sourceExt.includes(path$15.extname(executableFile));
|
|
1771
1771
|
let proc$1;
|
|
1772
|
-
if (process$
|
|
1772
|
+
if (process$4.platform !== "win32") if (launchWithNode) {
|
|
1773
1773
|
args.unshift(executableFile);
|
|
1774
|
-
args = incrementNodeInspectorPort(process$
|
|
1775
|
-
proc$1 = childProcess$1.spawn(process$
|
|
1774
|
+
args = incrementNodeInspectorPort(process$4.execArgv).concat(args);
|
|
1775
|
+
proc$1 = childProcess$1.spawn(process$4.argv[0], args, { stdio: "inherit" });
|
|
1776
1776
|
} else proc$1 = childProcess$1.spawn(executableFile, args, { stdio: "inherit" });
|
|
1777
1777
|
else {
|
|
1778
1778
|
args.unshift(executableFile);
|
|
1779
|
-
args = incrementNodeInspectorPort(process$
|
|
1780
|
-
proc$1 = childProcess$1.spawn(process$
|
|
1779
|
+
args = incrementNodeInspectorPort(process$4.execArgv).concat(args);
|
|
1780
|
+
proc$1 = childProcess$1.spawn(process$4.execPath, args, { stdio: "inherit" });
|
|
1781
1781
|
}
|
|
1782
1782
|
if (!proc$1.killed) [
|
|
1783
1783
|
"SIGUSR1",
|
|
@@ -1786,14 +1786,14 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
1786
1786
|
"SIGINT",
|
|
1787
1787
|
"SIGHUP"
|
|
1788
1788
|
].forEach((signal) => {
|
|
1789
|
-
process$
|
|
1789
|
+
process$4.on(signal, () => {
|
|
1790
1790
|
if (proc$1.killed === false && proc$1.exitCode === null) proc$1.kill(signal);
|
|
1791
1791
|
});
|
|
1792
1792
|
});
|
|
1793
1793
|
const exitCallback = this._exitCallback;
|
|
1794
1794
|
proc$1.on("close", (code$1) => {
|
|
1795
1795
|
code$1 = code$1 ?? 1;
|
|
1796
|
-
if (!exitCallback) process$
|
|
1796
|
+
if (!exitCallback) process$4.exit(code$1);
|
|
1797
1797
|
else exitCallback(new CommanderError(code$1, "commander.executeSubCommandAsync", "(close)"));
|
|
1798
1798
|
});
|
|
1799
1799
|
proc$1.on("error", (err) => {
|
|
@@ -1805,7 +1805,7 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
1805
1805
|
- ${executableDirMessage}`;
|
|
1806
1806
|
throw new Error(executableMissing);
|
|
1807
1807
|
} else if (err.code === "EACCES") throw new Error(`'${executableFile}' not executable`);
|
|
1808
|
-
if (!exitCallback) process$
|
|
1808
|
+
if (!exitCallback) process$4.exit(1);
|
|
1809
1809
|
else {
|
|
1810
1810
|
const wrappedError = new CommanderError(1, "commander.executeSubCommandAsync", "(error)");
|
|
1811
1811
|
wrappedError.nestedError = err;
|
|
@@ -2211,13 +2211,13 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
2211
2211
|
*/
|
|
2212
2212
|
_parseOptionsEnv() {
|
|
2213
2213
|
this.options.forEach((option) => {
|
|
2214
|
-
if (option.envVar && option.envVar in process$
|
|
2214
|
+
if (option.envVar && option.envVar in process$4.env) {
|
|
2215
2215
|
const optionKey = option.attributeName();
|
|
2216
2216
|
if (this.getOptionValue(optionKey) === void 0 || [
|
|
2217
2217
|
"default",
|
|
2218
2218
|
"config",
|
|
2219
2219
|
"env"
|
|
2220
|
-
].includes(this.getOptionValueSource(optionKey))) if (option.required || option.optional) this.emit(`optionEnv:${option.name()}`, process$
|
|
2220
|
+
].includes(this.getOptionValueSource(optionKey))) if (option.required || option.optional) this.emit(`optionEnv:${option.name()}`, process$4.env[option.envVar]);
|
|
2221
2221
|
else this.emit(`optionEnv:${option.name()}`);
|
|
2222
2222
|
}
|
|
2223
2223
|
});
|
|
@@ -2596,7 +2596,7 @@ Expecting one of '${allowedValues.join("', '")}'`);
|
|
|
2596
2596
|
*/
|
|
2597
2597
|
help(contextOptions) {
|
|
2598
2598
|
this.outputHelp(contextOptions);
|
|
2599
|
-
let exitCode = process$
|
|
2599
|
+
let exitCode = process$4.exitCode || 0;
|
|
2600
2600
|
if (exitCode === 0 && contextOptions && typeof contextOptions !== "function" && contextOptions.error) exitCode = 1;
|
|
2601
2601
|
this._exit(exitCode, "commander.help", "(outputHelp)");
|
|
2602
2602
|
}
|
|
@@ -2712,16 +2712,16 @@ var require_src = /* @__PURE__ */ __commonJSMin(((exports, module) => {
|
|
|
2712
2712
|
const CSI = `${ESC}[`;
|
|
2713
2713
|
const beep = "\x07";
|
|
2714
2714
|
const cursor = {
|
|
2715
|
-
to(x$2, y$
|
|
2716
|
-
if (!y$
|
|
2717
|
-
return `${CSI}${y$
|
|
2715
|
+
to(x$2, y$1) {
|
|
2716
|
+
if (!y$1) return `${CSI}${x$2 + 1}G`;
|
|
2717
|
+
return `${CSI}${y$1 + 1};${x$2 + 1}H`;
|
|
2718
2718
|
},
|
|
2719
|
-
move(x$2, y$
|
|
2719
|
+
move(x$2, y$1) {
|
|
2720
2720
|
let ret = "";
|
|
2721
2721
|
if (x$2 < 0) ret += `${CSI}${-x$2}D`;
|
|
2722
2722
|
else if (x$2 > 0) ret += `${CSI}${x$2}C`;
|
|
2723
|
-
if (y$
|
|
2724
|
-
else if (y$
|
|
2723
|
+
if (y$1 < 0) ret += `${CSI}${-y$1}A`;
|
|
2724
|
+
else if (y$1 > 0) ret += `${CSI}${y$1}B`;
|
|
2725
2725
|
return ret;
|
|
2726
2726
|
},
|
|
2727
2727
|
up: (count$1 = 1) => `${CSI}${count$1}A`,
|
|
@@ -3031,13 +3031,13 @@ function rD() {
|
|
|
3031
3031
|
}
|
|
3032
3032
|
}), r;
|
|
3033
3033
|
}
|
|
3034
|
-
const ED = rD(), d$1 = new Set(["\x1B", ""]), oD = 39, y
|
|
3034
|
+
const ED = rD(), d$1 = new Set(["\x1B", ""]), oD = 39, y = "\x07", V$1 = "[", nD = "]", G$1 = "m", _$1 = `${nD}8;;`, z = (e$1) => `${d$1.values().next().value}${V$1}${e$1}${G$1}`, K$1 = (e$1) => `${d$1.values().next().value}${_$1}${e$1}${y}`, aD = (e$1) => e$1.split(" ").map((u$2) => p(u$2)), k$1 = (e$1, u$2, t) => {
|
|
3035
3035
|
const F$1 = [...u$2];
|
|
3036
3036
|
let s = !1, i$1 = !1, D$1 = p(P$1(e$1[e$1.length - 1]));
|
|
3037
3037
|
for (const [C$1, n$1] of F$1.entries()) {
|
|
3038
3038
|
const E = p(n$1);
|
|
3039
3039
|
if (D$1 + E <= t ? e$1[e$1.length - 1] += n$1 : (e$1.push(n$1), D$1 = 0), d$1.has(n$1) && (s = !0, i$1 = F$1.slice(C$1 + 1).join("").startsWith(_$1)), s) {
|
|
3040
|
-
i$1 ? n$1 === y
|
|
3040
|
+
i$1 ? n$1 === y && (s = !1, i$1 = !1) : n$1 === G$1 && (s = !1);
|
|
3041
3041
|
continue;
|
|
3042
3042
|
}
|
|
3043
3043
|
D$1 += E, D$1 === t && C$1 < F$1.length - 1 && (e$1.push(""), D$1 = 0);
|
|
@@ -3079,7 +3079,7 @@ const ED = rD(), d$1 = new Set(["\x1B", ""]), oD = 39, y$1 = "\x07", V$1 = "["
|
|
|
3079
3079
|
`)];
|
|
3080
3080
|
for (const [E, a$1] of n$1.entries()) {
|
|
3081
3081
|
if (F$1 += a$1, d$1.has(a$1)) {
|
|
3082
|
-
const { groups: c$1 } = (/* @__PURE__ */ new RegExp(`(?:\\${V$1}(?<code>\\d+)m|\\${_$1}(?<uri>.*)${y
|
|
3082
|
+
const { groups: c$1 } = (/* @__PURE__ */ new RegExp(`(?:\\${V$1}(?<code>\\d+)m|\\${_$1}(?<uri>.*)${y})`)).exec(n$1.slice(E).join("")) || { groups: {} };
|
|
3083
3083
|
if (c$1.code !== void 0) {
|
|
3084
3084
|
const f = Number.parseFloat(c$1.code);
|
|
3085
3085
|
s = f === oD ? void 0 : f;
|
|
@@ -3480,7 +3480,7 @@ var RD = class extends x$1 {
|
|
|
3480
3480
|
//#endregion
|
|
3481
3481
|
//#region node_modules/@clack/prompts/dist/index.mjs
|
|
3482
3482
|
function ce() {
|
|
3483
|
-
return
|
|
3483
|
+
return process$1.platform !== "win32" ? process$1.env.TERM !== "linux" : !!process$1.env.CI || !!process$1.env.WT_SESSION || !!process$1.env.TERMINUS_SUBLIME || process$1.env.ConEmuTask === "{cmd::Cmder}" || process$1.env.TERM_PROGRAM === "Terminus-Sublime" || process$1.env.TERM_PROGRAM === "vscode" || process$1.env.TERM === "xterm-256color" || process$1.env.TERM === "alacritty" || process$1.env.TERMINAL_EMULATOR === "JetBrains-JediTerm";
|
|
3484
3484
|
}
|
|
3485
3485
|
const V = ce(), u$1 = (t, n$1) => V ? t : n$1, le = u$1("◆", "*"), L = u$1("■", "x"), W = u$1("▲", "x"), C = u$1("◇", "o"), ue = u$1("┌", "T"), o$1 = u$1("│", "|"), d = u$1("└", "—"), k = u$1("●", ">"), P = u$1("○", " "), A = u$1("◻", "[•]"), T = u$1("◼", "[+]"), F = u$1("◻", "[ ]"), $e = u$1("▪", "•"), _ = u$1("─", "-"), me = u$1("╮", "+"), de = u$1("├", "+"), pe = u$1("╯", "+"), q = u$1("●", "•"), D = u$1("◆", "*"), U = u$1("▲", "!"), K = u$1("■", "x"), b = (t) => {
|
|
3486
3486
|
switch (t) {
|
|
@@ -6654,7 +6654,7 @@ function initializeContext(params) {
|
|
|
6654
6654
|
external: params?.external ?? void 0
|
|
6655
6655
|
};
|
|
6656
6656
|
}
|
|
6657
|
-
function process$
|
|
6657
|
+
function process$3(schema, ctx, _params = {
|
|
6658
6658
|
path: [],
|
|
6659
6659
|
schemaPath: []
|
|
6660
6660
|
}) {
|
|
@@ -6691,7 +6691,7 @@ function process$2(schema, ctx, _params = {
|
|
|
6691
6691
|
const parent = schema._zod.parent;
|
|
6692
6692
|
if (parent) {
|
|
6693
6693
|
if (!result.ref) result.ref = parent;
|
|
6694
|
-
process$
|
|
6694
|
+
process$3(parent, ctx, params);
|
|
6695
6695
|
ctx.seen.get(parent).isParent = true;
|
|
6696
6696
|
}
|
|
6697
6697
|
}
|
|
@@ -6903,7 +6903,7 @@ const createToJSONSchemaMethod = (schema, processors = {}) => (params) => {
|
|
|
6903
6903
|
...params,
|
|
6904
6904
|
processors
|
|
6905
6905
|
});
|
|
6906
|
-
process$
|
|
6906
|
+
process$3(schema, ctx);
|
|
6907
6907
|
extractDefs(ctx, schema);
|
|
6908
6908
|
return finalize(ctx, schema);
|
|
6909
6909
|
};
|
|
@@ -6915,7 +6915,7 @@ const createStandardJSONSchemaMethod = (schema, io, processors = {}) => (params)
|
|
|
6915
6915
|
io,
|
|
6916
6916
|
processors
|
|
6917
6917
|
});
|
|
6918
|
-
process$
|
|
6918
|
+
process$3(schema, ctx);
|
|
6919
6919
|
extractDefs(ctx, schema);
|
|
6920
6920
|
return finalize(ctx, schema);
|
|
6921
6921
|
};
|
|
@@ -7002,7 +7002,7 @@ const arrayProcessor = (schema, ctx, _json, params) => {
|
|
|
7002
7002
|
if (typeof minimum === "number") json.minItems = minimum;
|
|
7003
7003
|
if (typeof maximum === "number") json.maxItems = maximum;
|
|
7004
7004
|
json.type = "array";
|
|
7005
|
-
json.items = process$
|
|
7005
|
+
json.items = process$3(def.element, ctx, {
|
|
7006
7006
|
...params,
|
|
7007
7007
|
path: [...params.path, "items"]
|
|
7008
7008
|
});
|
|
@@ -7013,7 +7013,7 @@ const objectProcessor = (schema, ctx, _json, params) => {
|
|
|
7013
7013
|
json.type = "object";
|
|
7014
7014
|
json.properties = {};
|
|
7015
7015
|
const shape = def.shape;
|
|
7016
|
-
for (const key in shape) json.properties[key] = process$
|
|
7016
|
+
for (const key in shape) json.properties[key] = process$3(shape[key], ctx, {
|
|
7017
7017
|
...params,
|
|
7018
7018
|
path: [
|
|
7019
7019
|
...params.path,
|
|
@@ -7031,7 +7031,7 @@ const objectProcessor = (schema, ctx, _json, params) => {
|
|
|
7031
7031
|
if (def.catchall?._zod.def.type === "never") json.additionalProperties = false;
|
|
7032
7032
|
else if (!def.catchall) {
|
|
7033
7033
|
if (ctx.io === "output") json.additionalProperties = false;
|
|
7034
|
-
} else if (def.catchall) json.additionalProperties = process$
|
|
7034
|
+
} else if (def.catchall) json.additionalProperties = process$3(def.catchall, ctx, {
|
|
7035
7035
|
...params,
|
|
7036
7036
|
path: [...params.path, "additionalProperties"]
|
|
7037
7037
|
});
|
|
@@ -7039,7 +7039,7 @@ const objectProcessor = (schema, ctx, _json, params) => {
|
|
|
7039
7039
|
const unionProcessor = (schema, ctx, json, params) => {
|
|
7040
7040
|
const def = schema._zod.def;
|
|
7041
7041
|
const isExclusive = def.inclusive === false;
|
|
7042
|
-
const options = def.options.map((x$2, i$1) => process$
|
|
7042
|
+
const options = def.options.map((x$2, i$1) => process$3(x$2, ctx, {
|
|
7043
7043
|
...params,
|
|
7044
7044
|
path: [
|
|
7045
7045
|
...params.path,
|
|
@@ -7052,7 +7052,7 @@ const unionProcessor = (schema, ctx, json, params) => {
|
|
|
7052
7052
|
};
|
|
7053
7053
|
const intersectionProcessor = (schema, ctx, json, params) => {
|
|
7054
7054
|
const def = schema._zod.def;
|
|
7055
|
-
const a$1 = process$
|
|
7055
|
+
const a$1 = process$3(def.left, ctx, {
|
|
7056
7056
|
...params,
|
|
7057
7057
|
path: [
|
|
7058
7058
|
...params.path,
|
|
@@ -7060,7 +7060,7 @@ const intersectionProcessor = (schema, ctx, json, params) => {
|
|
|
7060
7060
|
0
|
|
7061
7061
|
]
|
|
7062
7062
|
});
|
|
7063
|
-
const b$2 = process$
|
|
7063
|
+
const b$2 = process$3(def.right, ctx, {
|
|
7064
7064
|
...params,
|
|
7065
7065
|
path: [
|
|
7066
7066
|
...params.path,
|
|
@@ -7077,7 +7077,7 @@ const tupleProcessor = (schema, ctx, _json, params) => {
|
|
|
7077
7077
|
json.type = "array";
|
|
7078
7078
|
const prefixPath$1 = ctx.target === "draft-2020-12" ? "prefixItems" : "items";
|
|
7079
7079
|
const restPath = ctx.target === "draft-2020-12" ? "items" : ctx.target === "openapi-3.0" ? "items" : "additionalItems";
|
|
7080
|
-
const prefixItems = def.items.map((x$2, i$1) => process$
|
|
7080
|
+
const prefixItems = def.items.map((x$2, i$1) => process$3(x$2, ctx, {
|
|
7081
7081
|
...params,
|
|
7082
7082
|
path: [
|
|
7083
7083
|
...params.path,
|
|
@@ -7085,7 +7085,7 @@ const tupleProcessor = (schema, ctx, _json, params) => {
|
|
|
7085
7085
|
i$1
|
|
7086
7086
|
]
|
|
7087
7087
|
}));
|
|
7088
|
-
const rest = def.rest ? process$
|
|
7088
|
+
const rest = def.rest ? process$3(def.rest, ctx, {
|
|
7089
7089
|
...params,
|
|
7090
7090
|
path: [
|
|
7091
7091
|
...params.path,
|
|
@@ -7111,7 +7111,7 @@ const tupleProcessor = (schema, ctx, _json, params) => {
|
|
|
7111
7111
|
};
|
|
7112
7112
|
const nullableProcessor = (schema, ctx, json, params) => {
|
|
7113
7113
|
const def = schema._zod.def;
|
|
7114
|
-
const inner = process$
|
|
7114
|
+
const inner = process$3(def.innerType, ctx, params);
|
|
7115
7115
|
const seen = ctx.seen.get(schema);
|
|
7116
7116
|
if (ctx.target === "openapi-3.0") {
|
|
7117
7117
|
seen.ref = def.innerType;
|
|
@@ -7120,27 +7120,27 @@ const nullableProcessor = (schema, ctx, json, params) => {
|
|
|
7120
7120
|
};
|
|
7121
7121
|
const nonoptionalProcessor = (schema, ctx, _json, params) => {
|
|
7122
7122
|
const def = schema._zod.def;
|
|
7123
|
-
process$
|
|
7123
|
+
process$3(def.innerType, ctx, params);
|
|
7124
7124
|
const seen = ctx.seen.get(schema);
|
|
7125
7125
|
seen.ref = def.innerType;
|
|
7126
7126
|
};
|
|
7127
7127
|
const defaultProcessor = (schema, ctx, json, params) => {
|
|
7128
7128
|
const def = schema._zod.def;
|
|
7129
|
-
process$
|
|
7129
|
+
process$3(def.innerType, ctx, params);
|
|
7130
7130
|
const seen = ctx.seen.get(schema);
|
|
7131
7131
|
seen.ref = def.innerType;
|
|
7132
7132
|
json.default = JSON.parse(JSON.stringify(def.defaultValue));
|
|
7133
7133
|
};
|
|
7134
7134
|
const prefaultProcessor = (schema, ctx, json, params) => {
|
|
7135
7135
|
const def = schema._zod.def;
|
|
7136
|
-
process$
|
|
7136
|
+
process$3(def.innerType, ctx, params);
|
|
7137
7137
|
const seen = ctx.seen.get(schema);
|
|
7138
7138
|
seen.ref = def.innerType;
|
|
7139
7139
|
if (ctx.io === "input") json._prefault = JSON.parse(JSON.stringify(def.defaultValue));
|
|
7140
7140
|
};
|
|
7141
7141
|
const catchProcessor = (schema, ctx, json, params) => {
|
|
7142
7142
|
const def = schema._zod.def;
|
|
7143
|
-
process$
|
|
7143
|
+
process$3(def.innerType, ctx, params);
|
|
7144
7144
|
const seen = ctx.seen.get(schema);
|
|
7145
7145
|
seen.ref = def.innerType;
|
|
7146
7146
|
let catchValue;
|
|
@@ -7154,20 +7154,20 @@ const catchProcessor = (schema, ctx, json, params) => {
|
|
|
7154
7154
|
const pipeProcessor = (schema, ctx, _json, params) => {
|
|
7155
7155
|
const def = schema._zod.def;
|
|
7156
7156
|
const innerType = ctx.io === "input" ? def.in._zod.def.type === "transform" ? def.out : def.in : def.out;
|
|
7157
|
-
process$
|
|
7157
|
+
process$3(innerType, ctx, params);
|
|
7158
7158
|
const seen = ctx.seen.get(schema);
|
|
7159
7159
|
seen.ref = innerType;
|
|
7160
7160
|
};
|
|
7161
7161
|
const readonlyProcessor = (schema, ctx, json, params) => {
|
|
7162
7162
|
const def = schema._zod.def;
|
|
7163
|
-
process$
|
|
7163
|
+
process$3(def.innerType, ctx, params);
|
|
7164
7164
|
const seen = ctx.seen.get(schema);
|
|
7165
7165
|
seen.ref = def.innerType;
|
|
7166
7166
|
json.readOnly = true;
|
|
7167
7167
|
};
|
|
7168
7168
|
const optionalProcessor = (schema, ctx, _json, params) => {
|
|
7169
7169
|
const def = schema._zod.def;
|
|
7170
|
-
process$
|
|
7170
|
+
process$3(def.innerType, ctx, params);
|
|
7171
7171
|
const seen = ctx.seen.get(schema);
|
|
7172
7172
|
seen.ref = def.innerType;
|
|
7173
7173
|
};
|
|
@@ -16193,7 +16193,7 @@ const createIgnorePredicate = (patterns, cwd, baseDir) => {
|
|
|
16193
16193
|
};
|
|
16194
16194
|
const normalizeOptions$2 = (options = {}) => {
|
|
16195
16195
|
const ignoreOption = options.ignore ? Array.isArray(options.ignore) ? options.ignore : [options.ignore] : [];
|
|
16196
|
-
const cwd = toPath$1(options.cwd) ??
|
|
16196
|
+
const cwd = toPath$1(options.cwd) ?? process$1.cwd();
|
|
16197
16197
|
const deep = typeof options.deep === "number" ? Math.max(0, options.deep) + 1 : Number.POSITIVE_INFINITY;
|
|
16198
16198
|
return {
|
|
16199
16199
|
cwd,
|
|
@@ -16290,7 +16290,7 @@ const getDirectoryGlob = ({ directoryPath, files, extensions }) => {
|
|
|
16290
16290
|
const extensionGlob = extensions?.length > 0 ? `.${extensions.length > 1 ? `{${extensions.join(",")}}` : extensions[0]}` : "";
|
|
16291
16291
|
return files ? files.map((file) => path.posix.join(directoryPath, `**/${path.extname(file) ? file : `${file}${extensionGlob}`}`)) : [path.posix.join(directoryPath, `**${extensionGlob ? `/*${extensionGlob}` : ""}`)];
|
|
16292
16292
|
};
|
|
16293
|
-
const directoryToGlob = async (directoryPaths, { cwd =
|
|
16293
|
+
const directoryToGlob = async (directoryPaths, { cwd = process$1.cwd(), files, extensions, fs: fsImplementation } = {}) => {
|
|
16294
16294
|
return (await Promise.all(directoryPaths.map(async (directoryPath) => {
|
|
16295
16295
|
if (shouldExpandGlobstarDirectory(isNegativePattern(directoryPath) ? directoryPath.slice(1) : directoryPath)) return getDirectoryGlob({
|
|
16296
16296
|
directoryPath,
|
|
@@ -16304,7 +16304,7 @@ const directoryToGlob = async (directoryPaths, { cwd = y.cwd(), files, extension
|
|
|
16304
16304
|
}) : directoryPath;
|
|
16305
16305
|
}))).flat();
|
|
16306
16306
|
};
|
|
16307
|
-
const directoryToGlobSync = (directoryPaths, { cwd =
|
|
16307
|
+
const directoryToGlobSync = (directoryPaths, { cwd = process$1.cwd(), files, extensions, fs: fsImplementation } = {}) => directoryPaths.flatMap((directoryPath) => {
|
|
16308
16308
|
if (shouldExpandGlobstarDirectory(isNegativePattern(directoryPath) ? directoryPath.slice(1) : directoryPath)) return getDirectoryGlob({
|
|
16309
16309
|
directoryPath,
|
|
16310
16310
|
files,
|
|
@@ -16400,7 +16400,7 @@ const applyIgnoreFilesAndGetFilterSync = (options) => {
|
|
|
16400
16400
|
};
|
|
16401
16401
|
const createFilterFunction = (isIgnored, cwd) => {
|
|
16402
16402
|
const seen = /* @__PURE__ */ new Set();
|
|
16403
|
-
const basePath = cwd ||
|
|
16403
|
+
const basePath = cwd || process$1.cwd();
|
|
16404
16404
|
const pathCache = /* @__PURE__ */ new Map();
|
|
16405
16405
|
return (fastGlobResult) => {
|
|
16406
16406
|
const pathKey$1 = path.normalize(fastGlobResult.path ?? fastGlobResult);
|
|
@@ -16709,7 +16709,7 @@ const CreateProjectResponseSchema = looseObject({ id: string() });
|
|
|
16709
16709
|
const AppSchema = looseObject({
|
|
16710
16710
|
id: string(),
|
|
16711
16711
|
name: string(),
|
|
16712
|
-
|
|
16712
|
+
is_managed_source_code: boolean().optional()
|
|
16713
16713
|
});
|
|
16714
16714
|
const AppsResponseSchema = array(AppSchema);
|
|
16715
16715
|
|
|
@@ -16801,7 +16801,7 @@ async function fetchApps() {
|
|
|
16801
16801
|
return AppsResponseSchema.parse(await response.json());
|
|
16802
16802
|
}
|
|
16803
16803
|
async function fetchLinkableApps() {
|
|
16804
|
-
return (await fetchApps()).filter((app) =>
|
|
16804
|
+
return (await fetchApps()).filter((app) => app.is_managed_source_code === false);
|
|
16805
16805
|
}
|
|
16806
16806
|
|
|
16807
16807
|
//#endregion
|
|
@@ -30753,13 +30753,13 @@ var ansi_styles_default = ansiStyles;
|
|
|
30753
30753
|
|
|
30754
30754
|
//#endregion
|
|
30755
30755
|
//#region node_modules/chalk/source/vendor/supports-color/index.js
|
|
30756
|
-
function hasFlag(flag, argv = globalThis.Deno ? globalThis.Deno.args :
|
|
30756
|
+
function hasFlag(flag, argv = globalThis.Deno ? globalThis.Deno.args : process$1.argv) {
|
|
30757
30757
|
const prefix = flag.startsWith("-") ? "" : flag.length === 1 ? "-" : "--";
|
|
30758
30758
|
const position = argv.indexOf(prefix + flag);
|
|
30759
30759
|
const terminatorPosition = argv.indexOf("--");
|
|
30760
30760
|
return position !== -1 && (terminatorPosition === -1 || position < terminatorPosition);
|
|
30761
30761
|
}
|
|
30762
|
-
const { env } =
|
|
30762
|
+
const { env } = process$1;
|
|
30763
30763
|
let flagForceColor;
|
|
30764
30764
|
if (hasFlag("no-color") || hasFlag("no-colors") || hasFlag("color=false") || hasFlag("color=never")) flagForceColor = 0;
|
|
30765
30765
|
else if (hasFlag("color") || hasFlag("colors") || hasFlag("color=true") || hasFlag("color=always")) flagForceColor = 1;
|
|
@@ -30792,7 +30792,7 @@ function _supportsColor(haveStream, { streamIsTTY, sniffFlags = true } = {}) {
|
|
|
30792
30792
|
if (haveStream && !streamIsTTY && forceColor === void 0) return 0;
|
|
30793
30793
|
const min = forceColor || 0;
|
|
30794
30794
|
if (env.TERM === "dumb") return min;
|
|
30795
|
-
if (
|
|
30795
|
+
if (process$1.platform === "win32") {
|
|
30796
30796
|
const osRelease = os.release().split(".");
|
|
30797
30797
|
if (Number(osRelease[0]) >= 10 && Number(osRelease[2]) >= 10586) return Number(osRelease[2]) >= 14931 ? 3 : 2;
|
|
30798
30798
|
return 1;
|
|
@@ -31531,9 +31531,9 @@ const getSubprocessResult = ({ stdout: stdout$1 }) => {
|
|
|
31531
31531
|
//#region node_modules/execa/lib/utils/standard-stream.js
|
|
31532
31532
|
const isStandardStream = (stream) => STANDARD_STREAMS.includes(stream);
|
|
31533
31533
|
const STANDARD_STREAMS = [
|
|
31534
|
-
|
|
31535
|
-
|
|
31536
|
-
|
|
31534
|
+
process$1.stdin,
|
|
31535
|
+
process$1.stdout,
|
|
31536
|
+
process$1.stderr
|
|
31537
31537
|
];
|
|
31538
31538
|
const STANDARD_STREAMS_ALIASES = [
|
|
31539
31539
|
"stdin",
|
|
@@ -31658,9 +31658,9 @@ const NO_ESCAPE_REGEXP = /^[\w./-]+$/;
|
|
|
31658
31658
|
//#endregion
|
|
31659
31659
|
//#region node_modules/is-unicode-supported/index.js
|
|
31660
31660
|
function isUnicodeSupported() {
|
|
31661
|
-
const { env: env$1 } =
|
|
31661
|
+
const { env: env$1 } = process$1;
|
|
31662
31662
|
const { TERM, TERM_PROGRAM } = env$1;
|
|
31663
|
-
if (
|
|
31663
|
+
if (process$1.platform !== "win32") return TERM !== "linux";
|
|
31664
31664
|
return Boolean(env$1.WT_SESSION) || Boolean(env$1.TERMINUS_SUBLIME) || env$1.ConEmuTask === "{cmd::Cmder}" || TERM_PROGRAM === "Terminus-Sublime" || TERM_PROGRAM === "vscode" || TERM === "xterm-256color" || TERM === "alacritty" || TERM === "rxvt-unicode" || TERM === "rxvt-unicode-256color" || env$1.TERMINAL_EMULATOR === "JetBrains-JediTerm";
|
|
31665
31665
|
}
|
|
31666
31666
|
|
|
@@ -32587,7 +32587,7 @@ const TEN_MEGABYTES_IN_BYTES = 10 * 1024 * 1024;
|
|
|
32587
32587
|
|
|
32588
32588
|
//#endregion
|
|
32589
32589
|
//#region node_modules/npm-run-path/index.js
|
|
32590
|
-
const npmRunPath = ({ cwd =
|
|
32590
|
+
const npmRunPath = ({ cwd = process$1.cwd(), path: pathOption = process$1.env[pathKey()], preferLocal = true, execPath: execPath$1 = process$1.execPath, addExecPath = true } = {}) => {
|
|
32591
32591
|
const cwdPath = path.resolve(toPath(cwd));
|
|
32592
32592
|
const result = [];
|
|
32593
32593
|
const pathParts = pathOption.split(path.delimiter);
|
|
@@ -32605,7 +32605,7 @@ const applyExecPath = (result, pathParts, execPath$1, cwdPath) => {
|
|
|
32605
32605
|
const pathPart = path.resolve(cwdPath, toPath(execPath$1), "..");
|
|
32606
32606
|
if (!pathParts.includes(pathPart)) result.push(pathPart);
|
|
32607
32607
|
};
|
|
32608
|
-
const npmRunPathEnv = ({ env: env$1 =
|
|
32608
|
+
const npmRunPathEnv = ({ env: env$1 = process$1.env, ...options } = {}) => {
|
|
32609
32609
|
env$1 = { ...env$1 };
|
|
32610
32610
|
const pathName = pathKey({ env: env$1 });
|
|
32611
32611
|
options.path = env$1[pathName];
|
|
@@ -33740,7 +33740,7 @@ const normalizeCwd = (cwd = getDefaultCwd()) => {
|
|
|
33740
33740
|
};
|
|
33741
33741
|
const getDefaultCwd = () => {
|
|
33742
33742
|
try {
|
|
33743
|
-
return
|
|
33743
|
+
return process$1.cwd();
|
|
33744
33744
|
} catch (error) {
|
|
33745
33745
|
error.message = `The current directory does not exist.\n${error.message}`;
|
|
33746
33746
|
throw error;
|
|
@@ -33775,7 +33775,7 @@ const normalizeOptions = (filePath, rawArguments, rawOptions) => {
|
|
|
33775
33775
|
options.killSignal = normalizeKillSignal(options.killSignal);
|
|
33776
33776
|
options.forceKillAfterDelay = normalizeForceKillAfterDelay(options.forceKillAfterDelay);
|
|
33777
33777
|
options.lines = options.lines.map((lines, fdNumber) => lines && !BINARY_ENCODINGS.has(options.encoding) && options.buffer[fdNumber]);
|
|
33778
|
-
if (
|
|
33778
|
+
if (process$1.platform === "win32" && path.basename(file, ".exe") === "cmd") commandArguments.unshift("/q");
|
|
33779
33779
|
return {
|
|
33780
33780
|
file,
|
|
33781
33781
|
commandArguments,
|
|
@@ -33802,7 +33802,7 @@ const addDefaultOptions = ({ extendEnv = true, preferLocal = false, cwd, localDi
|
|
|
33802
33802
|
});
|
|
33803
33803
|
const getEnv = ({ env: envOption, extendEnv, preferLocal, node, localDirectory, nodePath }) => {
|
|
33804
33804
|
const env$1 = extendEnv ? {
|
|
33805
|
-
...
|
|
33805
|
+
...process$1.env,
|
|
33806
33806
|
...envOption
|
|
33807
33807
|
} : envOption;
|
|
33808
33808
|
if (preferLocal || node) return npmRunPathEnv({
|
|
@@ -34802,12 +34802,12 @@ const guessStreamDirection = {
|
|
|
34802
34802
|
}
|
|
34803
34803
|
};
|
|
34804
34804
|
const getStandardStreamDirection = (value) => {
|
|
34805
|
-
if ([0,
|
|
34805
|
+
if ([0, process$1.stdin].includes(value)) return "input";
|
|
34806
34806
|
if ([
|
|
34807
34807
|
1,
|
|
34808
34808
|
2,
|
|
34809
|
-
|
|
34810
|
-
|
|
34809
|
+
process$1.stdout,
|
|
34810
|
+
process$1.stderr
|
|
34811
34811
|
].includes(value)) return "output";
|
|
34812
34812
|
};
|
|
34813
34813
|
const DEFAULT_DIRECTION = "output";
|
|
@@ -35871,9 +35871,9 @@ const addIpcMethods = (subprocess, { ipc }) => {
|
|
|
35871
35871
|
Object.assign(subprocess, getIpcMethods(subprocess, false, ipc));
|
|
35872
35872
|
};
|
|
35873
35873
|
const getIpcExport = () => {
|
|
35874
|
-
const anyProcess =
|
|
35874
|
+
const anyProcess = process$1;
|
|
35875
35875
|
const isSubprocess = true;
|
|
35876
|
-
const ipc =
|
|
35876
|
+
const ipc = process$1.channel !== void 0;
|
|
35877
35877
|
return {
|
|
35878
35878
|
...getIpcMethods(anyProcess, isSubprocess, ipc),
|
|
35879
35879
|
getCancelSignal: getCancelSignal$1.bind(void 0, {
|
|
@@ -36115,7 +36115,7 @@ if (process.platform === "linux") signals.push("SIGIO", "SIGPOLL", "SIGPWR", "SI
|
|
|
36115
36115
|
|
|
36116
36116
|
//#endregion
|
|
36117
36117
|
//#region node_modules/signal-exit/dist/mjs/index.js
|
|
36118
|
-
const processOk = (process$
|
|
36118
|
+
const processOk = (process$5) => !!process$5 && typeof process$5 === "object" && typeof process$5.removeListener === "function" && typeof process$5.emit === "function" && typeof process$5.reallyExit === "function" && typeof process$5.listeners === "function" && typeof process$5.kill === "function" && typeof process$5.pid === "number" && typeof process$5.on === "function";
|
|
36119
36119
|
const kExitEmitter = Symbol.for("signal-exit emitter");
|
|
36120
36120
|
const global$1 = globalThis;
|
|
36121
36121
|
const ObjectDefineProperty = Object.defineProperty.bind(Object);
|
|
@@ -36183,7 +36183,7 @@ var SignalExitFallback = class extends SignalExitBase {
|
|
|
36183
36183
|
};
|
|
36184
36184
|
var SignalExit = class extends SignalExitBase {
|
|
36185
36185
|
/* c8 ignore start */
|
|
36186
|
-
#hupSig = process$
|
|
36186
|
+
#hupSig = process$2.platform === "win32" ? "SIGINT" : "SIGHUP";
|
|
36187
36187
|
/* c8 ignore stop */
|
|
36188
36188
|
#emitter = new Emitter();
|
|
36189
36189
|
#process;
|
|
@@ -36191,15 +36191,15 @@ var SignalExit = class extends SignalExitBase {
|
|
|
36191
36191
|
#originalProcessReallyExit;
|
|
36192
36192
|
#sigListeners = {};
|
|
36193
36193
|
#loaded = false;
|
|
36194
|
-
constructor(process$
|
|
36194
|
+
constructor(process$5) {
|
|
36195
36195
|
super();
|
|
36196
|
-
this.#process = process$
|
|
36196
|
+
this.#process = process$5;
|
|
36197
36197
|
this.#sigListeners = {};
|
|
36198
36198
|
for (const sig of signals) this.#sigListeners[sig] = () => {
|
|
36199
36199
|
const listeners = this.#process.listeners(sig);
|
|
36200
36200
|
let { count: count$1 } = this.#emitter;
|
|
36201
36201
|
/* c8 ignore start */
|
|
36202
|
-
const p$1 = process$
|
|
36202
|
+
const p$1 = process$5;
|
|
36203
36203
|
if (typeof p$1.__signal_exit_emitter__ === "object" && typeof p$1.__signal_exit_emitter__.count === "number") count$1 += p$1.__signal_exit_emitter__.count;
|
|
36204
36204
|
/* c8 ignore stop */
|
|
36205
36205
|
if (listeners.length === count$1) {
|
|
@@ -36207,11 +36207,11 @@ var SignalExit = class extends SignalExitBase {
|
|
|
36207
36207
|
const ret = this.#emitter.emit("exit", null, sig);
|
|
36208
36208
|
/* c8 ignore start */
|
|
36209
36209
|
const s = sig === "SIGHUP" ? this.#hupSig : sig;
|
|
36210
|
-
if (!ret) process$
|
|
36210
|
+
if (!ret) process$5.kill(process$5.pid, s);
|
|
36211
36211
|
}
|
|
36212
36212
|
};
|
|
36213
|
-
this.#originalProcessReallyExit = process$
|
|
36214
|
-
this.#originalProcessEmit = process$
|
|
36213
|
+
this.#originalProcessReallyExit = process$5.reallyExit;
|
|
36214
|
+
this.#originalProcessEmit = process$5.emit;
|
|
36215
36215
|
}
|
|
36216
36216
|
onExit(cb, opts) {
|
|
36217
36217
|
/* c8 ignore start */
|
|
@@ -36278,8 +36278,8 @@ var SignalExit = class extends SignalExitBase {
|
|
|
36278
36278
|
} else return og.call(this.#process, ev, ...args);
|
|
36279
36279
|
}
|
|
36280
36280
|
};
|
|
36281
|
-
const process$
|
|
36282
|
-
const { onExit, load, unload } = signalExitWrap(processOk(process$
|
|
36281
|
+
const process$2 = globalThis.process;
|
|
36282
|
+
const { onExit, load, unload } = signalExitWrap(processOk(process$2) ? new SignalExit(process$2) : new SignalExitFallback());
|
|
36283
36283
|
|
|
36284
36284
|
//#endregion
|
|
36285
36285
|
//#region node_modules/execa/lib/terminate/cleanup.js
|
|
@@ -38216,7 +38216,7 @@ function isInsideContainer() {
|
|
|
38216
38216
|
//#endregion
|
|
38217
38217
|
//#region node_modules/is-wsl/index.js
|
|
38218
38218
|
const isWsl = () => {
|
|
38219
|
-
if (
|
|
38219
|
+
if (process$1.platform !== "linux") return false;
|
|
38220
38220
|
if (os.release().toLowerCase().includes("microsoft")) {
|
|
38221
38221
|
if (isInsideContainer()) return false;
|
|
38222
38222
|
return true;
|
|
@@ -38227,12 +38227,12 @@ const isWsl = () => {
|
|
|
38227
38227
|
return false;
|
|
38228
38228
|
}
|
|
38229
38229
|
};
|
|
38230
|
-
var is_wsl_default =
|
|
38230
|
+
var is_wsl_default = process$1.env.__IS_WSL_TEST__ ? isWsl : isWsl();
|
|
38231
38231
|
|
|
38232
38232
|
//#endregion
|
|
38233
38233
|
//#region node_modules/powershell-utils/index.js
|
|
38234
38234
|
const execFile$2 = promisify(childProcess.execFile);
|
|
38235
|
-
const powerShellPath$1 = () => `${
|
|
38235
|
+
const powerShellPath$1 = () => `${process$1.env.SYSTEMROOT || process$1.env.windir || String.raw`C:\Windows`}\\System32\\WindowsPowerShell\\v1.0\\powershell.exe`;
|
|
38236
38236
|
const executePowerShell = async (command, options = {}) => {
|
|
38237
38237
|
const { powerShellPath: psPath, ...execFileOptions } = options;
|
|
38238
38238
|
const encodedCommand = executePowerShell.encodeCommand(command);
|
|
@@ -38343,7 +38343,7 @@ function defineLazyProperty(object$1, propertyName, valueGetter) {
|
|
|
38343
38343
|
//#region node_modules/default-browser-id/index.js
|
|
38344
38344
|
const execFileAsync$3 = promisify(execFile);
|
|
38345
38345
|
async function defaultBrowserId() {
|
|
38346
|
-
if (
|
|
38346
|
+
if (process$1.platform !== "darwin") throw new Error("macOS only");
|
|
38347
38347
|
const { stdout: stdout$1 } = await execFileAsync$3("defaults", [
|
|
38348
38348
|
"read",
|
|
38349
38349
|
"com.apple.LaunchServices/com.apple.launchservices.secure",
|
|
@@ -38358,7 +38358,7 @@ async function defaultBrowserId() {
|
|
|
38358
38358
|
//#region node_modules/run-applescript/index.js
|
|
38359
38359
|
const execFileAsync$2 = promisify(execFile);
|
|
38360
38360
|
async function runAppleScript(script, { humanReadableOutput = true, signal } = {}) {
|
|
38361
|
-
if (
|
|
38361
|
+
if (process$1.platform !== "darwin") throw new Error("macOS only");
|
|
38362
38362
|
const outputArguments = humanReadableOutput ? [] : ["-ss"];
|
|
38363
38363
|
const execOptions = {};
|
|
38364
38364
|
if (signal) execOptions.signal = signal;
|
|
@@ -38467,14 +38467,14 @@ async function defaultBrowser$1(_execFileAsync = execFileAsync$1) {
|
|
|
38467
38467
|
const execFileAsync = promisify(execFile);
|
|
38468
38468
|
const titleize = (string$2) => string$2.toLowerCase().replaceAll(/(?:^|\s|-)\S/g, (x$2) => x$2.toUpperCase());
|
|
38469
38469
|
async function defaultBrowser() {
|
|
38470
|
-
if (
|
|
38470
|
+
if (process$1.platform === "darwin") {
|
|
38471
38471
|
const id = await defaultBrowserId();
|
|
38472
38472
|
return {
|
|
38473
38473
|
name: await bundleName(id),
|
|
38474
38474
|
id
|
|
38475
38475
|
};
|
|
38476
38476
|
}
|
|
38477
|
-
if (
|
|
38477
|
+
if (process$1.platform === "linux") {
|
|
38478
38478
|
const { stdout: stdout$1 } = await execFileAsync("xdg-mime", [
|
|
38479
38479
|
"query",
|
|
38480
38480
|
"default",
|
|
@@ -38486,13 +38486,13 @@ async function defaultBrowser() {
|
|
|
38486
38486
|
id
|
|
38487
38487
|
};
|
|
38488
38488
|
}
|
|
38489
|
-
if (
|
|
38489
|
+
if (process$1.platform === "win32") return defaultBrowser$1();
|
|
38490
38490
|
throw new Error("Only macOS, Linux, and Windows are supported");
|
|
38491
38491
|
}
|
|
38492
38492
|
|
|
38493
38493
|
//#endregion
|
|
38494
38494
|
//#region node_modules/is-in-ssh/index.js
|
|
38495
|
-
const isInSsh = Boolean(
|
|
38495
|
+
const isInSsh = Boolean(process$1.env.SSH_CONNECTION || process$1.env.SSH_CLIENT || process$1.env.SSH_TTY);
|
|
38496
38496
|
var is_in_ssh_default = isInSsh;
|
|
38497
38497
|
|
|
38498
38498
|
//#endregion
|
|
@@ -38500,7 +38500,7 @@ var is_in_ssh_default = isInSsh;
|
|
|
38500
38500
|
const fallbackAttemptSymbol = Symbol("fallbackAttempt");
|
|
38501
38501
|
const __dirname = import.meta.url ? path.dirname(fileURLToPath(import.meta.url)) : "";
|
|
38502
38502
|
const localXdgOpenPath = path.join(__dirname, "xdg-open");
|
|
38503
|
-
const { platform: platform$1, arch } =
|
|
38503
|
+
const { platform: platform$1, arch } = process$1;
|
|
38504
38504
|
const tryEachApp = async (apps$1, opener) => {
|
|
38505
38505
|
if (apps$1.length === 0) return;
|
|
38506
38506
|
const errors = [];
|
|
@@ -38613,7 +38613,7 @@ const baseOpen = async (options) => {
|
|
|
38613
38613
|
await fs$1.access(localXdgOpenPath, constants$1.X_OK);
|
|
38614
38614
|
exeLocalXdgOpen = true;
|
|
38615
38615
|
} catch {}
|
|
38616
|
-
command =
|
|
38616
|
+
command = process$1.versions.electron ?? (platform$1 === "android" || isBundled || !exeLocalXdgOpen) ? "xdg-open" : localXdgOpenPath;
|
|
38617
38617
|
}
|
|
38618
38618
|
if (appArguments.length > 0) cliArguments.push(...appArguments);
|
|
38619
38619
|
if (!options.wait) {
|
|
@@ -38821,10 +38821,21 @@ async function link(options) {
|
|
|
38821
38821
|
if (!projectRoot) throw new Error("No Base44 project found. Run this command from a project directory with a config.jsonc file.");
|
|
38822
38822
|
if (await appConfigExists(projectRoot.root)) throw new Error("Project is already linked. An .app.jsonc file with the appId already exists.");
|
|
38823
38823
|
if (options.existing) {
|
|
38824
|
-
await
|
|
38825
|
-
|
|
38826
|
-
|
|
38827
|
-
|
|
38824
|
+
const app = (await runTask("Validating project...", async () => fetchApps(), {
|
|
38825
|
+
successMessage: "Project validated",
|
|
38826
|
+
errorMessage: "Failed to validate project"
|
|
38827
|
+
})).find((a$1) => a$1.id === options.existing);
|
|
38828
|
+
if (!app) throw new Error(`Project with ID "${options.existing}" not found. Please check the ID and try again.`);
|
|
38829
|
+
if (app.is_managed_source_code === true) throw new Error(`Project "${app.name}" is managed by Base44 AI and cannot be linked to external source code.`);
|
|
38830
|
+
await runTask("Linking project...", async () => {
|
|
38831
|
+
await writeAppConfig(projectRoot.root, options.existing);
|
|
38832
|
+
setAppConfig({
|
|
38833
|
+
id: options.existing,
|
|
38834
|
+
projectRoot: projectRoot.root
|
|
38835
|
+
});
|
|
38836
|
+
}, {
|
|
38837
|
+
successMessage: "Project linked successfully",
|
|
38838
|
+
errorMessage: "Failed to link project"
|
|
38828
38839
|
});
|
|
38829
38840
|
M.message(`${theme.styles.header("Dashboard")}: ${theme.colors.links(getDashboardUrl(options.existing))}`);
|
|
38830
38841
|
return { outroMessage: "Project linked" };
|
|
@@ -38845,15 +38856,21 @@ async function link(options) {
|
|
|
38845
38856
|
return { outroMessage: "Project linked" };
|
|
38846
38857
|
}
|
|
38847
38858
|
const linkableApps = await runTask("Fetching your projects...", async () => fetchLinkableApps(), {
|
|
38848
|
-
successMessage:
|
|
38859
|
+
successMessage: "Fetched projects",
|
|
38849
38860
|
errorMessage: "Failed to fetch projects"
|
|
38850
38861
|
});
|
|
38862
|
+
if (linkableApps.length > 0) M.info(`Found ${theme.colors.base44Orange(String(linkableApps.length))} project${linkableApps.length === 1 ? "" : "s"} available for linking`);
|
|
38851
38863
|
if (await promptForLinkAction(linkableApps) === "choose") {
|
|
38852
38864
|
const selectedApp = await promptForExistingApp(linkableApps);
|
|
38853
|
-
await
|
|
38854
|
-
|
|
38855
|
-
|
|
38856
|
-
|
|
38865
|
+
await runTask("Linking project...", async () => {
|
|
38866
|
+
await writeAppConfig(projectRoot.root, selectedApp.id);
|
|
38867
|
+
setAppConfig({
|
|
38868
|
+
id: selectedApp.id,
|
|
38869
|
+
projectRoot: projectRoot.root
|
|
38870
|
+
});
|
|
38871
|
+
}, {
|
|
38872
|
+
successMessage: "Project linked successfully",
|
|
38873
|
+
errorMessage: "Failed to link project"
|
|
38857
38874
|
});
|
|
38858
38875
|
M.message(`${theme.styles.header("Dashboard")}: ${theme.colors.links(getDashboardUrl(selectedApp.id))}`);
|
|
38859
38876
|
return { outroMessage: "Project linked" };
|
|
@@ -38873,7 +38890,7 @@ async function link(options) {
|
|
|
38873
38890
|
M.message(`${theme.styles.header("Dashboard")}: ${theme.colors.links(getDashboardUrl(projectId))}`);
|
|
38874
38891
|
return { outroMessage: "Project linked" };
|
|
38875
38892
|
}
|
|
38876
|
-
const linkCommand = new Command("link").description("Link a local project to a Base44 project").option("-c, --create", "Create a new project (skip selection prompt)").option("-e, --existing <id>", "Link to an existing project by ID (skip selection prompt)").option("-n, --name <name>", "Project name (required when --create is used)").option("-d, --description <description>", "Project description").hook("preAction", validateNonInteractiveFlags).action(async (options) => {
|
|
38893
|
+
const linkCommand = new Command("link").description("Link a local project to a Base44 project (create new or link existing)").option("-c, --create", "Create a new project (skip selection prompt)").option("-e, --existing <id>", "Link to an existing project by ID (skip selection prompt)").option("-n, --name <name>", "Project name (required when --create is used)").option("-d, --description <description>", "Project description").hook("preAction", validateNonInteractiveFlags).action(async (options) => {
|
|
38877
38894
|
await runCommand(() => link(options), {
|
|
38878
38895
|
requireAuth: true,
|
|
38879
38896
|
requireAppConfig: false
|
package/package.json
CHANGED