gsd-pi 2.41.0-dev.9446b20 → 2.41.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/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +14 -14
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/required-server-files.json +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
- package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +2 -2
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
- package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +5 -5
- package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +4 -4
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/page.js +2 -2
- package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +14 -14
- package/dist/web/standalone/.next/server/chunks/229.js +1 -1
- package/dist/web/standalone/.next/server/chunks/471.js +3 -3
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware.js +2 -2
- package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
- package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +2 -2
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/static/chunks/app/_not-found/page-e07acdb7dd069836.js +1 -0
- package/dist/web/standalone/.next/static/chunks/app/layout-745c6ed5fea5fb06.js +1 -0
- package/dist/web/standalone/.next/static/chunks/app/page-801b53eff6e83579.js +1 -0
- package/dist/web/standalone/.next/static/chunks/{main-app-fdab67f7802d7832.js → main-app-2f2ee7b85712c2bd.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-e6255954dccfcf0a.js +1 -0
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
- package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
- package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
- package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
- package/dist/web/standalone/server.js +1 -1
- package/package.json +1 -1
- package/dist/web/standalone/.next/static/chunks/app/_not-found/page-f2a7482d42a5614b.js +0 -1
- package/dist/web/standalone/.next/static/chunks/app/layout-a16c7a7ecdf0c2cf.js +0 -1
- package/dist/web/standalone/.next/static/chunks/app/page-b9367c5ae13b99c6.js +0 -1
- package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +0 -1
- /package/dist/web/standalone/.next/static/{02cti5IXH7FycOqkbAkWL → Ute3pMouVczQyT15qrBBO}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{02cti5IXH7FycOqkbAkWL → Ute3pMouVczQyT15qrBBO}/_ssgManifest.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";(()=>{var a={};a.id=851,a.ids=[851],a.modules={261:a=>{a.exports=require("next/dist/shared/lib/router/utils/app-paths")},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},21820:a=>{a.exports=require("os")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},46193:a=>{a.exports=require("node:string_decoder")},48161:a=>{a.exports=require("node:os")},53551:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>N,patchFetch:()=>M,routeModule:()=>I,serverHooks:()=>L,workAsyncStorage:()=>J,workUnitAsyncStorage:()=>K});var d={};c.r(d),c.d(d,{GET:()=>H,dynamic:()=>G,runtime:()=>F});var e=c(19225),f=c(84006),g=c(8317),h=c(99373),i=c(34775),j=c(24235),k=c(261),l=c(54365),m=c(90771),n=c(73461),o=c(67798),p=c(92280),q=c(62018),r=c(45696),s=c(47929),t=c(86439),u=c(37527),v=c(31421),w=c(73024),x=c(76760),y=c(73136),z=c(74900);function A(a){return(a instanceof Error?a.message:String(a??"")).replace(/sk-[A-Za-z0-9_-]{6,}/g,"[redacted]").replace(/xox[baprs]-[A-Za-z0-9-]+/g,"[redacted]").replace(/Bearer\s+[^\s]+/gi,"Bearer [redacted]").replace(/([A-Z0-9_]*(?:API[_-]?KEY|TOKEN|SECRET)["'=:\s]+)([^\s,;"']+)/gi,"$1[redacted]").replace(/\s+/g," ").trim()}function B(a){return a?.active.milestoneId?a.active.taskId&&a.active.sliceId?`${a.active.milestoneId}/${a.active.sliceId}/${a.active.taskId}`:a.active.sliceId?`${a.active.milestoneId}/${a.active.sliceId}`:a.active.milestoneId:null}function C(a){return{code:a.code,severity:a.severity,scope:a.scope,message:A(a.message),file:a.file,suggestion:a.suggestion?A(a.suggestion):void 0,unitId:a.unitId}}async function D(a,b,c,d,e,f){let g=f.env??process.env,h=f.existsSync??w.existsSync,i=(0,x.join)(a,"src","resources","extensions","gsd","tests","resolve-ts.mjs"),j=(0,x.join)(a,"src","resources","extensions","gsd","doctor.ts"),k=(0,x.join)(a,"src","resources","extensions","gsd","session-forensics.ts");if(!h(i)||!h(j)||!h(k))throw Error(`recovery diagnostics providers not found; checked=${i},${j},${k}`);return await new Promise((h,l)=>{(0,v.execFile)(f.execPath??process.execPath,["--import",(0,y.pathToFileURL)(i).href,"--experimental-strip-types","--input-type=module","--eval",'const { pathToFileURL } = await import("node:url"); const doctor = await import(pathToFileURL(process.env.GSD_RECOVERY_DOCTOR_MODULE).href); const forensics = await import(pathToFileURL(process.env.GSD_RECOVERY_FORENSICS_MODULE).href); const basePath = process.env.GSD_RECOVERY_BASE; const scope = process.env.GSD_RECOVERY_SCOPE || undefined; const unitType = process.env.GSD_RECOVERY_UNIT_TYPE || "execute-project"; const unitId = process.env.GSD_RECOVERY_UNIT_ID || "project"; const sessionFile = process.env.GSD_RECOVERY_SESSION_FILE || undefined; const activityDir = process.env.GSD_RECOVERY_ACTIVITY_DIR || undefined; const report = await doctor.runGSDDoctor(basePath, { fix: false, scope, fixLevel: "task" }); const summary = doctor.summarizeDoctorIssues(report.issues); const briefing = forensics.synthesizeCrashRecovery(basePath, unitType, unitId, sessionFile, activityDir); const trace = briefing?.trace; const available = Boolean(sessionFile || trace?.toolCallCount || briefing?.gitChanges); const detected = Boolean((trace?.toolCallCount ?? 0) > 0 || (trace?.errors?.length ?? 0) > 0 || (trace?.commandsRun?.length ?? 0) > 0 || (trace?.filesWritten?.length ?? 0) > 0 || briefing?.gitChanges); const interruptedRun = available ? detected ? { available: true, detected: true, label: "Interrupted-run recovery available", detail: "Recent session forensics captured unfinished work or errors that may need resume or retry follow-up.", unit: { type: briefing?.unitType ?? unitType, id: briefing?.unitId ?? unitId }, counts: { toolCalls: trace?.toolCallCount ?? 0, filesWritten: trace?.filesWritten?.length ?? 0, commandsRun: trace?.commandsRun?.length ?? 0, errors: trace?.errors?.length ?? 0, }, gitChangesDetected: Boolean(briefing?.gitChanges), lastError: trace?.errors?.at(-1) ?? null, } : { available: true, detected: false, label: "Session forensics available", detail: "A current-project session was inspected, but it did not show unfinished tool or error activity.", unit: { type: briefing?.unitType ?? unitType, id: briefing?.unitId ?? unitId }, counts: { toolCalls: trace?.toolCallCount ?? 0, filesWritten: trace?.filesWritten?.length ?? 0, commandsRun: trace?.commandsRun?.length ?? 0, errors: trace?.errors?.length ?? 0, }, gitChangesDetected: Boolean(briefing?.gitChanges), lastError: trace?.errors?.at(-1) ?? null, } : { available: false, detected: false, label: "No interrupted-run evidence", detail: "No current-project session or activity log is available for interrupted-run forensics yet.", unit: null, counts: { toolCalls: 0, filesWritten: 0, commandsRun: 0, errors: 0 }, gitChangesDetected: false, lastError: null, }; process.stdout.write(JSON.stringify({ doctor: { scope: scope ?? null, total: summary.total, errors: summary.errors, warnings: summary.warnings, infos: summary.infos, fixable: summary.fixable, codes: summary.byCode, topIssues: report.issues.slice(0, 6).map((issue) => ({ code: issue.code, severity: issue.severity, scope: issue.scope, message: issue.message, file: issue.file, unitId: issue.unitId, })), }, interruptedRun, }));'],{cwd:a,env:{...g,GSD_RECOVERY_BASE:b,GSD_RECOVERY_SCOPE:c??"",GSD_RECOVERY_UNIT_TYPE:d?.type??"execute-project",GSD_RECOVERY_UNIT_ID:d?.id??"project",GSD_RECOVERY_SESSION_FILE:e??"",GSD_RECOVERY_ACTIVITY_DIR:(0,x.join)(b,".gsd","activity"),GSD_RECOVERY_DOCTOR_MODULE:j,GSD_RECOVERY_FORENSICS_MODULE:k},maxBuffer:1048576},(a,b,c)=>{if(a)return void l(Error(`recovery diagnostics subprocess failed: ${c||a.message}`));try{h(JSON.parse(b))}catch(a){l(Error(`recovery diagnostics subprocess returned invalid JSON: ${a instanceof Error?a.message:String(a)}`))}})})}async function E(a={},b){var c,d,e,f;let g,h,i,j,k;a.env??process.env;let l=(0,z.eG)(a.env,b),[{bridge:m,workspace:n,resumableSessions:o},p]=await Promise.all([(0,z.yd)(["workspace","resumable_sessions"],b),(0,z.tL)(b)]),q=o??[],r=B(n),s=(g=B(n))?n?.active.taskId?{type:"execute-task",id:g}:n?.active.sliceId?{type:"execute-slice",id:g}:{type:"execute-milestone",id:g}:null,t=function(a,b){if(!a)return b[0]?.path??null;let c=(0,x.resolve)(a),d=b.find(a=>(0,x.resolve)(a.path)===c);return d?d.path:b[0]?.path??a}(m.activeSessionFile,q),u=function(a,b,c){if(!b)return a??null;let d=(0,x.resolve)(b);return c.find(a=>(0,x.resolve)(a.path)===d)?.id??a??null}(m.activeSessionId,t,q),v=await D(l.packageRoot,l.projectCwd,r,s,t,a),w=(n?.validationIssues??[]).map(a=>({code:a.ruleId??"unknown_validation_issue",severity:a.severity??"warning",scope:a.scope??"workspace",message:A(a.message??"Validation issue"),file:a.file,suggestion:a.suggestion?A(a.suggestion):void 0})),y=w.reduce((a,b)=>({errors:a.errors+Number("error"===b.severity),warnings:a.warnings+Number("warning"===b.severity),infos:a.infos+Number("info"===b.severity)}),{errors:0,warnings:0,infos:0}),F=function(a){let b=new Map,c={info:0,warning:1,error:2};for(let d of a){let a=b.get(d.code);if(!a){b.set(d.code,{count:1,severity:d.severity});continue}b.set(d.code,{count:a.count+1,severity:c[d.severity]>c[a.severity]?d.severity:a.severity})}return[...b.entries()].map(([a,b])=>({code:a,count:b.count,label:a.replace(/[_-]+/g," ").replace(/\b\w/g,a=>a.toUpperCase()),severity:b.severity})).sort((a,b)=>b.count-a.count||a.code.localeCompare(b.code))}(w),G=v.doctor.topIssues.map(C),H={...v.interruptedRun,label:A(v.interruptedRun.label),detail:A(v.interruptedRun.detail),lastError:v.interruptedRun.lastError?A(v.interruptedRun.lastError):null},I=m.lastError?{message:A(m.lastError.message),phase:m.lastError.phase,at:m.lastError.at,commandType:m.lastError.commandType??null,afterSessionAttachment:m.lastError.afterSessionAttachment}:null,J=p.bridgeAuthRefresh.phase,K=p.bridgeAuthRefresh.error?A(p.bridgeAuthRefresh.error):null,L=I||"failed"===J||w.length>0||v.doctor.total>0||H.available||q.length>0||m.sessionState?.retryInProgress||m.sessionState?.isCompacting?"ready":"unavailable",M=s?.id??r,N=(c={status:L,validationCount:w.length,validationErrors:y.errors,doctorTotal:v.doctor.total,doctorErrors:v.doctor.errors,retryAttempt:m.sessionState?.retryAttempt??0,retryInProgress:!!m.sessionState?.retryInProgress,compactionActive:!!m.sessionState?.isCompacting,currentUnitId:M??null,lastFailurePhase:"failed"===J?"bridge_auth_refresh":I?.phase??null,bridgeFailureMessage:I?.message??null,authFailureMessage:"failed"===J?K:null,interruptedRunDetected:H.detected,interruptedRunDetail:H.detail}).authFailureMessage?{tone:"danger",label:"Bridge auth refresh failed",detail:c.authFailureMessage}:c.bridgeFailureMessage?{tone:"danger",label:c.lastFailurePhase?`Bridge recovery failed during ${c.lastFailurePhase}`:"Bridge recovery failed",detail:c.bridgeFailureMessage}:c.doctorErrors>0||c.validationErrors>0?{tone:"danger",label:`Recovery blockers detected (${c.doctorErrors+c.validationErrors})`,detail:`Doctor and validation surfaced blocking issues for ${c.currentUnitId??"the current project"}.`}:c.retryInProgress?{tone:"warning",label:`Retry attempt ${Math.max(1,c.retryAttempt)} is active`,detail:"The bridge is retrying work right now; inspect retry controls before issuing more recovery actions."}:c.compactionActive?{tone:"warning",label:"Compaction is active",detail:"The live session is compacting context before work continues."}:c.validationCount>0||c.doctorTotal>0?{tone:"warning",label:`Recovery diagnostics found ${c.validationCount+c.doctorTotal} actionable issue${c.validationCount+c.doctorTotal===1?"":"s"}`,detail:`Review the doctor and validation sections below before resuming work on ${c.currentUnitId??"the current project"}.`}:c.interruptedRunDetected?{tone:"warning",label:"Interrupted-run evidence is available",detail:c.interruptedRunDetail}:"unavailable"===c.status?{tone:"healthy",label:"Recovery diagnostics unavailable",detail:"No current-project recovery evidence has been captured yet. Start or resume a session to populate diagnostics."}:{tone:"healthy",label:"Recovery diagnostics healthy",detail:"No bridge, validation, doctor, or interrupted-run recovery issues are currently active."};return{status:L,loadedAt:new Date().toISOString(),project:{cwd:l.projectCwd,activeScope:r,activeSessionPath:t,activeSessionId:u},summary:{tone:N.tone,label:N.label,detail:N.detail,validationCount:w.length,doctorIssueCount:v.doctor.total,lastFailurePhase:"failed"===J?"bridge_auth_refresh":I?.phase??null,currentUnitId:M??null,retryAttempt:m.sessionState?.retryAttempt??0,retryInProgress:!!m.sessionState?.retryInProgress,compactionActive:!!m.sessionState?.isCompacting},bridge:{phase:m.phase,retry:{enabled:!!m.sessionState?.autoRetryEnabled,inProgress:!!m.sessionState?.retryInProgress,attempt:m.sessionState?.retryAttempt??0,label:m.sessionState?.retryInProgress?`Attempt ${Math.max(1,m.sessionState?.retryAttempt??0)}`:m.sessionState?.autoRetryEnabled?"Enabled":"Disabled"},compaction:{active:!!m.sessionState?.isCompacting,label:m.sessionState?.isCompacting?"Compaction active":"Compaction idle"},lastFailure:I,authRefresh:{phase:J,error:K,label:"failed"===J?"Bridge auth refresh failed":"pending"===J?"Bridge auth refresh pending":"succeeded"===J?"Bridge auth refresh succeeded":"Bridge auth refresh idle"}},validation:{total:w.length,bySeverity:y,codes:F,topIssues:w.slice(0,6)},doctor:{scope:v.doctor.scope,total:v.doctor.total,errors:v.doctor.errors,warnings:v.doctor.warnings,infos:v.doctor.infos,fixable:v.doctor.fixable,codes:v.doctor.codes,topIssues:G},interruptedRun:H,actions:{browser:(d={hasSessions:q.length>0,retryActive:!!m.sessionState?.retryInProgress,autoRetryEnabled:!!m.sessionState?.autoRetryEnabled,bridgeFailure:!!I,compactionActive:!!m.sessionState?.isCompacting,authAttentionNeeded:p.locked||"failed"===J||p.lastValidation?.status==="failed"},h=new Map,(i=a=>{h.set(a.id,a)})({id:"refresh_diagnostics",label:"Refresh diagnostics",detail:"Reload the on-demand recovery route without refreshing the entire workspace.",emphasis:"primary"}),i({id:"refresh_workspace",label:"Refresh workspace",detail:"Run one soft workspace refresh so the browser re-syncs boot, bridge, and onboarding state."}),(d.retryActive||d.autoRetryEnabled||d.bridgeFailure||d.compactionActive)&&i({id:"open_retry_controls",label:"Open retry controls",detail:"Inspect or change live retry and compaction controls on the authoritative browser surface."}),d.hasSessions&&i({id:"open_resume_controls",label:"Open resume controls",detail:"Switch to another current-project session if recovery should continue elsewhere."}),d.authAttentionNeeded&&i({id:"open_auth_controls",label:"Open auth controls",detail:"Inspect provider setup and bridge auth refresh failures from the shared browser surface.",emphasis:"danger"}),[...h.values()]),commands:(e=n?.active.phase,f=w.length,j=new Map,k=(a,b)=>{j.has(a)||j.set(a,{command:a,label:b})},"planning"===e&&k("/gsd","Open GSD planning"),("executing"===e||"summarizing"===e)&&k("/gsd auto","Resume GSD auto mode"),r&&k(`/gsd doctor ${r}`,"Inspect scoped doctor report"),r&&k(`/gsd doctor fix ${r}`,"Apply scoped doctor fixes"),f>0&&r&&k(`/gsd doctor audit ${r}`,"Audit validation diagnostics"),k("/gsd status","Check current-project status"),[...j.values()])}}}let F="nodejs",G="force-dynamic";async function H(a){try{let b=(0,z.jL)(a),c=await E(void 0,b);return Response.json(c,{headers:{"Cache-Control":"no-store"}})}catch(b){let a=b instanceof Error?b.message:String(b);return Response.json({error:a},{status:500,headers:{"Cache-Control":"no-store"}})}}let I=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/recovery/route",pathname:"/api/recovery",filename:"route",bundlePath:"app/api/recovery/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"/__w/gsd-2/gsd-2/web/app/api/recovery/route.ts",nextConfigOutput:"standalone",userland:d}),{workAsyncStorage:J,workUnitAsyncStorage:K,serverHooks:L}=I;function M(){return(0,g.patchFetch)({workAsyncStorage:J,workUnitAsyncStorage:K})}async function N(a,b,c){I.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/recovery/route";"/index"===d&&(d="/");let e=await I.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,params:v,nextConfig:w,parsedUrl:x,isDraftMode:y,prerenderManifest:z,routerServerContext:A,isOnDemandRevalidate:B,revalidateOnlyGenerated:C,resolvedPathname:D,clientReferenceManifest:E,serverActionsManifest:F}=e,G=(0,k.normalizeAppPath)(d),H=!!(z.dynamicRoutes[G]||z.routes[D]),J=async()=>((null==A?void 0:A.render404)?await A.render404(a,b,x,!1):b.end("This page could not be found"),null);if(H&&!y){let a=!!z.routes[D],b=z.dynamicRoutes[G];if(b&&!1===b.fallback&&!a){if(w.experimental.adapterPath)return await J();throw new t.NoFallbackError}}let K=null;!H||I.isDev||y||(K="/index"===(K=D)?"/":K);let L=!0===I.isDev||!H,M=H&&!L;F&&E&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:E,serverActionsManifest:F});let N=a.method||"GET",O=(0,i.getTracer)(),P=O.getActiveScopeSpan(),Q={params:v,prerenderManifest:z,renderOpts:{experimental:{authInterrupts:!!w.experimental.authInterrupts},cacheComponents:!!w.cacheComponents,supportsDynamicResponse:L,incrementalCache:(0,h.getRequestMeta)(a,"incrementalCache"),cacheLifeProfiles:w.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>I.onRequestError(a,b,d,e,A)},sharedContext:{buildId:g}},R=new l.NodeNextRequest(a),S=new l.NodeNextResponse(b),T=m.NextRequestAdapter.fromNodeNextRequest(R,(0,m.signalFromNodeResponse)(b));try{let e=async a=>I.handle(T,Q).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=O.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let e=c.get("next.route");if(e){let b=`${N} ${e}`;a.setAttributes({"next.route":e,"http.route":e,"next.span_name":b}),a.updateName(b)}else a.updateName(`${N} ${d}`)}),g=!!(0,h.getRequestMeta)(a,"minimalMode"),j=async h=>{var i,j;let k=async({previousCacheEntry:f})=>{try{if(!g&&B&&C&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await e(h);a.fetchMetrics=Q.renderOpts.fetchMetrics;let i=Q.renderOpts.pendingWaitUntil;i&&c.waitUntil&&(c.waitUntil(i),i=void 0);let j=Q.renderOpts.collectedTags;if(!H)return await (0,p.I)(R,S,d,Q.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);j&&(b[s.NEXT_CACHE_TAGS_HEADER]=j),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==Q.renderOpts.collectedRevalidate&&!(Q.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&Q.renderOpts.collectedRevalidate,e=void 0===Q.renderOpts.collectedExpire||Q.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:Q.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await I.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:B})},!1,A),b}},l=await I.handleResponse({req:a,nextConfig:w,cacheKey:K,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:z,isRoutePPREnabled:!1,isOnDemandRevalidate:B,revalidateOnlyGenerated:C,responseGenerator:k,waitUntil:c.waitUntil,isMinimalMode:g});if(!H)return null;if((null==l||null==(i=l.value)?void 0:i.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==l||null==(j=l.value)?void 0:j.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});g||b.setHeader("x-nextjs-cache",B?"REVALIDATED":l.isMiss?"MISS":l.isStale?"STALE":"HIT"),y&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let m=(0,q.fromNodeOutgoingHttpHeaders)(l.value.headers);return g&&H||m.delete(s.NEXT_CACHE_TAGS_HEADER),!l.cacheControl||b.getHeader("Cache-Control")||m.get("Cache-Control")||m.set("Cache-Control",(0,r.getCacheControlHeader)(l.cacheControl)),await (0,p.I)(R,S,new Response(l.value.body,{headers:m,status:l.value.status||200})),null};P?await j(P):await O.withPropagatedContext(a.headers,()=>O.trace(n.BaseServerSpan.handleRequest,{spanName:`${N} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":N,"http.target":a.url}},j))}catch(b){if(b instanceof t.NoFallbackError||await I.onRequestError(a,b,{routerKind:"App Router",routePath:G,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:B})},!1,A),H)throw b;return await (0,p.I)(R,S,new Response(null,{status:500})),null}}},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},73136:a=>{a.exports=require("node:url")},76760:a=>{a.exports=require("node:path")},77598:a=>{a.exports=require("node:crypto")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")}};var b=require("../../../webpack-runtime.js");b.C(a);var c=b.X(0,[741,229],()=>b(b.s=53551));module.exports=c})();
|
|
1
|
+
"use strict";(()=>{var a={};a.id=851,a.ids=[851],a.modules={261:a=>{a.exports=require("next/dist/shared/lib/router/utils/app-paths")},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},21820:a=>{a.exports=require("os")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},46193:a=>{a.exports=require("node:string_decoder")},48161:a=>{a.exports=require("node:os")},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},73136:a=>{a.exports=require("node:url")},76760:a=>{a.exports=require("node:path")},77598:a=>{a.exports=require("node:crypto")},84309:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>N,patchFetch:()=>M,routeModule:()=>I,serverHooks:()=>L,workAsyncStorage:()=>J,workUnitAsyncStorage:()=>K});var d={};c.r(d),c.d(d,{GET:()=>H,dynamic:()=>G,runtime:()=>F});var e=c(19225),f=c(84006),g=c(8317),h=c(99373),i=c(34775),j=c(24235),k=c(261),l=c(54365),m=c(90771),n=c(73461),o=c(67798),p=c(92280),q=c(62018),r=c(45696),s=c(47929),t=c(86439),u=c(37527),v=c(31421),w=c(73024),x=c(76760),y=c(73136),z=c(74900);function A(a){return(a instanceof Error?a.message:String(a??"")).replace(/sk-[A-Za-z0-9_-]{6,}/g,"[redacted]").replace(/xox[baprs]-[A-Za-z0-9-]+/g,"[redacted]").replace(/Bearer\s+[^\s]+/gi,"Bearer [redacted]").replace(/([A-Z0-9_]*(?:API[_-]?KEY|TOKEN|SECRET)["'=:\s]+)([^\s,;"']+)/gi,"$1[redacted]").replace(/\s+/g," ").trim()}function B(a){return a?.active.milestoneId?a.active.taskId&&a.active.sliceId?`${a.active.milestoneId}/${a.active.sliceId}/${a.active.taskId}`:a.active.sliceId?`${a.active.milestoneId}/${a.active.sliceId}`:a.active.milestoneId:null}function C(a){return{code:a.code,severity:a.severity,scope:a.scope,message:A(a.message),file:a.file,suggestion:a.suggestion?A(a.suggestion):void 0,unitId:a.unitId}}async function D(a,b,c,d,e,f){let g=f.env??process.env,h=f.existsSync??w.existsSync,i=(0,x.join)(a,"src","resources","extensions","gsd","tests","resolve-ts.mjs"),j=(0,x.join)(a,"src","resources","extensions","gsd","doctor.ts"),k=(0,x.join)(a,"src","resources","extensions","gsd","session-forensics.ts");if(!h(i)||!h(j)||!h(k))throw Error(`recovery diagnostics providers not found; checked=${i},${j},${k}`);return await new Promise((h,l)=>{(0,v.execFile)(f.execPath??process.execPath,["--import",(0,y.pathToFileURL)(i).href,"--experimental-strip-types","--input-type=module","--eval",'const { pathToFileURL } = await import("node:url"); const doctor = await import(pathToFileURL(process.env.GSD_RECOVERY_DOCTOR_MODULE).href); const forensics = await import(pathToFileURL(process.env.GSD_RECOVERY_FORENSICS_MODULE).href); const basePath = process.env.GSD_RECOVERY_BASE; const scope = process.env.GSD_RECOVERY_SCOPE || undefined; const unitType = process.env.GSD_RECOVERY_UNIT_TYPE || "execute-project"; const unitId = process.env.GSD_RECOVERY_UNIT_ID || "project"; const sessionFile = process.env.GSD_RECOVERY_SESSION_FILE || undefined; const activityDir = process.env.GSD_RECOVERY_ACTIVITY_DIR || undefined; const report = await doctor.runGSDDoctor(basePath, { fix: false, scope, fixLevel: "task" }); const summary = doctor.summarizeDoctorIssues(report.issues); const briefing = forensics.synthesizeCrashRecovery(basePath, unitType, unitId, sessionFile, activityDir); const trace = briefing?.trace; const available = Boolean(sessionFile || trace?.toolCallCount || briefing?.gitChanges); const detected = Boolean((trace?.toolCallCount ?? 0) > 0 || (trace?.errors?.length ?? 0) > 0 || (trace?.commandsRun?.length ?? 0) > 0 || (trace?.filesWritten?.length ?? 0) > 0 || briefing?.gitChanges); const interruptedRun = available ? detected ? { available: true, detected: true, label: "Interrupted-run recovery available", detail: "Recent session forensics captured unfinished work or errors that may need resume or retry follow-up.", unit: { type: briefing?.unitType ?? unitType, id: briefing?.unitId ?? unitId }, counts: { toolCalls: trace?.toolCallCount ?? 0, filesWritten: trace?.filesWritten?.length ?? 0, commandsRun: trace?.commandsRun?.length ?? 0, errors: trace?.errors?.length ?? 0, }, gitChangesDetected: Boolean(briefing?.gitChanges), lastError: trace?.errors?.at(-1) ?? null, } : { available: true, detected: false, label: "Session forensics available", detail: "A current-project session was inspected, but it did not show unfinished tool or error activity.", unit: { type: briefing?.unitType ?? unitType, id: briefing?.unitId ?? unitId }, counts: { toolCalls: trace?.toolCallCount ?? 0, filesWritten: trace?.filesWritten?.length ?? 0, commandsRun: trace?.commandsRun?.length ?? 0, errors: trace?.errors?.length ?? 0, }, gitChangesDetected: Boolean(briefing?.gitChanges), lastError: trace?.errors?.at(-1) ?? null, } : { available: false, detected: false, label: "No interrupted-run evidence", detail: "No current-project session or activity log is available for interrupted-run forensics yet.", unit: null, counts: { toolCalls: 0, filesWritten: 0, commandsRun: 0, errors: 0 }, gitChangesDetected: false, lastError: null, }; process.stdout.write(JSON.stringify({ doctor: { scope: scope ?? null, total: summary.total, errors: summary.errors, warnings: summary.warnings, infos: summary.infos, fixable: summary.fixable, codes: summary.byCode, topIssues: report.issues.slice(0, 6).map((issue) => ({ code: issue.code, severity: issue.severity, scope: issue.scope, message: issue.message, file: issue.file, unitId: issue.unitId, })), }, interruptedRun, }));'],{cwd:a,env:{...g,GSD_RECOVERY_BASE:b,GSD_RECOVERY_SCOPE:c??"",GSD_RECOVERY_UNIT_TYPE:d?.type??"execute-project",GSD_RECOVERY_UNIT_ID:d?.id??"project",GSD_RECOVERY_SESSION_FILE:e??"",GSD_RECOVERY_ACTIVITY_DIR:(0,x.join)(b,".gsd","activity"),GSD_RECOVERY_DOCTOR_MODULE:j,GSD_RECOVERY_FORENSICS_MODULE:k},maxBuffer:1048576},(a,b,c)=>{if(a)return void l(Error(`recovery diagnostics subprocess failed: ${c||a.message}`));try{h(JSON.parse(b))}catch(a){l(Error(`recovery diagnostics subprocess returned invalid JSON: ${a instanceof Error?a.message:String(a)}`))}})})}async function E(a={},b){var c,d,e,f;let g,h,i,j,k;a.env??process.env;let l=(0,z.eG)(a.env,b),[{bridge:m,workspace:n,resumableSessions:o},p]=await Promise.all([(0,z.yd)(["workspace","resumable_sessions"],b),(0,z.tL)(b)]),q=o??[],r=B(n),s=(g=B(n))?n?.active.taskId?{type:"execute-task",id:g}:n?.active.sliceId?{type:"execute-slice",id:g}:{type:"execute-milestone",id:g}:null,t=function(a,b){if(!a)return b[0]?.path??null;let c=(0,x.resolve)(a),d=b.find(a=>(0,x.resolve)(a.path)===c);return d?d.path:b[0]?.path??a}(m.activeSessionFile,q),u=function(a,b,c){if(!b)return a??null;let d=(0,x.resolve)(b);return c.find(a=>(0,x.resolve)(a.path)===d)?.id??a??null}(m.activeSessionId,t,q),v=await D(l.packageRoot,l.projectCwd,r,s,t,a),w=(n?.validationIssues??[]).map(a=>({code:a.ruleId??"unknown_validation_issue",severity:a.severity??"warning",scope:a.scope??"workspace",message:A(a.message??"Validation issue"),file:a.file,suggestion:a.suggestion?A(a.suggestion):void 0})),y=w.reduce((a,b)=>({errors:a.errors+Number("error"===b.severity),warnings:a.warnings+Number("warning"===b.severity),infos:a.infos+Number("info"===b.severity)}),{errors:0,warnings:0,infos:0}),F=function(a){let b=new Map,c={info:0,warning:1,error:2};for(let d of a){let a=b.get(d.code);if(!a){b.set(d.code,{count:1,severity:d.severity});continue}b.set(d.code,{count:a.count+1,severity:c[d.severity]>c[a.severity]?d.severity:a.severity})}return[...b.entries()].map(([a,b])=>({code:a,count:b.count,label:a.replace(/[_-]+/g," ").replace(/\b\w/g,a=>a.toUpperCase()),severity:b.severity})).sort((a,b)=>b.count-a.count||a.code.localeCompare(b.code))}(w),G=v.doctor.topIssues.map(C),H={...v.interruptedRun,label:A(v.interruptedRun.label),detail:A(v.interruptedRun.detail),lastError:v.interruptedRun.lastError?A(v.interruptedRun.lastError):null},I=m.lastError?{message:A(m.lastError.message),phase:m.lastError.phase,at:m.lastError.at,commandType:m.lastError.commandType??null,afterSessionAttachment:m.lastError.afterSessionAttachment}:null,J=p.bridgeAuthRefresh.phase,K=p.bridgeAuthRefresh.error?A(p.bridgeAuthRefresh.error):null,L=I||"failed"===J||w.length>0||v.doctor.total>0||H.available||q.length>0||m.sessionState?.retryInProgress||m.sessionState?.isCompacting?"ready":"unavailable",M=s?.id??r,N=(c={status:L,validationCount:w.length,validationErrors:y.errors,doctorTotal:v.doctor.total,doctorErrors:v.doctor.errors,retryAttempt:m.sessionState?.retryAttempt??0,retryInProgress:!!m.sessionState?.retryInProgress,compactionActive:!!m.sessionState?.isCompacting,currentUnitId:M??null,lastFailurePhase:"failed"===J?"bridge_auth_refresh":I?.phase??null,bridgeFailureMessage:I?.message??null,authFailureMessage:"failed"===J?K:null,interruptedRunDetected:H.detected,interruptedRunDetail:H.detail}).authFailureMessage?{tone:"danger",label:"Bridge auth refresh failed",detail:c.authFailureMessage}:c.bridgeFailureMessage?{tone:"danger",label:c.lastFailurePhase?`Bridge recovery failed during ${c.lastFailurePhase}`:"Bridge recovery failed",detail:c.bridgeFailureMessage}:c.doctorErrors>0||c.validationErrors>0?{tone:"danger",label:`Recovery blockers detected (${c.doctorErrors+c.validationErrors})`,detail:`Doctor and validation surfaced blocking issues for ${c.currentUnitId??"the current project"}.`}:c.retryInProgress?{tone:"warning",label:`Retry attempt ${Math.max(1,c.retryAttempt)} is active`,detail:"The bridge is retrying work right now; inspect retry controls before issuing more recovery actions."}:c.compactionActive?{tone:"warning",label:"Compaction is active",detail:"The live session is compacting context before work continues."}:c.validationCount>0||c.doctorTotal>0?{tone:"warning",label:`Recovery diagnostics found ${c.validationCount+c.doctorTotal} actionable issue${c.validationCount+c.doctorTotal===1?"":"s"}`,detail:`Review the doctor and validation sections below before resuming work on ${c.currentUnitId??"the current project"}.`}:c.interruptedRunDetected?{tone:"warning",label:"Interrupted-run evidence is available",detail:c.interruptedRunDetail}:"unavailable"===c.status?{tone:"healthy",label:"Recovery diagnostics unavailable",detail:"No current-project recovery evidence has been captured yet. Start or resume a session to populate diagnostics."}:{tone:"healthy",label:"Recovery diagnostics healthy",detail:"No bridge, validation, doctor, or interrupted-run recovery issues are currently active."};return{status:L,loadedAt:new Date().toISOString(),project:{cwd:l.projectCwd,activeScope:r,activeSessionPath:t,activeSessionId:u},summary:{tone:N.tone,label:N.label,detail:N.detail,validationCount:w.length,doctorIssueCount:v.doctor.total,lastFailurePhase:"failed"===J?"bridge_auth_refresh":I?.phase??null,currentUnitId:M??null,retryAttempt:m.sessionState?.retryAttempt??0,retryInProgress:!!m.sessionState?.retryInProgress,compactionActive:!!m.sessionState?.isCompacting},bridge:{phase:m.phase,retry:{enabled:!!m.sessionState?.autoRetryEnabled,inProgress:!!m.sessionState?.retryInProgress,attempt:m.sessionState?.retryAttempt??0,label:m.sessionState?.retryInProgress?`Attempt ${Math.max(1,m.sessionState?.retryAttempt??0)}`:m.sessionState?.autoRetryEnabled?"Enabled":"Disabled"},compaction:{active:!!m.sessionState?.isCompacting,label:m.sessionState?.isCompacting?"Compaction active":"Compaction idle"},lastFailure:I,authRefresh:{phase:J,error:K,label:"failed"===J?"Bridge auth refresh failed":"pending"===J?"Bridge auth refresh pending":"succeeded"===J?"Bridge auth refresh succeeded":"Bridge auth refresh idle"}},validation:{total:w.length,bySeverity:y,codes:F,topIssues:w.slice(0,6)},doctor:{scope:v.doctor.scope,total:v.doctor.total,errors:v.doctor.errors,warnings:v.doctor.warnings,infos:v.doctor.infos,fixable:v.doctor.fixable,codes:v.doctor.codes,topIssues:G},interruptedRun:H,actions:{browser:(d={hasSessions:q.length>0,retryActive:!!m.sessionState?.retryInProgress,autoRetryEnabled:!!m.sessionState?.autoRetryEnabled,bridgeFailure:!!I,compactionActive:!!m.sessionState?.isCompacting,authAttentionNeeded:p.locked||"failed"===J||p.lastValidation?.status==="failed"},h=new Map,(i=a=>{h.set(a.id,a)})({id:"refresh_diagnostics",label:"Refresh diagnostics",detail:"Reload the on-demand recovery route without refreshing the entire workspace.",emphasis:"primary"}),i({id:"refresh_workspace",label:"Refresh workspace",detail:"Run one soft workspace refresh so the browser re-syncs boot, bridge, and onboarding state."}),(d.retryActive||d.autoRetryEnabled||d.bridgeFailure||d.compactionActive)&&i({id:"open_retry_controls",label:"Open retry controls",detail:"Inspect or change live retry and compaction controls on the authoritative browser surface."}),d.hasSessions&&i({id:"open_resume_controls",label:"Open resume controls",detail:"Switch to another current-project session if recovery should continue elsewhere."}),d.authAttentionNeeded&&i({id:"open_auth_controls",label:"Open auth controls",detail:"Inspect provider setup and bridge auth refresh failures from the shared browser surface.",emphasis:"danger"}),[...h.values()]),commands:(e=n?.active.phase,f=w.length,j=new Map,k=(a,b)=>{j.has(a)||j.set(a,{command:a,label:b})},"planning"===e&&k("/gsd","Open GSD planning"),("executing"===e||"summarizing"===e)&&k("/gsd auto","Resume GSD auto mode"),r&&k(`/gsd doctor ${r}`,"Inspect scoped doctor report"),r&&k(`/gsd doctor fix ${r}`,"Apply scoped doctor fixes"),f>0&&r&&k(`/gsd doctor audit ${r}`,"Audit validation diagnostics"),k("/gsd status","Check current-project status"),[...j.values()])}}}let F="nodejs",G="force-dynamic";async function H(a){try{let b=(0,z.jL)(a),c=await E(void 0,b);return Response.json(c,{headers:{"Cache-Control":"no-store"}})}catch(b){let a=b instanceof Error?b.message:String(b);return Response.json({error:a},{status:500,headers:{"Cache-Control":"no-store"}})}}let I=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/recovery/route",pathname:"/api/recovery",filename:"route",bundlePath:"app/api/recovery/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"/home/runner/work/gsd-2/gsd-2/web/app/api/recovery/route.ts",nextConfigOutput:"standalone",userland:d}),{workAsyncStorage:J,workUnitAsyncStorage:K,serverHooks:L}=I;function M(){return(0,g.patchFetch)({workAsyncStorage:J,workUnitAsyncStorage:K})}async function N(a,b,c){I.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/recovery/route";"/index"===d&&(d="/");let e=await I.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,params:v,nextConfig:w,parsedUrl:x,isDraftMode:y,prerenderManifest:z,routerServerContext:A,isOnDemandRevalidate:B,revalidateOnlyGenerated:C,resolvedPathname:D,clientReferenceManifest:E,serverActionsManifest:F}=e,G=(0,k.normalizeAppPath)(d),H=!!(z.dynamicRoutes[G]||z.routes[D]),J=async()=>((null==A?void 0:A.render404)?await A.render404(a,b,x,!1):b.end("This page could not be found"),null);if(H&&!y){let a=!!z.routes[D],b=z.dynamicRoutes[G];if(b&&!1===b.fallback&&!a){if(w.experimental.adapterPath)return await J();throw new t.NoFallbackError}}let K=null;!H||I.isDev||y||(K="/index"===(K=D)?"/":K);let L=!0===I.isDev||!H,M=H&&!L;F&&E&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:E,serverActionsManifest:F});let N=a.method||"GET",O=(0,i.getTracer)(),P=O.getActiveScopeSpan(),Q={params:v,prerenderManifest:z,renderOpts:{experimental:{authInterrupts:!!w.experimental.authInterrupts},cacheComponents:!!w.cacheComponents,supportsDynamicResponse:L,incrementalCache:(0,h.getRequestMeta)(a,"incrementalCache"),cacheLifeProfiles:w.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>I.onRequestError(a,b,d,e,A)},sharedContext:{buildId:g}},R=new l.NodeNextRequest(a),S=new l.NodeNextResponse(b),T=m.NextRequestAdapter.fromNodeNextRequest(R,(0,m.signalFromNodeResponse)(b));try{let e=async a=>I.handle(T,Q).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=O.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let e=c.get("next.route");if(e){let b=`${N} ${e}`;a.setAttributes({"next.route":e,"http.route":e,"next.span_name":b}),a.updateName(b)}else a.updateName(`${N} ${d}`)}),g=!!(0,h.getRequestMeta)(a,"minimalMode"),j=async h=>{var i,j;let k=async({previousCacheEntry:f})=>{try{if(!g&&B&&C&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await e(h);a.fetchMetrics=Q.renderOpts.fetchMetrics;let i=Q.renderOpts.pendingWaitUntil;i&&c.waitUntil&&(c.waitUntil(i),i=void 0);let j=Q.renderOpts.collectedTags;if(!H)return await (0,p.I)(R,S,d,Q.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);j&&(b[s.NEXT_CACHE_TAGS_HEADER]=j),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==Q.renderOpts.collectedRevalidate&&!(Q.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&Q.renderOpts.collectedRevalidate,e=void 0===Q.renderOpts.collectedExpire||Q.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:Q.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await I.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:B})},!1,A),b}},l=await I.handleResponse({req:a,nextConfig:w,cacheKey:K,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:z,isRoutePPREnabled:!1,isOnDemandRevalidate:B,revalidateOnlyGenerated:C,responseGenerator:k,waitUntil:c.waitUntil,isMinimalMode:g});if(!H)return null;if((null==l||null==(i=l.value)?void 0:i.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==l||null==(j=l.value)?void 0:j.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});g||b.setHeader("x-nextjs-cache",B?"REVALIDATED":l.isMiss?"MISS":l.isStale?"STALE":"HIT"),y&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let m=(0,q.fromNodeOutgoingHttpHeaders)(l.value.headers);return g&&H||m.delete(s.NEXT_CACHE_TAGS_HEADER),!l.cacheControl||b.getHeader("Cache-Control")||m.get("Cache-Control")||m.set("Cache-Control",(0,r.getCacheControlHeader)(l.cacheControl)),await (0,p.I)(R,S,new Response(l.value.body,{headers:m,status:l.value.status||200})),null};P?await j(P):await O.withPropagatedContext(a.headers,()=>O.trace(n.BaseServerSpan.handleRequest,{spanName:`${N} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":N,"http.target":a.url}},j))}catch(b){if(b instanceof t.NoFallbackError||await I.onRequestError(a,b,{routerKind:"App Router",routePath:G,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:B})},!1,A),H)throw b;return await (0,p.I)(R,S,new Response(null,{status:500})),null}}},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")}};var b=require("../../../webpack-runtime.js");b.C(a);var c=b.X(0,[741,229],()=>b(b.s=84309));module.exports=c})();
|
package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
globalThis.__RSC_MANIFEST=(globalThis.__RSC_MANIFEST||{});globalThis.__RSC_MANIFEST["/api/recovery/route"]={"moduleLoading":{"prefix":"/_next/"},"ssrModuleMapping":{"21942":{"*":{"id":"18550","name":"*","chunks":[],"async":false}},"27123":{"*":{"id":"81921","name":"*","chunks":[],"async":false}},"57121":{"*":{"id":"35421","name":"*","chunks":[],"async":false}},"61304":{"*":{"id":"60440","name":"*","chunks":[],"async":false}},"61549":{"*":{"id":"99703","name":"*","chunks":[],"async":false}},"64777":{"*":{"id":"82265","name":"*","chunks":[],"async":false}},"66919":{"*":{"id":"65720","name":"*","chunks":[],"async":false}},"74581":{"*":{"id":"61335","name":"*","chunks":[],"async":false}},"78616":{"*":{"id":"84342","name":"*","chunks":[],"async":false}},"86869":{"*":{"id":"74661","name":"*","chunks":[],"async":false}},"90484":{"*":{"id":"70664","name":"*","chunks":[],"async":false}}},"edgeSSRModuleMapping":{},"clientModules":{"/
|
|
1
|
+
globalThis.__RSC_MANIFEST=(globalThis.__RSC_MANIFEST||{});globalThis.__RSC_MANIFEST["/api/recovery/route"]={"moduleLoading":{"prefix":"/_next/"},"ssrModuleMapping":{"21942":{"*":{"id":"18550","name":"*","chunks":[],"async":false}},"27123":{"*":{"id":"81921","name":"*","chunks":[],"async":false}},"57121":{"*":{"id":"35421","name":"*","chunks":[],"async":false}},"61304":{"*":{"id":"60440","name":"*","chunks":[],"async":false}},"61549":{"*":{"id":"99703","name":"*","chunks":[],"async":false}},"64777":{"*":{"id":"82265","name":"*","chunks":[],"async":false}},"66919":{"*":{"id":"65720","name":"*","chunks":[],"async":false}},"74581":{"*":{"id":"61335","name":"*","chunks":[],"async":false}},"78616":{"*":{"id":"84342","name":"*","chunks":[],"async":false}},"86869":{"*":{"id":"74661","name":"*","chunks":[],"async":false}},"90484":{"*":{"id":"70664","name":"*","chunks":[],"async":false}}},"edgeSSRModuleMapping":{},"clientModules":{"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/client/components/builtin/global-error.js":{"id":27123,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/client/components/builtin/global-error.js":{"id":27123,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/client/components/client-page.js":{"id":61304,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/client/components/client-page.js":{"id":61304,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/client/components/client-segment.js":{"id":78616,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/client/components/client-segment.js":{"id":78616,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/client/components/http-access-fallback/error-boundary.js":{"id":64777,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/client/components/http-access-fallback/error-boundary.js":{"id":64777,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/client/components/layout-router.js":{"id":57121,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/client/components/layout-router.js":{"id":57121,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/client/components/render-from-template-context.js":{"id":74581,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/client/components/render-from-template-context.js":{"id":74581,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/lib/framework/boundary-components.js":{"id":90484,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/lib/framework/boundary-components.js":{"id":90484,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/lib/metadata/generate/icon-mark.js":{"id":86869,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/dist/esm/lib/metadata/generate/icon-mark.js":{"id":86869,"name":"*","chunks":[],"async":false},"/home/runner/work/gsd-2/gsd-2/web/components/theme-provider.tsx":{"id":21942,"name":"*","chunks":["4986","static/chunks/4986-c2fc8845ce785303.js","7177","static/chunks/app/layout-745c6ed5fea5fb06.js"],"async":false},"/home/runner/work/gsd-2/gsd-2/web/components/ui/sonner.tsx":{"id":61549,"name":"*","chunks":["4986","static/chunks/4986-c2fc8845ce785303.js","7177","static/chunks/app/layout-745c6ed5fea5fb06.js"],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/font/google/target.css?{\"path\":\"app/layout.tsx\",\"import\":\"Geist\",\"arguments\":[{\"subsets\":[\"latin\"],\"variable\":\"--font-geist-sans\"}],\"variableName\":\"geistSans\"}":{"id":85048,"name":"*","chunks":["4986","static/chunks/4986-c2fc8845ce785303.js","7177","static/chunks/app/layout-745c6ed5fea5fb06.js"],"async":false},"/home/runner/work/gsd-2/gsd-2/web/node_modules/next/font/google/target.css?{\"path\":\"app/layout.tsx\",\"import\":\"Geist_Mono\",\"arguments\":[{\"subsets\":[\"latin\"],\"variable\":\"--font-geist-mono\"}],\"variableName\":\"geistMono\"}":{"id":35696,"name":"*","chunks":["4986","static/chunks/4986-c2fc8845ce785303.js","7177","static/chunks/app/layout-745c6ed5fea5fb06.js"],"async":false},"/home/runner/work/gsd-2/gsd-2/web/app/globals.css":{"id":66872,"name":"*","chunks":["4986","static/chunks/4986-c2fc8845ce785303.js","7177","static/chunks/app/layout-745c6ed5fea5fb06.js"],"async":false},"/home/runner/work/gsd-2/gsd-2/web/app/page.tsx":{"id":66919,"name":"*","chunks":["8974","static/chunks/app/page-801b53eff6e83579.js"],"async":false}},"entryCSSFiles":{"/home/runner/work/gsd-2/gsd-2/web/":[],"/home/runner/work/gsd-2/gsd-2/web/app/layout":[{"inlined":false,"path":"static/css/de70bee13400563f.css"},{"inlined":false,"path":"static/css/123c0bb039697968.css"}],"/home/runner/work/gsd-2/gsd-2/web/app/page":[],"/home/runner/work/gsd-2/gsd-2/web/app/api/recovery/route":[]},"rscModuleMapping":{"21942":{"*":{"id":"9796","name":"*","chunks":[],"async":false}},"27123":{"*":{"id":"95547","name":"*","chunks":[],"async":false}},"57121":{"*":{"id":"98099","name":"*","chunks":[],"async":false}},"61304":{"*":{"id":"15098","name":"*","chunks":[],"async":false}},"61549":{"*":{"id":"85561","name":"*","chunks":[],"async":false}},"64777":{"*":{"id":"33859","name":"*","chunks":[],"async":false}},"66872":{"*":{"id":"82704","name":"*","chunks":[],"async":false}},"66919":{"*":{"id":"99647","name":"*","chunks":[],"async":false}},"74581":{"*":{"id":"16237","name":"*","chunks":[],"async":false}},"78616":{"*":{"id":"47644","name":"*","chunks":[],"async":false}},"86869":{"*":{"id":"36675","name":"*","chunks":[],"async":false}},"90484":{"*":{"id":"98562","name":"*","chunks":[],"async":false}}},"edgeRscModuleMapping":{}}
|