@percher/core 0.2.6 → 0.4.0
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/ai-files-manifest.d.ts +28 -0
- package/dist/ai-files-manifest.d.ts.map +1 -0
- package/dist/ai-files-manifest.js +96 -0
- package/dist/ai-files-manifest.js.map +1 -0
- package/dist/commands/account.d.ts +51 -0
- package/dist/commands/account.d.ts.map +1 -0
- package/dist/commands/account.js +88 -0
- package/dist/commands/account.js.map +1 -0
- package/dist/commands/ai-files.d.ts +73 -0
- package/dist/commands/ai-files.d.ts.map +1 -0
- package/dist/commands/ai-files.js +179 -0
- package/dist/commands/ai-files.js.map +1 -0
- package/dist/commands/billing.d.ts +1 -1
- package/dist/commands/billing.d.ts.map +1 -1
- package/dist/commands/billing.js +1 -1
- package/dist/commands/billing.js.map +1 -1
- package/dist/commands/continue.d.ts +48 -0
- package/dist/commands/continue.d.ts.map +1 -0
- package/dist/commands/continue.js +121 -0
- package/dist/commands/continue.js.map +1 -0
- package/dist/commands/create.d.ts +1 -1
- package/dist/commands/create.d.ts.map +1 -1
- package/dist/commands/create.js +1 -1
- package/dist/commands/create.js.map +1 -1
- package/dist/commands/dashboard.d.ts +15 -0
- package/dist/commands/dashboard.d.ts.map +1 -0
- package/dist/commands/dashboard.js +33 -0
- package/dist/commands/dashboard.js.map +1 -0
- package/dist/commands/data-export.d.ts +21 -0
- package/dist/commands/data-export.d.ts.map +1 -0
- package/dist/commands/data-export.js +36 -0
- package/dist/commands/data-export.js.map +1 -0
- package/dist/commands/data.d.ts +3 -3
- package/dist/commands/data.d.ts.map +1 -1
- package/dist/commands/data.js +1 -1
- package/dist/commands/data.js.map +1 -1
- package/dist/commands/delete.d.ts +1 -1
- package/dist/commands/delete.d.ts.map +1 -1
- package/dist/commands/delete.js +1 -1
- package/dist/commands/delete.js.map +1 -1
- package/dist/commands/deploys.d.ts +2 -2
- package/dist/commands/deploys.d.ts.map +1 -1
- package/dist/commands/deploys.js +21 -5
- package/dist/commands/deploys.js.map +1 -1
- package/dist/commands/dev.d.ts +1 -9
- package/dist/commands/dev.d.ts.map +1 -1
- package/dist/commands/dev.js +79 -24
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/diagnose.d.ts +1 -1
- package/dist/commands/diagnose.d.ts.map +1 -1
- package/dist/commands/diagnose.js +1 -1
- package/dist/commands/diagnose.js.map +1 -1
- package/dist/commands/doctor.d.ts +75 -3
- package/dist/commands/doctor.d.ts.map +1 -1
- package/dist/commands/doctor.js +822 -10
- package/dist/commands/doctor.js.map +1 -1
- package/dist/commands/domains.d.ts +1 -1
- package/dist/commands/domains.d.ts.map +1 -1
- package/dist/commands/domains.js +1 -1
- package/dist/commands/domains.js.map +1 -1
- package/dist/commands/env-scan.d.ts +2 -0
- package/dist/commands/env-scan.d.ts.map +1 -0
- package/dist/commands/env-scan.js +92 -0
- package/dist/commands/env-scan.js.map +1 -0
- package/dist/commands/env.d.ts +1 -1
- package/dist/commands/env.d.ts.map +1 -1
- package/dist/commands/env.js +1 -1
- package/dist/commands/env.js.map +1 -1
- package/dist/commands/export.d.ts +1 -1
- package/dist/commands/export.js +1 -1
- package/dist/commands/generate.d.ts +1 -1
- package/dist/commands/generate.d.ts.map +1 -1
- package/dist/commands/generate.js +14 -9
- package/dist/commands/generate.js.map +1 -1
- package/dist/commands/github.d.ts +60 -0
- package/dist/commands/github.d.ts.map +1 -0
- package/dist/commands/github.js +112 -0
- package/dist/commands/github.js.map +1 -0
- package/dist/commands/import-project.d.ts +1 -1
- package/dist/commands/import-project.d.ts.map +1 -1
- package/dist/commands/import-project.js +1 -1
- package/dist/commands/import-project.js.map +1 -1
- package/dist/commands/init.d.ts +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +1 -1
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/insights.d.ts +1 -1
- package/dist/commands/insights.d.ts.map +1 -1
- package/dist/commands/insights.js +1 -1
- package/dist/commands/insights.js.map +1 -1
- package/dist/commands/login.d.ts +1 -1
- package/dist/commands/login.d.ts.map +1 -1
- package/dist/commands/login.js +1 -1
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/logs.d.ts +1 -1
- package/dist/commands/logs.d.ts.map +1 -1
- package/dist/commands/logs.js +1 -1
- package/dist/commands/logs.js.map +1 -1
- package/dist/commands/mcp.d.ts +1 -1
- package/dist/commands/mcp.d.ts.map +1 -1
- package/dist/commands/mcp.js +1 -1
- package/dist/commands/mcp.js.map +1 -1
- package/dist/commands/open.d.ts +1 -1
- package/dist/commands/open.d.ts.map +1 -1
- package/dist/commands/open.js +1 -1
- package/dist/commands/open.js.map +1 -1
- package/dist/commands/publish-failure.d.ts +31 -0
- package/dist/commands/publish-failure.d.ts.map +1 -0
- package/dist/commands/publish-failure.js +150 -0
- package/dist/commands/publish-failure.js.map +1 -0
- package/dist/commands/publish-node.d.ts +16 -0
- package/dist/commands/publish-node.d.ts.map +1 -0
- package/dist/commands/publish-node.js +42 -0
- package/dist/commands/publish-node.js.map +1 -0
- package/dist/commands/publish.d.ts +105 -3
- package/dist/commands/publish.d.ts.map +1 -1
- package/dist/commands/publish.js +746 -158
- package/dist/commands/publish.js.map +1 -1
- package/dist/commands/push.d.ts +45 -8
- package/dist/commands/push.d.ts.map +1 -1
- package/dist/commands/push.js +233 -22
- package/dist/commands/push.js.map +1 -1
- package/dist/commands/redeploy.d.ts +28 -0
- package/dist/commands/redeploy.d.ts.map +1 -0
- package/dist/commands/redeploy.js +421 -0
- package/dist/commands/redeploy.js.map +1 -0
- package/dist/commands/rename.d.ts +1 -1
- package/dist/commands/rename.d.ts.map +1 -1
- package/dist/commands/rename.js +1 -1
- package/dist/commands/rename.js.map +1 -1
- package/dist/commands/reproduce.d.ts +64 -0
- package/dist/commands/reproduce.d.ts.map +1 -0
- package/dist/commands/reproduce.js +211 -0
- package/dist/commands/reproduce.js.map +1 -0
- package/dist/commands/reset-superuser.d.ts +1 -1
- package/dist/commands/reset-superuser.d.ts.map +1 -1
- package/dist/commands/reset-superuser.js +1 -1
- package/dist/commands/reset-superuser.js.map +1 -1
- package/dist/commands/restore.d.ts +79 -0
- package/dist/commands/restore.d.ts.map +1 -0
- package/dist/commands/restore.js +164 -0
- package/dist/commands/restore.js.map +1 -0
- package/dist/commands/resume.d.ts +1 -1
- package/dist/commands/resume.d.ts.map +1 -1
- package/dist/commands/resume.js +1 -1
- package/dist/commands/resume.js.map +1 -1
- package/dist/commands/rollback.d.ts +21 -8
- package/dist/commands/rollback.d.ts.map +1 -1
- package/dist/commands/rollback.js +12 -6
- package/dist/commands/rollback.js.map +1 -1
- package/dist/commands/status.d.ts +33 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +48 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/unsuspend.d.ts +35 -0
- package/dist/commands/unsuspend.d.ts.map +1 -0
- package/dist/commands/unsuspend.js +27 -0
- package/dist/commands/unsuspend.js.map +1 -0
- package/dist/commands/versions.d.ts +1 -1
- package/dist/commands/versions.d.ts.map +1 -1
- package/dist/commands/versions.js +1 -1
- package/dist/commands/versions.js.map +1 -1
- package/dist/commands/wait-deploy.d.ts +92 -0
- package/dist/commands/wait-deploy.d.ts.map +1 -0
- package/dist/commands/wait-deploy.js +226 -0
- package/dist/commands/wait-deploy.js.map +1 -0
- package/dist/env-scan-source.d.ts +39 -0
- package/dist/env-scan-source.d.ts.map +1 -0
- package/dist/env-scan-source.js +332 -0
- package/dist/env-scan-source.js.map +1 -0
- package/dist/error-classifier.d.ts.map +1 -1
- package/dist/error-classifier.js +67 -4
- package/dist/error-classifier.js.map +1 -1
- package/dist/errors.d.ts +8 -1
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +2 -0
- package/dist/errors.js.map +1 -1
- package/dist/event-renderer.d.ts +17 -0
- package/dist/event-renderer.d.ts.map +1 -0
- package/dist/event-renderer.js +130 -0
- package/dist/event-renderer.js.map +1 -0
- package/dist/index.d.ts +16 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +15 -0
- package/dist/index.js.map +1 -1
- package/dist/plans.d.ts +20 -0
- package/dist/plans.d.ts.map +1 -1
- package/dist/plans.js +15 -0
- package/dist/plans.js.map +1 -1
- package/dist/poll-deployment.d.ts +59 -0
- package/dist/poll-deployment.d.ts.map +1 -0
- package/dist/poll-deployment.js +93 -0
- package/dist/poll-deployment.js.map +1 -0
- package/dist/publish-retry.d.ts +29 -0
- package/dist/publish-retry.d.ts.map +1 -0
- package/dist/publish-retry.js +224 -0
- package/dist/publish-retry.js.map +1 -0
- package/dist/recovery.d.ts +356 -0
- package/dist/recovery.d.ts.map +1 -0
- package/dist/recovery.js +300 -0
- package/dist/recovery.js.map +1 -0
- package/dist/stream-utils.d.ts +21 -0
- package/dist/stream-utils.d.ts.map +1 -0
- package/dist/stream-utils.js +41 -0
- package/dist/stream-utils.js.map +1 -0
- package/dist/structured-error-codes.d.ts +30 -0
- package/dist/structured-error-codes.d.ts.map +1 -0
- package/dist/structured-error-codes.js +86 -0
- package/dist/structured-error-codes.js.map +1 -0
- package/dist/tarball.d.ts +11 -0
- package/dist/tarball.d.ts.map +1 -1
- package/dist/tarball.js +30 -9
- package/dist/tarball.js.map +1 -1
- package/dist/templates/ai-files/claude-md.d.ts +7 -0
- package/dist/templates/ai-files/claude-md.d.ts.map +1 -0
- package/dist/templates/ai-files/claude-md.js +78 -0
- package/dist/templates/ai-files/claude-md.js.map +1 -0
- package/dist/templates/ai-files/cursor-percher-mdc.d.ts +7 -0
- package/dist/templates/ai-files/cursor-percher-mdc.d.ts.map +1 -0
- package/dist/templates/ai-files/cursor-percher-mdc.js +111 -0
- package/dist/templates/ai-files/cursor-percher-mdc.js.map +1 -0
- package/dist/templates/ai-files/index.d.ts +8 -0
- package/dist/templates/ai-files/index.d.ts.map +1 -0
- package/dist/templates/ai-files/index.js +4 -0
- package/dist/templates/ai-files/index.js.map +1 -0
- package/package.json +6 -5
package/dist/recovery.js
ADDED
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import { TIMEOUTS } from "@percher/shared/timeouts";
|
|
2
|
+
// ── Builders ─────────────────────────────────────────────────────────
|
|
3
|
+
//
|
|
4
|
+
// All recovery construction goes through these. Each builder enforces
|
|
5
|
+
// the required fields for its branch, so a typo or missing field is
|
|
6
|
+
// caught at compile time rather than producing an inline literal that
|
|
7
|
+
// silently violates the contract (e.g. ask_user without prompt).
|
|
8
|
+
/** Success / no-op recovery. `url` is the current live URL when known. */
|
|
9
|
+
export function recoveryNone(opts = {}) {
|
|
10
|
+
return {
|
|
11
|
+
retryable: false,
|
|
12
|
+
nextAction: "none",
|
|
13
|
+
reasonCode: opts.reasonCode ?? "none",
|
|
14
|
+
...(opts.url !== undefined ? { url: opts.url } : {}),
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
/** Authentication required — agent should call `percher_login`. */
|
|
18
|
+
export function recoveryLogin(opts = {}) {
|
|
19
|
+
return {
|
|
20
|
+
retryable: false,
|
|
21
|
+
nextAction: "open_login",
|
|
22
|
+
suggestedTool: "percher_login",
|
|
23
|
+
args: {},
|
|
24
|
+
reasonCode: opts.reasonCode ?? "auth_required",
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
/** Wait on an in-flight deploy — agent should call `percher_wait_for_deploy`. */
|
|
28
|
+
export function recoveryWait(opts) {
|
|
29
|
+
return {
|
|
30
|
+
retryable: false,
|
|
31
|
+
nextAction: "wait_deploy",
|
|
32
|
+
suggestedTool: "percher_wait_for_deploy",
|
|
33
|
+
args: {
|
|
34
|
+
app: opts.app,
|
|
35
|
+
deployId: opts.deployId,
|
|
36
|
+
timeoutSeconds: opts.timeoutSeconds ?? TIMEOUTS.mcpWaitDeployDefault / 1000,
|
|
37
|
+
},
|
|
38
|
+
reasonCode: opts.reasonCode,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
/** Route to `percher_doctor` for an ambiguous failure that needs diagnosis. */
|
|
42
|
+
export function recoveryDoctor(opts) {
|
|
43
|
+
const args = {};
|
|
44
|
+
if (opts.app !== undefined)
|
|
45
|
+
args.app = opts.app;
|
|
46
|
+
if (opts.deployId !== undefined)
|
|
47
|
+
args.deployId = opts.deployId;
|
|
48
|
+
if (opts.mode !== undefined)
|
|
49
|
+
args.mode = opts.mode;
|
|
50
|
+
return {
|
|
51
|
+
retryable: false,
|
|
52
|
+
nextAction: "run_doctor",
|
|
53
|
+
suggestedTool: "percher_doctor",
|
|
54
|
+
args,
|
|
55
|
+
reasonCode: opts.reasonCode,
|
|
56
|
+
...(opts.alternativeActions !== undefined
|
|
57
|
+
? { alternativeActions: opts.alternativeActions }
|
|
58
|
+
: {}),
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
/** Build/runtime needs env keys — agent should call `percher_env_set`. */
|
|
62
|
+
export function recoveryEnv(opts) {
|
|
63
|
+
const args = {};
|
|
64
|
+
if (opts.app !== undefined)
|
|
65
|
+
args.app = opts.app;
|
|
66
|
+
if (opts.keys.length > 0)
|
|
67
|
+
args.keys = opts.keys;
|
|
68
|
+
return {
|
|
69
|
+
retryable: false,
|
|
70
|
+
nextAction: "set_env_vars",
|
|
71
|
+
suggestedTool: "percher_env_set",
|
|
72
|
+
args,
|
|
73
|
+
reasonCode: opts.reasonCode ?? "missing_env",
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* `percher.toml` is invalid or missing — agent should fix the file
|
|
78
|
+
* directly. `problems` carries the structured issue list (file,
|
|
79
|
+
* line/column, message) so the agent can apply edits without parsing
|
|
80
|
+
* a free-text error.
|
|
81
|
+
*/
|
|
82
|
+
export function recoveryFixConfig(opts) {
|
|
83
|
+
return {
|
|
84
|
+
retryable: false,
|
|
85
|
+
nextAction: "fix_config",
|
|
86
|
+
problems: opts.problems,
|
|
87
|
+
reasonCode: opts.reasonCode ?? "config_invalid",
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Build failed and the API extracted at least one structured problem
|
|
92
|
+
* with file/line data — agent should patch the offending file(s).
|
|
93
|
+
*/
|
|
94
|
+
export function recoveryFixProblems(opts) {
|
|
95
|
+
return {
|
|
96
|
+
retryable: false,
|
|
97
|
+
nextAction: "fix_problems",
|
|
98
|
+
problems: opts.problems,
|
|
99
|
+
reasonCode: opts.reasonCode ?? "build_failed",
|
|
100
|
+
...(opts.alternativeActions !== undefined
|
|
101
|
+
? { alternativeActions: opts.alternativeActions }
|
|
102
|
+
: {}),
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
/** Transient infra failure — agent can re-issue the same call. */
|
|
106
|
+
export function recoveryRetry(opts) {
|
|
107
|
+
return {
|
|
108
|
+
retryable: true,
|
|
109
|
+
nextAction: "retry",
|
|
110
|
+
suggestedTool: opts.suggestedTool,
|
|
111
|
+
args: opts.args,
|
|
112
|
+
reasonCode: opts.reasonCode,
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Human-input required. `prompt` MUST be a concrete question — agents
|
|
117
|
+
* surface it verbatim, so empty/placeholder strings violate the
|
|
118
|
+
* contract.
|
|
119
|
+
*/
|
|
120
|
+
export function recoveryAsk(opts) {
|
|
121
|
+
if (!opts.prompt || opts.prompt.trim().length === 0) {
|
|
122
|
+
throw new Error("recoveryAsk requires a non-empty prompt");
|
|
123
|
+
}
|
|
124
|
+
return {
|
|
125
|
+
retryable: opts.retryable ?? false,
|
|
126
|
+
nextAction: "ask_user",
|
|
127
|
+
prompt: opts.prompt,
|
|
128
|
+
...(opts.options !== undefined ? { options: opts.options } : {}),
|
|
129
|
+
reasonCode: opts.reasonCode,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Legacy `inspect_build_log` recovery — kept for the build-failure
|
|
134
|
+
* paths that haven't migrated to `run_doctor` yet. FUTURE12 Phase 4
|
|
135
|
+
* will replace these emit sites with `recoveryDoctor`.
|
|
136
|
+
*/
|
|
137
|
+
export function recoveryInspectBuildLog(opts) {
|
|
138
|
+
const args = opts.deployId
|
|
139
|
+
? { id: opts.deployId, app: opts.app }
|
|
140
|
+
: { latestFailed: true, app: opts.app };
|
|
141
|
+
return {
|
|
142
|
+
retryable: false,
|
|
143
|
+
nextAction: "inspect_build_log",
|
|
144
|
+
suggestedTool: "percher_deploys_inspect",
|
|
145
|
+
args,
|
|
146
|
+
reasonCode: opts.reasonCode ?? "build_failed",
|
|
147
|
+
...(opts.alternativeActions !== undefined
|
|
148
|
+
? { alternativeActions: opts.alternativeActions }
|
|
149
|
+
: {}),
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
// ── Legacy const exports ─────────────────────────────────────────────
|
|
153
|
+
//
|
|
154
|
+
// Kept as concrete values so existing call-sites compile until they
|
|
155
|
+
// migrate to the builders directly. Each is just the corresponding
|
|
156
|
+
// builder evaluated with default reasonCode.
|
|
157
|
+
/** Recovery on the success path. */
|
|
158
|
+
export const RECOVERY_NONE = recoveryNone();
|
|
159
|
+
/** Recovery for the unauthenticated path. */
|
|
160
|
+
export const RECOVERY_NEEDS_LOGIN = recoveryLogin();
|
|
161
|
+
/**
|
|
162
|
+
* Convert a `BuildProblem` into the lossless `RecoveryProblem` shape.
|
|
163
|
+
* Drops fields that aren't part of the recovery contract (severity,
|
|
164
|
+
* code) — those still ride on `error.problems` for the CLI's pretty
|
|
165
|
+
* printer. `hint` is folded into the message because it carries the
|
|
166
|
+
* actionable next step (especially for problems without a line, like
|
|
167
|
+
* malformed package.json) and the recovery contract has no separate
|
|
168
|
+
* hint slot.
|
|
169
|
+
*
|
|
170
|
+
* Exported so doctor (Phase 2c fix_problems path) can reuse the
|
|
171
|
+
* same hint-preserving mapping rather than re-implementing it.
|
|
172
|
+
*/
|
|
173
|
+
export function buildProblemToRecoveryProblem(p) {
|
|
174
|
+
// p.file is optional on BuildProblem but the caller filters to
|
|
175
|
+
// file-bearing problems before reaching here.
|
|
176
|
+
const file = p.file ?? "";
|
|
177
|
+
const message = p.hint && p.hint.length > 0 ? `${p.message}\nHint: ${p.hint}` : p.message;
|
|
178
|
+
return {
|
|
179
|
+
file,
|
|
180
|
+
...(typeof p.line === "number" ? { line: p.line } : {}),
|
|
181
|
+
...(typeof p.column === "number" ? { column: p.column } : {}),
|
|
182
|
+
message,
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Map an `ErrorClass` to a recovery action. Conservative by default —
|
|
187
|
+
* unknown classes resolve to `ask_user` so an agent never blindly retries
|
|
188
|
+
* something we haven't classified.
|
|
189
|
+
*/
|
|
190
|
+
export function recoveryFromErrorClass(errorClass, failure = {}) {
|
|
191
|
+
switch (errorClass) {
|
|
192
|
+
case "missing_env":
|
|
193
|
+
return recoveryEnv({
|
|
194
|
+
keys: failure.missingEnvVars ?? [],
|
|
195
|
+
reasonCode: "missing_env",
|
|
196
|
+
});
|
|
197
|
+
case "infra_unavailable":
|
|
198
|
+
return recoveryRetry({
|
|
199
|
+
suggestedTool: "percher_publish",
|
|
200
|
+
args: failure.publishInput ?? {},
|
|
201
|
+
reasonCode: "infra_unavailable",
|
|
202
|
+
});
|
|
203
|
+
case "config_invalid":
|
|
204
|
+
return recoveryFixConfig({
|
|
205
|
+
problems: [
|
|
206
|
+
{
|
|
207
|
+
file: "percher.toml",
|
|
208
|
+
message: "percher.toml failed validation — fix the file and re-run.",
|
|
209
|
+
},
|
|
210
|
+
],
|
|
211
|
+
reasonCode: "config_invalid",
|
|
212
|
+
});
|
|
213
|
+
case "build_failed":
|
|
214
|
+
case "missing_dependency":
|
|
215
|
+
case "health_check_timeout":
|
|
216
|
+
case "port_mismatch":
|
|
217
|
+
case "permission_denied":
|
|
218
|
+
case "runtime_crash":
|
|
219
|
+
case "oom_killed": {
|
|
220
|
+
// FUTURE1 Phase 2.3: when the API parser extracted at least one
|
|
221
|
+
// problem WITH a file location, give the agent a structured
|
|
222
|
+
// `fix_problems` recovery instead of routing through doctor.
|
|
223
|
+
// Problems without a file (missing-module by bare name,
|
|
224
|
+
// missing-build-env) are still actionable by hint but the agent
|
|
225
|
+
// has nothing to open — let doctor classify those so it can pull
|
|
226
|
+
// the build log and decide between set_env_vars / ask_user / etc.
|
|
227
|
+
const fileProblems = (failure.problems ?? []).filter((p) => p.file);
|
|
228
|
+
const reproduceAlt = failure.deployId
|
|
229
|
+
? {
|
|
230
|
+
action: "reproduce_locally",
|
|
231
|
+
suggestedTool: "percher_reproduce",
|
|
232
|
+
args: { deployId: failure.deployId, app: failure.appName },
|
|
233
|
+
when: "after the primary path didn't surface a clear fix and the user has nixpacks installed locally",
|
|
234
|
+
}
|
|
235
|
+
: undefined;
|
|
236
|
+
if (fileProblems.length > 0) {
|
|
237
|
+
return recoveryFixProblems({
|
|
238
|
+
problems: fileProblems.map(buildProblemToRecoveryProblem),
|
|
239
|
+
reasonCode: "build_failed",
|
|
240
|
+
...(reproduceAlt
|
|
241
|
+
? {
|
|
242
|
+
alternativeActions: [
|
|
243
|
+
{
|
|
244
|
+
...reproduceAlt,
|
|
245
|
+
when: "after fixing the file-located problems didn't make the build pass and the user has nixpacks installed locally",
|
|
246
|
+
},
|
|
247
|
+
],
|
|
248
|
+
}
|
|
249
|
+
: {}),
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
// FUTURE12 Phase 4: route ambiguous build failures through
|
|
253
|
+
// `percher_doctor` instead of straight to `inspect_build_log`.
|
|
254
|
+
// Doctor's deploy-mode dispatch (Phase 2c) fetches the build
|
|
255
|
+
// log, runs `classifyError`, and returns a more specific
|
|
256
|
+
// recovery (`set_env_vars` when missing env keys are extracted,
|
|
257
|
+
// `fix_problems` when structured BuildProblems with file
|
|
258
|
+
// locations are extracted, falling back to `inspect_build_log`
|
|
259
|
+
// only when classification yields nothing). Publish/wait don't
|
|
260
|
+
// always have the build log when they hit this path, so handing
|
|
261
|
+
// off to doctor closes the loop with one consistent contract for
|
|
262
|
+
// agents.
|
|
263
|
+
//
|
|
264
|
+
// `inspect_build_log` is preserved as an `alternativeAction` so
|
|
265
|
+
// agents that want the raw log can still opt in after doctor's
|
|
266
|
+
// primary recovery doesn't help. Reproduce-locally chains after
|
|
267
|
+
// that for users with nixpacks installed.
|
|
268
|
+
const inspectAlt = {
|
|
269
|
+
action: "inspect_build_log",
|
|
270
|
+
suggestedTool: "percher_deploys_inspect",
|
|
271
|
+
args: failure.deployId
|
|
272
|
+
? { id: failure.deployId, app: failure.appName }
|
|
273
|
+
: { latestFailed: true, app: failure.appName },
|
|
274
|
+
when: "after percher_doctor's recovery didn't yield a fix and you want to read the raw build log directly",
|
|
275
|
+
};
|
|
276
|
+
const alternativeActions = [inspectAlt];
|
|
277
|
+
if (reproduceAlt) {
|
|
278
|
+
alternativeActions.push({
|
|
279
|
+
...reproduceAlt,
|
|
280
|
+
when: "after percher_doctor + percher_deploys_inspect didn't surface a clear fix and the user has nixpacks installed locally",
|
|
281
|
+
});
|
|
282
|
+
}
|
|
283
|
+
return recoveryDoctor({
|
|
284
|
+
app: failure.appName,
|
|
285
|
+
deployId: failure.deployId,
|
|
286
|
+
mode: "deploy",
|
|
287
|
+
reasonCode: "build_failed",
|
|
288
|
+
alternativeActions,
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
default:
|
|
292
|
+
// Exhaustiveness fallback. New `ErrorClass` values land here until a
|
|
293
|
+
// mapping is added — better than misclassifying as `retry`.
|
|
294
|
+
return recoveryAsk({
|
|
295
|
+
prompt: "Unexpected failure — Percher couldn't classify this error. Try `percher doctor` for diagnostics, or surface the error to the user.",
|
|
296
|
+
reasonCode: "unknown",
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
//# sourceMappingURL=recovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recovery.js","sourceRoot":"","sources":["../src/recovery.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cross-runtime streaming file write.
|
|
3
|
+
*
|
|
4
|
+
* Both the CLI and MCP server advertise Node.js compatibility
|
|
5
|
+
* (`npx percher`, `npx -y @percher/mcp`). The core package must not
|
|
6
|
+
* call Bun globals directly.
|
|
7
|
+
*
|
|
8
|
+
* In Bun: Bun.write(path, Response) streams to disk natively and
|
|
9
|
+
* returns the byte count — zero intermediate allocation.
|
|
10
|
+
*
|
|
11
|
+
* In Node.js 18+: we use Readable.fromWeb() + pipeline() to pipe the
|
|
12
|
+
* Web ReadableStream from the fetch Response to a fs.createWriteStream.
|
|
13
|
+
* The byte count is read back from fs.stat after the pipeline finishes.
|
|
14
|
+
*/
|
|
15
|
+
/**
|
|
16
|
+
* Node.js fallback — exported for direct testing so we don't need to
|
|
17
|
+
* mask the read-only Bun global in tests.
|
|
18
|
+
*/
|
|
19
|
+
export declare function writeResponseToFileNode(res: Response, filePath: string): Promise<number>;
|
|
20
|
+
export declare function writeResponseToFile(res: Response, filePath: string): Promise<number>;
|
|
21
|
+
//# sourceMappingURL=stream-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-utils.d.ts","sourceRoot":"","sources":["../src/stream-utils.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH;;;GAGG;AACH,wBAAsB,uBAAuB,CAAC,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAmB9F;AAED,wBAAsB,mBAAmB,CAAC,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAQ1F"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cross-runtime streaming file write.
|
|
3
|
+
*
|
|
4
|
+
* Both the CLI and MCP server advertise Node.js compatibility
|
|
5
|
+
* (`npx percher`, `npx -y @percher/mcp`). The core package must not
|
|
6
|
+
* call Bun globals directly.
|
|
7
|
+
*
|
|
8
|
+
* In Bun: Bun.write(path, Response) streams to disk natively and
|
|
9
|
+
* returns the byte count — zero intermediate allocation.
|
|
10
|
+
*
|
|
11
|
+
* In Node.js 18+: we use Readable.fromWeb() + pipeline() to pipe the
|
|
12
|
+
* Web ReadableStream from the fetch Response to a fs.createWriteStream.
|
|
13
|
+
* The byte count is read back from fs.stat after the pipeline finishes.
|
|
14
|
+
*/
|
|
15
|
+
/**
|
|
16
|
+
* Node.js fallback — exported for direct testing so we don't need to
|
|
17
|
+
* mask the read-only Bun global in tests.
|
|
18
|
+
*/
|
|
19
|
+
export async function writeResponseToFileNode(res, filePath) {
|
|
20
|
+
if (!res.body)
|
|
21
|
+
throw new Error("Server returned empty response body");
|
|
22
|
+
const { createWriteStream } = await import("node:fs");
|
|
23
|
+
const { stat } = await import("node:fs/promises");
|
|
24
|
+
const { Readable } = await import("node:stream");
|
|
25
|
+
const { pipeline } = await import("node:stream/promises");
|
|
26
|
+
const fileStream = createWriteStream(filePath);
|
|
27
|
+
// fromWeb converts a WHATWG ReadableStream to a Node.js Readable.
|
|
28
|
+
// The cast is needed because TypeScript's Node typedefs require
|
|
29
|
+
// stream.web.ReadableStream but fetch returns the global ReadableStream.
|
|
30
|
+
const nodeReadable = Readable.fromWeb(res.body);
|
|
31
|
+
await pipeline(nodeReadable, fileStream);
|
|
32
|
+
const { size } = await stat(filePath);
|
|
33
|
+
return size;
|
|
34
|
+
}
|
|
35
|
+
export async function writeResponseToFile(res, filePath) {
|
|
36
|
+
if (typeof Bun !== "undefined") {
|
|
37
|
+
return Bun.write(filePath, res);
|
|
38
|
+
}
|
|
39
|
+
return writeResponseToFileNode(res, filePath);
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=stream-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-utils.js","sourceRoot":"","sources":["../src/stream-utils.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAC,GAAa,EAAE,QAAgB;IAC3E,IAAI,CAAC,GAAG,CAAC,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;IAEtE,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC,CAAC;IACtD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,kBAAkB,CAAC,CAAC;IAClD,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,CAAC;IACjD,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC;IAE1D,MAAM,UAAU,GAAG,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IAC/C,kEAAkE;IAClE,gEAAgE;IAChE,yEAAyE;IACzE,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CACnC,GAAG,CAAC,IAAyD,CAC9D,CAAC;IACF,MAAM,QAAQ,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;IAEzC,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,GAAa,EAAE,QAAgB;IACvE,IAAI,OAAO,GAAG,KAAK,WAAW,EAAE,CAAC;QAC/B,OAAQ,GAAyE,CAAC,KAAK,CACrF,QAAQ,EACR,GAAG,CACJ,CAAC;IACJ,CAAC;IACD,OAAO,uBAAuB,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;AAChD,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { ClassifiedError } from "./error-classifier";
|
|
2
|
+
/**
|
|
3
|
+
* Phase 4 of the publish-resilience plan — CLI-side mapping from
|
|
4
|
+
* the canonical `DeployErrorCode` strings (defined server-side in
|
|
5
|
+
* `@percher/api/src/worker/error-codes.ts`) to the
|
|
6
|
+
* `ClassifiedError` shape the CLI's publish-failure renderer
|
|
7
|
+
* already consumes.
|
|
8
|
+
*
|
|
9
|
+
* Why this lives in @percher/core instead of @percher/client: the
|
|
10
|
+
* client surfaces the raw `errorCode` string on `Deployment` and
|
|
11
|
+
* stays unopinionated; the core package owns the rendering of
|
|
12
|
+
* publish failures and is the right place to decide "given this
|
|
13
|
+
* canonical code, what title/explanation/suggestion does the user
|
|
14
|
+
* see". The CLI's `publish-failure.ts` calls into this module
|
|
15
|
+
* BEFORE the regex-based `classifyError` so the structured code
|
|
16
|
+
* always wins when present.
|
|
17
|
+
*
|
|
18
|
+
* Set parity: the strings here MUST match the ones in the API's
|
|
19
|
+
* `DEPLOY_ERROR_CODES` const. Adding a new code requires updating
|
|
20
|
+
* both files. Forward-compat: an unknown code returns null, the
|
|
21
|
+
* CLI falls back to the regex classifier, no breakage.
|
|
22
|
+
*/
|
|
23
|
+
export type DeployErrorCode = "WORKER_UNAVAILABLE" | "WORKER_UNAVAILABLE_PERSISTENT" | "BUILD_TIMEOUT" | "BUILD_FAILED" | "WORKER_ERROR" | "DEPLOY_STALLED";
|
|
24
|
+
/**
|
|
25
|
+
* Map a canonical Phase 4 error code to a {@link ClassifiedError}.
|
|
26
|
+
* Returns null for NULL / unknown codes so the caller can fall back
|
|
27
|
+
* to the regex-based `classifyError`.
|
|
28
|
+
*/
|
|
29
|
+
export declare function classifyByErrorCode(code: string | null | undefined, rawMessage: string): ClassifiedError | null;
|
|
30
|
+
//# sourceMappingURL=structured-error-codes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-error-codes.d.ts","sourceRoot":"","sources":["../src/structured-error-codes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAc,MAAM,oBAAoB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;GAoBG;AAEH,MAAM,MAAM,eAAe,GACvB,oBAAoB,GACpB,+BAA+B,GAC/B,eAAe,GACf,cAAc,GACd,cAAc,GACd,gBAAgB,CAAC;AAoFrB;;;;GAIG;AACH,wBAAgB,mBAAmB,CACjC,IAAI,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EAC/B,UAAU,EAAE,MAAM,GACjB,eAAe,GAAG,IAAI,CAcxB"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
const MAPPINGS = {
|
|
2
|
+
WORKER_UNAVAILABLE: {
|
|
3
|
+
errorClass: "infra_unavailable",
|
|
4
|
+
phase: "infra",
|
|
5
|
+
cause: "worker_fetch_failed",
|
|
6
|
+
title: "Build worker is unreachable",
|
|
7
|
+
explanation: (raw) => raw
|
|
8
|
+
? `The Percher build worker did not respond in time: ${trimMessage(raw)}. This is a platform-side issue, not your code.`
|
|
9
|
+
: "The Percher build worker did not respond in time. This is a platform-side issue, not your code.",
|
|
10
|
+
suggestion: "Wait 30 seconds and run `percher publish` again. If retry #2 also fails, pause 5 minutes before the next attempt — back-to-back retries during a partial outage just waste your time. After 3 spaced-out retries, check status.percher.app or contact support. Your build never started.",
|
|
11
|
+
},
|
|
12
|
+
WORKER_UNAVAILABLE_PERSISTENT: {
|
|
13
|
+
errorClass: "infra_unavailable",
|
|
14
|
+
phase: "infra",
|
|
15
|
+
cause: "worker_circuit_breaker_open",
|
|
16
|
+
title: "Build worker is in a crash loop",
|
|
17
|
+
explanation: () => "The Percher build worker has failed repeatedly in the last minute and the platform's circuit breaker has flipped open. Retrying immediately would just queue more failures.",
|
|
18
|
+
suggestion: "Wait 2-3 minutes for the platform to recover, then retry. If it persists past 5 minutes check status.percher.app or contact support — this is a platform incident, not your code.",
|
|
19
|
+
},
|
|
20
|
+
BUILD_TIMEOUT: {
|
|
21
|
+
errorClass: "build_failed",
|
|
22
|
+
phase: "build",
|
|
23
|
+
cause: "build_timeout",
|
|
24
|
+
title: "Build timed out",
|
|
25
|
+
explanation: () => "The build ran longer than the 10-minute platform limit and was aborted.",
|
|
26
|
+
suggestion: "Common causes: a slow `postinstall` hook, very large dependency tree, or a Dockerfile that pulls a huge base image. Try `bun install` locally and check what's slow. If it's legitimately a heavy build, contact support to discuss raising the limit for your account.",
|
|
27
|
+
},
|
|
28
|
+
BUILD_FAILED: {
|
|
29
|
+
errorClass: "build_failed",
|
|
30
|
+
phase: "build",
|
|
31
|
+
cause: "build_nonzero_exit",
|
|
32
|
+
title: "Build failed",
|
|
33
|
+
explanation: (raw) => raw
|
|
34
|
+
? `The build process returned a non-zero exit code: ${trimMessage(raw)}. Read the build log below for the exact error.`
|
|
35
|
+
: "The build process returned a non-zero exit code. Read the build log below for the exact error.",
|
|
36
|
+
suggestion: "Run your build locally to reproduce: `bun install && bun run build`. The error in the build log usually points to a missing dependency, a TypeScript/syntax error, or a misconfigured framework setting.",
|
|
37
|
+
},
|
|
38
|
+
WORKER_ERROR: {
|
|
39
|
+
errorClass: "infra_unavailable",
|
|
40
|
+
phase: "infra",
|
|
41
|
+
cause: "worker_internal_error",
|
|
42
|
+
title: "Platform error inside the build worker",
|
|
43
|
+
explanation: (raw) => raw
|
|
44
|
+
? `The build worker hit an internal error: ${trimMessage(raw)}. This is a Percher bug, not your code.`
|
|
45
|
+
: "The build worker hit an internal error. This is a Percher bug, not your code.",
|
|
46
|
+
suggestion: "Retry once — transient platform errors usually clear within a minute. If it repeats, please report it: include the deploy ID and we'll investigate. Your account is not at fault.",
|
|
47
|
+
},
|
|
48
|
+
DEPLOY_STALLED: {
|
|
49
|
+
errorClass: "infra_unavailable",
|
|
50
|
+
phase: "infra",
|
|
51
|
+
cause: "deploy_stalled",
|
|
52
|
+
title: "Deploy stalled",
|
|
53
|
+
explanation: () => "The platform abandoned this deploy — likely because the API or build worker restarted mid-build. Your code is fine; the build never finished.",
|
|
54
|
+
suggestion: "Run `percher publish` again. The new deploy will start fresh. If you see this repeatedly across multiple publishes, check status.percher.app — it implies a recurring platform issue.",
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
/**
|
|
58
|
+
* Map a canonical Phase 4 error code to a {@link ClassifiedError}.
|
|
59
|
+
* Returns null for NULL / unknown codes so the caller can fall back
|
|
60
|
+
* to the regex-based `classifyError`.
|
|
61
|
+
*/
|
|
62
|
+
export function classifyByErrorCode(code, rawMessage) {
|
|
63
|
+
if (!code)
|
|
64
|
+
return null;
|
|
65
|
+
const mapping = MAPPINGS[code];
|
|
66
|
+
if (!mapping)
|
|
67
|
+
return null;
|
|
68
|
+
return {
|
|
69
|
+
title: mapping.title,
|
|
70
|
+
explanation: mapping.explanation(rawMessage),
|
|
71
|
+
suggestion: mapping.suggestion,
|
|
72
|
+
errorClass: mapping.errorClass,
|
|
73
|
+
phase: mapping.phase,
|
|
74
|
+
cause: mapping.cause,
|
|
75
|
+
relevantFiles: [],
|
|
76
|
+
missingEnvVars: [],
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
function trimMessage(raw) {
|
|
80
|
+
// Keep the first line + truncate. The CLI already shows the
|
|
81
|
+
// full build-log tail below; this is just enough context to
|
|
82
|
+
// explain WHY the platform-side classifier picked this code.
|
|
83
|
+
const firstLine = raw.split("\n")[0] ?? "";
|
|
84
|
+
return firstLine.length > 200 ? `${firstLine.slice(0, 200)}…` : firstLine;
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=structured-error-codes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-error-codes.js","sourceRoot":"","sources":["../src/structured-error-codes.ts"],"names":[],"mappings":"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"}
|
package/dist/tarball.d.ts
CHANGED
|
@@ -12,6 +12,17 @@ export interface TarballResult {
|
|
|
12
12
|
path: string;
|
|
13
13
|
size: number;
|
|
14
14
|
}>;
|
|
15
|
+
/**
|
|
16
|
+
* Phase 7.8 follow-up — deterministic content-hash of the bundle.
|
|
17
|
+
* Used by the CLI's cache-probe call so identical sources hash to
|
|
18
|
+
* the same value across runs. Distinct from the gzipped-bytes hash
|
|
19
|
+
* the API computes on upload (which carries embedded mtimes from
|
|
20
|
+
* tar/gzip headers and therefore *cannot* be deterministic). The
|
|
21
|
+
* CLI sends this value as the `X-Tarball-Hash` header on the
|
|
22
|
+
* upload; the API stores it on `deployments.tarball_hash` so a
|
|
23
|
+
* subsequent probe matches.
|
|
24
|
+
*/
|
|
25
|
+
contentHash: string;
|
|
15
26
|
}
|
|
16
27
|
export declare function createTarball(options: TarballOptions): Promise<TarballResult>;
|
|
17
28
|
//# sourceMappingURL=tarball.d.ts.map
|
package/dist/tarball.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tarball.d.ts","sourceRoot":"","sources":["../src/tarball.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"tarball.d.ts","sourceRoot":"","sources":["../src/tarball.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAInD,MAAM,WAAW,cAAc;IAC7B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,aAAa,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CACxB;AAED,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,cAAc,CAAC,UAAU,CAAC,CAAC;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAChD;;;;;;;;;OASG;IACH,WAAW,EAAE,MAAM,CAAC;CACrB;AAiCD,wBAAsB,aAAa,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC,CAgEnF"}
|
package/dist/tarball.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { createHash } from "node:crypto";
|
|
1
2
|
import { existsSync, readFileSync, readdirSync, statSync } from "node:fs";
|
|
2
3
|
import { join, relative, sep } from "node:path";
|
|
3
4
|
import { Readable } from "node:stream";
|
|
@@ -45,18 +46,34 @@ export async function createTarball(options) {
|
|
|
45
46
|
}
|
|
46
47
|
if (options.extraIgnore)
|
|
47
48
|
ig.add(options.extraIgnore);
|
|
48
|
-
|
|
49
|
+
// Sorted entries — required for the deterministic content-hash
|
|
50
|
+
// below. Without this, readdirSync's platform-dependent order
|
|
51
|
+
// produces a different hash on every run even for unchanged
|
|
52
|
+
// sources, and cache-probe never matches. Codex P2, 2026-05-08.
|
|
53
|
+
const fileBuffers = [];
|
|
49
54
|
for (const rel of walk(options.cwd, options.cwd, ig)) {
|
|
50
|
-
const
|
|
51
|
-
|
|
55
|
+
const data = readFileSync(join(options.cwd, rel));
|
|
56
|
+
fileBuffers.push({ path: rel, size: data.length, data });
|
|
52
57
|
}
|
|
53
|
-
|
|
58
|
+
fileBuffers.sort((a, b) => (a.path < b.path ? -1 : a.path > b.path ? 1 : 0));
|
|
59
|
+
const totalBytes = fileBuffers.reduce((sum, f) => sum + f.size, 0);
|
|
60
|
+
// Deterministic content-hash: SHA-256 over a canonical encoding of
|
|
61
|
+
// every file's path + bytes, in sorted order. The encoding uses
|
|
62
|
+
// length-prefixed sections so a path containing a delimiter can't
|
|
63
|
+
// collide with a longer/shorter path of the same prefix.
|
|
64
|
+
const contentHasher = createHash("sha256");
|
|
65
|
+
for (const f of fileBuffers) {
|
|
66
|
+
contentHasher.update(`PATH:${f.path.length}:${f.path}\n`);
|
|
67
|
+
contentHasher.update(`SIZE:${f.size}\n`);
|
|
68
|
+
contentHasher.update(f.data);
|
|
69
|
+
contentHasher.update("\n");
|
|
70
|
+
}
|
|
71
|
+
const contentHash = contentHasher.digest("hex");
|
|
54
72
|
const pack = tarPack();
|
|
55
73
|
(async () => {
|
|
56
|
-
for (const file of
|
|
57
|
-
const data = readFileSync(join(options.cwd, file.path));
|
|
74
|
+
for (const file of fileBuffers) {
|
|
58
75
|
await new Promise((resolve, reject) => {
|
|
59
|
-
pack.entry({ name: file.path, size: data.length }, data, (err) => err ? reject(err) : resolve());
|
|
76
|
+
pack.entry({ name: file.path, size: file.data.length }, file.data, (err) => err ? reject(err) : resolve());
|
|
60
77
|
});
|
|
61
78
|
}
|
|
62
79
|
pack.finalize();
|
|
@@ -64,12 +81,16 @@ export async function createTarball(options) {
|
|
|
64
81
|
const gzip = createGzip();
|
|
65
82
|
const nodeStream = pack.pipe(gzip);
|
|
66
83
|
const webStream = Readable.toWeb(nodeStream);
|
|
67
|
-
const topFiles = [...
|
|
84
|
+
const topFiles = [...fileBuffers]
|
|
85
|
+
.sort((a, b) => b.size - a.size)
|
|
86
|
+
.slice(0, 5)
|
|
87
|
+
.map((f) => ({ path: f.path, size: f.size }));
|
|
68
88
|
return {
|
|
69
89
|
stream: webStream,
|
|
70
90
|
bytes: totalBytes,
|
|
71
|
-
fileCount:
|
|
91
|
+
fileCount: fileBuffers.length,
|
|
72
92
|
topFiles,
|
|
93
|
+
contentHash,
|
|
73
94
|
};
|
|
74
95
|
}
|
|
75
96
|
//# sourceMappingURL=tarball.js.map
|
package/dist/tarball.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tarball.js","sourceRoot":"","sources":["../src/tarball.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,IAAI,IAAI,OAAO,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"tarball.js","sourceRoot":"","sources":["../src/tarball.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"claude-md.d.ts","sourceRoot":"","sources":["../../../src/templates/ai-files/claude-md.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,SAAS;;;;;CA4ErB,CAAC"}
|