sparkecoder 0.1.106 → 0.1.108
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/agent/index.d.ts +3 -3
- package/dist/agent/index.js.map +1 -1
- package/dist/cli.js +21 -8
- package/dist/cli.js.map +1 -1
- package/dist/db/index.d.ts +2 -2
- package/dist/{index--JjYcERz.d.ts → index-D5l-DMGC.d.ts} +83 -83
- package/dist/index.d.ts +5 -5
- package/dist/index.js +12 -5
- package/dist/index.js.map +1 -1
- package/dist/{schema-BQ3Wfu-a.d.ts → schema-ecQSnCMz.d.ts} +3 -3
- package/dist/{search-BRnGaIl-.d.ts → search-DOzC4ojH.d.ts} +7 -7
- package/dist/server/index.js +12 -5
- package/dist/server/index.js.map +1 -1
- package/dist/tools/index.d.ts +3 -3
- package/dist/tools/index.js.map +1 -1
- package/package.json +1 -1
- package/web/.next/BUILD_ID +1 -1
- package/web/.next/standalone/web/.next/BUILD_ID +1 -1
- package/web/.next/standalone/web/.next/build-manifest.json +2 -2
- package/web/.next/standalone/web/.next/prerender-manifest.json +3 -3
- package/web/.next/standalone/web/.next/server/app/(main)/agents/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/(main)/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/(main)/session/[id]/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/(main)/settings/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.html +2 -2
- package/web/.next/standalone/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.html +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/agents.html +1 -1
- package/web/.next/standalone/web/.next/server/app/agents.rsc +4 -4
- package/web/.next/standalone/web/.next/server/app/agents.segments/!KG1haW4p/agents/__PAGE__.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/agents.segments/!KG1haW4p/agents.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/agents.segments/!KG1haW4p.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/agents.segments/_full.segment.rsc +4 -4
- package/web/.next/standalone/web/.next/server/app/agents.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/agents.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/agents.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/installation.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_full.segment.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs/installation/__PAGE__.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs/installation.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/skills.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_full.segment.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs/skills/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs/skills.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/tools/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/tools.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_full.segment.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs/tools/__PAGE__.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs/tools.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs.segments/_full.segment.rsc +3 -3
- package/web/.next/standalone/web/.next/server/app/docs.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/docs/__PAGE__.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/docs.segments/docs.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/index.html +1 -1
- package/web/.next/standalone/web/.next/server/app/index.rsc +4 -4
- package/web/.next/standalone/web/.next/server/app/index.segments/!KG1haW4p/__PAGE__.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/index.segments/!KG1haW4p.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/index.segments/_full.segment.rsc +4 -4
- package/web/.next/standalone/web/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/settings.html +1 -1
- package/web/.next/standalone/web/.next/server/app/settings.rsc +4 -4
- package/web/.next/standalone/web/.next/server/app/settings.segments/!KG1haW4p/settings/__PAGE__.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/settings.segments/!KG1haW4p/settings.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/settings.segments/!KG1haW4p.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/settings.segments/_full.segment.rsc +4 -4
- package/web/.next/standalone/web/.next/server/app/settings.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/settings.segments/_index.segment.rsc +2 -2
- package/web/.next/standalone/web/.next/server/app/settings.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/pages/404.html +1 -1
- package/web/.next/standalone/web/.next/server/pages/500.html +2 -2
- package/web/.next/standalone/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/server-reference-manifest.json +1 -1
- package/web/.next/standalone/web/.next/static/chunks/b203b9aa975135d3.js +1 -0
- package/web/.next/standalone/web/.next/static/static/chunks/b203b9aa975135d3.js +1 -0
- package/web/.next/standalone/web/src/lib/config.ts +55 -6
- package/web/.next/static/chunks/b203b9aa975135d3.js +1 -0
- package/web/.next/standalone/web/.next/static/chunks/4239395558fab3ef.js +0 -1
- package/web/.next/standalone/web/.next/static/static/chunks/4239395558fab3ef.js +0 -1
- package/web/.next/static/chunks/4239395558fab3ef.js +0 -1
- /package/web/.next/standalone/web/.next/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_buildManifest.js +0 -0
- /package/web/.next/standalone/web/.next/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/standalone/web/.next/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_ssgManifest.js +0 -0
- /package/web/.next/standalone/web/.next/static/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_buildManifest.js +0 -0
- /package/web/.next/standalone/web/.next/static/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/standalone/web/.next/static/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_ssgManifest.js +0 -0
- /package/web/.next/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_buildManifest.js +0 -0
- /package/web/.next/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/static/{gBMaoIWuyMCzyJoRerJkB → 0eOLjVRvTvNCm5RgROk6n}/_ssgManifest.js +0 -0
package/dist/cli.js
CHANGED
|
@@ -1329,11 +1329,18 @@ function getStoredAuthKeyInfo() {
|
|
|
1329
1329
|
}
|
|
1330
1330
|
return null;
|
|
1331
1331
|
}
|
|
1332
|
-
async function registerWithRemoteServer(serverUrl, name) {
|
|
1332
|
+
async function registerWithRemoteServer(serverUrl, name, token) {
|
|
1333
|
+
const registerToken = token || process.env.SPARKECODER_REGISTER_TOKEN || process.env.SPARKECODER_SETUP_SECRET;
|
|
1333
1334
|
const response = await fetch(`${serverUrl}/auth/register`, {
|
|
1334
1335
|
method: "POST",
|
|
1335
|
-
headers: {
|
|
1336
|
-
|
|
1336
|
+
headers: {
|
|
1337
|
+
"Content-Type": "application/json",
|
|
1338
|
+
...registerToken ? { "X-Register-Token": registerToken } : {}
|
|
1339
|
+
},
|
|
1340
|
+
body: JSON.stringify({
|
|
1341
|
+
name: name || `CLI ${(/* @__PURE__ */ new Date()).toISOString()}`,
|
|
1342
|
+
...registerToken ? { token: registerToken } : {}
|
|
1343
|
+
})
|
|
1337
1344
|
});
|
|
1338
1345
|
if (!response.ok) {
|
|
1339
1346
|
const error = await response.json().catch(() => ({}));
|
|
@@ -1343,7 +1350,7 @@ async function registerWithRemoteServer(serverUrl, name) {
|
|
|
1343
1350
|
saveAuthKey(data.authKey, data.userId);
|
|
1344
1351
|
return data;
|
|
1345
1352
|
}
|
|
1346
|
-
async function ensureRemoteAuthKey(serverUrl) {
|
|
1353
|
+
async function ensureRemoteAuthKey(serverUrl, token) {
|
|
1347
1354
|
if (process.env.SPARKECODER_AUTH_KEY) {
|
|
1348
1355
|
return process.env.SPARKECODER_AUTH_KEY;
|
|
1349
1356
|
}
|
|
@@ -1351,7 +1358,7 @@ async function ensureRemoteAuthKey(serverUrl) {
|
|
|
1351
1358
|
if (storedKey) {
|
|
1352
1359
|
return storedKey;
|
|
1353
1360
|
}
|
|
1354
|
-
const { authKey: authKey3 } = await registerWithRemoteServer(serverUrl);
|
|
1361
|
+
const { authKey: authKey3 } = await registerWithRemoteServer(serverUrl, void 0, token);
|
|
1355
1362
|
return authKey3;
|
|
1356
1363
|
}
|
|
1357
1364
|
function getApiKeysPath() {
|
|
@@ -16696,13 +16703,19 @@ program.name("sparkecoder").description("AI coding agent - just type sparkecoder
|
|
|
16696
16703
|
}
|
|
16697
16704
|
await runChat(options);
|
|
16698
16705
|
});
|
|
16699
|
-
program.command("server").description("Start the SparkECoder server (API + Web UI)").option("-p, --port <port>", "API server port", "3141").option("-h, --host <host>", "Server host", "127.0.0.1").option("-c, --config <path>", "Path to config file").option("-w, --working-dir <path>", "Working directory").option("--web-port <port>", "Web UI port", "6969").option("--no-web", "Do not start web UI").option("--public-url <url>", "Public URL for web UI to connect to API (for Docker/remote access)").option("-v, --verbose", "Enable verbose logging for web server").option("--enable-computer-use", "Enable the Anthropic computer use tool for all new sessions by default (macOS only)").action(async (options) => {
|
|
16706
|
+
program.command("server").description("Start the SparkECoder server (API + Web UI)").option("-p, --port <port>", "API server port", "3141").option("-h, --host <host>", "Server host", "127.0.0.1").option("-c, --config <path>", "Path to config file").option("-w, --working-dir <path>", "Working directory").option("--web-port <port>", "Web UI port", "6969").option("--no-web", "Do not start web UI").option("--public-url <url>", "Public URL for web UI to connect to API (for Docker/remote access)").option("-v, --verbose", "Enable verbose logging for web server").option("--enable-computer-use", "Enable the Anthropic computer use tool for all new sessions by default (macOS only)").option("--setup-secret <secret>", "Setup secret (or short-lived JWT) used for /auth/register and /tunnels when the remote server has SETUP_SECRET configured. Equivalent to setting SPARKECODER_SETUP_SECRET env.").action(async (options) => {
|
|
16700
16707
|
const globalOpts = program.opts();
|
|
16701
16708
|
const enableCU = options.enableComputerUse || globalOpts.enableComputerUse;
|
|
16702
16709
|
if (enableCU) {
|
|
16703
16710
|
process.env.SPARKECODER_COMPUTER_USE = "1";
|
|
16704
16711
|
console.log(chalk.cyan("\u2192 Computer use enabled by default for new sessions."));
|
|
16705
16712
|
}
|
|
16713
|
+
if (options.setupSecret) {
|
|
16714
|
+
process.env.SPARKECODER_SETUP_SECRET = options.setupSecret;
|
|
16715
|
+
if (!process.env.SPARKECODER_TUNNEL_SECRET) {
|
|
16716
|
+
process.env.SPARKECODER_TUNNEL_SECRET = options.setupSecret;
|
|
16717
|
+
}
|
|
16718
|
+
}
|
|
16706
16719
|
await ensureDependencies({ quiet: false });
|
|
16707
16720
|
const spinner = ora("Starting SparkECoder server...").start();
|
|
16708
16721
|
try {
|
|
@@ -16909,7 +16922,7 @@ program.command("slack-setup").description("Interactively configure Slack integr
|
|
|
16909
16922
|
process.exit(1);
|
|
16910
16923
|
}
|
|
16911
16924
|
});
|
|
16912
|
-
program.command("cloudflared-setup").description("Auto-detect cloudflared + set up a tunnel to this sparkecoder (interactive)").option("--port <port>", "Local sparkecoder web UI port", "6969").option("--api-port <port>", "Local sparkecoder API port", "3141").option("--hostname <host>", "Public hostname you want to assign (e.g. sf-mac-1.example.com)").option("--tunnel-name <name>", "Tunnel name to reuse or create", "sparkecoder").option("--team <team>", "Your Cloudflare Access team subdomain (e.g. studyfetch -> studyfetch.cloudflareaccess.com)").option("--allowed-emails <emails>", "Comma-separated allow-listed emails").option("-y, --yes", "Skip confirmations and do everything non-interactively", false).option("--print-only", "Skip auto-setup and just print the copy/paste recipe", false).option("--cf-api-token <token>", "Cloudflare API token (Account: Cloudflare Tunnel: Edit + Zone: DNS: Edit). Or set CF_API_TOKEN env").option("--cf-account-id <id>", "Cloudflare account ID. Or set CF_ACCOUNT_ID env").option("--cf-zone-id <id>", "Cloudflare zone ID for the hostname. Or set CF_ZONE_ID env").option("--remote", "Provision the tunnel via the remote sparkecoder server (server holds the Cloudflare credentials)", false).option("--setup-secret <secret>", "
|
|
16925
|
+
program.command("cloudflared-setup").description("Auto-detect cloudflared + set up a tunnel to this sparkecoder (interactive)").option("--port <port>", "Local sparkecoder web UI port", "6969").option("--api-port <port>", "Local sparkecoder API port", "3141").option("--hostname <host>", "Public hostname you want to assign (e.g. sf-mac-1.example.com)").option("--tunnel-name <name>", "Tunnel name to reuse or create", "sparkecoder").option("--team <team>", "Your Cloudflare Access team subdomain (e.g. studyfetch -> studyfetch.cloudflareaccess.com)").option("--allowed-emails <emails>", "Comma-separated allow-listed emails").option("-y, --yes", "Skip confirmations and do everything non-interactively", false).option("--print-only", "Skip auto-setup and just print the copy/paste recipe", false).option("--cf-api-token <token>", "Cloudflare API token (Account: Cloudflare Tunnel: Edit + Zone: DNS: Edit). Or set CF_API_TOKEN env").option("--cf-account-id <id>", "Cloudflare account ID. Or set CF_ACCOUNT_ID env").option("--cf-zone-id <id>", "Cloudflare zone ID for the hostname. Or set CF_ZONE_ID env").option("--remote", "Provision the tunnel via the remote sparkecoder server (server holds the Cloudflare credentials)", false).option("--setup-secret <secret>", "Setup secret (required when server has SETUP_SECRET / TUNNEL_SETUP_SECRET set). Falls back to env SPARKECODER_SETUP_SECRET, then SPARKECODER_TUNNEL_SECRET").option("--new-tunnel", "In --remote mode: force a new tunnel even if this user already has one (default: re-use existing)", false).action(async (options) => {
|
|
16913
16926
|
const { execSync: execSync2, spawnSync } = await import("child_process");
|
|
16914
16927
|
const { homedir: homedir2 } = await import("os");
|
|
16915
16928
|
const { copyFileSync } = await import("fs");
|
|
@@ -16970,7 +16983,7 @@ program.command("cloudflared-setup").description("Auto-detect cloudflared + set
|
|
|
16970
16983
|
if (!authKey3) {
|
|
16971
16984
|
authKey3 = await ensureRemoteAuthKey(remoteUrl);
|
|
16972
16985
|
}
|
|
16973
|
-
const setupSecret = options.setupSecret || process.env.SPARKECODER_TUNNEL_SECRET;
|
|
16986
|
+
const setupSecret = options.setupSecret || process.env.SPARKECODER_SETUP_SECRET || process.env.SPARKECODER_TUNNEL_SECRET;
|
|
16974
16987
|
const hostname = options.hostname;
|
|
16975
16988
|
const path = options.newTunnel ? "/tunnels" : "/tunnels/ensure";
|
|
16976
16989
|
console.log(chalk.bold(
|