@slycode/slycode 0.2.3 → 0.2.4
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/bridge/api.js +1 -1
- package/dist/bridge/api.js.map +1 -1
- package/dist/bridge/session-manager.js +54 -14
- package/dist/bridge/session-manager.js.map +1 -1
- package/dist/bridge/types.d.ts +6 -0
- package/dist/web/.next/BUILD_ID +1 -1
- package/dist/web/.next/build-manifest.json +2 -2
- package/dist/web/.next/server/app/_global-error.html +2 -2
- package/dist/web/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.html +1 -1
- package/dist/web/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/.next/server/app/api/bridge/[...path]/route.js +1 -1
- package/dist/web/.next/server/app/api/bridge/[...path]/route.js.nft.json +1 -1
- package/dist/web/.next/server/app/api/kanban/route.js +4 -4
- package/dist/web/.next/server/app/api/kanban/route.js.nft.json +1 -1
- package/dist/web/.next/server/app/api/kanban/stream/route.js +1 -1
- package/dist/web/.next/server/app/api/kanban/stream/route.js.nft.json +1 -1
- package/dist/web/.next/server/app/api/scheduler/route.js +1 -1
- package/dist/web/.next/server/app/api/scheduler/route.js.nft.json +1 -1
- package/dist/web/.next/server/app/api/sly-actions/stream/route.js +1 -1
- package/dist/web/.next/server/app/api/sly-actions/stream/route.js.nft.json +1 -1
- package/dist/web/.next/server/chunks/{[externals]__3d917172._.js → [externals]__65615fd8._.js} +2 -2
- package/dist/web/.next/server/chunks/[root-of-the-server]__09aec55a._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__198f01e0._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__2b639eab._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__3b9d3e43._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__3f239285._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__46b023d4._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__4c7995bf._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__4d0d3464._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__6d330d40._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__6ffce934._.js +3 -0
- package/dist/web/.next/server/chunks/[root-of-the-server]__884d73e4._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__8ab096a3._.js +3 -0
- package/dist/web/.next/server/chunks/[root-of-the-server]__9058a007._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__933e6077._.js +2 -2
- package/dist/web/.next/server/chunks/[root-of-the-server]__949bb248._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__aa814a86._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__ad64e04f._.js +2 -2
- package/dist/web/.next/server/chunks/[root-of-the-server]__b90bbd70._.js +1 -1
- package/dist/web/.next/server/chunks/{[root-of-the-server]__4244617a._.js → [root-of-the-server]__b9e7d34c._.js} +4 -4
- package/dist/web/.next/server/chunks/[root-of-the-server]__baa99257._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__bbb4b3ac._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__bc55c42a._.js +2 -2
- package/dist/web/.next/server/chunks/[root-of-the-server]__bf286c26._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__d219e3f0._.js +18 -0
- package/dist/web/.next/server/chunks/[root-of-the-server]__d38c7a96._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__e88a19d2._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__e9b0e744._.js +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__f1fe18e6._.js +2 -2
- package/dist/web/.next/server/chunks/[root-of-the-server]__f4124388._.js +3 -0
- package/dist/web/.next/server/chunks/[root-of-the-server]__f59af2bc._.js +1 -1
- package/dist/web/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_ffc6c790.js +4 -4
- package/dist/web/.next/server/chunks/src_677020aa._.js +1 -1
- package/dist/web/.next/server/chunks/src_lib_scheduler_ts_03988e3e._.js +1 -1
- package/dist/web/.next/server/chunks/src_lib_scheduler_ts_7120457c._.js +1 -1
- package/dist/web/.next/server/chunks/ssr/src_lib_registry_ts_2fc87c9c._.js +1 -1
- package/dist/web/.next/server/pages/404.html +1 -1
- package/dist/web/.next/server/pages/500.html +2 -2
- package/dist/web/src/app/api/bridge/[...path]/route.ts +3 -1
- package/dist/web/src/app/api/dashboard/route.ts +2 -1
- package/dist/web/src/app/api/search/route.ts +2 -1
- package/dist/web/src/app/api/transcribe/route.ts +6 -1
- package/dist/web/src/lib/paths.ts +21 -0
- package/dist/web/src/lib/registry.ts +2 -1
- package/dist/web/src/lib/scheduler.ts +130 -30
- package/dist/web/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/templates/kanban-seed.json +1 -1
- package/dist/web/.next/server/chunks/[root-of-the-server]__289ec56e._.js +0 -3
- package/dist/web/.next/server/chunks/[root-of-the-server]__543058c2._.js +0 -18
- package/dist/web/.next/server/chunks/[root-of-the-server]__949d814c._.js +0 -3
- package/dist/web/.next/server/chunks/[root-of-the-server]__ce429522._.js +0 -3
- /package/dist/web/.next/static/{awhR2yoOiaXMMqO3AHnAQ → sQ8knGS1B967Ng9HqMKOG}/_buildManifest.js +0 -0
- /package/dist/web/.next/static/{awhR2yoOiaXMMqO3AHnAQ → sQ8knGS1B967Ng9HqMKOG}/_clientMiddlewareManifest.json +0 -0
- /package/dist/web/.next/static/{awhR2yoOiaXMMqO3AHnAQ → sQ8knGS1B967Ng9HqMKOG}/_ssgManifest.js +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function n(){let e=a(),n=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(n)?n:e}e.s(["getPackageDir",()=>n,"getSlycodeRoot",()=>a])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),a=e.i(46676),n=e.i(7367);function s(){return r.default.join((0,n.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,n.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,n.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),a={};Function("module","exports",r)(a,a);let n=a.exports;if(n?.skills)return{skills:n.skills,actions:n.actions||[],agents:n.agents||[],mcp:n.mcp||[]}}}catch{}return null}function o(e,n){let s=[],i="skill"===n?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return s;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===n){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,a.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:n,path:d,frontmatter:c,isValid:(0,a.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),a=i(),n=o(e,"skill"),l=o(e,"agent"),d=function(e){let a=r.default.join(e,"mcp"),n=[];try{if(!t.default.existsSync(a))return n;for(let e of t.default.readdirSync(a,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(a,e.name),o=t.default.readFileSync(i,"utf-8");try{s=JSON.parse(o)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");n.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return n}(e);if(a){if(a.skills){let e=new Set(a.skills);n=n.filter(t=>e.has(t.name))}if(a.agents){let e=new Set(a.agents);l=l.filter(t=>e.has(t.name))}if(a.mcp){let e=new Set(a.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:n,agents:l,mcp:d}}function d(){let e=s(),t=i(),r=o(e,"skill"),a=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);a=a.filter(t=>e.has(t.name))}}return[...r,...a]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),a=e.i(14747),n=e.i(46676),s=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,a=0,n=i){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:n.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);s.push({name:"Stale Cards",weight:n.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:n.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:n.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:n.nonCompliantFrontmatter,value:a,maxValue:f});let m=0;for(let e of s)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:s}}function l(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?a.default.dirname(e):e}let d=l(),u=a.default.join(d,"projects","registry.json");async function c(){try{let e=await t.promises.readFile(u,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${u}`)}}async function p(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(u,r,"utf-8")}async function f(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function m(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function h(e,t,r){let n=a.default.join(e,"documentation","backlog.json"),s=await m(n);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function g(e,t){let r=a.default.join(e,"documentation","designs.json"),n=await m(r);return n?n.map(e=>({...e,projectId:t})):[]}async function x(e,t){let r=a.default.join(e,"documentation","features.json"),n=await m(r);return n?n.map(e=>({...e,projectId:t})):[]}async function y(e){let t=e.path;if(!await f(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[a,s,i]=await Promise.all([h(t,e.id,e.name),g(t,e.id),x(t,e.id)]),o=(0,n.scanProjectAssets)(t,e.id),l=(0,n.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:a,designs:s,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function v(){let e=await c();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>y(e)),r=await Promise.all(t),i=(0,s.getStoreAssets)(),d=["skill","agent"],u=0,p=[];for(let t of["claude","agents"])for(let r of d){let a=i.filter(e=>e.type===r),s=new Map;for(let a of e.projects){let e=(0,n.scanProviderAssets)(a.path,t);s.set(a.id,e.filter(e=>e.type===r))}let o=(0,n.buildStoreAssetMatrix)(a,s,e.projects,r);p.push(...o)}for(let e of p)for(let t of e.cells)"outdated"===t.status&&u++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of p)for(let a of r.cells)a.projectId===e.id&&"outdated"===a.status&&t++;e.healthScore=function(e,t,r=0,a){if(!t)return o(e,0,0,0,void 0);let n=[...t.skills,...t.agents];return o(e,r,n.length,n.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let f=0,h=0;for(let e of r){if(!e.accessible)continue;let t=a.default.join(e.path,"documentation","kanban.json"),r=await m(t);if(r?.stages){f+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);h+=e.length+t.length}}let g=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),x=process.env.BRIDGE_URL||"http://127.0.0.1:7592";try{let e=await fetch(`${x}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),a={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];a[t]=(a[t]||0)+1}for(let e of r)e.activeSessions=a[e.id]??0}}catch{}let v=l();return{projects:r,totalBacklogItems:f,activeItems:h,totalOutdatedAssets:u,totalUncommitted:g,lastRefresh:new Date().toISOString(),slycodeRoot:v,projectsDir:a.default.dirname(v)}}e.s(["getRepoRoot",()=>l,"loadDashboardData",()=>v,"loadRegistry",()=>c,"saveRegistry",()=>p],48044)},70457,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),v=e.i(48044);async function w(e,t){try{let{id:r}=await t.params,a=await e.json(),n=await (0,v.loadRegistry)(),s=n.projects.findIndex(e=>e.id===r);if(-1===s)return y.NextResponse.json({error:`Project '${r}' not found`},{status:404});let i=n.projects[s];return void 0!==a.name&&(i.name=a.name),void 0!==a.description&&(i.description=a.description),void 0!==a.path&&(i.path=a.path),void 0!==a.tags&&(i.tags=a.tags),void 0!==a.areas&&(i.areas=a.areas),void 0!==a.hasClaudeMd&&(i.hasClaudeMd=a.hasClaudeMd),void 0!==a.masterCompliant&&(i.masterCompliant=a.masterCompliant),n.lastUpdated=new Date().toISOString(),await (0,v.saveRegistry)(n),y.NextResponse.json(i)}catch(e){return console.error("Failed to update project:",e),y.NextResponse.json({error:"Failed to update project",details:String(e)},{status:500})}}async function R(e,t){try{let{id:e}=await t.params,r=await (0,v.loadRegistry)(),a=r.projects.findIndex(t=>t.id===e);if(-1===a)return y.NextResponse.json({error:`Project '${e}' not found`},{status:404});let n=r.projects.splice(a,1)[0];return r.lastUpdated=new Date().toISOString(),await (0,v.saveRegistry)(r),y.NextResponse.json({removed:n})}catch(e){return console.error("Failed to delete project:",e),y.NextResponse.json({error:"Failed to delete project",details:String(e)},{status:500})}}e.s(["DELETE",()=>R,"PUT",()=>w,"dynamic",0,"force-dynamic"],54701);var j=e.i(54701);let S=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/projects/[id]/route",pathname:"/api/projects/[id]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/projects/[id]/route.ts",nextConfigOutput:"standalone",userland:j}),{workAsyncStorage:E,workUnitAsyncStorage:C,serverHooks:b}=S;function k(){return(0,a.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:C})}async function A(e,t,a){S.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/projects/[id]/route";y=y.replace(/\/index$/,"")||"/";let v=await S.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:w,params:R,nextConfig:j,parsedUrl:E,isDraftMode:C,prerenderManifest:b,routerServerContext:k,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,resolvedPathname:P,clientReferenceManifest:N,serverActionsManifest:D}=v,M=(0,o.normalizeAppPath)(y),_=!!(b.dynamicRoutes[M]||b.routes[P]),F=async()=>((null==k?void 0:k.render404)?await k.render404(e,t,E,!1):t.end("This page could not be found"),null);if(_&&!C){let e=!!b.routes[P],t=b.dynamicRoutes[M];if(t&&!1===t.fallback&&!e){if(j.experimental.adapterPath)return await F();throw new g.NoFallbackError}}let T=null;!_||S.isDev||C||(T="/index"===(T=P)?"/":T);let U=!0===S.isDev||!_,q=_&&!U;D&&N&&(0,i.setManifestsSingleton)({page:y,clientReferenceManifest:N,serverActionsManifest:D});let I=e.method||"GET",H=(0,s.getTracer)(),L=H.getActiveScopeSpan(),$={params:R,prerenderManifest:b,renderOpts:{experimental:{authInterrupts:!!j.experimental.authInterrupts},cacheComponents:!!j.cacheComponents,supportsDynamicResponse:U,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:j.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>S.onRequestError(e,t,a,n,k)},sharedContext:{buildId:w}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),W=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>S.handle(W,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${I} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${I} ${y}`)}),o=!!(0,n.getRequestMeta)(e,"minimalMode"),l=async n=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&A&&O&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(n);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=$.renderOpts.collectedTags;if(!_)return await (0,p.sendResponse)(V,K,s,$.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await S.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:A})},!1,k),t}},u=await S.handleResponse({req:e,nextConfig:j,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:b,isRoutePPREnabled:!1,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:o});if(!_)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",A?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),C&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&_||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};L?await l(L):await H.withPropagatedContext(e.headers,()=>H.trace(u.BaseServerSpan.handleRequest,{spanName:`${I} ${y}`,kind:s.SpanKind.SERVER,attributes:{"http.method":I,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await S.onRequestError(e,t,{routerKind:"App Router",routePath:M,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:A})},!1,k),_)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>A,"patchFetch",()=>k,"routeModule",()=>S,"serverHooks",()=>b,"workAsyncStorage",()=>E,"workUnitAsyncStorage",()=>C],70457)}];
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function n(){let e=a(),n=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(n)?n:e}function s(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>s,"getPackageDir",()=>n,"getSlycodeRoot",()=>a])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),a=e.i(46676),n=e.i(7367);function s(){return r.default.join((0,n.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,n.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,n.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),a={};Function("module","exports",r)(a,a);let n=a.exports;if(n?.skills)return{skills:n.skills,actions:n.actions||[],agents:n.agents||[],mcp:n.mcp||[]}}}catch{}return null}function o(e,n){let s=[],i="skill"===n?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return s;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===n){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,a.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:n,path:d,frontmatter:c,isValid:(0,a.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),a=i(),n=o(e,"skill"),l=o(e,"agent"),d=function(e){let a=r.default.join(e,"mcp"),n=[];try{if(!t.default.existsSync(a))return n;for(let e of t.default.readdirSync(a,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(a,e.name),o=t.default.readFileSync(i,"utf-8");try{s=JSON.parse(o)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");n.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return n}(e);if(a){if(a.skills){let e=new Set(a.skills);n=n.filter(t=>e.has(t.name))}if(a.agents){let e=new Set(a.agents);l=l.filter(t=>e.has(t.name))}if(a.mcp){let e=new Set(a.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:n,agents:l,mcp:d}}function d(){let e=s(),t=i(),r=o(e,"skill"),a=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);a=a.filter(t=>e.has(t.name))}}return[...r,...a]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),a=e.i(14747),n=e.i(46676),s=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,a=0,n=i){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:n.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);s.push({name:"Stale Cards",weight:n.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:n.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:n.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:n.nonCompliantFrontmatter,value:a,maxValue:f});let m=0;for(let e of s)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:s}}var l=e.i(7367);function d(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?a.default.dirname(e):e}let u=d(),c=a.default.join(u,"projects","registry.json");async function p(){try{let e=await t.promises.readFile(c,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${c}`)}}async function f(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(c,r,"utf-8")}async function m(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function h(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function g(e,t,r){let n=a.default.join(e,"documentation","backlog.json"),s=await h(n);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function x(e,t){let r=a.default.join(e,"documentation","designs.json"),n=await h(r);return n?n.map(e=>({...e,projectId:t})):[]}async function y(e,t){let r=a.default.join(e,"documentation","features.json"),n=await h(r);return n?n.map(e=>({...e,projectId:t})):[]}async function v(e){let t=e.path;if(!await m(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[a,s,i]=await Promise.all([g(t,e.id,e.name),x(t,e.id),y(t,e.id)]),o=(0,n.scanProjectAssets)(t,e.id),l=(0,n.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:a,designs:s,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function w(){let e=await p();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>v(e)),r=await Promise.all(t),i=(0,s.getStoreAssets)(),u=["skill","agent"],c=0,f=[];for(let t of["claude","agents"])for(let r of u){let a=i.filter(e=>e.type===r),s=new Map;for(let a of e.projects){let e=(0,n.scanProviderAssets)(a.path,t);s.set(a.id,e.filter(e=>e.type===r))}let o=(0,n.buildStoreAssetMatrix)(a,s,e.projects,r);f.push(...o)}for(let e of f)for(let t of e.cells)"outdated"===t.status&&c++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of f)for(let a of r.cells)a.projectId===e.id&&"outdated"===a.status&&t++;e.healthScore=function(e,t,r=0,a){if(!t)return o(e,0,0,0,void 0);let n=[...t.skills,...t.agents];return o(e,r,n.length,n.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let m=0,g=0;for(let e of r){if(!e.accessible)continue;let t=a.default.join(e.path,"documentation","kanban.json"),r=await h(t);if(r?.stages){m+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);g+=e.length+t.length}}let x=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),y=(0,l.getBridgeUrl)();try{let e=await fetch(`${y}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),a={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];a[t]=(a[t]||0)+1}for(let e of r)e.activeSessions=a[e.id]??0}}catch{}let w=d();return{projects:r,totalBacklogItems:m,activeItems:g,totalOutdatedAssets:c,totalUncommitted:x,lastRefresh:new Date().toISOString(),slycodeRoot:w,projectsDir:a.default.dirname(w)}}e.s(["getRepoRoot",()=>d,"loadDashboardData",()=>w,"loadRegistry",()=>p,"saveRegistry",()=>f],48044)},70457,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),v=e.i(48044);async function w(e,t){try{let{id:r}=await t.params,a=await e.json(),n=await (0,v.loadRegistry)(),s=n.projects.findIndex(e=>e.id===r);if(-1===s)return y.NextResponse.json({error:`Project '${r}' not found`},{status:404});let i=n.projects[s];return void 0!==a.name&&(i.name=a.name),void 0!==a.description&&(i.description=a.description),void 0!==a.path&&(i.path=a.path),void 0!==a.tags&&(i.tags=a.tags),void 0!==a.areas&&(i.areas=a.areas),void 0!==a.hasClaudeMd&&(i.hasClaudeMd=a.hasClaudeMd),void 0!==a.masterCompliant&&(i.masterCompliant=a.masterCompliant),n.lastUpdated=new Date().toISOString(),await (0,v.saveRegistry)(n),y.NextResponse.json(i)}catch(e){return console.error("Failed to update project:",e),y.NextResponse.json({error:"Failed to update project",details:String(e)},{status:500})}}async function R(e,t){try{let{id:e}=await t.params,r=await (0,v.loadRegistry)(),a=r.projects.findIndex(t=>t.id===e);if(-1===a)return y.NextResponse.json({error:`Project '${e}' not found`},{status:404});let n=r.projects.splice(a,1)[0];return r.lastUpdated=new Date().toISOString(),await (0,v.saveRegistry)(r),y.NextResponse.json({removed:n})}catch(e){return console.error("Failed to delete project:",e),y.NextResponse.json({error:"Failed to delete project",details:String(e)},{status:500})}}e.s(["DELETE",()=>R,"PUT",()=>w,"dynamic",0,"force-dynamic"],54701);var j=e.i(54701);let S=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/projects/[id]/route",pathname:"/api/projects/[id]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/projects/[id]/route.ts",nextConfigOutput:"standalone",userland:j}),{workAsyncStorage:E,workUnitAsyncStorage:C,serverHooks:b}=S;function k(){return(0,a.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:C})}async function A(e,t,a){S.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/projects/[id]/route";y=y.replace(/\/index$/,"")||"/";let v=await S.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:w,params:R,nextConfig:j,parsedUrl:E,isDraftMode:C,prerenderManifest:b,routerServerContext:k,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,resolvedPathname:P,clientReferenceManifest:N,serverActionsManifest:D}=v,M=(0,o.normalizeAppPath)(y),_=!!(b.dynamicRoutes[M]||b.routes[P]),F=async()=>((null==k?void 0:k.render404)?await k.render404(e,t,E,!1):t.end("This page could not be found"),null);if(_&&!C){let e=!!b.routes[P],t=b.dynamicRoutes[M];if(t&&!1===t.fallback&&!e){if(j.experimental.adapterPath)return await F();throw new g.NoFallbackError}}let T=null;!_||S.isDev||C||(T="/index"===(T=P)?"/":T);let U=!0===S.isDev||!_,I=_&&!U;D&&N&&(0,i.setManifestsSingleton)({page:y,clientReferenceManifest:N,serverActionsManifest:D});let q=e.method||"GET",H=(0,s.getTracer)(),L=H.getActiveScopeSpan(),$={params:R,prerenderManifest:b,renderOpts:{experimental:{authInterrupts:!!j.experimental.authInterrupts},cacheComponents:!!j.cacheComponents,supportsDynamicResponse:U,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:j.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>S.onRequestError(e,t,a,n,k)},sharedContext:{buildId:w}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>S.handle(B,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${q} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${q} ${y}`)}),o=!!(0,n.getRequestMeta)(e,"minimalMode"),l=async n=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&A&&O&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(n);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=$.renderOpts.collectedTags;if(!_)return await (0,p.sendResponse)(V,K,s,$.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await S.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:I,isOnDemandRevalidate:A})},!1,k),t}},u=await S.handleResponse({req:e,nextConfig:j,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:b,isRoutePPREnabled:!1,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:o});if(!_)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",A?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),C&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&_||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};L?await l(L):await H.withPropagatedContext(e.headers,()=>H.trace(u.BaseServerSpan.handleRequest,{spanName:`${q} ${y}`,kind:s.SpanKind.SERVER,attributes:{"http.method":q,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await S.onRequestError(e,t,{routerKind:"App Router",routePath:M,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:I,isOnDemandRevalidate:A})},!1,k),_)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>A,"patchFetch",()=>k,"routeModule",()=>S,"serverHooks",()=>b,"workAsyncStorage",()=>E,"workUnitAsyncStorage",()=>C],70457)}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__6d330d40._.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function n(){let e=a(),n=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(n)?n:e}function s(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>s,"getPackageDir",()=>n,"getSlycodeRoot",()=>a])},15088,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),o=e.i(74677),i=e.i(69741),l=e.i(16795),d=e.i(87718),c=e.i(95169),u=e.i(47587),p=e.i(66012),h=e.i(70101),R=e.i(74838),x=e.i(10372),f=e.i(93695);e.i(52474);var g=e.i(220),E=e.i(89171);let v=(0,e.i(7367).getBridgeUrl)();async function w(e,{params:t}){let{path:r}=await t,a=r.join("/"),n=`${v}/${a}${e.nextUrl.search}`;if(a.endsWith("/stream")){let t=`stream-${Date.now().toString(36)}`;console.log(`[SSE-PROXY] ${t} OPEN → ${a}`);let r=new AbortController;e.signal.addEventListener("abort",()=>{console.log(`[SSE-PROXY] ${t} CLIENT_ABORT → ${a}`),r.abort()},{once:!0});try{let e=await fetch(n,{headers:{Accept:"text/event-stream"},signal:r.signal});if(!e.ok){console.log(`[SSE-PROXY] ${t} BRIDGE_ERROR status=${e.status}`);let r=await e.json();return E.NextResponse.json(r,{status:e.status})}let s=new ReadableStream({async start(r){let n=e.body?.getReader();if(!n)return void r.close();try{for(;;){let{done:e,value:s}=await n.read();if(e){console.log(`[SSE-PROXY] ${t} BRIDGE_DONE (reader finished) → ${a}`);break}r.enqueue(s)}}catch(r){let e=r instanceof Error?r.message:String(r);e.includes("abort")||console.log(`[SSE-PROXY] ${t} READ_ERROR → ${a}: ${e}`)}finally{n.cancel().catch(()=>{});try{r.close()}catch{}}},cancel(){console.log(`[SSE-PROXY] ${t} CANCEL → ${a}`),r.abort(),e.body?.cancel().catch(()=>{})}});return new Response(s,{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache, no-transform",Connection:"keep-alive","X-Accel-Buffering":"no"}})}catch(e){if(e instanceof Error&&"AbortError"===e.name)return new Response(null,{status:499});return console.log(`[SSE-PROXY] ${t} FETCH_ERROR → ${a}:`,e),E.NextResponse.json({error:"Bridge unavailable"},{status:502})}}try{let e=await fetch(n),t=await e.json();return E.NextResponse.json(t,{status:e.status})}catch(e){return E.NextResponse.json({error:"Bridge unavailable"},{status:502})}}async function y(e,{params:t}){let{path:r}=await t,a=r.join("/"),n=`${v}/${a}`;try{let t=e.headers.get("content-type")||"";if(t.includes("multipart/form-data")){let r=await fetch(n,{method:"POST",headers:{"content-type":t},body:e.body,duplex:"half"}),a=await r.json();return E.NextResponse.json(a,{status:r.status})}let r={},a=e.headers.get("content-length");a&&parseInt(a)>0&&(r=await e.json());let s=await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)}),o=await s.json();return E.NextResponse.json(o,{status:s.status})}catch(e){return E.NextResponse.json({error:"Bridge unavailable"},{status:502})}}async function m(e,{params:t}){let{path:r}=await t,a=r.join("/"),n=`${v}/${a}${e.nextUrl.search}`;try{let e=await fetch(n,{method:"DELETE"}),t=await e.json();return E.NextResponse.json(t,{status:e.status})}catch(e){return E.NextResponse.json({error:"Bridge unavailable"},{status:502})}}e.s(["DELETE",()=>m,"GET",()=>w,"POST",()=>y,"dynamic",0,"force-dynamic"],81877);var b=e.i(81877);let C=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/bridge/[...path]/route",pathname:"/api/bridge/[...path]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/bridge/[...path]/route.ts",nextConfigOutput:"standalone",userland:b}),{workAsyncStorage:S,workUnitAsyncStorage:O,serverHooks:j}=C;function N(){return(0,a.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:O})}async function A(e,t,a){C.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let E="/api/bridge/[...path]/route";E=E.replace(/\/index$/,"")||"/";let v=await C.prepare(e,t,{srcPage:E,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:w,params:y,nextConfig:m,parsedUrl:b,isDraftMode:S,prerenderManifest:O,routerServerContext:j,isOnDemandRevalidate:N,revalidateOnlyGenerated:A,resolvedPathname:P,clientReferenceManifest:T,serverActionsManifest:_}=v,$=(0,i.normalizeAppPath)(E),k=!!(O.dynamicRoutes[$]||O.routes[P]),D=async()=>((null==j?void 0:j.render404)?await j.render404(e,t,b,!1):t.end("This page could not be found"),null);if(k&&!S){let e=!!O.routes[P],t=O.dynamicRoutes[$];if(t&&!1===t.fallback&&!e){if(m.experimental.adapterPath)return await D();throw new f.NoFallbackError}}let q=null;!k||C.isDev||S||(q="/index"===(q=P)?"/":q);let U=!0===C.isDev||!k,H=k&&!U;_&&T&&(0,o.setManifestsSingleton)({page:E,clientReferenceManifest:T,serverActionsManifest:_});let I=e.method||"GET",B=(0,s.getTracer)(),L=B.getActiveScopeSpan(),M={params:y,prerenderManifest:O,renderOpts:{experimental:{authInterrupts:!!m.experimental.authInterrupts},cacheComponents:!!m.cacheComponents,supportsDynamicResponse:U,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:m.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>C.onRequestError(e,t,a,n,j)},sharedContext:{buildId:w}},X=new l.NodeNextRequest(e),Y=new l.NodeNextResponse(t),F=d.NextRequestAdapter.fromNodeNextRequest(X,(0,d.signalFromNodeResponse)(t));try{let o=async e=>C.handle(F,M).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=B.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==c.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${I} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${I} ${E}`)}),i=!!(0,n.getRequestMeta)(e,"minimalMode"),l=async n=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!i&&N&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await o(n);e.fetchMetrics=M.renderOpts.fetchMetrics;let l=M.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=M.renderOpts.collectedTags;if(!k)return await (0,p.sendResponse)(X,Y,s,M.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[x.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==M.renderOpts.collectedRevalidate&&!(M.renderOpts.collectedRevalidate>=x.INFINITE_CACHE)&&M.renderOpts.collectedRevalidate,a=void 0===M.renderOpts.collectedExpire||M.renderOpts.collectedExpire>=x.INFINITE_CACHE?void 0:M.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await C.onRequestError(e,t,{routerKind:"App Router",routePath:E,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:H,isOnDemandRevalidate:N})},!1,j),t}},c=await C.handleResponse({req:e,nextConfig:m,cacheKey:q,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:O,isRoutePPREnabled:!1,isOnDemandRevalidate:N,revalidateOnlyGenerated:A,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:i});if(!k)return null;if((null==c||null==(s=c.value)?void 0:s.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(l=c.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",N?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),S&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let f=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return i&&k||f.delete(x.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||f.get("Cache-Control")||f.set("Cache-Control",(0,R.getCacheControlHeader)(c.cacheControl)),await (0,p.sendResponse)(X,Y,new Response(c.value.body,{headers:f,status:c.value.status||200})),null};L?await l(L):await B.withPropagatedContext(e.headers,()=>B.trace(c.BaseServerSpan.handleRequest,{spanName:`${I} ${E}`,kind:s.SpanKind.SERVER,attributes:{"http.method":I,"http.target":e.url}},l))}catch(t){if(t instanceof f.NoFallbackError||await C.onRequestError(e,t,{routerKind:"App Router",routePath:$,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:H,isOnDemandRevalidate:N})},!1,j),k)throw t;return await (0,p.sendResponse)(X,Y,new Response(null,{status:500})),null}}e.s(["handler",()=>A,"patchFetch",()=>N,"routeModule",()=>C,"serverHooks",()=>j,"workAsyncStorage",()=>S,"workUnitAsyncStorage",()=>O],15088)}];
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__6ffce934._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function s(){let e=a(),s=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(s)?s:e}e.s(["getPackageDir",()=>s,"getSlycodeRoot",()=>a])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),a=e.i(46676),s=e.i(7367);function n(){return r.default.join((0,s.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,s.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,s.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),a={};Function("module","exports",r)(a,a);let s=a.exports;if(s?.skills)return{skills:s.skills,actions:s.actions||[],agents:s.agents||[],mcp:s.mcp||[]}}}catch{}return null}function o(e,s){let n=[],i="skill"===s?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return n;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===s){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,a.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");n.push({name:p,type:s,path:d,frontmatter:c,isValid:(0,a.validateFrontmatter)(c)})}}catch{}return n.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=n(),a=i(),s=o(e,"skill"),l=o(e,"agent"),d=function(e){let a=r.default.join(e,"mcp"),s=[];try{if(!t.default.existsSync(a))return s;for(let e of t.default.readdirSync(a,{withFileTypes:!0})){let n;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(a,e.name),o=t.default.readFileSync(i,"utf-8");try{n=JSON.parse(o)}catch{continue}let l=n.name||e.name.replace(/\.json$/,"");s.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:n.version,description:n.description,updated:n.updated},isValid:!!(n.name&&n.command)})}}catch{}return s}(e);if(a){if(a.skills){let e=new Set(a.skills);s=s.filter(t=>e.has(t.name))}if(a.agents){let e=new Set(a.agents);l=l.filter(t=>e.has(t.name))}if(a.mcp){let e=new Set(a.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:s,agents:l,mcp:d}}function d(){let e=n(),t=i(),r=o(e,"skill"),a=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);a=a.filter(t=>e.has(t.name))}}return[...r,...a]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),a=e.i(14747),s=e.i(46676),n=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,a=0,s=i){let n=[],l=Math.max(r,1);n.push({name:"Outdated Assets",weight:s.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);n.push({name:"Stale Cards",weight:s.staleCards,value:c,maxValue:p}),n.push({name:"Unresolved Problems",weight:s.unresolvedProblems,value:0,maxValue:1}),n.push({name:"Missing CLAUDE.md",weight:s.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);n.push({name:"Non-compliant Frontmatter",weight:s.nonCompliantFrontmatter,value:a,maxValue:f});let m=0;for(let e of n)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:n}}function l(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?a.default.dirname(e):e}let d=l(),u=a.default.join(d,"projects","registry.json");async function c(){try{let e=await t.promises.readFile(u,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${u}`)}}async function p(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(u,r,"utf-8")}async function f(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function m(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function h(e,t,r){let s=a.default.join(e,"documentation","backlog.json"),n=await m(s);return n?n.map(e=>({...e,projectId:t,projectName:r})):[]}async function g(e,t){let r=a.default.join(e,"documentation","designs.json"),s=await m(r);return s?s.map(e=>({...e,projectId:t})):[]}async function x(e,t){let r=a.default.join(e,"documentation","features.json"),s=await m(r);return s?s.map(e=>({...e,projectId:t})):[]}async function y(e){let t=e.path;if(!await f(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[a,n,i]=await Promise.all([h(t,e.id,e.name),g(t,e.id),x(t,e.id)]),o=(0,s.scanProjectAssets)(t,e.id),l=(0,s.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:a,designs:n,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function w(){let e=await c();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>y(e)),r=await Promise.all(t),i=(0,n.getStoreAssets)(),d=["skill","agent"],u=0,p=[];for(let t of["claude","agents"])for(let r of d){let a=i.filter(e=>e.type===r),n=new Map;for(let a of e.projects){let e=(0,s.scanProviderAssets)(a.path,t);n.set(a.id,e.filter(e=>e.type===r))}let o=(0,s.buildStoreAssetMatrix)(a,n,e.projects,r);p.push(...o)}for(let e of p)for(let t of e.cells)"outdated"===t.status&&u++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of p)for(let a of r.cells)a.projectId===e.id&&"outdated"===a.status&&t++;e.healthScore=function(e,t,r=0,a){if(!t)return o(e,0,0,0,void 0);let s=[...t.skills,...t.agents];return o(e,r,s.length,s.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let f=0,h=0;for(let e of r){if(!e.accessible)continue;let t=a.default.join(e.path,"documentation","kanban.json"),r=await m(t);if(r?.stages){f+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);h+=e.length+t.length}}let g=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),x=process.env.BRIDGE_URL||"http://127.0.0.1:7592";try{let e=await fetch(`${x}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),a={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];a[t]=(a[t]||0)+1}for(let e of r)e.activeSessions=a[e.id]??0}}catch{}let w=l();return{projects:r,totalBacklogItems:f,activeItems:h,totalOutdatedAssets:u,totalUncommitted:g,lastRefresh:new Date().toISOString(),slycodeRoot:w,projectsDir:a.default.dirname(w)}}e.s(["getRepoRoot",()=>l,"loadDashboardData",()=>w,"loadRegistry",()=>c,"saveRegistry",()=>p],48044)},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},77981,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),s=e.i(59756),n=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),w=e.i(48044),v=e.i(33405),j=e.i(24361),R=e.i(14747),S=e.i(46786),E=e.i(7367);let C=(0,j.promisify)(v.execFile);async function b(){try{let e=await (0,w.loadRegistry)();return y.NextResponse.json(e.projects)}catch(e){return console.error("Failed to load projects:",e),y.NextResponse.json({error:"Failed to load projects"},{status:500})}}async function k(e){try{let t,{name:r,description:a,path:s,tags:n,scaffoldConfig:i,providers:o}=await e.json();if(!r||!s)return y.NextResponse.json({error:"name and path are required"},{status:400});let l=R.default.resolve(s.startsWith("~/")||"~"===s?s.replace(/^~/,S.default.homedir()):s),d=await (0,w.loadRegistry)(),u=r.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-|-$/g,"");if(d.projects.some(e=>e.id===u))return y.NextResponse.json({error:`Project with id '${u}' already exists`},{status:409});if(d.projects.some(e=>e.path===l)){let e=d.projects.find(e=>e.path===l);return y.NextResponse.json({error:`This directory is already registered as '${e?.name}'`},{status:409})}let c=[R.default.join((0,E.getPackageDir)(),"scripts","scaffold.js"),"create","--path",l,"--name",r,"--id",u];a&&c.push("--description",a),o&&Array.isArray(o)&&o.length>0&&c.push("--providers",o.join(",")),i&&c.push("--config",JSON.stringify(i));let{stdout:p,stderr:f}=await C("node",c,{timeout:3e4,windowsHide:!0});try{t=JSON.parse(p)}catch{return y.NextResponse.json({error:"Scaffold script returned invalid output",details:p,stderr:f},{status:500})}if(!t.success)return y.NextResponse.json({error:"Scaffolding failed",details:t},{status:500});let m={id:u,name:r,description:a||"",path:l,hasClaudeMd:!0,masterCompliant:!0,areas:[],tags:n||[]};return d.projects.push(m),d.lastUpdated=new Date().toISOString(),await (0,w.saveRegistry)(d),y.NextResponse.json({project:m,scaffold:t},{status:201})}catch(e){return console.error("Failed to create project:",e),y.NextResponse.json({error:"Failed to create project",details:String(e)},{status:500})}}e.s(["GET",()=>b,"POST",()=>k,"dynamic",0,"force-dynamic"],50364);var A=e.i(50364);let O=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/projects/route",pathname:"/api/projects",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/projects/route.ts",nextConfigOutput:"standalone",userland:A}),{workAsyncStorage:N,workUnitAsyncStorage:P,serverHooks:D}=O;function F(){return(0,a.patchFetch)({workAsyncStorage:N,workUnitAsyncStorage:P})}async function _(e,t,a){O.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/projects/route";y=y.replace(/\/index$/,"")||"/";let w=await O.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!w)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:v,params:j,nextConfig:R,parsedUrl:S,isDraftMode:E,prerenderManifest:C,routerServerContext:b,isOnDemandRevalidate:k,revalidateOnlyGenerated:A,resolvedPathname:N,clientReferenceManifest:P,serverActionsManifest:D}=w,F=(0,o.normalizeAppPath)(y),_=!!(C.dynamicRoutes[F]||C.routes[N]),M=async()=>((null==b?void 0:b.render404)?await b.render404(e,t,S,!1):t.end("This page could not be found"),null);if(_&&!E){let e=!!C.routes[N],t=C.dynamicRoutes[F];if(t&&!1===t.fallback&&!e){if(R.experimental.adapterPath)return await M();throw new g.NoFallbackError}}let T=null;!_||O.isDev||E||(T="/index"===(T=N)?"/":T);let q=!0===O.isDev||!_,U=_&&!q;D&&P&&(0,i.setManifestsSingleton)({page:y,clientReferenceManifest:P,serverActionsManifest:D});let H=e.method||"GET",I=(0,n.getTracer)(),L=I.getActiveScopeSpan(),$={params:j,prerenderManifest:C,renderOpts:{experimental:{authInterrupts:!!R.experimental.authInterrupts},cacheComponents:!!R.cacheComponents,supportsDynamicResponse:q,incrementalCache:(0,s.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:R.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,s)=>O.onRequestError(e,t,a,s,b)},sharedContext:{buildId:v}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),W=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>O.handle(W,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=I.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${H} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${H} ${y}`)}),o=!!(0,s.getRequestMeta)(e,"minimalMode"),l=async s=>{var n,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&k&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await i(s);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=$.renderOpts.collectedTags;if(!_)return await (0,p.sendResponse)(V,K,n,$.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(n.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await O.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:k})},!1,b),t}},u=await O.handleResponse({req:e,nextConfig:R,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:k,revalidateOnlyGenerated:A,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:o});if(!_)return null;if((null==u||null==(n=u.value)?void 0:n.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",k?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&_||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};L?await l(L):await I.withPropagatedContext(e.headers,()=>I.trace(u.BaseServerSpan.handleRequest,{spanName:`${H} ${y}`,kind:n.SpanKind.SERVER,attributes:{"http.method":H,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await O.onRequestError(e,t,{routerKind:"App Router",routePath:F,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:k})},!1,b),_)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>_,"patchFetch",()=>F,"routeModule",()=>O,"serverHooks",()=>D,"workAsyncStorage",()=>N,"workUnitAsyncStorage",()=>P],77981)}];
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function s(){let e=a(),s=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(s)?s:e}function n(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>n,"getPackageDir",()=>s,"getSlycodeRoot",()=>a])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),a=e.i(46676),s=e.i(7367);function n(){return r.default.join((0,s.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,s.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,s.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),a={};Function("module","exports",r)(a,a);let s=a.exports;if(s?.skills)return{skills:s.skills,actions:s.actions||[],agents:s.agents||[],mcp:s.mcp||[]}}}catch{}return null}function o(e,s){let n=[],i="skill"===s?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return n;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===s){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,a.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");n.push({name:p,type:s,path:d,frontmatter:c,isValid:(0,a.validateFrontmatter)(c)})}}catch{}return n.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=n(),a=i(),s=o(e,"skill"),l=o(e,"agent"),d=function(e){let a=r.default.join(e,"mcp"),s=[];try{if(!t.default.existsSync(a))return s;for(let e of t.default.readdirSync(a,{withFileTypes:!0})){let n;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(a,e.name),o=t.default.readFileSync(i,"utf-8");try{n=JSON.parse(o)}catch{continue}let l=n.name||e.name.replace(/\.json$/,"");s.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:n.version,description:n.description,updated:n.updated},isValid:!!(n.name&&n.command)})}}catch{}return s}(e);if(a){if(a.skills){let e=new Set(a.skills);s=s.filter(t=>e.has(t.name))}if(a.agents){let e=new Set(a.agents);l=l.filter(t=>e.has(t.name))}if(a.mcp){let e=new Set(a.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:s,agents:l,mcp:d}}function d(){let e=n(),t=i(),r=o(e,"skill"),a=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);a=a.filter(t=>e.has(t.name))}}return[...r,...a]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),a=e.i(14747),s=e.i(46676),n=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,a=0,s=i){let n=[],l=Math.max(r,1);n.push({name:"Outdated Assets",weight:s.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);n.push({name:"Stale Cards",weight:s.staleCards,value:c,maxValue:p}),n.push({name:"Unresolved Problems",weight:s.unresolvedProblems,value:0,maxValue:1}),n.push({name:"Missing CLAUDE.md",weight:s.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);n.push({name:"Non-compliant Frontmatter",weight:s.nonCompliantFrontmatter,value:a,maxValue:f});let m=0;for(let e of n)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:n}}var l=e.i(7367);function d(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?a.default.dirname(e):e}let u=d(),c=a.default.join(u,"projects","registry.json");async function p(){try{let e=await t.promises.readFile(c,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${c}`)}}async function f(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(c,r,"utf-8")}async function m(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function h(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function g(e,t,r){let s=a.default.join(e,"documentation","backlog.json"),n=await h(s);return n?n.map(e=>({...e,projectId:t,projectName:r})):[]}async function x(e,t){let r=a.default.join(e,"documentation","designs.json"),s=await h(r);return s?s.map(e=>({...e,projectId:t})):[]}async function y(e,t){let r=a.default.join(e,"documentation","features.json"),s=await h(r);return s?s.map(e=>({...e,projectId:t})):[]}async function w(e){let t=e.path;if(!await m(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[a,n,i]=await Promise.all([g(t,e.id,e.name),x(t,e.id),y(t,e.id)]),o=(0,s.scanProjectAssets)(t,e.id),l=(0,s.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:a,designs:n,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function v(){let e=await p();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>w(e)),r=await Promise.all(t),i=(0,n.getStoreAssets)(),u=["skill","agent"],c=0,f=[];for(let t of["claude","agents"])for(let r of u){let a=i.filter(e=>e.type===r),n=new Map;for(let a of e.projects){let e=(0,s.scanProviderAssets)(a.path,t);n.set(a.id,e.filter(e=>e.type===r))}let o=(0,s.buildStoreAssetMatrix)(a,n,e.projects,r);f.push(...o)}for(let e of f)for(let t of e.cells)"outdated"===t.status&&c++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of f)for(let a of r.cells)a.projectId===e.id&&"outdated"===a.status&&t++;e.healthScore=function(e,t,r=0,a){if(!t)return o(e,0,0,0,void 0);let s=[...t.skills,...t.agents];return o(e,r,s.length,s.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let m=0,g=0;for(let e of r){if(!e.accessible)continue;let t=a.default.join(e.path,"documentation","kanban.json"),r=await h(t);if(r?.stages){m+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);g+=e.length+t.length}}let x=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),y=(0,l.getBridgeUrl)();try{let e=await fetch(`${y}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),a={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];a[t]=(a[t]||0)+1}for(let e of r)e.activeSessions=a[e.id]??0}}catch{}let v=d();return{projects:r,totalBacklogItems:m,activeItems:g,totalOutdatedAssets:c,totalUncommitted:x,lastRefresh:new Date().toISOString(),slycodeRoot:v,projectsDir:a.default.dirname(v)}}e.s(["getRepoRoot",()=>d,"loadDashboardData",()=>v,"loadRegistry",()=>p,"saveRegistry",()=>f],48044)},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},77981,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),s=e.i(59756),n=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),w=e.i(48044),v=e.i(33405),j=e.i(24361),R=e.i(14747),S=e.i(46786),E=e.i(7367);let C=(0,j.promisify)(v.execFile);async function b(){try{let e=await (0,w.loadRegistry)();return y.NextResponse.json(e.projects)}catch(e){return console.error("Failed to load projects:",e),y.NextResponse.json({error:"Failed to load projects"},{status:500})}}async function k(e){try{let t,{name:r,description:a,path:s,tags:n,scaffoldConfig:i,providers:o}=await e.json();if(!r||!s)return y.NextResponse.json({error:"name and path are required"},{status:400});let l=R.default.resolve(s.startsWith("~/")||"~"===s?s.replace(/^~/,S.default.homedir()):s),d=await (0,w.loadRegistry)(),u=r.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-|-$/g,"");if(d.projects.some(e=>e.id===u))return y.NextResponse.json({error:`Project with id '${u}' already exists`},{status:409});if(d.projects.some(e=>e.path===l)){let e=d.projects.find(e=>e.path===l);return y.NextResponse.json({error:`This directory is already registered as '${e?.name}'`},{status:409})}let c=[R.default.join((0,E.getPackageDir)(),"scripts","scaffold.js"),"create","--path",l,"--name",r,"--id",u];a&&c.push("--description",a),o&&Array.isArray(o)&&o.length>0&&c.push("--providers",o.join(",")),i&&c.push("--config",JSON.stringify(i));let{stdout:p,stderr:f}=await C("node",c,{timeout:3e4,windowsHide:!0});try{t=JSON.parse(p)}catch{return y.NextResponse.json({error:"Scaffold script returned invalid output",details:p,stderr:f},{status:500})}if(!t.success)return y.NextResponse.json({error:"Scaffolding failed",details:t},{status:500});let m={id:u,name:r,description:a||"",path:l,hasClaudeMd:!0,masterCompliant:!0,areas:[],tags:n||[]};return d.projects.push(m),d.lastUpdated=new Date().toISOString(),await (0,w.saveRegistry)(d),y.NextResponse.json({project:m,scaffold:t},{status:201})}catch(e){return console.error("Failed to create project:",e),y.NextResponse.json({error:"Failed to create project",details:String(e)},{status:500})}}e.s(["GET",()=>b,"POST",()=>k,"dynamic",0,"force-dynamic"],50364);var A=e.i(50364);let O=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/projects/route",pathname:"/api/projects",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/projects/route.ts",nextConfigOutput:"standalone",userland:A}),{workAsyncStorage:N,workUnitAsyncStorage:P,serverHooks:D}=O;function _(){return(0,a.patchFetch)({workAsyncStorage:N,workUnitAsyncStorage:P})}async function F(e,t,a){O.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/projects/route";y=y.replace(/\/index$/,"")||"/";let w=await O.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!w)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:v,params:j,nextConfig:R,parsedUrl:S,isDraftMode:E,prerenderManifest:C,routerServerContext:b,isOnDemandRevalidate:k,revalidateOnlyGenerated:A,resolvedPathname:N,clientReferenceManifest:P,serverActionsManifest:D}=w,_=(0,o.normalizeAppPath)(y),F=!!(C.dynamicRoutes[_]||C.routes[N]),M=async()=>((null==b?void 0:b.render404)?await b.render404(e,t,S,!1):t.end("This page could not be found"),null);if(F&&!E){let e=!!C.routes[N],t=C.dynamicRoutes[_];if(t&&!1===t.fallback&&!e){if(R.experimental.adapterPath)return await M();throw new g.NoFallbackError}}let T=null;!F||O.isDev||E||(T="/index"===(T=N)?"/":T);let q=!0===O.isDev||!F,U=F&&!q;D&&P&&(0,i.setManifestsSingleton)({page:y,clientReferenceManifest:P,serverActionsManifest:D});let H=e.method||"GET",I=(0,n.getTracer)(),L=I.getActiveScopeSpan(),$={params:j,prerenderManifest:C,renderOpts:{experimental:{authInterrupts:!!R.experimental.authInterrupts},cacheComponents:!!R.cacheComponents,supportsDynamicResponse:q,incrementalCache:(0,s.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:R.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,s)=>O.onRequestError(e,t,a,s,b)},sharedContext:{buildId:v}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>O.handle(B,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=I.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${H} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${H} ${y}`)}),o=!!(0,s.getRequestMeta)(e,"minimalMode"),l=async s=>{var n,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&k&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await i(s);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=$.renderOpts.collectedTags;if(!F)return await (0,p.sendResponse)(V,K,n,$.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(n.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await O.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:k})},!1,b),t}},u=await O.handleResponse({req:e,nextConfig:R,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:k,revalidateOnlyGenerated:A,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:o});if(!F)return null;if((null==u||null==(n=u.value)?void 0:n.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",k?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&F||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};L?await l(L):await I.withPropagatedContext(e.headers,()=>I.trace(u.BaseServerSpan.handleRequest,{spanName:`${H} ${y}`,kind:n.SpanKind.SERVER,attributes:{"http.method":H,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await O.onRequestError(e,t,{routerKind:"App Router",routePath:_,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:k})},!1,b),F)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>F,"patchFetch",()=>_,"routeModule",()=>O,"serverHooks",()=>D,"workAsyncStorage",()=>N,"workUnitAsyncStorage",()=>P],77981)}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__884d73e4._.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function n(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function a(){let e=n(),a=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(a)?a:e}function s(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>s,"getPackageDir",()=>a,"getSlycodeRoot",()=>n])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),n=e.i(46676),a=e.i(7367);function s(){return r.default.join((0,a.getSlycodeRoot)(),"store")}function o(){for(let e of[r.default.join((0,a.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,a.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),n={};Function("module","exports",r)(n,n);let a=n.exports;if(a?.skills)return{skills:a.skills,actions:a.actions||[],agents:a.agents||[],mcp:a.mcp||[]}}}catch{}return null}function i(e,a){let s=[],o="skill"===a?"skills":"agents",i=r.default.join(e,o);try{if(!t.default.existsSync(i))return s;for(let e of t.default.readdirSync(i,{withFileTypes:!0})){let l,u;if("skill"===a){if(!e.isDirectory()||(l=r.default.join(i,e.name,"SKILL.md"),u=r.default.join(o,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(i,e.name),u=r.default.join(o,e.name)}let d=t.default.readFileSync(l,"utf-8"),c=(0,n.parseFrontmatter)(d),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:a,path:u,frontmatter:c,isValid:(0,n.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),n=o(),a=i(e,"skill"),l=i(e,"agent"),u=function(e){let n=r.default.join(e,"mcp"),a=[];try{if(!t.default.existsSync(n))return a;for(let e of t.default.readdirSync(n,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let o=r.default.join(n,e.name),i=t.default.readFileSync(o,"utf-8");try{s=JSON.parse(i)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");a.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return a}(e);if(n){if(n.skills){let e=new Set(n.skills);a=a.filter(t=>e.has(t.name))}if(n.agents){let e=new Set(n.agents);l=l.filter(t=>e.has(t.name))}if(n.mcp){let e=new Set(n.mcp);u=u.filter(t=>e.has(t.name))}}return{skills:a,agents:l,mcp:u}}function u(){let e=s(),t=o(),r=i(e,"skill"),n=i(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);n=n.filter(t=>e.has(t.name))}}return[...r,...n]}e.s(["getStoreAssets",()=>u,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),n=e.i(14747),a=e.i(46676),s=e.i(73178);let o={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function i(e,t=0,r=0,n=0,a=o){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:a.outdatedAssets,value:t,maxValue:l});let u=Date.now(),d=[...e.backlog],c=d.filter(e=>(u-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(d.length,1);s.push({name:"Stale Cards",weight:a.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:a.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:a.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:a.nonCompliantFrontmatter,value:n,maxValue:f});let h=0;for(let e of s)h+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let m=Math.round(Math.max(0,(1-h)*100));return{score:m,level:m>=80?"green":m>=50?"amber":"red",factors:s}}var l=e.i(7367);function u(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?n.default.dirname(e):e}let d=u(),c=n.default.join(d,"projects","registry.json");async function p(){try{let e=await t.promises.readFile(c,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${c}`)}}async function f(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(c,r,"utf-8")}async function h(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function m(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function g(e,t,r){let a=n.default.join(e,"documentation","backlog.json"),s=await m(a);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function x(e,t){let r=n.default.join(e,"documentation","designs.json"),a=await m(r);return a?a.map(e=>({...e,projectId:t})):[]}async function y(e,t){let r=n.default.join(e,"documentation","features.json"),a=await m(r);return a?a.map(e=>({...e,projectId:t})):[]}async function w(e){let t=e.path;if(!await h(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[n,s,o]=await Promise.all([g(t,e.id,e.name),x(t,e.id),y(t,e.id)]),i=(0,a.scanProjectAssets)(t,e.id),l=(0,a.detectPlatforms)(t),u=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:n,designs:s,features:o,assets:i,platforms:l,gitUncommitted:u>=0?u:void 0,accessible:!0}}async function R(){let e=await p();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>w(e)),r=await Promise.all(t),o=(0,s.getStoreAssets)(),d=["skill","agent"],c=0,f=[];for(let t of["claude","agents"])for(let r of d){let n=o.filter(e=>e.type===r),s=new Map;for(let n of e.projects){let e=(0,a.scanProviderAssets)(n.path,t);s.set(n.id,e.filter(e=>e.type===r))}let i=(0,a.buildStoreAssetMatrix)(n,s,e.projects,r);f.push(...i)}for(let e of f)for(let t of e.cells)"outdated"===t.status&&c++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of f)for(let n of r.cells)n.projectId===e.id&&"outdated"===n.status&&t++;e.healthScore=function(e,t,r=0,n){if(!t)return i(e,0,0,0,void 0);let a=[...t.skills,...t.agents];return i(e,r,a.length,a.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let h=0,g=0;for(let e of r){if(!e.accessible)continue;let t=n.default.join(e.path,"documentation","kanban.json"),r=await m(t);if(r?.stages){h+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);g+=e.length+t.length}}let x=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),y=(0,l.getBridgeUrl)();try{let e=await fetch(`${y}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),n={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];n[t]=(n[t]||0)+1}for(let e of r)e.activeSessions=n[e.id]??0}}catch{}let R=u();return{projects:r,totalBacklogItems:h,activeItems:g,totalOutdatedAssets:c,totalUncommitted:x,lastRefresh:new Date().toISOString(),slycodeRoot:R,projectsDir:n.default.dirname(R)}}e.s(["getRepoRoot",()=>u,"loadDashboardData",()=>R,"loadRegistry",()=>p,"saveRegistry",()=>f],48044)},46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},71741,e=>{"use strict";var t=e.i(14747),r=e.i(48044);let n={hourly:36e5,daily:864e5,weekly:6048e5},a=null,s=0;async function o(){let e=Date.now();return a&&e-s<5e3||(a=await (0,r.loadRegistry)(),s=e),a}class i extends Error{code;constructor(e,t){super(e),this.code=t,this.name="ProjectResolutionError"}}async function l(e){if(e===t.default.basename((0,r.getRepoRoot)()).replace(/_/g,"-"))return(0,r.getRepoRoot)();let n=(await o()).projects.find(t=>t.id===e);if(!n)throw new i(`Project '${e}' not found in registry`,"NOT_FOUND");return n.path}async function u(e){let r=await l(e);return t.default.join(r,"documentation","kanban.json")}async function d(e){let r=await l(e);return t.default.join(r,"documentation","archive")}async function c(e,r,n=1){let a=await d(e),s=String(n).padStart(3,"0");return t.default.join(a,`kanban_${r}_${s}.json`)}async function p(e){let r=await d(e),a=[];for(let e=1;e<=10;e++){let n=String(e).padStart(3,"0");a.push(t.default.join(r,`kanban_${n}.json`))}for(let e of Object.keys(n))a.push(t.default.join(r,`kanban_${e}.json`));return a}async function f(e){return e?u(e):t.default.join((0,r.getRepoRoot)(),"documentation")}e.s(["BACKUP_TIERS",0,n,"ProjectResolutionError",()=>i,"getArchiveDir",()=>d,"getKanbanPath",()=>u,"getLegacyBackupPaths",()=>p,"getTieredBackupPath",()=>c,"getWatchPath",()=>f,"resolveProjectRoot",()=>l])},45079,e=>{"use strict";var t=e.i(47909),r=e.i(74017),n=e.i(96250),a=e.i(59756),s=e.i(61916),o=e.i(74677),i=e.i(69741),l=e.i(16795),u=e.i(87718),d=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),h=e.i(74838),m=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),w=e.i(32695),R=e.i(22734),v=e.i(14747),j=e.i(71741);async function S(){let e=(0,w.getSchedulerStatus)(),t=(0,w.getConfiguredTimezone)();return y.NextResponse.json({...e,...t})}async function b(e){try{let t=await e.json(),{action:r,cardId:n,projectId:a}=t;if("start"===r)return(0,w.startScheduler)(),y.NextResponse.json({ok:!0,message:"Scheduler started"});if("stop"===r)return(0,w.stopScheduler)(),y.NextResponse.json({ok:!0,message:"Scheduler stopped"});if("nextRun"===r){let{schedule:e,scheduleType:r}=t;if(!e)return y.NextResponse.json({error:"schedule required"},{status:400});let n=(0,w.getNextRun)(e,r||"recurring");return y.NextResponse.json({nextRun:n?n.toISOString():null})}if("trigger"===r){if(!n||!a)return y.NextResponse.json({error:"cardId and projectId required"},{status:400});let e=await (0,j.resolveProjectRoot)(a),t=v.default.join(e,"documentation","kanban.json"),r=await R.promises.readFile(t,"utf-8"),s=JSON.parse(r),o=null;for(let e of Object.values(s.stages)){let t=e.find(e=>e.id===n);if(t){o=t;break}}if(!o)return y.NextResponse.json({error:"Card not found"},{status:404});if(!o.automation)return y.NextResponse.json({error:"Card has no automation config"},{status:400});let i=await (0,w.triggerAutomation)(o,a,e,{trigger:"manual"}),l={lastRun:new Date().toISOString(),lastResult:i.success?"success":"error"};return await (0,w.updateCardAutomation)(e,n,l),y.NextResponse.json(i)}return y.NextResponse.json({error:"Unknown action"},{status:400})}catch(e){return y.NextResponse.json({error:e.message},{status:500})}}e.s(["GET",()=>S,"POST",()=>b],94132);var E=e.i(94132);let k=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/scheduler/route",pathname:"/api/scheduler",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/scheduler/route.ts",nextConfigOutput:"standalone",userland:E}),{workAsyncStorage:C,workUnitAsyncStorage:O,serverHooks:P}=k;function A(){return(0,n.patchFetch)({workAsyncStorage:C,workUnitAsyncStorage:O})}async function N(e,t,n){k.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/scheduler/route";y=y.replace(/\/index$/,"")||"/";let w=await k.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!w)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:R,params:v,nextConfig:j,parsedUrl:S,isDraftMode:b,prerenderManifest:E,routerServerContext:C,isOnDemandRevalidate:O,revalidateOnlyGenerated:P,resolvedPathname:A,clientReferenceManifest:N,serverActionsManifest:_}=w,D=(0,i.normalizeAppPath)(y),T=!!(E.dynamicRoutes[D]||E.routes[A]),M=async()=>((null==C?void 0:C.render404)?await C.render404(e,t,S,!1):t.end("This page could not be found"),null);if(T&&!b){let e=!!E.routes[A],t=E.dynamicRoutes[D];if(t&&!1===t.fallback&&!e){if(j.experimental.adapterPath)return await M();throw new g.NoFallbackError}}let U=null;!T||k.isDev||b||(U="/index"===(U=A)?"/":U);let F=!0===k.isDev||!T,q=T&&!F;_&&N&&(0,o.setManifestsSingleton)({page:y,clientReferenceManifest:N,serverActionsManifest:_});let I=e.method||"GET",H=(0,s.getTracer)(),$=H.getActiveScopeSpan(),L={params:v,prerenderManifest:E,renderOpts:{experimental:{authInterrupts:!!j.experimental.authInterrupts},cacheComponents:!!j.cacheComponents,supportsDynamicResponse:F,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:j.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,a)=>k.onRequestError(e,t,n,a,C)},sharedContext:{buildId:R}},V=new l.NodeNextRequest(e),B=new l.NodeNextResponse(t),K=u.NextRequestAdapter.fromNodeNextRequest(V,(0,u.signalFromNodeResponse)(t));try{let o=async e=>k.handle(K,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=r.get("next.route");if(n){let t=`${I} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${I} ${y}`)}),i=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var s,l;let u=async({previousCacheEntry:r})=>{try{if(!i&&O&&P&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await o(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let l=L.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let u=L.renderOpts.collectedTags;if(!T)return await (0,p.sendResponse)(V,B,s,L.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);u&&(t[m.NEXT_CACHE_TAGS_HEADER]=u),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=m.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,n=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=m.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await k.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:O})},!1,C),t}},d=await k.handleResponse({req:e,nextConfig:j,cacheKey:U,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:O,revalidateOnlyGenerated:P,responseGenerator:u,waitUntil:n.waitUntil,isMinimalMode:i});if(!T)return null;if((null==d||null==(s=d.value)?void 0:s.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(l=d.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",O?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),b&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(d.value.headers);return i&&T||g.delete(m.NEXT_CACHE_TAGS_HEADER),!d.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,h.getCacheControlHeader)(d.cacheControl)),await (0,p.sendResponse)(V,B,new Response(d.value.body,{headers:g,status:d.value.status||200})),null};$?await l($):await H.withPropagatedContext(e.headers,()=>H.trace(d.BaseServerSpan.handleRequest,{spanName:`${I} ${y}`,kind:s.SpanKind.SERVER,attributes:{"http.method":I,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await k.onRequestError(e,t,{routerKind:"App Router",routePath:D,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:O})},!1,C),T)throw t;return await (0,p.sendResponse)(V,B,new Response(null,{status:500})),null}}e.s(["handler",()=>N,"patchFetch",()=>A,"routeModule",()=>k,"serverHooks",()=>P,"workAsyncStorage",()=>C,"workUnitAsyncStorage",()=>O],45079)},44264,e=>{e.v(e=>Promise.resolve().then(()=>e(33405)))}];
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__8ab096a3._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,r,t)=>{r.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,r,t)=>{r.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,r,t)=>{r.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,r,t)=>{r.exports=e.x("path",()=>require("path"))},22734,(e,r,t)=>{r.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var r=e.i(14747),t=e.i(22734);function s(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?r.default.dirname(e):e}function n(){let e=s(),n=r.default.join(e,"node_modules","@slycode","slycode","dist");return t.default.existsSync(n)?n:e}e.s(["getPackageDir",()=>n,"getSlycodeRoot",()=>s])},33405,(e,r,t)=>{r.exports=e.x("child_process",()=>require("child_process"))}];
|
|
1
|
+
module.exports=[18622,(e,r,t)=>{r.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,r,t)=>{r.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,r,t)=>{r.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,r,t)=>{r.exports=e.x("path",()=>require("path"))},22734,(e,r,t)=>{r.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var r=e.i(14747),t=e.i(22734);function s(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?r.default.dirname(e):e}function n(){let e=s(),n=r.default.join(e,"node_modules","@slycode","slycode","dist");return t.default.existsSync(n)?n:e}function o(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>o,"getPackageDir",()=>n,"getSlycodeRoot",()=>s])},33405,(e,r,t)=>{r.exports=e.x("child_process",()=>require("child_process"))}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__9058a007._.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function n(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function s(){let e=n(),s=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(s)?s:e}e.s(["getPackageDir",()=>s,"getSlycodeRoot",()=>n])},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},55012,e=>{"use strict";var t=e.i(22734),r=e.i(14747),n=e.i(54799),s=e.i(7367),a=e.i(46676);function o(e){let t=e.match(/^---\s*\n([\s\S]*?)\n---\s*\n?([\s\S]*)/);if(!t)return null;let r=t[1],n=(t[2]||"").trim(),s={},a=null,o=null,l=null;for(let e of r.split("\n")){if(e.startsWith(" ")){let t=e.trim();if(null!==l&&t.startsWith("- ")){let e=t.slice(2).trim();e=i(e),l.push(e);continue}if(null!==o){let e=t.indexOf(":");if(-1!==e){let r=t.slice(0,e).trim(),n=t.slice(e+1).trim();o[r]=Number(n)}}continue}a&&o&&(s[a]=o,o=null,a=null),a&&l&&(s[a]=l,l=null,a=null);let t=e.indexOf(":");if(-1===t)continue;let r=e.slice(0,t).trim(),n=e.slice(t+1).trim();if(!n){a=r,"classes"===r?o={}:l=[];continue}s[r]=i(n)}return a&&o&&(s[a]=o),a&&l&&(s[a]=l),{frontmatter:s,body:n}}function i(e){return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}function l(e,t){return{name:String(e.name||""),version:String(e.version||"1.0.0"),label:String(e.label||""),description:String(e.description||""),group:String(e.group||""),placement:e.placement||"both",scope:e.scope||"global",projects:Array.isArray(e.projects)?e.projects.map(String):[],cardTypes:Array.isArray(e.cardTypes)?e.cardTypes.map(String):void 0,classes:"object"!=typeof e.classes||null===e.classes||Array.isArray(e.classes)?{}:e.classes,prompt:t}}function c(e){let n=[];if(!t.default.existsSync(e))return n;try{for(let s of t.default.readdirSync(e)){if(!s.endsWith(".md"))continue;let a=r.default.join(e,s);try{let e=t.default.readFileSync(a,"utf-8"),r=o(e);if(!r)continue;let i=l(r.frontmatter,r.body);i.name||(i.name=s.replace(/\.md$/,"")),n.push(i)}catch{}}}catch{}return n}let u=null,d=0;function p(){return r.default.join((0,s.getSlycodeRoot)(),"store","actions")}function f(){return u&&!(Date.now()-d>3e4)||(u=function(e){let t={};for(let r of e)t[r.name]={id:r.name,label:r.label,description:r.description,group:r.group||void 0,cardTypes:r.cardTypes,placement:r.placement,prompt:r.prompt,scope:r.scope,projects:r.projects};return{version:"4.0",commands:t,classAssignments:function(e){let t={};for(let r of e)for(let[e,n]of Object.entries(r.classes))t[e]||(t[e]=[]),t[e].push({name:r.name,priority:n});let r={};for(let[e,n]of Object.entries(t))n.sort((e,t)=>e.priority!==t.priority?e.priority-t.priority:e.name.localeCompare(t.name)),r[e]=n.map(e=>e.name);return r}(e)}}(c(p())),d=Date.now()),u}function m(){u=null,d=0}function h(e,n){let s=n||p();t.default.mkdirSync(s,{recursive:!0});let a=function(e){let t=["---"];if(t.push(`name: ${e.name}`),t.push(`version: ${e.version}`),t.push(`label: "${e.label}"`),t.push(`description: "${e.description.replace(/"/g,'\\"')}"`),e.group&&t.push(`group: "${e.group}"`),t.push(`placement: ${e.placement}`),t.push(`scope: ${e.scope}`),e.projects.length>0)for(let r of(t.push("projects:"),e.projects))t.push(` - "${r}"`);if(e.cardTypes&&e.cardTypes.length>0)for(let r of(t.push("cardTypes:"),e.cardTypes))t.push(` - "${r}"`);if(Object.keys(e.classes).length>0)for(let[r,n]of(t.push("classes:"),Object.entries(e.classes).sort((e,t)=>e[0].localeCompare(t[0]))))t.push(` ${r}: ${n}`);return t.push("---"),`${t.join("\n")}
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function n(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function s(){let e=n(),s=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(s)?s:e}function a(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>a,"getPackageDir",()=>s,"getSlycodeRoot",()=>n])},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},55012,e=>{"use strict";var t=e.i(22734),r=e.i(14747),n=e.i(54799),s=e.i(7367),a=e.i(46676);function o(e){let t=e.match(/^---\s*\n([\s\S]*?)\n---\s*\n?([\s\S]*)/);if(!t)return null;let r=t[1],n=(t[2]||"").trim(),s={},a=null,o=null,l=null;for(let e of r.split("\n")){if(e.startsWith(" ")){let t=e.trim();if(null!==l&&t.startsWith("- ")){let e=t.slice(2).trim();e=i(e),l.push(e);continue}if(null!==o){let e=t.indexOf(":");if(-1!==e){let r=t.slice(0,e).trim(),n=t.slice(e+1).trim();o[r]=Number(n)}}continue}a&&o&&(s[a]=o,o=null,a=null),a&&l&&(s[a]=l,l=null,a=null);let t=e.indexOf(":");if(-1===t)continue;let r=e.slice(0,t).trim(),n=e.slice(t+1).trim();if(!n){a=r,"classes"===r?o={}:l=[];continue}s[r]=i(n)}return a&&o&&(s[a]=o),a&&l&&(s[a]=l),{frontmatter:s,body:n}}function i(e){return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}function l(e,t){return{name:String(e.name||""),version:String(e.version||"1.0.0"),label:String(e.label||""),description:String(e.description||""),group:String(e.group||""),placement:e.placement||"both",scope:e.scope||"global",projects:Array.isArray(e.projects)?e.projects.map(String):[],cardTypes:Array.isArray(e.cardTypes)?e.cardTypes.map(String):void 0,classes:"object"!=typeof e.classes||null===e.classes||Array.isArray(e.classes)?{}:e.classes,prompt:t}}function c(e){let n=[];if(!t.default.existsSync(e))return n;try{for(let s of t.default.readdirSync(e)){if(!s.endsWith(".md"))continue;let a=r.default.join(e,s);try{let e=t.default.readFileSync(a,"utf-8"),r=o(e);if(!r)continue;let i=l(r.frontmatter,r.body);i.name||(i.name=s.replace(/\.md$/,"")),n.push(i)}catch{}}}catch{}return n}let u=null,d=0;function p(){return r.default.join((0,s.getSlycodeRoot)(),"store","actions")}function f(){return u&&!(Date.now()-d>3e4)||(u=function(e){let t={};for(let r of e)t[r.name]={id:r.name,label:r.label,description:r.description,group:r.group||void 0,cardTypes:r.cardTypes,placement:r.placement,prompt:r.prompt,scope:r.scope,projects:r.projects};return{version:"4.0",commands:t,classAssignments:function(e){let t={};for(let r of e)for(let[e,n]of Object.entries(r.classes))t[e]||(t[e]=[]),t[e].push({name:r.name,priority:n});let r={};for(let[e,n]of Object.entries(t))n.sort((e,t)=>e.priority!==t.priority?e.priority-t.priority:e.name.localeCompare(t.name)),r[e]=n.map(e=>e.name);return r}(e)}}(c(p())),d=Date.now()),u}function m(){u=null,d=0}function h(e,n){let s=n||p();t.default.mkdirSync(s,{recursive:!0});let a=function(e){let t=["---"];if(t.push(`name: ${e.name}`),t.push(`version: ${e.version}`),t.push(`label: "${e.label}"`),t.push(`description: "${e.description.replace(/"/g,'\\"')}"`),e.group&&t.push(`group: "${e.group}"`),t.push(`placement: ${e.placement}`),t.push(`scope: ${e.scope}`),e.projects.length>0)for(let r of(t.push("projects:"),e.projects))t.push(` - "${r}"`);if(e.cardTypes&&e.cardTypes.length>0)for(let r of(t.push("cardTypes:"),e.cardTypes))t.push(` - "${r}"`);if(Object.keys(e.classes).length>0)for(let[r,n]of(t.push("classes:"),Object.entries(e.classes).sort((e,t)=>e[0].localeCompare(t[0]))))t.push(` ${r}: ${n}`);return t.push("---"),`${t.join("\n")}
|
|
2
2
|
|
|
3
3
|
${e.prompt}
|
|
4
|
-
`}(e),o=r.default.join(s,`${e.name}.md`),i=r.default.join(s,`.${e.name}.md.tmp`);t.default.writeFileSync(i,a,"utf-8"),t.default.renameSync(i,o)}function y(e,n){let s=n||p(),a={};for(let[t,r]of Object.entries(e.classAssignments))for(let e=0;e<r.length;e++){let n=r[e];a[n]||(a[n]={}),a[n][t]=(e+1)*10}let o=c(s),i={};for(let e of o)i[e.name]=e.version;for(let[t,r]of Object.entries(e.commands))h({name:t,version:i[t]||"1.0.0",label:r.label,description:r.description,group:r.group||"",placement:r.placement,scope:r.scope,projects:r.projects,cardTypes:r.cardTypes,classes:a[t]||{},prompt:r.prompt},s);try{let n=t.default.readdirSync(s).filter(e=>e.endsWith(".md")),a=new Set(Object.keys(e.commands));for(let e of n){let n=e.replace(/\.md$/,"");a.has(n)||t.default.unlinkSync(r.default.join(s,e))}}catch{}m()}function g(e){return n.default.createHash("sha256").update(e).digest("hex").slice(0,12)}function x(e){let n,i=(0,s.getSlycodeRoot)(),c=r.default.join(i,"updates","actions"),u=r.default.join(i,"store","actions");if(!t.default.existsSync(c))return[];let d=[],p=!1;try{n=t.default.readdirSync(c).filter(e=>e.endsWith(".md"))}catch{return[]}for(let s of n)try{let n=r.default.join(c,s),a=t.default.readFileSync(n,"utf-8"),i=g(a),f=o(a);if(!f)continue;let m=l(f.frontmatter,f.body);m.name||(m.name=s.replace(/\.md$/,""));let h=`actions/${m.name}`;if(e[h]===i)continue;let y=r.default.join(u,s);if(t.default.existsSync(y)){let r=t.default.readFileSync(y,"utf-8"),n=g(r);if(i===n){e[h]||(e[h]=i,p=!0);continue}let s=o(r),a=s?l(s.frontmatter,s.body):null,c=[];a&&(m.prompt!==a.prompt&&c.push("prompt"),m.label!==a.label&&c.push("label"),m.description!==a.description&&c.push("description"),m.placement!==a.placement&&c.push("placement"),m.group!==a.group&&c.push("group"));let u=a?Object.keys(m.classes).filter(e=>!(e in a.classes)):Object.keys(m.classes);d.push({name:m.name,assetType:"action",status:"update",currentVersion:a?.version,upstreamVersion:m.version,contentHash:i,description:m.description,changedFields:c,newClasses:u.length>0?u:void 0})}else d.push({name:m.name,assetType:"action",status:"new",upstreamVersion:m.version,contentHash:i,description:m.description,newClasses:Object.keys(m.classes)})}catch{}return p&&(0,a.saveIgnoredUpdates)(e),d}function v(e){let n=(0,s.getSlycodeRoot)(),i=r.default.join(n,"updates","actions",`${e}.md`),c=r.default.join(n,"store","actions",`${e}.md`);if(!t.default.existsSync(i))throw Error(`Action update not found: ${e}`);let u=t.default.readFileSync(i,"utf-8"),d=g(u),p=o(u);if(!p)throw Error(`Failed to parse upstream action: ${e}`);let f=l(p.frontmatter,p.body),y=null;if(t.default.existsSync(c)){let s=r.default.join(n,"store",".backups","actions");t.default.mkdirSync(s,{recursive:!0}),y=r.default.join(s,`${e}.md`),t.default.copyFileSync(c,y);let a=o(t.default.readFileSync(c,"utf-8"));if(a){let e={...l(a.frontmatter,a.body).classes};for(let[t,r]of Object.entries(f.classes))t in e||(e[t]=r);f.classes=e}}let x=r.default.join(n,"store","actions");t.default.mkdirSync(x,{recursive:!0}),h(f,x);let v=(0,a.getIgnoredUpdates)();return v[`actions/${e}`]=d,(0,a.saveIgnoredUpdates)(v),m(),y}e.s(["acceptActionUpdate",()=>v,"getActionsConfig",()=>f,"invalidateActionsCache",()=>m,"scanActionUpdates",()=>x,"writeActionsFromConfig",()=>y])},31798,e=>{"use strict";var t=e.i(47909),r=e.i(74017),n=e.i(96250),s=e.i(59756),a=e.i(61916),o=e.i(74677),i=e.i(69741),l=e.i(16795),c=e.i(87718),u=e.i(95169),d=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),y=e.i(93695);e.i(52474);var g=e.i(220),x=e.i(89171),v=e.i(55012);async function R(){try{let e=(0,v.getActionsConfig)();return x.NextResponse.json(e)}catch(e){return console.error("Failed to read actions:",e),x.NextResponse.json({version:"4.0",commands:{},classAssignments:{}})}}async function b(e){try{let t=await e.json();if(!t.commands||"object"!=typeof t.commands)return x.NextResponse.json({error:"Invalid format: commands object required"},{status:400});return(0,v.writeActionsFromConfig)(t),x.NextResponse.json({success:!0})}catch(e){return console.error("Failed to save actions:",e),x.NextResponse.json({error:"Failed to save configuration"},{status:500})}}e.s(["GET",()=>R,"PUT",()=>b],31810);var j=e.i(31810);let w=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/sly-actions/route",pathname:"/api/sly-actions",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/sly-actions/route.ts",nextConfigOutput:"standalone",userland:j}),{workAsyncStorage:S,workUnitAsyncStorage:E,serverHooks:C}=w;function A(){return(0,n.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:E})}async function O(e,t,n){w.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let x="/api/sly-actions/route";x=x.replace(/\/index$/,"")||"/";let v=await w.prepare(e,t,{srcPage:x,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:R,params:b,nextConfig:j,parsedUrl:S,isDraftMode:E,prerenderManifest:C,routerServerContext:A,isOnDemandRevalidate:O,revalidateOnlyGenerated:T,resolvedPathname:$,clientReferenceManifest:k,serverActionsManifest:N}=v,
|
|
4
|
+
`}(e),o=r.default.join(s,`${e.name}.md`),i=r.default.join(s,`.${e.name}.md.tmp`);t.default.writeFileSync(i,a,"utf-8"),t.default.renameSync(i,o)}function y(e,n){let s=n||p(),a={};for(let[t,r]of Object.entries(e.classAssignments))for(let e=0;e<r.length;e++){let n=r[e];a[n]||(a[n]={}),a[n][t]=(e+1)*10}let o=c(s),i={};for(let e of o)i[e.name]=e.version;for(let[t,r]of Object.entries(e.commands))h({name:t,version:i[t]||"1.0.0",label:r.label,description:r.description,group:r.group||"",placement:r.placement,scope:r.scope,projects:r.projects,cardTypes:r.cardTypes,classes:a[t]||{},prompt:r.prompt},s);try{let n=t.default.readdirSync(s).filter(e=>e.endsWith(".md")),a=new Set(Object.keys(e.commands));for(let e of n){let n=e.replace(/\.md$/,"");a.has(n)||t.default.unlinkSync(r.default.join(s,e))}}catch{}m()}function g(e){return n.default.createHash("sha256").update(e).digest("hex").slice(0,12)}function x(e){let n,i=(0,s.getSlycodeRoot)(),c=r.default.join(i,"updates","actions"),u=r.default.join(i,"store","actions");if(!t.default.existsSync(c))return[];let d=[],p=!1;try{n=t.default.readdirSync(c).filter(e=>e.endsWith(".md"))}catch{return[]}for(let s of n)try{let n=r.default.join(c,s),a=t.default.readFileSync(n,"utf-8"),i=g(a),f=o(a);if(!f)continue;let m=l(f.frontmatter,f.body);m.name||(m.name=s.replace(/\.md$/,""));let h=`actions/${m.name}`;if(e[h]===i)continue;let y=r.default.join(u,s);if(t.default.existsSync(y)){let r=t.default.readFileSync(y,"utf-8"),n=g(r);if(i===n){e[h]||(e[h]=i,p=!0);continue}let s=o(r),a=s?l(s.frontmatter,s.body):null,c=[];a&&(m.prompt!==a.prompt&&c.push("prompt"),m.label!==a.label&&c.push("label"),m.description!==a.description&&c.push("description"),m.placement!==a.placement&&c.push("placement"),m.group!==a.group&&c.push("group"));let u=a?Object.keys(m.classes).filter(e=>!(e in a.classes)):Object.keys(m.classes);d.push({name:m.name,assetType:"action",status:"update",currentVersion:a?.version,upstreamVersion:m.version,contentHash:i,description:m.description,changedFields:c,newClasses:u.length>0?u:void 0})}else d.push({name:m.name,assetType:"action",status:"new",upstreamVersion:m.version,contentHash:i,description:m.description,newClasses:Object.keys(m.classes)})}catch{}return p&&(0,a.saveIgnoredUpdates)(e),d}function v(e){let n=(0,s.getSlycodeRoot)(),i=r.default.join(n,"updates","actions",`${e}.md`),c=r.default.join(n,"store","actions",`${e}.md`);if(!t.default.existsSync(i))throw Error(`Action update not found: ${e}`);let u=t.default.readFileSync(i,"utf-8"),d=g(u),p=o(u);if(!p)throw Error(`Failed to parse upstream action: ${e}`);let f=l(p.frontmatter,p.body),y=null;if(t.default.existsSync(c)){let s=r.default.join(n,"store",".backups","actions");t.default.mkdirSync(s,{recursive:!0}),y=r.default.join(s,`${e}.md`),t.default.copyFileSync(c,y);let a=o(t.default.readFileSync(c,"utf-8"));if(a){let e={...l(a.frontmatter,a.body).classes};for(let[t,r]of Object.entries(f.classes))t in e||(e[t]=r);f.classes=e}}let x=r.default.join(n,"store","actions");t.default.mkdirSync(x,{recursive:!0}),h(f,x);let v=(0,a.getIgnoredUpdates)();return v[`actions/${e}`]=d,(0,a.saveIgnoredUpdates)(v),m(),y}e.s(["acceptActionUpdate",()=>v,"getActionsConfig",()=>f,"invalidateActionsCache",()=>m,"scanActionUpdates",()=>x,"writeActionsFromConfig",()=>y])},31798,e=>{"use strict";var t=e.i(47909),r=e.i(74017),n=e.i(96250),s=e.i(59756),a=e.i(61916),o=e.i(74677),i=e.i(69741),l=e.i(16795),c=e.i(87718),u=e.i(95169),d=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),y=e.i(93695);e.i(52474);var g=e.i(220),x=e.i(89171),v=e.i(55012);async function R(){try{let e=(0,v.getActionsConfig)();return x.NextResponse.json(e)}catch(e){return console.error("Failed to read actions:",e),x.NextResponse.json({version:"4.0",commands:{},classAssignments:{}})}}async function b(e){try{let t=await e.json();if(!t.commands||"object"!=typeof t.commands)return x.NextResponse.json({error:"Invalid format: commands object required"},{status:400});return(0,v.writeActionsFromConfig)(t),x.NextResponse.json({success:!0})}catch(e){return console.error("Failed to save actions:",e),x.NextResponse.json({error:"Failed to save configuration"},{status:500})}}e.s(["GET",()=>R,"PUT",()=>b],31810);var j=e.i(31810);let w=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/sly-actions/route",pathname:"/api/sly-actions",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/sly-actions/route.ts",nextConfigOutput:"standalone",userland:j}),{workAsyncStorage:S,workUnitAsyncStorage:E,serverHooks:C}=w;function A(){return(0,n.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:E})}async function O(e,t,n){w.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let x="/api/sly-actions/route";x=x.replace(/\/index$/,"")||"/";let v=await w.prepare(e,t,{srcPage:x,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:R,params:b,nextConfig:j,parsedUrl:S,isDraftMode:E,prerenderManifest:C,routerServerContext:A,isOnDemandRevalidate:O,revalidateOnlyGenerated:T,resolvedPathname:$,clientReferenceManifest:k,serverActionsManifest:N}=v,_=(0,i.normalizeAppPath)(x),P=!!(C.dynamicRoutes[_]||C.routes[$]),U=async()=>((null==A?void 0:A.render404)?await A.render404(e,t,S,!1):t.end("This page could not be found"),null);if(P&&!E){let e=!!C.routes[$],t=C.dynamicRoutes[_];if(t&&!1===t.fallback&&!e){if(j.experimental.adapterPath)return await U();throw new y.NoFallbackError}}let q=null;!P||w.isDev||E||(q="/index"===(q=$)?"/":q);let H=!0===w.isDev||!P,D=P&&!H;N&&k&&(0,o.setManifestsSingleton)({page:x,clientReferenceManifest:k,serverActionsManifest:N});let F=e.method||"GET",I=(0,a.getTracer)(),M=I.getActiveScopeSpan(),W={params:b,prerenderManifest:C,renderOpts:{experimental:{authInterrupts:!!j.experimental.authInterrupts},cacheComponents:!!j.cacheComponents,supportsDynamicResponse:H,incrementalCache:(0,s.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:j.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,s)=>w.onRequestError(e,t,n,s,A)},sharedContext:{buildId:R}},L=new l.NodeNextRequest(e),B=new l.NodeNextResponse(t),K=c.NextRequestAdapter.fromNodeNextRequest(L,(0,c.signalFromNodeResponse)(t));try{let o=async e=>w.handle(K,W).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=I.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=r.get("next.route");if(n){let t=`${F} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${F} ${x}`)}),i=!!(0,s.getRequestMeta)(e,"minimalMode"),l=async s=>{var a,l;let c=async({previousCacheEntry:r})=>{try{if(!i&&O&&T&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await o(s);e.fetchMetrics=W.renderOpts.fetchMetrics;let l=W.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let c=W.renderOpts.collectedTags;if(!P)return await (0,p.sendResponse)(L,B,a,W.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(a.headers);c&&(t[h.NEXT_CACHE_TAGS_HEADER]=c),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==W.renderOpts.collectedRevalidate&&!(W.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&W.renderOpts.collectedRevalidate,n=void 0===W.renderOpts.collectedExpire||W.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:W.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:a.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await w.onRequestError(e,t,{routerKind:"App Router",routePath:x,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:O})},!1,A),t}},u=await w.handleResponse({req:e,nextConfig:j,cacheKey:q,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:O,revalidateOnlyGenerated:T,responseGenerator:c,waitUntil:n.waitUntil,isMinimalMode:i});if(!P)return null;if((null==u||null==(a=u.value)?void 0:a.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",O?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let y=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return i&&P||y.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||y.get("Cache-Control")||y.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(L,B,new Response(u.value.body,{headers:y,status:u.value.status||200})),null};M?await l(M):await I.withPropagatedContext(e.headers,()=>I.trace(u.BaseServerSpan.handleRequest,{spanName:`${F} ${x}`,kind:a.SpanKind.SERVER,attributes:{"http.method":F,"http.target":e.url}},l))}catch(t){if(t instanceof y.NoFallbackError||await w.onRequestError(e,t,{routerKind:"App Router",routePath:_,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:O})},!1,A),P)throw t;return await (0,p.sendResponse)(L,B,new Response(null,{status:500})),null}}e.s(["handler",()=>O,"patchFetch",()=>A,"routeModule",()=>w,"serverHooks",()=>C,"workAsyncStorage",()=>S,"workUnitAsyncStorage",()=>E],31798)}];
|
|
5
5
|
|
|
6
6
|
//# sourceMappingURL=%5Broot-of-the-server%5D__933e6077._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function n(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function a(){let e=n(),a=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(a)?a:e}e.s(["getPackageDir",()=>a,"getSlycodeRoot",()=>n])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),n=e.i(46676),a=e.i(7367);function s(){return r.default.join((0,a.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,a.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,a.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),n={};Function("module","exports",r)(n,n);let a=n.exports;if(a?.skills)return{skills:a.skills,actions:a.actions||[],agents:a.agents||[],mcp:a.mcp||[]}}}catch{}return null}function o(e,a){let s=[],i="skill"===a?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return s;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===a){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,n.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:a,path:d,frontmatter:c,isValid:(0,n.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),n=i(),a=o(e,"skill"),l=o(e,"agent"),d=function(e){let n=r.default.join(e,"mcp"),a=[];try{if(!t.default.existsSync(n))return a;for(let e of t.default.readdirSync(n,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(n,e.name),o=t.default.readFileSync(i,"utf-8");try{s=JSON.parse(o)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");a.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return a}(e);if(n){if(n.skills){let e=new Set(n.skills);a=a.filter(t=>e.has(t.name))}if(n.agents){let e=new Set(n.agents);l=l.filter(t=>e.has(t.name))}if(n.mcp){let e=new Set(n.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:a,agents:l,mcp:d}}function d(){let e=s(),t=i(),r=o(e,"skill"),n=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);n=n.filter(t=>e.has(t.name))}}return[...r,...n]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),n=e.i(14747),a=e.i(46676),s=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,n=0,a=i){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:a.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);s.push({name:"Stale Cards",weight:a.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:a.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:a.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:a.nonCompliantFrontmatter,value:n,maxValue:f});let m=0;for(let e of s)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:s}}function l(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?n.default.dirname(e):e}let d=l(),u=n.default.join(d,"projects","registry.json");async function c(){try{let e=await t.promises.readFile(u,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${u}`)}}async function p(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(u,r,"utf-8")}async function f(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function m(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function h(e,t,r){let a=n.default.join(e,"documentation","backlog.json"),s=await m(a);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function g(e,t){let r=n.default.join(e,"documentation","designs.json"),a=await m(r);return a?a.map(e=>({...e,projectId:t})):[]}async function y(e,t){let r=n.default.join(e,"documentation","features.json"),a=await m(r);return a?a.map(e=>({...e,projectId:t})):[]}async function x(e){let t=e.path;if(!await f(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[n,s,i]=await Promise.all([h(t,e.id,e.name),g(t,e.id),y(t,e.id)]),o=(0,a.scanProjectAssets)(t,e.id),l=(0,a.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:n,designs:s,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function v(){let e=await c();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>x(e)),r=await Promise.all(t),i=(0,s.getStoreAssets)(),d=["skill","agent"],u=0,p=[];for(let t of["claude","agents"])for(let r of d){let n=i.filter(e=>e.type===r),s=new Map;for(let n of e.projects){let e=(0,a.scanProviderAssets)(n.path,t);s.set(n.id,e.filter(e=>e.type===r))}let o=(0,a.buildStoreAssetMatrix)(n,s,e.projects,r);p.push(...o)}for(let e of p)for(let t of e.cells)"outdated"===t.status&&u++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of p)for(let n of r.cells)n.projectId===e.id&&"outdated"===n.status&&t++;e.healthScore=function(e,t,r=0,n){if(!t)return o(e,0,0,0,void 0);let a=[...t.skills,...t.agents];return o(e,r,a.length,a.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let f=0,h=0;for(let e of r){if(!e.accessible)continue;let t=n.default.join(e.path,"documentation","kanban.json"),r=await m(t);if(r?.stages){f+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);h+=e.length+t.length}}let g=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),y=process.env.BRIDGE_URL||"http://127.0.0.1:7592";try{let e=await fetch(`${y}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),n={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];n[t]=(n[t]||0)+1}for(let e of r)e.activeSessions=n[e.id]??0}}catch{}let v=l();return{projects:r,totalBacklogItems:f,activeItems:h,totalOutdatedAssets:u,totalUncommitted:g,lastRefresh:new Date().toISOString(),slycodeRoot:v,projectsDir:n.default.dirname(v)}}e.s(["getRepoRoot",()=>l,"loadDashboardData",()=>v,"loadRegistry",()=>c,"saveRegistry",()=>p],48044)},1365,e=>{"use strict";var t=e.i(22734),r=e.i(14747);let n=(0,e.i(7367).getSlycodeRoot)(),a=r.default.join(n,"documentation","events.json");function s(){try{if(!t.default.existsSync(a))return[];let e=t.default.readFileSync(a,"utf-8"),r=JSON.parse(e);return Array.isArray(r)?r:[]}catch{return[]}}function i(e){let n,i=s(),o={id:`evt-${Date.now()}-${Math.random().toString(36).slice(2,6)}`,...e};return i.push(o),i.length>500&&i.splice(0,i.length-500),n=r.default.dirname(a),t.default.existsSync(n)||t.default.mkdirSync(n,{recursive:!0}),t.default.writeFileSync(a,JSON.stringify(i,null,2)),o}function o(e={}){let t=s();if(e.project&&(t=t.filter(t=>t.project===e.project)),e.type&&(t=t.filter(t=>t.type===e.type)),e.since){let r=new Date(e.since).getTime();t=t.filter(e=>new Date(e.timestamp).getTime()>=r)}return t.reverse(),e.limit&&e.limit>0&&(t=t.slice(0,e.limit)),t}e.s(["appendEvent",()=>i,"queryEvents",()=>o])},3089,e=>{"use strict";var t=e.i(47909),r=e.i(74017),n=e.i(96250),a=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var y=e.i(220),x=e.i(89171),v=e.i(22734),w=e.i(14747),S=e.i(73178),R=e.i(46676),j=e.i(7367),E=e.i(48044),k=e.i(1365);async function b(){try{let e=(0,S.scanStore)();return x.NextResponse.json(e)}catch(e){return console.error("Store scan failed:",e),x.NextResponse.json({error:"Failed to scan store",details:String(e)},{status:500})}}async function C(e){try{let{projectPath:t,provider:r,assetType:n,assetName:a,sourceProjectId:s,skillMainOnly:i}=await e.json();if(!r||!n||!a)return x.NextResponse.json({error:"provider, assetType, and assetName are required"},{status:400});let o=t;if(!o&&s){let e=(await (0,E.loadRegistry)()).projects.find(e=>e.id===s);e&&(o=e.path)}if(!o)return x.NextResponse.json({error:"Either projectPath or sourceProjectId is required"},{status:400});(0,R.importAssetToStore)(o,r,n,a,{skillMainOnly:i??!0}),(0,k.appendEvent)({type:"skill_imported",project:s||"unknown",detail:`Imported ${n} '${a}' to store`,timestamp:new Date().toISOString()});let l=(0,S.scanStore)();return x.NextResponse.json({success:!0,storeData:l})}catch(e){return console.error("Store import failed:",e),x.NextResponse.json({error:"Failed to import to store",details:String(e)},{status:500})}}async function A(e){try{let{assetType:t,assetName:r}=await e.json();if(!t||!r)return x.NextResponse.json({error:"assetType and assetName are required"},{status:400});let n=(0,j.getSlycodeRoot)(),a="skill"===t?"skills":"agents";if("skill"===t){let e=w.default.join(n,"store",a,r);v.default.existsSync(e)&&v.default.rmSync(e,{recursive:!0,force:!0})}else{let e=w.default.join(n,"store",a,`${r}.md`);v.default.existsSync(e)&&v.default.unlinkSync(e)}(0,k.appendEvent)({type:"skill_removed",project:"store",detail:`Deleted ${t} '${r}' from store`,timestamp:new Date().toISOString()});let s=(0,S.scanStore)();return x.NextResponse.json({success:!0,storeData:s})}catch(e){return console.error("Store delete failed:",e),x.NextResponse.json({error:"Failed to delete from store",details:String(e)},{status:500})}}e.s(["DELETE",()=>A,"GET",()=>b,"POST",()=>C,"dynamic",0,"force-dynamic"],1972);var O=e.i(1972);let N=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/cli-assets/store/route",pathname:"/api/cli-assets/store",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/cli-assets/store/route.ts",nextConfigOutput:"standalone",userland:O}),{workAsyncStorage:D,workUnitAsyncStorage:P,serverHooks:T}=N;function _(){return(0,n.patchFetch)({workAsyncStorage:D,workUnitAsyncStorage:P})}async function F(e,t,n){N.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let x="/api/cli-assets/store/route";x=x.replace(/\/index$/,"")||"/";let v=await N.prepare(e,t,{srcPage:x,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:w,params:S,nextConfig:R,parsedUrl:j,isDraftMode:E,prerenderManifest:k,routerServerContext:b,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,resolvedPathname:O,clientReferenceManifest:D,serverActionsManifest:P}=v,T=(0,o.normalizeAppPath)(x),_=!!(k.dynamicRoutes[T]||k.routes[O]),F=async()=>((null==b?void 0:b.render404)?await b.render404(e,t,j,!1):t.end("This page could not be found"),null);if(_&&!E){let e=!!k.routes[O],t=k.dynamicRoutes[T];if(t&&!1===t.fallback&&!e){if(R.experimental.adapterPath)return await F();throw new g.NoFallbackError}}let M=null;!_||N.isDev||E||(M="/index"===(M=O)?"/":M);let q=!0===N.isDev||!_,I=_&&!q;P&&D&&(0,i.setManifestsSingleton)({page:x,clientReferenceManifest:D,serverActionsManifest:P});let U=e.method||"GET",H=(0,s.getTracer)(),$=H.getActiveScopeSpan(),L={params:S,prerenderManifest:k,renderOpts:{experimental:{authInterrupts:!!R.experimental.authInterrupts},cacheComponents:!!R.cacheComponents,supportsDynamicResponse:q,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:R.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,a)=>N.onRequestError(e,t,n,a,b)},sharedContext:{buildId:w}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),W=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>N.handle(W,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=r.get("next.route");if(n){let t=`${U} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${U} ${x}`)}),o=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&C&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let l=L.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let d=L.renderOpts.collectedTags;if(!_)return await (0,p.sendResponse)(V,K,s,L.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,n=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:y.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await N.onRequestError(e,t,{routerKind:"App Router",routePath:x,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:I,isOnDemandRevalidate:C})},!1,b),t}},u=await N.handleResponse({req:e,nextConfig:R,cacheKey:M,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:k,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,responseGenerator:d,waitUntil:n.waitUntil,isMinimalMode:o});if(!_)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==y.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",C?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&_||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};$?await l($):await H.withPropagatedContext(e.headers,()=>H.trace(u.BaseServerSpan.handleRequest,{spanName:`${U} ${x}`,kind:s.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await N.onRequestError(e,t,{routerKind:"App Router",routePath:T,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:I,isOnDemandRevalidate:C})},!1,b),_)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>F,"patchFetch",()=>_,"routeModule",()=>N,"serverHooks",()=>T,"workAsyncStorage",()=>D,"workUnitAsyncStorage",()=>P],3089)}];
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function n(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function a(){let e=n(),a=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(a)?a:e}function s(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>s,"getPackageDir",()=>a,"getSlycodeRoot",()=>n])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),n=e.i(46676),a=e.i(7367);function s(){return r.default.join((0,a.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,a.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,a.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),n={};Function("module","exports",r)(n,n);let a=n.exports;if(a?.skills)return{skills:a.skills,actions:a.actions||[],agents:a.agents||[],mcp:a.mcp||[]}}}catch{}return null}function o(e,a){let s=[],i="skill"===a?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return s;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===a){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,n.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:a,path:d,frontmatter:c,isValid:(0,n.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),n=i(),a=o(e,"skill"),l=o(e,"agent"),d=function(e){let n=r.default.join(e,"mcp"),a=[];try{if(!t.default.existsSync(n))return a;for(let e of t.default.readdirSync(n,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(n,e.name),o=t.default.readFileSync(i,"utf-8");try{s=JSON.parse(o)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");a.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return a}(e);if(n){if(n.skills){let e=new Set(n.skills);a=a.filter(t=>e.has(t.name))}if(n.agents){let e=new Set(n.agents);l=l.filter(t=>e.has(t.name))}if(n.mcp){let e=new Set(n.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:a,agents:l,mcp:d}}function d(){let e=s(),t=i(),r=o(e,"skill"),n=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);n=n.filter(t=>e.has(t.name))}}return[...r,...n]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),n=e.i(14747),a=e.i(46676),s=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,n=0,a=i){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:a.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);s.push({name:"Stale Cards",weight:a.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:a.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:a.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:a.nonCompliantFrontmatter,value:n,maxValue:f});let m=0;for(let e of s)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:s}}var l=e.i(7367);function d(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?n.default.dirname(e):e}let u=d(),c=n.default.join(u,"projects","registry.json");async function p(){try{let e=await t.promises.readFile(c,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${c}`)}}async function f(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(c,r,"utf-8")}async function m(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function h(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function g(e,t,r){let a=n.default.join(e,"documentation","backlog.json"),s=await h(a);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function y(e,t){let r=n.default.join(e,"documentation","designs.json"),a=await h(r);return a?a.map(e=>({...e,projectId:t})):[]}async function x(e,t){let r=n.default.join(e,"documentation","features.json"),a=await h(r);return a?a.map(e=>({...e,projectId:t})):[]}async function v(e){let t=e.path;if(!await m(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[n,s,i]=await Promise.all([g(t,e.id,e.name),y(t,e.id),x(t,e.id)]),o=(0,a.scanProjectAssets)(t,e.id),l=(0,a.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:n,designs:s,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function w(){let e=await p();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>v(e)),r=await Promise.all(t),i=(0,s.getStoreAssets)(),u=["skill","agent"],c=0,f=[];for(let t of["claude","agents"])for(let r of u){let n=i.filter(e=>e.type===r),s=new Map;for(let n of e.projects){let e=(0,a.scanProviderAssets)(n.path,t);s.set(n.id,e.filter(e=>e.type===r))}let o=(0,a.buildStoreAssetMatrix)(n,s,e.projects,r);f.push(...o)}for(let e of f)for(let t of e.cells)"outdated"===t.status&&c++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of f)for(let n of r.cells)n.projectId===e.id&&"outdated"===n.status&&t++;e.healthScore=function(e,t,r=0,n){if(!t)return o(e,0,0,0,void 0);let a=[...t.skills,...t.agents];return o(e,r,a.length,a.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let m=0,g=0;for(let e of r){if(!e.accessible)continue;let t=n.default.join(e.path,"documentation","kanban.json"),r=await h(t);if(r?.stages){m+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);g+=e.length+t.length}}let y=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),x=(0,l.getBridgeUrl)();try{let e=await fetch(`${x}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),n={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];n[t]=(n[t]||0)+1}for(let e of r)e.activeSessions=n[e.id]??0}}catch{}let w=d();return{projects:r,totalBacklogItems:m,activeItems:g,totalOutdatedAssets:c,totalUncommitted:y,lastRefresh:new Date().toISOString(),slycodeRoot:w,projectsDir:n.default.dirname(w)}}e.s(["getRepoRoot",()=>d,"loadDashboardData",()=>w,"loadRegistry",()=>p,"saveRegistry",()=>f],48044)},1365,e=>{"use strict";var t=e.i(22734),r=e.i(14747);let n=(0,e.i(7367).getSlycodeRoot)(),a=r.default.join(n,"documentation","events.json");function s(){try{if(!t.default.existsSync(a))return[];let e=t.default.readFileSync(a,"utf-8"),r=JSON.parse(e);return Array.isArray(r)?r:[]}catch{return[]}}function i(e){let n,i=s(),o={id:`evt-${Date.now()}-${Math.random().toString(36).slice(2,6)}`,...e};return i.push(o),i.length>500&&i.splice(0,i.length-500),n=r.default.dirname(a),t.default.existsSync(n)||t.default.mkdirSync(n,{recursive:!0}),t.default.writeFileSync(a,JSON.stringify(i,null,2)),o}function o(e={}){let t=s();if(e.project&&(t=t.filter(t=>t.project===e.project)),e.type&&(t=t.filter(t=>t.type===e.type)),e.since){let r=new Date(e.since).getTime();t=t.filter(e=>new Date(e.timestamp).getTime()>=r)}return t.reverse(),e.limit&&e.limit>0&&(t=t.slice(0,e.limit)),t}e.s(["appendEvent",()=>i,"queryEvents",()=>o])},3089,e=>{"use strict";var t=e.i(47909),r=e.i(74017),n=e.i(96250),a=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var y=e.i(220),x=e.i(89171),v=e.i(22734),w=e.i(14747),S=e.i(73178),R=e.i(46676),j=e.i(7367),E=e.i(48044),k=e.i(1365);async function b(){try{let e=(0,S.scanStore)();return x.NextResponse.json(e)}catch(e){return console.error("Store scan failed:",e),x.NextResponse.json({error:"Failed to scan store",details:String(e)},{status:500})}}async function C(e){try{let{projectPath:t,provider:r,assetType:n,assetName:a,sourceProjectId:s,skillMainOnly:i}=await e.json();if(!r||!n||!a)return x.NextResponse.json({error:"provider, assetType, and assetName are required"},{status:400});let o=t;if(!o&&s){let e=(await (0,E.loadRegistry)()).projects.find(e=>e.id===s);e&&(o=e.path)}if(!o)return x.NextResponse.json({error:"Either projectPath or sourceProjectId is required"},{status:400});(0,R.importAssetToStore)(o,r,n,a,{skillMainOnly:i??!0}),(0,k.appendEvent)({type:"skill_imported",project:s||"unknown",detail:`Imported ${n} '${a}' to store`,timestamp:new Date().toISOString()});let l=(0,S.scanStore)();return x.NextResponse.json({success:!0,storeData:l})}catch(e){return console.error("Store import failed:",e),x.NextResponse.json({error:"Failed to import to store",details:String(e)},{status:500})}}async function A(e){try{let{assetType:t,assetName:r}=await e.json();if(!t||!r)return x.NextResponse.json({error:"assetType and assetName are required"},{status:400});let n=(0,j.getSlycodeRoot)(),a="skill"===t?"skills":"agents";if("skill"===t){let e=w.default.join(n,"store",a,r);v.default.existsSync(e)&&v.default.rmSync(e,{recursive:!0,force:!0})}else{let e=w.default.join(n,"store",a,`${r}.md`);v.default.existsSync(e)&&v.default.unlinkSync(e)}(0,k.appendEvent)({type:"skill_removed",project:"store",detail:`Deleted ${t} '${r}' from store`,timestamp:new Date().toISOString()});let s=(0,S.scanStore)();return x.NextResponse.json({success:!0,storeData:s})}catch(e){return console.error("Store delete failed:",e),x.NextResponse.json({error:"Failed to delete from store",details:String(e)},{status:500})}}e.s(["DELETE",()=>A,"GET",()=>b,"POST",()=>C,"dynamic",0,"force-dynamic"],1972);var O=e.i(1972);let N=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/cli-assets/store/route",pathname:"/api/cli-assets/store",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/cli-assets/store/route.ts",nextConfigOutput:"standalone",userland:O}),{workAsyncStorage:D,workUnitAsyncStorage:P,serverHooks:T}=N;function _(){return(0,n.patchFetch)({workAsyncStorage:D,workUnitAsyncStorage:P})}async function F(e,t,n){N.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let x="/api/cli-assets/store/route";x=x.replace(/\/index$/,"")||"/";let v=await N.prepare(e,t,{srcPage:x,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:w,params:S,nextConfig:R,parsedUrl:j,isDraftMode:E,prerenderManifest:k,routerServerContext:b,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,resolvedPathname:O,clientReferenceManifest:D,serverActionsManifest:P}=v,T=(0,o.normalizeAppPath)(x),_=!!(k.dynamicRoutes[T]||k.routes[O]),F=async()=>((null==b?void 0:b.render404)?await b.render404(e,t,j,!1):t.end("This page could not be found"),null);if(_&&!E){let e=!!k.routes[O],t=k.dynamicRoutes[T];if(t&&!1===t.fallback&&!e){if(R.experimental.adapterPath)return await F();throw new g.NoFallbackError}}let M=null;!_||N.isDev||E||(M="/index"===(M=O)?"/":M);let q=!0===N.isDev||!_,U=_&&!q;P&&D&&(0,i.setManifestsSingleton)({page:x,clientReferenceManifest:D,serverActionsManifest:P});let I=e.method||"GET",H=(0,s.getTracer)(),$=H.getActiveScopeSpan(),L={params:S,prerenderManifest:k,renderOpts:{experimental:{authInterrupts:!!R.experimental.authInterrupts},cacheComponents:!!R.cacheComponents,supportsDynamicResponse:q,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:R.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,a)=>N.onRequestError(e,t,n,a,b)},sharedContext:{buildId:w}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>N.handle(B,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=r.get("next.route");if(n){let t=`${I} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${I} ${x}`)}),o=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&C&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let l=L.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let d=L.renderOpts.collectedTags;if(!_)return await (0,p.sendResponse)(V,K,s,L.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,n=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:y.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await N.onRequestError(e,t,{routerKind:"App Router",routePath:x,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:C})},!1,b),t}},u=await N.handleResponse({req:e,nextConfig:R,cacheKey:M,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:k,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,responseGenerator:d,waitUntil:n.waitUntil,isMinimalMode:o});if(!_)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==y.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",C?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&_||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};$?await l($):await H.withPropagatedContext(e.headers,()=>H.trace(u.BaseServerSpan.handleRequest,{spanName:`${I} ${x}`,kind:s.SpanKind.SERVER,attributes:{"http.method":I,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await N.onRequestError(e,t,{routerKind:"App Router",routePath:T,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:C})},!1,b),_)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>F,"patchFetch",()=>_,"routeModule",()=>N,"serverHooks",()=>T,"workAsyncStorage",()=>D,"workUnitAsyncStorage",()=>P],3089)}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__949bb248._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function n(){let e=a(),n=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(n)?n:e}e.s(["getPackageDir",()=>n,"getSlycodeRoot",()=>a])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),a=e.i(46676),n=e.i(7367);function s(){return r.default.join((0,n.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,n.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,n.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),a={};Function("module","exports",r)(a,a);let n=a.exports;if(n?.skills)return{skills:n.skills,actions:n.actions||[],agents:n.agents||[],mcp:n.mcp||[]}}}catch{}return null}function o(e,n){let s=[],i="skill"===n?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return s;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===n){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,a.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:n,path:d,frontmatter:c,isValid:(0,a.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),a=i(),n=o(e,"skill"),l=o(e,"agent"),d=function(e){let a=r.default.join(e,"mcp"),n=[];try{if(!t.default.existsSync(a))return n;for(let e of t.default.readdirSync(a,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(a,e.name),o=t.default.readFileSync(i,"utf-8");try{s=JSON.parse(o)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");n.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return n}(e);if(a){if(a.skills){let e=new Set(a.skills);n=n.filter(t=>e.has(t.name))}if(a.agents){let e=new Set(a.agents);l=l.filter(t=>e.has(t.name))}if(a.mcp){let e=new Set(a.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:n,agents:l,mcp:d}}function d(){let e=s(),t=i(),r=o(e,"skill"),a=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);a=a.filter(t=>e.has(t.name))}}return[...r,...a]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),a=e.i(14747),n=e.i(46676),s=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,a=0,n=i){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:n.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);s.push({name:"Stale Cards",weight:n.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:n.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:n.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:n.nonCompliantFrontmatter,value:a,maxValue:f});let m=0;for(let e of s)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:s}}function l(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?a.default.dirname(e):e}let d=l(),u=a.default.join(d,"projects","registry.json");async function c(){try{let e=await t.promises.readFile(u,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${u}`)}}async function p(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(u,r,"utf-8")}async function f(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function m(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function h(e,t,r){let n=a.default.join(e,"documentation","backlog.json"),s=await m(n);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function g(e,t){let r=a.default.join(e,"documentation","designs.json"),n=await m(r);return n?n.map(e=>({...e,projectId:t})):[]}async function x(e,t){let r=a.default.join(e,"documentation","features.json"),n=await m(r);return n?n.map(e=>({...e,projectId:t})):[]}async function y(e){let t=e.path;if(!await f(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[a,s,i]=await Promise.all([h(t,e.id,e.name),g(t,e.id),x(t,e.id)]),o=(0,n.scanProjectAssets)(t,e.id),l=(0,n.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:a,designs:s,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function w(){let e=await c();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>y(e)),r=await Promise.all(t),i=(0,s.getStoreAssets)(),d=["skill","agent"],u=0,p=[];for(let t of["claude","agents"])for(let r of d){let a=i.filter(e=>e.type===r),s=new Map;for(let a of e.projects){let e=(0,n.scanProviderAssets)(a.path,t);s.set(a.id,e.filter(e=>e.type===r))}let o=(0,n.buildStoreAssetMatrix)(a,s,e.projects,r);p.push(...o)}for(let e of p)for(let t of e.cells)"outdated"===t.status&&u++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of p)for(let a of r.cells)a.projectId===e.id&&"outdated"===a.status&&t++;e.healthScore=function(e,t,r=0,a){if(!t)return o(e,0,0,0,void 0);let n=[...t.skills,...t.agents];return o(e,r,n.length,n.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let f=0,h=0;for(let e of r){if(!e.accessible)continue;let t=a.default.join(e.path,"documentation","kanban.json"),r=await m(t);if(r?.stages){f+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);h+=e.length+t.length}}let g=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),x=process.env.BRIDGE_URL||"http://127.0.0.1:7592";try{let e=await fetch(`${x}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),a={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];a[t]=(a[t]||0)+1}for(let e of r)e.activeSessions=a[e.id]??0}}catch{}let w=l();return{projects:r,totalBacklogItems:f,activeItems:h,totalOutdatedAssets:u,totalUncommitted:g,lastRefresh:new Date().toISOString(),slycodeRoot:w,projectsDir:a.default.dirname(w)}}e.s(["getRepoRoot",()=>l,"loadDashboardData",()=>w,"loadRegistry",()=>c,"saveRegistry",()=>p],48044)},98036,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),w=e.i(33405),v=e.i(48044);async function R(){try{let e=await (0,v.loadRegistry)(),t={};for(let r of e.projects)t[r.id]=function(e){try{return(0,w.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3,windowsHide:!0}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(r.path);return y.NextResponse.json(t)}catch(e){return console.error("Failed to get git status:",e),y.NextResponse.json({error:"Failed to get git status",details:String(e)},{status:500})}}e.s(["GET",()=>R,"dynamic",0,"force-dynamic"],46438);var S=e.i(46438);let j=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/git-status/route",pathname:"/api/git-status",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/git-status/route.ts",nextConfigOutput:"standalone",userland:S}),{workAsyncStorage:E,workUnitAsyncStorage:b,serverHooks:C}=j;function k(){return(0,a.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:b})}async function A(e,t,a){j.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/git-status/route";y=y.replace(/\/index$/,"")||"/";let w=await j.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!w)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:v,params:R,nextConfig:S,parsedUrl:E,isDraftMode:b,prerenderManifest:C,routerServerContext:k,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,resolvedPathname:P,clientReferenceManifest:_,serverActionsManifest:N}=w,D=(0,o.normalizeAppPath)(y),M=!!(C.dynamicRoutes[D]||C.routes[P]),F=async()=>((null==k?void 0:k.render404)?await k.render404(e,t,E,!1):t.end("This page could not be found"),null);if(M&&!b){let e=!!C.routes[P],t=C.dynamicRoutes[D];if(t&&!1===t.fallback&&!e){if(S.experimental.adapterPath)return await F();throw new g.NoFallbackError}}let T=null;!M||j.isDev||b||(T="/index"===(T=P)?"/":T);let q=!0===j.isDev||!M,H=M&&!q;N&&_&&(0,i.setManifestsSingleton)({page:y,clientReferenceManifest:_,serverActionsManifest:N});let U=e.method||"GET",I=(0,s.getTracer)(),L=I.getActiveScopeSpan(),$={params:R,prerenderManifest:C,renderOpts:{experimental:{authInterrupts:!!S.experimental.authInterrupts},cacheComponents:!!S.cacheComponents,supportsDynamicResponse:q,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:S.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>j.onRequestError(e,t,a,n,k)},sharedContext:{buildId:v}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),W=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>j.handle(W,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=I.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${U} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${U} ${y}`)}),o=!!(0,n.getRequestMeta)(e,"minimalMode"),l=async n=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&A&&O&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(n);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=$.renderOpts.collectedTags;if(!M)return await (0,p.sendResponse)(V,K,s,$.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await j.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:H,isOnDemandRevalidate:A})},!1,k),t}},u=await j.handleResponse({req:e,nextConfig:S,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:o});if(!M)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",A?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),b&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&M||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};L?await l(L):await I.withPropagatedContext(e.headers,()=>I.trace(u.BaseServerSpan.handleRequest,{spanName:`${U} ${y}`,kind:s.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await j.onRequestError(e,t,{routerKind:"App Router",routePath:D,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:H,isOnDemandRevalidate:A})},!1,k),M)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>A,"patchFetch",()=>k,"routeModule",()=>j,"serverHooks",()=>C,"workAsyncStorage",()=>E,"workUnitAsyncStorage",()=>b],98036)}];
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},7367,e=>{"use strict";var t=e.i(14747),r=e.i(22734);function a(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return(console.warn("[paths] SLYCODE_HOME not set in production — falling back to cwd:",e),e.endsWith("/web")||e.endsWith("\\web"))?t.default.dirname(e):e}function n(){let e=a(),n=t.default.join(e,"node_modules","@slycode","slycode","dist");return r.default.existsSync(n)?n:e}function s(){return process.env.BRIDGE_URL?process.env.BRIDGE_URL:"http://127.0.0.1:3004"}e.s(["getBridgeUrl",()=>s,"getPackageDir",()=>n,"getSlycodeRoot",()=>a])},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},54799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},73178,e=>{"use strict";var t=e.i(22734),r=e.i(14747),a=e.i(46676),n=e.i(7367);function s(){return r.default.join((0,n.getSlycodeRoot)(),"store")}function i(){for(let e of[r.default.join((0,n.getSlycodeRoot)(),"build","store-manifest.js"),r.default.join((0,n.getSlycodeRoot)(),"node_modules","@slycode","slycode","build","store-manifest.js")])try{if(t.default.existsSync(e)){let r=t.default.readFileSync(e,"utf-8"),a={};Function("module","exports",r)(a,a);let n=a.exports;if(n?.skills)return{skills:n.skills,actions:n.actions||[],agents:n.agents||[],mcp:n.mcp||[]}}}catch{}return null}function o(e,n){let s=[],i="skill"===n?"skills":"agents",o=r.default.join(e,i);try{if(!t.default.existsSync(o))return s;for(let e of t.default.readdirSync(o,{withFileTypes:!0})){let l,d;if("skill"===n){if(!e.isDirectory()||(l=r.default.join(o,e.name,"SKILL.md"),d=r.default.join(i,e.name,"SKILL.md"),!t.default.existsSync(l)))continue}else{if(!e.isFile()||!e.name.endsWith(".md"))continue;l=r.default.join(o,e.name),d=r.default.join(i,e.name)}let u=t.default.readFileSync(l,"utf-8"),c=(0,a.parseFrontmatter)(u),p=c?.name||e.name.replace(/\.md$/,"");s.push({name:p,type:n,path:d,frontmatter:c,isValid:(0,a.validateFrontmatter)(c)})}}catch{}return s.sort((e,t)=>e.name.localeCompare(t.name))}function l(){let e=s(),a=i(),n=o(e,"skill"),l=o(e,"agent"),d=function(e){let a=r.default.join(e,"mcp"),n=[];try{if(!t.default.existsSync(a))return n;for(let e of t.default.readdirSync(a,{withFileTypes:!0})){let s;if(!e.isFile()||!e.name.endsWith(".json"))continue;let i=r.default.join(a,e.name),o=t.default.readFileSync(i,"utf-8");try{s=JSON.parse(o)}catch{continue}let l=s.name||e.name.replace(/\.json$/,"");n.push({name:l,type:"mcp",path:r.default.join("mcp",e.name),frontmatter:{name:l,version:s.version,description:s.description,updated:s.updated},isValid:!!(s.name&&s.command)})}}catch{}return n}(e);if(a){if(a.skills){let e=new Set(a.skills);n=n.filter(t=>e.has(t.name))}if(a.agents){let e=new Set(a.agents);l=l.filter(t=>e.has(t.name))}if(a.mcp){let e=new Set(a.mcp);d=d.filter(t=>e.has(t.name))}}return{skills:n,agents:l,mcp:d}}function d(){let e=s(),t=i(),r=o(e,"skill"),a=o(e,"agent");if(t){if(t.skills){let e=new Set(t.skills);r=r.filter(t=>e.has(t.name))}if(t.agents){let e=new Set(t.agents);a=a.filter(t=>e.has(t.name))}}return[...r,...a]}e.s(["getStoreAssets",()=>d,"scanStore",()=>l])},48044,e=>{"use strict";var t=e.i(22734),r=e.i(33405),a=e.i(14747),n=e.i(46676),s=e.i(73178);let i={outdatedAssets:.3,staleCards:.15,unresolvedProblems:.25,missingClaudeMd:.1,nonCompliantFrontmatter:.2};function o(e,t=0,r=0,a=0,n=i){let s=[],l=Math.max(r,1);s.push({name:"Outdated Assets",weight:n.outdatedAssets,value:t,maxValue:l});let d=Date.now(),u=[...e.backlog],c=u.filter(e=>(d-new Date(e.created_at).getTime())/864e5>14&&"done"!==e.status).length,p=Math.max(u.length,1);s.push({name:"Stale Cards",weight:n.staleCards,value:c,maxValue:p}),s.push({name:"Unresolved Problems",weight:n.unresolvedProblems,value:0,maxValue:1}),s.push({name:"Missing CLAUDE.md",weight:n.missingClaudeMd,value:+!e.hasClaudeMd,maxValue:1});let f=Math.max(r,1);s.push({name:"Non-compliant Frontmatter",weight:n.nonCompliantFrontmatter,value:a,maxValue:f});let m=0;for(let e of s)m+=Math.min(e.maxValue>0?e.value/e.maxValue:0,1)*e.weight;let h=Math.round(Math.max(0,(1-m)*100));return{score:h,level:h>=80?"green":h>=50?"amber":"red",factors:s}}var l=e.i(7367);function d(){if(process.env.SLYCODE_HOME)return process.env.SLYCODE_HOME;let e=process.cwd();return e.endsWith("/web")||e.endsWith("\\web")?a.default.dirname(e):e}let u=d(),c=a.default.join(u,"projects","registry.json");async function p(){try{let e=await t.promises.readFile(c,"utf-8");return JSON.parse(e)}catch(e){throw console.error("Failed to load registry:",e),Error(`Failed to load registry from ${c}`)}}async function f(e){let r=JSON.stringify(e,null,2)+"\n";await t.promises.writeFile(c,r,"utf-8")}async function m(e){try{return(await t.promises.stat(e)).isDirectory()}catch{return!1}}async function h(e){try{let r=await t.promises.readFile(e,"utf-8");return JSON.parse(r)}catch{return null}}async function g(e,t,r){let n=a.default.join(e,"documentation","backlog.json"),s=await h(n);return s?s.map(e=>({...e,projectId:t,projectName:r})):[]}async function x(e,t){let r=a.default.join(e,"documentation","designs.json"),n=await h(r);return n?n.map(e=>({...e,projectId:t})):[]}async function y(e,t){let r=a.default.join(e,"documentation","features.json"),n=await h(r);return n?n.map(e=>({...e,projectId:t})):[]}async function v(e){let t=e.path;if(!await m(t))return{...e,backlog:[],designs:[],features:[],accessible:!1,error:`Path not accessible: ${t}`};let[a,s,i]=await Promise.all([g(t,e.id,e.name),x(t,e.id),y(t,e.id)]),o=(0,n.scanProjectAssets)(t,e.id),l=(0,n.detectPlatforms)(t),d=function(e){try{return(0,r.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(t);return{...e,backlog:a,designs:s,features:i,assets:o,platforms:l,gitUncommitted:d>=0?d:void 0,accessible:!0}}async function w(){let e=await p();for(let t=0;t<e.projects.length;t++)void 0===e.projects[t].order&&(e.projects[t].order=t);e.projects.sort((e,t)=>(e.order??0)-(t.order??0));let t=e.projects.map(e=>v(e)),r=await Promise.all(t),i=(0,s.getStoreAssets)(),u=["skill","agent"],c=0,f=[];for(let t of["claude","agents"])for(let r of u){let a=i.filter(e=>e.type===r),s=new Map;for(let a of e.projects){let e=(0,n.scanProviderAssets)(a.path,t);s.set(a.id,e.filter(e=>e.type===r))}let o=(0,n.buildStoreAssetMatrix)(a,s,e.projects,r);f.push(...o)}for(let e of f)for(let t of e.cells)"outdated"===t.status&&c++;for(let e of r){if(!e.accessible)continue;let t=0;for(let r of f)for(let a of r.cells)a.projectId===e.id&&"outdated"===a.status&&t++;e.healthScore=function(e,t,r=0,a){if(!t)return o(e,0,0,0,void 0);let n=[...t.skills,...t.agents];return o(e,r,n.length,n.filter(e=>!e.isValid).length,void 0)}(e,e.assets,t)}let m=0,g=0;for(let e of r){if(!e.accessible)continue;let t=a.default.join(e.path,"documentation","kanban.json"),r=await h(t);if(r?.stages){m+=(r.stages.backlog||[]).filter(e=>!e.archived).length;let e=(r.stages.implementation||[]).filter(e=>!e.archived),t=(r.stages.testing||[]).filter(e=>!e.archived);g+=e.length+t.length}}let x=r.reduce((e,t)=>e+(t.gitUncommitted&&t.gitUncommitted>0?t.gitUncommitted:0),0),y=(0,l.getBridgeUrl)();try{let e=await fetch(`${y}/stats`,{signal:AbortSignal.timeout(2e3)});if(e.ok){let t=await e.json(),a={};for(let e of t.sessions||[])if(e.isActive){let t=e.name.split(":")[0];a[t]=(a[t]||0)+1}for(let e of r)e.activeSessions=a[e.id]??0}}catch{}let w=d();return{projects:r,totalBacklogItems:m,activeItems:g,totalOutdatedAssets:c,totalUncommitted:x,lastRefresh:new Date().toISOString(),slycodeRoot:w,projectsDir:a.default.dirname(w)}}e.s(["getRepoRoot",()=>d,"loadDashboardData",()=>w,"loadRegistry",()=>p,"saveRegistry",()=>f],48044)},98036,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),m=e.i(74838),h=e.i(10372),g=e.i(93695);e.i(52474);var x=e.i(220),y=e.i(89171),v=e.i(33405),w=e.i(48044);async function R(){try{let e=await (0,w.loadRegistry)(),t={};for(let r of e.projects)t[r.id]=function(e){try{return(0,v.execSync)("git status --porcelain",{cwd:e,encoding:"utf-8",timeout:5e3,windowsHide:!0}).split("\n").filter(e=>e.trim().length>0).length}catch{return -1}}(r.path);return y.NextResponse.json(t)}catch(e){return console.error("Failed to get git status:",e),y.NextResponse.json({error:"Failed to get git status",details:String(e)},{status:500})}}e.s(["GET",()=>R,"dynamic",0,"force-dynamic"],46438);var S=e.i(46438);let j=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/git-status/route",pathname:"/api/git-status",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/git-status/route.ts",nextConfigOutput:"standalone",userland:S}),{workAsyncStorage:E,workUnitAsyncStorage:b,serverHooks:C}=j;function k(){return(0,a.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:b})}async function A(e,t,a){j.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/git-status/route";y=y.replace(/\/index$/,"")||"/";let v=await j.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:w,params:R,nextConfig:S,parsedUrl:E,isDraftMode:b,prerenderManifest:C,routerServerContext:k,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,resolvedPathname:P,clientReferenceManifest:_,serverActionsManifest:D}=v,N=(0,o.normalizeAppPath)(y),M=!!(C.dynamicRoutes[N]||C.routes[P]),F=async()=>((null==k?void 0:k.render404)?await k.render404(e,t,E,!1):t.end("This page could not be found"),null);if(M&&!b){let e=!!C.routes[P],t=C.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(S.experimental.adapterPath)return await F();throw new g.NoFallbackError}}let T=null;!M||j.isDev||b||(T="/index"===(T=P)?"/":T);let U=!0===j.isDev||!M,q=M&&!U;D&&_&&(0,i.setManifestsSingleton)({page:y,clientReferenceManifest:_,serverActionsManifest:D});let H=e.method||"GET",I=(0,s.getTracer)(),L=I.getActiveScopeSpan(),$={params:R,prerenderManifest:C,renderOpts:{experimental:{authInterrupts:!!S.experimental.authInterrupts},cacheComponents:!!S.cacheComponents,supportsDynamicResponse:U,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:S.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>j.onRequestError(e,t,a,n,k)},sharedContext:{buildId:w}},V=new l.NodeNextRequest(e),K=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let i=async e=>j.handle(B,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=I.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${H} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${H} ${y}`)}),o=!!(0,n.getRequestMeta)(e,"minimalMode"),l=async n=>{var s,l;let d=async({previousCacheEntry:r})=>{try{if(!o&&A&&O&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(n);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let d=$.renderOpts.collectedTags;if(!M)return await (0,p.sendResponse)(V,K,s,$.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);d&&(t[h.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await j.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:A})},!1,k),t}},u=await j.handleResponse({req:e,nextConfig:S,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:A,revalidateOnlyGenerated:O,responseGenerator:d,waitUntil:a.waitUntil,isMinimalMode:o});if(!M)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",A?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),b&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return o&&M||g.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(V,K,new Response(u.value.body,{headers:g,status:u.value.status||200})),null};L?await l(L):await I.withPropagatedContext(e.headers,()=>I.trace(u.BaseServerSpan.handleRequest,{spanName:`${H} ${y}`,kind:s.SpanKind.SERVER,attributes:{"http.method":H,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await j.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:A})},!1,k),M)throw t;return await (0,p.sendResponse)(V,K,new Response(null,{status:500})),null}}e.s(["handler",()=>A,"patchFetch",()=>k,"routeModule",()=>j,"serverHooks",()=>C,"workAsyncStorage",()=>E,"workUnitAsyncStorage",()=>b],98036)}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__aa814a86._.js.map
|