constellai 0.3.8 → 0.3.10
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/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +2 -2
- package/.next/prerender-manifest.json +3 -3
- package/.next/server/app/(app)/activity/page.js +2 -2
- package/.next/server/app/(app)/activity/page.js.nft.json +1 -1
- package/.next/server/app/(app)/activity/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/agents/[handle]/page.js +3 -3
- package/.next/server/app/(app)/agents/[handle]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/agents/[handle]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/code/page.js +2 -2
- package/.next/server/app/(app)/code/page.js.nft.json +1 -1
- package/.next/server/app/(app)/code/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/config/page.js +2 -2
- package/.next/server/app/(app)/config/page.js.nft.json +1 -1
- package/.next/server/app/(app)/config/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/costs/page.js +2 -2
- package/.next/server/app/(app)/costs/page.js.nft.json +1 -1
- package/.next/server/app/(app)/costs/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/cron/page.js +2 -2
- package/.next/server/app/(app)/cron/page.js.nft.json +1 -1
- package/.next/server/app/(app)/cron/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/dashboard/page.js +2 -2
- package/.next/server/app/(app)/dashboard/page.js.nft.json +1 -1
- package/.next/server/app/(app)/dashboard/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/design/page.js +3 -3
- package/.next/server/app/(app)/design/page.js.nft.json +1 -1
- package/.next/server/app/(app)/design/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/docs/[id]/page.js +2 -2
- package/.next/server/app/(app)/docs/[id]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/docs/[id]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/docs/page.js +2 -2
- package/.next/server/app/(app)/docs/page.js.nft.json +1 -1
- package/.next/server/app/(app)/docs/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/github/page.js +2 -2
- package/.next/server/app/(app)/github/page.js.nft.json +1 -1
- package/.next/server/app/(app)/github/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/goals/page.js +2 -2
- package/.next/server/app/(app)/goals/page.js.nft.json +1 -1
- package/.next/server/app/(app)/goals/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/inbox/page.js +2 -2
- package/.next/server/app/(app)/inbox/page.js.nft.json +1 -1
- package/.next/server/app/(app)/inbox/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/knowledge/page.js +3 -3
- package/.next/server/app/(app)/knowledge/page.js.nft.json +1 -1
- package/.next/server/app/(app)/knowledge/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/models/page.js +2 -2
- package/.next/server/app/(app)/models/page.js.nft.json +1 -1
- package/.next/server/app/(app)/models/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/notifications/page.js +2 -2
- package/.next/server/app/(app)/notifications/page.js.nft.json +1 -1
- package/.next/server/app/(app)/notifications/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/org/page.js +4 -4
- package/.next/server/app/(app)/org/page.js.nft.json +1 -1
- package/.next/server/app/(app)/org/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/organizations/page.js +1 -1
- package/.next/server/app/(app)/organizations/page.js.nft.json +1 -1
- package/.next/server/app/(app)/organizations/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/page.js +3 -3
- package/.next/server/app/(app)/page.js.nft.json +1 -1
- package/.next/server/app/(app)/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/planner/page.js +2 -2
- package/.next/server/app/(app)/planner/page.js.nft.json +1 -1
- package/.next/server/app/(app)/planner/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/plugins/page.js +2 -2
- package/.next/server/app/(app)/plugins/page.js.nft.json +1 -1
- package/.next/server/app/(app)/plugins/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/pm/page.js +2 -2
- package/.next/server/app/(app)/pm/page.js.nft.json +1 -1
- package/.next/server/app/(app)/pm/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/prepare-deploy/page.js +3 -3
- package/.next/server/app/(app)/prepare-deploy/page.js.nft.json +1 -1
- package/.next/server/app/(app)/prepare-deploy/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/profile/page.js +2 -2
- package/.next/server/app/(app)/profile/page.js.nft.json +1 -1
- package/.next/server/app/(app)/profile/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/pulse/page.js +2 -2
- package/.next/server/app/(app)/pulse/page.js.nft.json +1 -1
- package/.next/server/app/(app)/pulse/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/reports/[id]/page.js +2 -2
- package/.next/server/app/(app)/reports/[id]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/reports/[id]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/reports/page.js +3 -3
- package/.next/server/app/(app)/reports/page.js.nft.json +1 -1
- package/.next/server/app/(app)/reports/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/routines/page.js +2 -2
- package/.next/server/app/(app)/routines/page.js.nft.json +1 -1
- package/.next/server/app/(app)/routines/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/search/page.js +2 -2
- package/.next/server/app/(app)/search/page.js.nft.json +1 -1
- package/.next/server/app/(app)/search/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/security/page.js +2 -2
- package/.next/server/app/(app)/security/page.js.nft.json +1 -1
- package/.next/server/app/(app)/security/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/skills/page.js +3 -3
- package/.next/server/app/(app)/skills/page.js.nft.json +1 -1
- package/.next/server/app/(app)/skills/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/tasks/page.js +2 -2
- package/.next/server/app/(app)/tasks/page.js.nft.json +1 -1
- package/.next/server/app/(app)/tasks/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/test-dev/page.js +1 -1
- package/.next/server/app/(app)/test-dev/page.js.nft.json +1 -1
- package/.next/server/app/(app)/test-dev/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/update/page.js +2 -2
- package/.next/server/app/(app)/update/page.js.nft.json +1 -1
- package/.next/server/app/(app)/update/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(auth)/login/page.js +2 -2
- package/.next/server/app/(auth)/login/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(auth)/onboarding/page.js +1 -1
- package/.next/server/app/(auth)/onboarding/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_global-error.html +1 -1
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/server/app/api/cron/tick/route.js +2 -2
- package/.next/server/app/api/passkey/authenticate/verify/route.js +1 -1
- package/.next/server/app/api/passkey/register/verify/route.js +1 -1
- package/.next/server/app/api/sync/file/route.js +1 -1
- package/.next/server/app/api/telegram/poll/route.js +3 -3
- package/.next/server/app/api/v1/[[...path]]/route.js +1 -1
- package/.next/server/chunks/1033.js +1 -1
- package/.next/server/chunks/1881.js +1 -0
- package/.next/server/chunks/1986.js +1 -1
- package/.next/server/chunks/2118.js +1 -1
- package/.next/server/chunks/2170.js +1 -0
- package/.next/server/chunks/{1678.js → 2718.js} +16 -16
- package/.next/server/chunks/3987.js +3 -3
- package/.next/server/chunks/4288.js +1 -1
- package/.next/server/chunks/5580.js +12 -0
- package/.next/server/chunks/5878.js +1 -1
- package/.next/server/chunks/6296.js +4 -0
- package/.next/server/chunks/7867.js +1 -1
- package/.next/server/chunks/7905.js +1 -1
- package/.next/server/chunks/8013.js +1 -0
- package/.next/server/chunks/8134.js +1 -1
- package/.next/server/chunks/8211.js +1 -1
- package/.next/server/chunks/8236.js +21 -0
- package/.next/server/chunks/907.js +1 -1
- package/.next/server/chunks/9344.js +3 -3
- package/.next/server/middleware-build-manifest.js +1 -1
- package/.next/server/middleware.js +1 -1
- package/.next/server/pages/500.html +1 -1
- package/.next/server/server-reference-manifest.js +1 -1
- package/.next/server/server-reference-manifest.json +1 -1
- package/.next/static/chunks/1352-1e5e6e2ea57a0821.js +4 -0
- package/.next/static/chunks/2171-7d8bf2df1d540a82.js +1 -0
- package/.next/static/chunks/2636-13f5de5bc9726cc3.js +1 -0
- package/.next/static/chunks/{7218-21f40f9caef5d658.js → 7218-9fbc00e6cec34afa.js} +2 -2
- package/.next/static/chunks/8834-3c7f77ceebbeb079.js +1 -0
- package/.next/static/chunks/app/(app)/activity/{page-ce3fc6003368f592.js → page-c6f3b54a1401c391.js} +1 -1
- package/.next/static/chunks/app/(app)/agents/[handle]/page-38922257bbd82998.js +1 -0
- package/.next/static/chunks/app/(app)/code/page-51869dcdc0b0a50f.js +1 -0
- package/.next/static/chunks/app/(app)/config/page-ccaa231f4f64912a.js +1 -0
- package/.next/static/chunks/app/(app)/costs/page-864fe3407d0dc6c0.js +1 -0
- package/.next/static/chunks/app/(app)/cron/page-7be322a05e559da8.js +1 -0
- package/.next/static/chunks/app/(app)/dashboard/page-f181d957748f8f27.js +1 -0
- package/.next/static/chunks/app/(app)/design/{page-5997054187e59e74.js → page-dac84fe4a5e31454.js} +3 -3
- package/.next/static/chunks/app/(app)/docs/[id]/page-74da9f8a13f14a07.js +1 -0
- package/.next/static/chunks/app/(app)/docs/page-689045673b039708.js +1 -0
- package/.next/static/chunks/app/(app)/github/page-7b8ae16a0cd14bd3.js +1 -0
- package/.next/static/chunks/app/(app)/goals/page-49682d30eb297a16.js +1 -0
- package/.next/static/chunks/app/(app)/inbox/{page-474c3f0a181bbbd3.js → page-000769b0e849a435.js} +2 -2
- package/.next/static/chunks/app/(app)/knowledge/page-c329694479ee85cb.js +1 -0
- package/.next/static/chunks/app/(app)/{layout-720a1171f7152d86.js → layout-21e16931eac987ab.js} +1 -1
- package/.next/static/chunks/app/(app)/models/page-3e92db0acfbf844b.js +1 -0
- package/.next/static/chunks/app/(app)/notifications/page-646bdc5a20cac43b.js +12 -0
- package/.next/static/chunks/app/(app)/org/page-08141e549fea39ad.js +12 -0
- package/.next/static/chunks/app/(app)/organizations/{page-0de7da829c9b2249.js → page-b5617487ef2255ce.js} +1 -1
- package/.next/static/chunks/app/(app)/page-f2a05b3f92886a0c.js +1 -0
- package/.next/static/chunks/app/(app)/planner/{page-0fc0ebe2d338769a.js → page-4241aa863f23a96d.js} +1 -1
- package/.next/static/chunks/app/(app)/plugins/page-2e96b6b32d288dca.js +1 -0
- package/.next/static/chunks/app/(app)/pm/page-182d8faa90ed2643.js +1 -0
- package/.next/static/chunks/app/(app)/prepare-deploy/page-15ba476bf716d7e2.js +1 -0
- package/.next/static/chunks/app/(app)/profile/page-e18ad0668e7e7305.js +1 -0
- package/.next/static/chunks/app/(app)/pulse/page-d528de016fb3ec49.js +1 -0
- package/.next/static/chunks/app/(app)/reports/[id]/page-7be322a05e559da8.js +1 -0
- package/.next/static/chunks/app/(app)/reports/page-67f64d0e809c2bca.js +1 -0
- package/.next/static/chunks/app/(app)/routines/page-cdb5f6e2ca82640b.js +1 -0
- package/.next/static/chunks/app/(app)/search/page-a91bfaab25cd6aff.js +1 -0
- package/.next/static/chunks/app/(app)/security/page-79d44198dd58f2dd.js +1 -0
- package/.next/static/chunks/app/(app)/skills/page-2af4de1e97575285.js +1 -0
- package/.next/static/chunks/app/(app)/tasks/{page-4d535f34ae9c44ca.js → page-c975303be89aaee5.js} +1 -1
- package/.next/static/chunks/app/(app)/test-dev/page-2e0b655d1a79a326.js +1 -0
- package/.next/static/chunks/app/(app)/update/{page-decdb0ece526b50f.js → page-a1f8b007304e9bdc.js} +1 -1
- package/.next/static/chunks/app/(auth)/login/page-a8d0d8f09f9794ef.js +1 -0
- package/.next/static/chunks/app/(auth)/onboarding/page-7ce367a9bc0bcbeb.js +1 -0
- package/.next/trace-build +1 -1
- package/CHANGELOG.md +27 -0
- package/README.md +1 -1
- package/README.pt-BR.md +1 -1
- package/bin/constella.mjs +22 -0
- package/docs/UPDATE.md +15 -3
- package/package.json +1 -1
- package/.next/server/chunks/3392.js +0 -1
- package/.next/server/chunks/6538.js +0 -4
- package/.next/server/chunks/7727.js +0 -1
- package/.next/server/chunks/8237.js +0 -12
- package/.next/server/chunks/939.js +0 -1
- package/.next/server/chunks/9795.js +0 -21
- package/.next/static/chunks/3556-dbb9200143640484.js +0 -1
- package/.next/static/chunks/5523-9c369c915ee6d9c9.js +0 -1
- package/.next/static/chunks/7363-b9ebe28fed23b997.js +0 -1
- package/.next/static/chunks/7621-87d8d0d0568de3ca.js +0 -4
- package/.next/static/chunks/app/(app)/agents/[handle]/page-236e13b8edadd480.js +0 -1
- package/.next/static/chunks/app/(app)/code/page-18ae765c81a2c709.js +0 -1
- package/.next/static/chunks/app/(app)/config/page-8a6fcf6c04337210.js +0 -1
- package/.next/static/chunks/app/(app)/costs/page-230b0ef03a2024b0.js +0 -1
- package/.next/static/chunks/app/(app)/cron/page-ca89769e2522191d.js +0 -1
- package/.next/static/chunks/app/(app)/dashboard/page-6237c3a35cce55ce.js +0 -1
- package/.next/static/chunks/app/(app)/docs/[id]/page-3362d323e0f4dada.js +0 -1
- package/.next/static/chunks/app/(app)/docs/page-d7d8018a7884a4b4.js +0 -1
- package/.next/static/chunks/app/(app)/github/page-f5c1cae725d080fb.js +0 -1
- package/.next/static/chunks/app/(app)/goals/page-95e85ce115ed9ff3.js +0 -1
- package/.next/static/chunks/app/(app)/knowledge/page-08596428ca34b620.js +0 -1
- package/.next/static/chunks/app/(app)/models/page-fa1eb257e6911c9a.js +0 -1
- package/.next/static/chunks/app/(app)/notifications/page-31f2a041bdb497b9.js +0 -12
- package/.next/static/chunks/app/(app)/org/page-666438930ddc4639.js +0 -12
- package/.next/static/chunks/app/(app)/page-bfcf3d25f468240f.js +0 -1
- package/.next/static/chunks/app/(app)/plugins/page-ad369fbfec6f3d1c.js +0 -1
- package/.next/static/chunks/app/(app)/pm/page-bb39c9d9a4f0d597.js +0 -1
- package/.next/static/chunks/app/(app)/prepare-deploy/page-f182991e68b159c1.js +0 -1
- package/.next/static/chunks/app/(app)/profile/page-cf5fe16bfad2a7ba.js +0 -1
- package/.next/static/chunks/app/(app)/pulse/page-03877c467c491e8a.js +0 -1
- package/.next/static/chunks/app/(app)/reports/[id]/page-ca89769e2522191d.js +0 -1
- package/.next/static/chunks/app/(app)/reports/page-7741b6a25e582791.js +0 -1
- package/.next/static/chunks/app/(app)/routines/page-ea83e6337e7502c2.js +0 -1
- package/.next/static/chunks/app/(app)/search/page-5e7f7cf0cc51b76f.js +0 -1
- package/.next/static/chunks/app/(app)/security/page-410144cdc35e19cc.js +0 -1
- package/.next/static/chunks/app/(app)/skills/page-90e5d8a24920c275.js +0 -1
- package/.next/static/chunks/app/(app)/test-dev/page-782c8cadd8a10feb.js +0 -1
- package/.next/static/chunks/app/(auth)/login/page-147a9be880c44d42.js +0 -1
- package/.next/static/chunks/app/(auth)/onboarding/page-8548be7e3ab3659e.js +0 -1
- /package/.next/static/{ehoxBsPzAtE_FyZ2VpMF0 → PjU7M0g-BKQT9AfTuZvgl}/_buildManifest.js +0 -0
- /package/.next/static/{ehoxBsPzAtE_FyZ2VpMF0 → PjU7M0g-BKQT9AfTuZvgl}/_ssgManifest.js +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";(()=>{var a={};a.id=4384,a.ids=[4384],a.modules={261:a=>{a.exports=require("next/dist/shared/lib/router/utils/app-paths")},1302:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>D,patchFetch:()=>C,routeModule:()=>y,serverHooks:()=>B,workAsyncStorage:()=>z,workUnitAsyncStorage:()=>A});var d={};c.r(d),c.d(d,{POST:()=>x});var e=c(16633),f=c(35526),g=c(80445),h=c(49421),i=c(68279),j=c(22827),k=c(261),l=c(45469),m=c(19923),n=c(17653),o=c(70486),p=c(49496),q=c(16674),r=c(11264),s=c(7001),t=c(86439),u=c(4535),v=c(91736),w=c(89258);async function x(a){let b=process.env.CONSTELLA_WORKER_SECRET;if(!b||a.headers.get("x-worker-secret")!==b)return v.NextResponse.json({error:"unauthorized"},{status:401});let{orgId:c,rel:d,event:e}=await a.json().catch(()=>({}));if(!c||!d)return v.NextResponse.json({ok:!1,error:"missing orgId/rel"},{status:400});let f="unlink"===e?await (0,w.eA)(c,d):await (0,w.LV)(c,d);return v.NextResponse.json(f)}let y=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/sync/file/route",pathname:"/api/sync/file",filename:"route",bundlePath:"app/api/sync/file/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"C:\\Users\\Usuario\\Documents\\constella\\src\\app\\api\\sync\\file\\route.ts",nextConfigOutput:"",userland:d,...{}}),{workAsyncStorage:z,workUnitAsyncStorage:A,serverHooks:B}=y;function C(){return(0,g.patchFetch)({workAsyncStorage:z,workUnitAsyncStorage:A})}async function D(a,b,c){c.requestMeta&&(0,h.setRequestMeta)(a,c.requestMeta),y.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/sync/file/route";"/index"===d&&(d="/");let e=await y.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,deploymentId:v,params:w,nextConfig:x,parsedUrl:z,isDraftMode:A,prerenderManifest:B,routerServerContext:C,isOnDemandRevalidate:D,revalidateOnlyGenerated:E,resolvedPathname:F,clientReferenceManifest:G,serverActionsManifest:H}=e,I=(0,k.normalizeAppPath)(d),J=!!(B.dynamicRoutes[I]||B.routes[F]),K=async()=>((null==C?void 0:C.render404)?await C.render404(a,b,z,!1):b.end("This page could not be found"),null);if(J&&!A){let a=!!B.routes[F],b=B.dynamicRoutes[I];if(b&&!1===b.fallback&&!a){if(x.adapterPath)return await K();throw new t.NoFallbackError}}let L=null;!J||y.isDev||A||(L="/index"===(L=F)?"/":L);let M=!0===y.isDev||!J,N=J&&!M;H&&G&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:G,serverActionsManifest:H});let O=a.method||"GET",P=(0,i.getTracer)(),Q=P.getActiveScopeSpan(),R=!!(null==C?void 0:C.isWrappedByNextServer),S=!!(0,h.getRequestMeta)(a,"minimalMode"),T=(0,h.getRequestMeta)(a,"incrementalCache")||await y.getIncrementalCache(a,x,B,S);null==T||T.resetRequestCache(),globalThis.__incrementalCache=T;let U={params:w,previewProps:B.preview,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:M,incrementalCache:T,cacheLifeProfiles:x.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>y.onRequestError(a,b,d,e,C)},sharedContext:{buildId:g,deploymentId:v}},V=new l.NodeNextRequest(a),W=new l.NodeNextResponse(b),X=m.NextRequestAdapter.fromNodeNextRequest(V,(0,m.signalFromNodeResponse)(b));try{let e,g=async a=>y.handle(X,U).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=P.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let f=c.get("next.route");if(f){let b=`${O} ${f}`;a.setAttributes({"next.route":f,"http.route":f,"next.span_name":b}),a.updateName(b),e&&e!==a&&(e.setAttribute("http.route",f),e.updateName(b))}else a.updateName(`${O} ${d}`)}),h=async e=>{var h,i;let j=async({previousCacheEntry:f})=>{try{if(!S&&D&&E&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await g(e);a.fetchMetrics=U.renderOpts.fetchMetrics;let h=U.renderOpts.pendingWaitUntil;h&&c.waitUntil&&(c.waitUntil(h),h=void 0);let i=U.renderOpts.collectedTags;if(!J)return await (0,p.I)(V,W,d,U.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);i&&(b[s.NEXT_CACHE_TAGS_HEADER]=i),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==U.renderOpts.collectedRevalidate&&!(U.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&U.renderOpts.collectedRevalidate,e=void 0===U.renderOpts.collectedExpire||U.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:U.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await y.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:N,isOnDemandRevalidate:D})},!1,C),b}},k=await y.handleResponse({req:a,nextConfig:x,cacheKey:L,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:B,isRoutePPREnabled:!1,isOnDemandRevalidate:D,revalidateOnlyGenerated:E,responseGenerator:j,waitUntil:c.waitUntil,isMinimalMode:S});if(!J)return null;if((null==k||null==(h=k.value)?void 0:h.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==k||null==(i=k.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});S||b.setHeader("x-nextjs-cache",D?"REVALIDATED":k.isMiss?"MISS":k.isStale?"STALE":"HIT"),A&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let l=(0,q.fromNodeOutgoingHttpHeaders)(k.value.headers);return S&&J||l.delete(s.NEXT_CACHE_TAGS_HEADER),!k.cacheControl||b.getHeader("Cache-Control")||l.get("Cache-Control")||l.set("Cache-Control",(0,r.getCacheControlHeader)(k.cacheControl)),await (0,p.I)(V,W,new Response(k.value.body,{headers:l,status:k.value.status||200})),null};R&&Q?await h(Q):(e=P.getActiveScopeSpan(),await P.withPropagatedContext(a.headers,()=>P.trace(n.BaseServerSpan.handleRequest,{spanName:`${O} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":O,"http.target":a.url}},h),void 0,!R))}catch(b){if(b instanceof t.NoFallbackError||await y.onRequestError(a,b,{routerKind:"App Router",routePath:I,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:N,isOnDemandRevalidate:D})},!1,C),J)throw b;return await (0,p.I)(V,W,new Response(null,{status:500})),null}}},2148:(a,b,c)=>{c.d(b,{$x:()=>k,Ht:()=>j,K4:()=>l,O5:()=>m,nP:()=>n});var d=c(46309),e=c(17474),f=c(50730),g=c(12940),h=c(76561),i=c(69539);async function j(){return i.j2.api.getSession({headers:await (0,d.headers)()})}async function k(a,b){if(b){let[c]=await g.db.select({org:h.organization}).from(h.member).innerJoin(h.organization,(0,f.eq)(h.member.orgId,h.organization.id)).where((0,f.Uo)((0,f.eq)(h.member.userId,a),(0,f.eq)(h.organization.id,b)));if(c)return c.org}let c=await g.db.select({org:h.organization}).from(h.member).innerJoin(h.organization,(0,f.eq)(h.member.orgId,h.organization.id)).where((0,f.eq)(h.member.userId,a));return c[0]?.org??null}async function l(a){let[b]=await g.db.select().from(h.workspace).where((0,f.eq)(h.workspace.orgId,a));return b??null}async function m(a){return g.db.select({id:h.organization.id,name:h.organization.name}).from(h.member).innerJoin(h.organization,(0,f.eq)(h.member.orgId,h.organization.id)).where((0,f.eq)(h.member.userId,a))}async function n(){let a=await j();a||(0,e.redirect)("/login"),"1"===process.env.CONSTELLA_FORCE_ONBOARDING&&(0,e.redirect)("/onboarding");let b=await k(a.user.id,a.session.activeOrgId);b||(0,e.redirect)("/onboarding");let c=await l(b.id);return c||(0,e.redirect)("/onboarding"),{session:a,org:b,workspace:c}}},3295:a=>{a.exports=require("next/dist/server/app-render/after-task-async-storage.external.js")},9323:(a,b,c)=>{Object.defineProperty(b,"__esModule",{value:!0});var d={INTERCEPTION_ROUTE_MARKERS:function(){return g},extractInterceptionRouteInformation:function(){return i},isInterceptionRouteAppPath:function(){return h}};for(var e in d)Object.defineProperty(b,e,{enumerable:!0,get:d[e]});let f=c(98508),g=["(..)(..)","(.)","(..)","(...)"];function h(a){return void 0!==a.split("/").find(a=>g.find(b=>a.startsWith(b)))}function i(a){let b,c,d;for(let e of a.split("/"))if(c=g.find(a=>e.startsWith(a))){[b,d]=a.split(c,2);break}if(!b||!c||!d)throw Object.defineProperty(Error(`Invalid interception route: ${a}. Must be in the format /<intercepting route>/(..|...|..)(..)/<intercepted route>`),"__NEXT_ERROR_CODE",{value:"E269",enumerable:!1,configurable:!0});switch(b=(0,f.normalizeAppPath)(b),c){case"(.)":d="/"===b?`/${d}`:b+"/"+d;break;case"(..)":if("/"===b)throw Object.defineProperty(Error(`Invalid interception route: ${a}. Cannot use (..) marker at the root level, use (.) instead.`),"__NEXT_ERROR_CODE",{value:"E207",enumerable:!1,configurable:!0});d=b.split("/").slice(0,-1).concat(d).join("/");break;case"(...)":d="/"+d;break;case"(..)(..)":let e=b.split("/");if(e.length<=2)throw Object.defineProperty(Error(`Invalid interception route: ${a}. Cannot use (..)(..) marker at the root level or one level up.`),"__NEXT_ERROR_CODE",{value:"E486",enumerable:!1,configurable:!0});d=e.slice(0,-2).concat(d).join("/");break;default:throw Object.defineProperty(Error("Invariant: unexpected marker"),"__NEXT_ERROR_CODE",{value:"E112",enumerable:!1,configurable:!0})}return{interceptingRoute:b,interceptedRoute:d}}},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},36548:(a,b,c)=>{Object.defineProperty(b,"A",{enumerable:!0,get:function(){return d.registerServerReference}});let d=c(97879)},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},48161:a=>{a.exports=require("node:os")},51455:a=>{a.exports=require("node:fs/promises")},57752:(a,b,c)=>{c.r(b),c.d(b,{"40c679f63e25b10357f3d3231817fcc35b1db6ddfb":()=>d.mg,"60546c3703874a3d7415fa213900e30f539ca5b9d0":()=>d.eA,"70c9946ce7b4d59b33995bd699fa6d230d232d09ac":()=>d.LV});var d=c(89258)},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},69539:(a,b,c)=>{c.d(b,{dp:()=>o,j2:()=>p});var d=c(20140),e=c(75797),f=c(59814),g=c(12940),h=c(76561);let i=process.env.BETTER_AUTH_URL??"http://localhost:3000";function j(a){return a?.split(",")[0]?.trim()||null}function k(a){if(!a)return null;try{return new URL(a).origin}catch{return null}}function l(a,b){let c=k(b?.trim());c&&a.add(c)}let m=(()=>{let a=new Set;for(let b of[i,process.env.BETTER_AUTH_URL,process.env.NEXT_PUBLIC_BETTER_AUTH_URL,...(process.env.CONSTELLA_TRUSTED_ORIGINS??"").split(",")])l(a,b);return[...a]})();process.env.BETTER_AUTH_SECRET||console.error("[auth] FATAL: BETTER_AUTH_SECRET is required (sessions would be forgeable). Set it in your environment.");let n={};process.env.GITHUB_CLIENT_ID&&process.env.GITHUB_CLIENT_SECRET&&(n.github={clientId:process.env.GITHUB_CLIENT_ID,clientSecret:process.env.GITHUB_CLIENT_SECRET,scope:["repo","read:user"]}),process.env.GOOGLE_CLIENT_ID&&process.env.GOOGLE_CLIENT_SECRET&&(n.google={clientId:process.env.GOOGLE_CLIENT_ID,clientSecret:process.env.GOOGLE_CLIENT_SECRET});let o=Object.keys(n),p=(0,d.l)({baseURL:i,trustedOrigins:function(a){let b=new Set(m);l(b,a?.url);let c=function(a){let b=a?.headers,c=j(b?.get("x-forwarded-host"))??j(b?.get("host"));if(!c)return null;let d=(j(b?.get("x-forwarded-proto"))??(i.startsWith("https://")?"https":"http")).replace(/:$/,"");return/^[a-z][a-z0-9+.-]*$/i.test(d)?k(`${d}://${c}`):null}(a);return c&&b.add(c),[...b]},secret:process.env.BETTER_AUTH_SECRET,database:(0,e.y)(g.db,{provider:"sqlite",schema:{user:h.user,session:h.session,account:h.account,verification:h.verification,twoFactor:h.twoFactor}}),emailAndPassword:{enabled:!0,autoSignIn:!0,requireEmailVerification:!1},socialProviders:n,account:{accountLinking:{enabled:!0,trustedProviders:["github","google"]}},session:{expiresIn:2592e3,additionalFields:{activeOrgId:{type:"string",required:!1}}},plugins:[(0,f.d)()],advanced:{useSecureCookies:i.startsWith("https://")}})},73024:a=>{a.exports=require("node:fs")},76760:a=>{a.exports=require("node:path")},77598:a=>{a.exports=require("node:crypto")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")},89258:(a,b,c)=>{c.d(b,{LV:()=>v,eA:()=>w,mg:()=>x});var d=c(36548),e=c(77598),f=c(50730),g=c(5557),h=c(12940),i=c(76561),j=c(2148),k=c(66408),l=c(50415);function m(a,b){let c=RegExp(`##\\s+${b}\\s*\\n([\\s\\S]*?)(?:\\n##\\s|$)`,"i");return a.match(c)?.[1].trim()??""}function n(a){return a.split("\n").find(a=>a.trim()&&!a.startsWith("#")&&!a.startsWith("**")&&!a.startsWith("---")&&!a.startsWith("|"))?.trim()??""}function o(a,b){let c=a.split("\n").find(a=>a.startsWith("# "));return c?c.slice(2).trim():b}async function p(a){let[b]=await h.db.select().from(i.workspace).where((0,f.eq)(i.workspace.orgId,a));return b??null}async function q(a,b,c){let d=(0,k.sL)(b,`.claude/skills/${c}.md`)??"",g=n(d),j=(d.match(/\*\*Trigger:\*\*\s*(.+)/)?.[1]??"").trim(),l=m(d,"Procedure")||"",[o]=await h.db.select().from(i.skill).where((0,f.Uo)((0,f.eq)(i.skill.workspaceId,a),(0,f.eq)(i.skill.name,c)));o?await h.db.update(i.skill).set({summary:g,trigger:j,...l?{instructions:l}:{},indexed:"indexed"}).where((0,f.eq)(i.skill.id,o.id)):await h.db.insert(i.skill).values({id:(0,e.randomUUID)(),workspaceId:a,name:c,summary:g,trigger:j,instructions:l,native:!0,provisional:!1,indexed:"indexed"})}async function r(a,b,c){let d=(0,k.sL)(b,`.claude/agents/${c}/Agent.md`)??"";if(!d)return;let[e]=await h.db.select().from(i.agent).where((0,f.Uo)((0,f.eq)(i.agent.workspaceId,a),(0,f.eq)(i.agent.handle,c)));if(!e)return;let g=function(a){let b=a.match(/^---\n([\s\S]*?)\n---/);if(!b)return{};let c={};for(let a of b[1].split("\n")){let b=a.indexOf(":");b>0&&(c[a.slice(0,b).trim()]=a.slice(b+1).trim())}return c}(d),j={identity:(d.match(/\*\*Identity:\*\*\s*(.+)/)?.[1]??"").trim(),ritual:(d.match(/\*\*Ritual:\*\*\s*(.+)/)?.[1]??"").trim(),tone:(d.match(/\*\*Tone:\*\*\s*(.+)/)?.[1]??"").trim()||(e.persona?.tone??""),systemPrompt:m(d,"System prompt")},l={...g.provider?{adapter:g.provider}:{},...g.model?{model:g.model}:{},...g.temperature?{temperature:parseFloat(g.temperature)}:{},...g.dailyCapUsd?{dailyCapUsd:parseFloat(g.dailyCapUsd)}:{},...g.tierFloor?{tierFloor:g.tierFloor}:{},...g.reportsTo&&"null"!==g.reportsTo?{reportsTo:g.reportsTo}:{},persona:j};for(let d of(await h.db.update(i.agent).set(l).where((0,f.eq)(i.agent.id,e.id)),[...((0,k.sL)(b,`.claude/agents/${c}/skills.md`)??"").matchAll(/`([a-z0-9-]+)`/g)].map(a=>a[1]))){let[b]=await h.db.select().from(i.skill).where((0,f.Uo)((0,f.eq)(i.skill.workspaceId,a),(0,f.eq)(i.skill.name,d)));b&&await h.db.insert(i.agentSkill).values({agentId:e.id,skillId:b.id}).onConflictDoNothing()}}async function s(a,b,c){let d=c.split("/").pop()??c;if("README.md"===d)return;let g=(0,k.sL)(b,c)??"",j=o(g,d),[l]=await h.db.select().from(i.report).where((0,f.Uo)((0,f.eq)(i.report.workspaceId,a),(0,f.eq)(i.report.title,j)));l?await h.db.update(i.report).set({body:g}).where((0,f.eq)(i.report.id,l.id)):await h.db.insert(i.report).values({id:(0,e.randomUUID)(),workspaceId:a,title:j,type:"Report",body:g})}async function t(a,b,c,d){let g=(0,k.sL)(b,c)??"",j=o(g,c.split("/").pop()??c),l=n(g),[m]=await h.db.select().from(i.docIndex).where((0,f.Uo)((0,f.eq)(i.docIndex.workspaceId,a),(0,f.eq)(i.docIndex.path,c)));m?await h.db.update(i.docIndex).set({title:j,summary:l,updatedAt:new Date}).where((0,f.eq)(i.docIndex.id,m.id)):await h.db.insert(i.docIndex).values({id:(0,e.randomUUID)(),workspaceId:a,kind:d,path:c,title:j,summary:l})}function u(a){(a.startsWith(".claude/skills")||a.endsWith("/skills.md"))&&(0,g.revalidatePath)("/skills"),a.startsWith(".claude/agents")&&(0,g.revalidatePath)("/agents/[handle]","page"),a.startsWith("DOCS")&&(0,g.revalidatePath)("/docs"),a.startsWith("PO")&&(0,g.revalidatePath)("/pm"),a.startsWith("Reports")&&(0,g.revalidatePath)("/reports"),(0,g.revalidatePath)("/code")}async function v(a,b,c=!0){let d,e=await p(a);if(!e)return{ok:!1};let f=e.id;if((0,l.Nm)(a,b),d=b.match(/^\.claude\/skills\/(.+)\.md$/))await q(f,a,d[1]);else if(d=b.match(/^\.claude\/agents\/([^/]+)\/(?:Agent|skills)\.md$/))await r(f,a,d[1]);else if(/^Reports\/.+\.md$/.test(b))await s(f,a,b);else if(/^DOCS\/.+\.md$/.test(b))await t(f,a,b,"docs");else{if(!/^PO\/.+\.md$/.test(b))return{ok:!0};await t(f,a,b,"po")}return c&&u(b),{ok:!0}}async function w(a,b){let c,d=await p(a);if(!d)return{ok:!1};let e=d.id;return(0,l.SH)(a,b).catch(()=>{}),(c=b.match(/^\.claude\/skills\/(.+)\.md$/))?await h.db.delete(i.skill).where((0,f.Uo)((0,f.eq)(i.skill.workspaceId,e),(0,f.eq)(i.skill.name,c[1]))):/^(?:DOCS|PO)\/.+\.md$/.test(b)&&await h.db.delete(i.docIndex).where((0,f.Uo)((0,f.eq)(i.docIndex.workspaceId,e),(0,f.eq)(i.docIndex.path,b))),u(b),{ok:!0}}async function x(a=!0){let{org:b}=await (0,j.nP)(),c=b.id;for(let a of(0,k.Ci)(c,".claude/skills"))!a.isDir&&a.name.endsWith(".md")&&await v(c,a.path,!1);for(let a of(0,k.Ci)(c,".claude/agents"))a.isDir&&await v(c,`${a.path}/Agent.md`,!1);for(let a of["DOCS","PO","Reports"])for(let b of(0,k.Ci)(c,a))!b.isDir&&b.name.endsWith(".md")&&await v(c,b.path,!1);return a&&(0,g.revalidatePath)("/","layout"),{ok:!0}}(0,c(99688).D)([v,w,x]),(0,d.A)(v,"70c9946ce7b4d59b33995bd699fa6d230d232d09ac",null),(0,d.A)(w,"60546c3703874a3d7415fa213900e30f539ca5b9d0",null),(0,d.A)(x,"40c679f63e25b10357f3d3231817fcc35b1db6ddfb",null)},97879:(a,b,c)=>{a.exports=c(9345).vendored["react-rsc"].ReactServerDOMWebpackServer},99688:(a,b)=>{function c(a){for(let b=0;b<a.length;b++){let c=a[b];if("function"!=typeof c)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof c}.
|
|
1
|
+
"use strict";(()=>{var a={};a.id=4384,a.ids=[4384],a.modules={107:(a,b,c)=>{c.r(b),c.d(b,{"40235447972a45e7be663bd2f00f82430e6d4c0271":()=>d.mg,"60f11f39424b3df2e69f7eef9d8e80488894814d06":()=>d.eA,"70cfbb806c07829324f1ef5574523a9278094c87f1":()=>d.LV});var d=c(89258)},261:a=>{a.exports=require("next/dist/shared/lib/router/utils/app-paths")},1302:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>D,patchFetch:()=>C,routeModule:()=>y,serverHooks:()=>B,workAsyncStorage:()=>z,workUnitAsyncStorage:()=>A});var d={};c.r(d),c.d(d,{POST:()=>x});var e=c(16633),f=c(35526),g=c(80445),h=c(49421),i=c(68279),j=c(22827),k=c(261),l=c(45469),m=c(19923),n=c(17653),o=c(70486),p=c(49496),q=c(16674),r=c(11264),s=c(7001),t=c(86439),u=c(4535),v=c(91736),w=c(89258);async function x(a){let b=process.env.CONSTELLA_WORKER_SECRET;if(!b||a.headers.get("x-worker-secret")!==b)return v.NextResponse.json({error:"unauthorized"},{status:401});let{orgId:c,rel:d,event:e}=await a.json().catch(()=>({}));if(!c||!d)return v.NextResponse.json({ok:!1,error:"missing orgId/rel"},{status:400});let f="unlink"===e?await (0,w.eA)(c,d):await (0,w.LV)(c,d);return v.NextResponse.json(f)}let y=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/sync/file/route",pathname:"/api/sync/file",filename:"route",bundlePath:"app/api/sync/file/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"C:\\Users\\Usuario\\Documents\\constella\\src\\app\\api\\sync\\file\\route.ts",nextConfigOutput:"",userland:d,...{}}),{workAsyncStorage:z,workUnitAsyncStorage:A,serverHooks:B}=y;function C(){return(0,g.patchFetch)({workAsyncStorage:z,workUnitAsyncStorage:A})}async function D(a,b,c){c.requestMeta&&(0,h.setRequestMeta)(a,c.requestMeta),y.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/sync/file/route";"/index"===d&&(d="/");let e=await y.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,deploymentId:v,params:w,nextConfig:x,parsedUrl:z,isDraftMode:A,prerenderManifest:B,routerServerContext:C,isOnDemandRevalidate:D,revalidateOnlyGenerated:E,resolvedPathname:F,clientReferenceManifest:G,serverActionsManifest:H}=e,I=(0,k.normalizeAppPath)(d),J=!!(B.dynamicRoutes[I]||B.routes[F]),K=async()=>((null==C?void 0:C.render404)?await C.render404(a,b,z,!1):b.end("This page could not be found"),null);if(J&&!A){let a=!!B.routes[F],b=B.dynamicRoutes[I];if(b&&!1===b.fallback&&!a){if(x.adapterPath)return await K();throw new t.NoFallbackError}}let L=null;!J||y.isDev||A||(L="/index"===(L=F)?"/":L);let M=!0===y.isDev||!J,N=J&&!M;H&&G&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:G,serverActionsManifest:H});let O=a.method||"GET",P=(0,i.getTracer)(),Q=P.getActiveScopeSpan(),R=!!(null==C?void 0:C.isWrappedByNextServer),S=!!(0,h.getRequestMeta)(a,"minimalMode"),T=(0,h.getRequestMeta)(a,"incrementalCache")||await y.getIncrementalCache(a,x,B,S);null==T||T.resetRequestCache(),globalThis.__incrementalCache=T;let U={params:w,previewProps:B.preview,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:M,incrementalCache:T,cacheLifeProfiles:x.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>y.onRequestError(a,b,d,e,C)},sharedContext:{buildId:g,deploymentId:v}},V=new l.NodeNextRequest(a),W=new l.NodeNextResponse(b),X=m.NextRequestAdapter.fromNodeNextRequest(V,(0,m.signalFromNodeResponse)(b));try{let e,g=async a=>y.handle(X,U).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=P.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let f=c.get("next.route");if(f){let b=`${O} ${f}`;a.setAttributes({"next.route":f,"http.route":f,"next.span_name":b}),a.updateName(b),e&&e!==a&&(e.setAttribute("http.route",f),e.updateName(b))}else a.updateName(`${O} ${d}`)}),h=async e=>{var h,i;let j=async({previousCacheEntry:f})=>{try{if(!S&&D&&E&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await g(e);a.fetchMetrics=U.renderOpts.fetchMetrics;let h=U.renderOpts.pendingWaitUntil;h&&c.waitUntil&&(c.waitUntil(h),h=void 0);let i=U.renderOpts.collectedTags;if(!J)return await (0,p.I)(V,W,d,U.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);i&&(b[s.NEXT_CACHE_TAGS_HEADER]=i),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==U.renderOpts.collectedRevalidate&&!(U.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&U.renderOpts.collectedRevalidate,e=void 0===U.renderOpts.collectedExpire||U.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:U.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await y.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:N,isOnDemandRevalidate:D})},!1,C),b}},k=await y.handleResponse({req:a,nextConfig:x,cacheKey:L,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:B,isRoutePPREnabled:!1,isOnDemandRevalidate:D,revalidateOnlyGenerated:E,responseGenerator:j,waitUntil:c.waitUntil,isMinimalMode:S});if(!J)return null;if((null==k||null==(h=k.value)?void 0:h.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==k||null==(i=k.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});S||b.setHeader("x-nextjs-cache",D?"REVALIDATED":k.isMiss?"MISS":k.isStale?"STALE":"HIT"),A&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let l=(0,q.fromNodeOutgoingHttpHeaders)(k.value.headers);return S&&J||l.delete(s.NEXT_CACHE_TAGS_HEADER),!k.cacheControl||b.getHeader("Cache-Control")||l.get("Cache-Control")||l.set("Cache-Control",(0,r.getCacheControlHeader)(k.cacheControl)),await (0,p.I)(V,W,new Response(k.value.body,{headers:l,status:k.value.status||200})),null};R&&Q?await h(Q):(e=P.getActiveScopeSpan(),await P.withPropagatedContext(a.headers,()=>P.trace(n.BaseServerSpan.handleRequest,{spanName:`${O} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":O,"http.target":a.url}},h),void 0,!R))}catch(b){if(b instanceof t.NoFallbackError||await y.onRequestError(a,b,{routerKind:"App Router",routePath:I,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:N,isOnDemandRevalidate:D})},!1,C),J)throw b;return await (0,p.I)(V,W,new Response(null,{status:500})),null}}},2148:(a,b,c)=>{c.d(b,{$x:()=>k,Ht:()=>j,K4:()=>l,O5:()=>m,nP:()=>n});var d=c(46309),e=c(17474),f=c(50730),g=c(12940),h=c(76561),i=c(69539);async function j(){return i.j2.api.getSession({headers:await (0,d.headers)()})}async function k(a,b){if(b){let[c]=await g.db.select({org:h.organization}).from(h.member).innerJoin(h.organization,(0,f.eq)(h.member.orgId,h.organization.id)).where((0,f.Uo)((0,f.eq)(h.member.userId,a),(0,f.eq)(h.organization.id,b)));if(c)return c.org}let c=await g.db.select({org:h.organization}).from(h.member).innerJoin(h.organization,(0,f.eq)(h.member.orgId,h.organization.id)).where((0,f.eq)(h.member.userId,a));return c[0]?.org??null}async function l(a){let[b]=await g.db.select().from(h.workspace).where((0,f.eq)(h.workspace.orgId,a));return b??null}async function m(a){return g.db.select({id:h.organization.id,name:h.organization.name}).from(h.member).innerJoin(h.organization,(0,f.eq)(h.member.orgId,h.organization.id)).where((0,f.eq)(h.member.userId,a))}async function n(){let a=await j();a||(0,e.redirect)("/login"),"1"===process.env.CONSTELLA_FORCE_ONBOARDING&&(0,e.redirect)("/onboarding");let b=await k(a.user.id,a.session.activeOrgId);b||(0,e.redirect)("/onboarding");let c=await l(b.id);return c||(0,e.redirect)("/onboarding"),{session:a,org:b,workspace:c}}},3295:a=>{a.exports=require("next/dist/server/app-render/after-task-async-storage.external.js")},9323:(a,b,c)=>{Object.defineProperty(b,"__esModule",{value:!0});var d={INTERCEPTION_ROUTE_MARKERS:function(){return g},extractInterceptionRouteInformation:function(){return i},isInterceptionRouteAppPath:function(){return h}};for(var e in d)Object.defineProperty(b,e,{enumerable:!0,get:d[e]});let f=c(98508),g=["(..)(..)","(.)","(..)","(...)"];function h(a){return void 0!==a.split("/").find(a=>g.find(b=>a.startsWith(b)))}function i(a){let b,c,d;for(let e of a.split("/"))if(c=g.find(a=>e.startsWith(a))){[b,d]=a.split(c,2);break}if(!b||!c||!d)throw Object.defineProperty(Error(`Invalid interception route: ${a}. Must be in the format /<intercepting route>/(..|...|..)(..)/<intercepted route>`),"__NEXT_ERROR_CODE",{value:"E269",enumerable:!1,configurable:!0});switch(b=(0,f.normalizeAppPath)(b),c){case"(.)":d="/"===b?`/${d}`:b+"/"+d;break;case"(..)":if("/"===b)throw Object.defineProperty(Error(`Invalid interception route: ${a}. Cannot use (..) marker at the root level, use (.) instead.`),"__NEXT_ERROR_CODE",{value:"E207",enumerable:!1,configurable:!0});d=b.split("/").slice(0,-1).concat(d).join("/");break;case"(...)":d="/"+d;break;case"(..)(..)":let e=b.split("/");if(e.length<=2)throw Object.defineProperty(Error(`Invalid interception route: ${a}. Cannot use (..)(..) marker at the root level or one level up.`),"__NEXT_ERROR_CODE",{value:"E486",enumerable:!1,configurable:!0});d=e.slice(0,-2).concat(d).join("/");break;default:throw Object.defineProperty(Error("Invariant: unexpected marker"),"__NEXT_ERROR_CODE",{value:"E112",enumerable:!1,configurable:!0})}return{interceptingRoute:b,interceptedRoute:d}}},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},36548:(a,b,c)=>{Object.defineProperty(b,"A",{enumerable:!0,get:function(){return d.registerServerReference}});let d=c(97879)},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},48161:a=>{a.exports=require("node:os")},51455:a=>{a.exports=require("node:fs/promises")},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},69539:(a,b,c)=>{c.d(b,{dp:()=>o,j2:()=>p});var d=c(20140),e=c(75797),f=c(59814),g=c(12940),h=c(76561);let i=process.env.BETTER_AUTH_URL??"http://localhost:3000";function j(a){return a?.split(",")[0]?.trim()||null}function k(a){if(!a)return null;try{return new URL(a).origin}catch{return null}}function l(a,b){let c=k(b?.trim());c&&a.add(c)}let m=(()=>{let a=new Set;for(let b of[i,process.env.BETTER_AUTH_URL,process.env.NEXT_PUBLIC_BETTER_AUTH_URL,...(process.env.CONSTELLA_TRUSTED_ORIGINS??"").split(",")])l(a,b);return[...a]})();process.env.BETTER_AUTH_SECRET||console.error("[auth] FATAL: BETTER_AUTH_SECRET is required (sessions would be forgeable). Set it in your environment.");let n={};process.env.GITHUB_CLIENT_ID&&process.env.GITHUB_CLIENT_SECRET&&(n.github={clientId:process.env.GITHUB_CLIENT_ID,clientSecret:process.env.GITHUB_CLIENT_SECRET,scope:["repo","read:user"]}),process.env.GOOGLE_CLIENT_ID&&process.env.GOOGLE_CLIENT_SECRET&&(n.google={clientId:process.env.GOOGLE_CLIENT_ID,clientSecret:process.env.GOOGLE_CLIENT_SECRET});let o=Object.keys(n),p=(0,d.l)({baseURL:i,trustedOrigins:function(a){let b=new Set(m);l(b,a?.url);let c=function(a){let b=a?.headers,c=j(b?.get("x-forwarded-host"))??j(b?.get("host"));if(!c)return null;let d=(j(b?.get("x-forwarded-proto"))??(i.startsWith("https://")?"https":"http")).replace(/:$/,"");return/^[a-z][a-z0-9+.-]*$/i.test(d)?k(`${d}://${c}`):null}(a);return c&&b.add(c),[...b]},secret:process.env.BETTER_AUTH_SECRET,database:(0,e.y)(g.db,{provider:"sqlite",schema:{user:h.user,session:h.session,account:h.account,verification:h.verification,twoFactor:h.twoFactor}}),emailAndPassword:{enabled:!0,autoSignIn:!0,requireEmailVerification:!1},socialProviders:n,account:{accountLinking:{enabled:!0,trustedProviders:["github","google"]}},session:{expiresIn:2592e3,additionalFields:{activeOrgId:{type:"string",required:!1}}},plugins:[(0,f.d)()],advanced:{useSecureCookies:i.startsWith("https://")}})},73024:a=>{a.exports=require("node:fs")},76760:a=>{a.exports=require("node:path")},77598:a=>{a.exports=require("node:crypto")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")},89258:(a,b,c)=>{c.d(b,{LV:()=>v,eA:()=>w,mg:()=>x});var d=c(36548),e=c(77598),f=c(50730),g=c(5557),h=c(12940),i=c(76561),j=c(2148),k=c(66408),l=c(50415);function m(a,b){let c=RegExp(`##\\s+${b}\\s*\\n([\\s\\S]*?)(?:\\n##\\s|$)`,"i");return a.match(c)?.[1].trim()??""}function n(a){return a.split("\n").find(a=>a.trim()&&!a.startsWith("#")&&!a.startsWith("**")&&!a.startsWith("---")&&!a.startsWith("|"))?.trim()??""}function o(a,b){let c=a.split("\n").find(a=>a.startsWith("# "));return c?c.slice(2).trim():b}async function p(a){let[b]=await h.db.select().from(i.workspace).where((0,f.eq)(i.workspace.orgId,a));return b??null}async function q(a,b,c){let d=(0,k.sL)(b,`.claude/skills/${c}.md`)??"",g=n(d),j=(d.match(/\*\*Trigger:\*\*\s*(.+)/)?.[1]??"").trim(),l=m(d,"Procedure")||"",[o]=await h.db.select().from(i.skill).where((0,f.Uo)((0,f.eq)(i.skill.workspaceId,a),(0,f.eq)(i.skill.name,c)));o?await h.db.update(i.skill).set({summary:g,trigger:j,...l?{instructions:l}:{},indexed:"indexed"}).where((0,f.eq)(i.skill.id,o.id)):await h.db.insert(i.skill).values({id:(0,e.randomUUID)(),workspaceId:a,name:c,summary:g,trigger:j,instructions:l,native:!0,provisional:!1,indexed:"indexed"})}async function r(a,b,c){let d=(0,k.sL)(b,`.claude/agents/${c}/Agent.md`)??"";if(!d)return;let[e]=await h.db.select().from(i.agent).where((0,f.Uo)((0,f.eq)(i.agent.workspaceId,a),(0,f.eq)(i.agent.handle,c)));if(!e)return;let g=function(a){let b=a.match(/^---\n([\s\S]*?)\n---/);if(!b)return{};let c={};for(let a of b[1].split("\n")){let b=a.indexOf(":");b>0&&(c[a.slice(0,b).trim()]=a.slice(b+1).trim())}return c}(d),j={identity:(d.match(/\*\*Identity:\*\*\s*(.+)/)?.[1]??"").trim(),ritual:(d.match(/\*\*Ritual:\*\*\s*(.+)/)?.[1]??"").trim(),tone:(d.match(/\*\*Tone:\*\*\s*(.+)/)?.[1]??"").trim()||(e.persona?.tone??""),systemPrompt:m(d,"System prompt")},l={...g.provider?{adapter:g.provider}:{},...g.model?{model:g.model}:{},...g.temperature?{temperature:parseFloat(g.temperature)}:{},...g.dailyCapUsd?{dailyCapUsd:parseFloat(g.dailyCapUsd)}:{},...g.tierFloor?{tierFloor:g.tierFloor}:{},...g.reportsTo&&"null"!==g.reportsTo?{reportsTo:g.reportsTo}:{},persona:j};for(let d of(await h.db.update(i.agent).set(l).where((0,f.eq)(i.agent.id,e.id)),[...((0,k.sL)(b,`.claude/agents/${c}/skills.md`)??"").matchAll(/`([a-z0-9-]+)`/g)].map(a=>a[1]))){let[b]=await h.db.select().from(i.skill).where((0,f.Uo)((0,f.eq)(i.skill.workspaceId,a),(0,f.eq)(i.skill.name,d)));b&&await h.db.insert(i.agentSkill).values({agentId:e.id,skillId:b.id}).onConflictDoNothing()}}async function s(a,b,c){let d=c.split("/").pop()??c;if("README.md"===d)return;let g=(0,k.sL)(b,c)??"",j=o(g,d),[l]=await h.db.select().from(i.report).where((0,f.Uo)((0,f.eq)(i.report.workspaceId,a),(0,f.eq)(i.report.title,j)));l?await h.db.update(i.report).set({body:g}).where((0,f.eq)(i.report.id,l.id)):await h.db.insert(i.report).values({id:(0,e.randomUUID)(),workspaceId:a,title:j,type:"Report",body:g})}async function t(a,b,c,d){let g=(0,k.sL)(b,c)??"",j=o(g,c.split("/").pop()??c),l=n(g),[m]=await h.db.select().from(i.docIndex).where((0,f.Uo)((0,f.eq)(i.docIndex.workspaceId,a),(0,f.eq)(i.docIndex.path,c)));m?await h.db.update(i.docIndex).set({title:j,summary:l,updatedAt:new Date}).where((0,f.eq)(i.docIndex.id,m.id)):await h.db.insert(i.docIndex).values({id:(0,e.randomUUID)(),workspaceId:a,kind:d,path:c,title:j,summary:l})}function u(a){(a.startsWith(".claude/skills")||a.endsWith("/skills.md"))&&(0,g.revalidatePath)("/skills"),a.startsWith(".claude/agents")&&(0,g.revalidatePath)("/agents/[handle]","page"),a.startsWith("DOCS")&&(0,g.revalidatePath)("/docs"),a.startsWith("PO")&&(0,g.revalidatePath)("/pm"),a.startsWith("Reports")&&(0,g.revalidatePath)("/reports"),(0,g.revalidatePath)("/code")}async function v(a,b,c=!0){let d,e=await p(a);if(!e)return{ok:!1};let f=e.id;if((0,l.Nm)(a,b),d=b.match(/^\.claude\/skills\/(.+)\.md$/))await q(f,a,d[1]);else if(d=b.match(/^\.claude\/agents\/([^/]+)\/(?:Agent|skills)\.md$/))await r(f,a,d[1]);else if(/^Reports\/.+\.md$/.test(b))await s(f,a,b);else if(/^DOCS\/.+\.md$/.test(b))await t(f,a,b,"docs");else{if(!/^PO\/.+\.md$/.test(b))return{ok:!0};await t(f,a,b,"po")}return c&&u(b),{ok:!0}}async function w(a,b){let c,d=await p(a);if(!d)return{ok:!1};let e=d.id;return(0,l.SH)(a,b).catch(()=>{}),(c=b.match(/^\.claude\/skills\/(.+)\.md$/))?await h.db.delete(i.skill).where((0,f.Uo)((0,f.eq)(i.skill.workspaceId,e),(0,f.eq)(i.skill.name,c[1]))):/^(?:DOCS|PO)\/.+\.md$/.test(b)&&await h.db.delete(i.docIndex).where((0,f.Uo)((0,f.eq)(i.docIndex.workspaceId,e),(0,f.eq)(i.docIndex.path,b))),u(b),{ok:!0}}async function x(a=!0){let{org:b}=await (0,j.nP)(),c=b.id;for(let a of(0,k.Ci)(c,".claude/skills"))!a.isDir&&a.name.endsWith(".md")&&await v(c,a.path,!1);for(let a of(0,k.Ci)(c,".claude/agents"))a.isDir&&await v(c,`${a.path}/Agent.md`,!1);for(let a of["DOCS","PO","Reports"])for(let b of(0,k.Ci)(c,a))!b.isDir&&b.name.endsWith(".md")&&await v(c,b.path,!1);return a&&(0,g.revalidatePath)("/","layout"),{ok:!0}}(0,c(99688).D)([v,w,x]),(0,d.A)(v,"70cfbb806c07829324f1ef5574523a9278094c87f1",null),(0,d.A)(w,"60f11f39424b3df2e69f7eef9d8e80488894814d06",null),(0,d.A)(x,"40235447972a45e7be663bd2f00f82430e6d4c0271",null)},97879:(a,b,c)=>{a.exports=c(9345).vendored["react-rsc"].ReactServerDOMWebpackServer},99688:(a,b)=>{function c(a){for(let b=0;b<a.length;b++){let c=a[b];if("function"!=typeof c)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof c}.
|
|
2
2
|
Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(b,"D",{enumerable:!0,get:function(){return c}})}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[5911,5361,6309,4679,7474,5557,6585,912,415],()=>b(b.s=1302));module.exports=c})();
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
created_at INTEGER NOT NULL DEFAULT (unixepoch())
|
|
39
39
|
);
|
|
40
40
|
CREATE INDEX IF NOT EXISTS design_comment_sess_idx ON design_comment (session_id);
|
|
41
|
-
`))}},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},29021:a=>{a.exports=require("fs")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},38522:a=>{a.exports=require("node:zlib")},
|
|
41
|
+
`))}},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},29021:a=>{a.exports=require("fs")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},38522:a=>{a.exports=require("node:zlib")},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},46466:a=>{a.exports=require("node:stream/promises")},48161:a=>{a.exports=require("node:os")},49131:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>ag,patchFetch:()=>af,routeModule:()=>ab,serverHooks:()=>ae,workAsyncStorage:()=>ac,workUnitAsyncStorage:()=>ad});var d={};c.r(d),c.d(d,{POST:()=>aa,dynamic:()=>_,runtime:()=>$});var e=c(16633),f=c(35526),g=c(80445),h=c(49421),i=c(68279),j=c(22827),k=c(261),l=c(45469),m=c(19923),n=c(17653),o=c(70486),p=c(49496),q=c(16674),r=c(11264),s=c(7001),t=c(86439),u=c(4535),v=c(91736),w=c(77598),x=c(73024),y=c(76760),z=c(50730),A=c(23888),B=c(12940),C=c(76561),D=c(66408),E=c(8646),F=c(84534),G=c(20699),H=c(66263),I=c(87355),J=c(56425),K=c(15563),L=c(74910),M=c(28134),N=c(63942);let O="telegram",P=new Set,Q=new Set,R=new Set;async function S(){let a=await B.db.select().from(C.workspace),b=0;for(let c of a){let a=c.settings??{};if(!(0,E.Ml)(a.integrations,"telegram"))continue;let d=await (0,F._9)(c.id);if(!d)continue;R.has(d.botToken)||(0,F.A3)(d.botToken).then(()=>R.add(d.botToken)).catch(()=>{});let e=a.telegram?.offset??0,f=await (0,F.SD)(d.botToken,e),g=e;for(let a of f)try{await T(c,d,a),g=Math.max(g,a.update_id+1)}catch(a){console.error("[telegram] ingest failed:",a);break}g!==e&&await B.db.update(C.workspace).set({settings:{...a,telegram:{...a.telegram??{},offset:g}}}).where((0,z.eq)(C.workspace.id,c.id)),b+=f.length}return{updates:b}}async function T(a,b,c){if(c.callback_query)return void await Z(a,b,c.callback_query);let d=c.message;if(!d||String(d.chat.id)!==String(b.chatId)||d.from&&String(d.from.id)!==String(b.chatId))return;let e=(d.text??d.caption??"").slice(0,4e3),f=[],g=(0,D.HZ)(a.orgId),h=(0,w.randomUUID)().slice(0,8),i=async(a,c,d)=>{let e=await (0,F.G3)(b.botToken,a);if(!e)return;let i=c.replace(/[^\w.\-]+/g,"_").slice(-60)||`file.${e.ext}`,j=`uploads/tg-${h}/${i}`;try{(0,x.mkdirSync)((0,y.join)(g,`uploads/tg-${h}`),{recursive:!0}),(0,x.writeFileSync)((0,y.join)(g,j),e.buf),f.push({name:i,type:d,size:e.buf.length,path:j})}catch{}};if(d.photo?.length&&await i(d.photo[d.photo.length-1].file_id,"photo.jpg","image/jpeg"),d.document&&await i(d.document.file_id,d.document.file_name??"document",d.document.mime_type??"application/octet-stream"),e||0!==f.length){if(await B.db.insert(C.message).values({id:(0,w.randomUUID)(),workspaceId:a.id,channel:O,fromKind:"operator",text:e||"(attachment)",attachments:f.length?f:null}),(0,H.r)(a.id),P.has(a.id)&&e&&!e.startsWith("/")){P.delete(a.id),await (0,I.TR)(a.id,e),await X(a,b,"↩️ Recorded — the CEO will revise the plan with your reason.");return}if(Q.has(a.id)&&e&&!e.startsWith("/")){Q.delete(a.id);try{await B.db.insert(C.message).values({id:(0,w.randomUUID)(),workspaceId:a.id,channel:"design",fromKind:"operator",text:`Change request (via Telegram): ${e}`})}catch{}await X(a,b,"\uD83D\uDCDD Recorded — open the Design module and Grace will apply your changes, then Send to execution.");return}if(e.startsWith("/"))return void await Y(a,b,e);await U(a,b)}}async function U(a,b){let c=(await B.db.select().from(C.agent).where((0,z.Uo)((0,z.eq)(C.agent.workspaceId,a.id),(0,z.eq)(C.agent.handle,"ada"))))[0]??(await B.db.select().from(C.agent).where((0,z.eq)(C.agent.workspaceId,a.id)))[0];if(!c)return;await B.db.update(C.agent).set({status:"working"}).where((0,z.eq)(C.agent.id,c.id)),await (0,F.sK)(b.botToken,b.chatId,"typing");let d=setInterval(()=>{(0,F.sK)(b.botToken,b.chatId,"typing").catch(()=>{})},4e3),e="",f=!1;try{({text:e,planRequested:f}=await (0,G.PM)(a.orgId,a,O,c,"chat"))}finally{clearInterval(d)}if(await B.db.update(C.agent).set({status:"idle"}).where((0,z.eq)(C.agent.id,c.id)),e&&await (0,F.vH)(b.botToken,b.chatId,(0,N.Z)(e,[b.botToken])),f){let c=await (0,K.G)(a.orgId,a,O);await X(a,b,c.ok?"\uD83D\uDCDD Got it — drafting the plan now (specs \xb7 issues \xb7 TODOs); it'll appear in the CEO Planner for your approval, and I'll post here when it's ready.":`I couldn't start a plan from this yet${c.error?` (${c.error})`:""} — add a little more detail and I'll try again.`)}}let V=`Remote control:
|
|
42
42
|
/status — quick status
|
|
43
43
|
/review — full plan / issues / tasks summary
|
|
44
44
|
/tasks — what's in flight right now
|
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
/kb <question> — ask the Knowledge Base
|
|
53
53
|
Or just message me to talk to the CEO.`;async function W(a){let[b]=await B.db.select({id:C.goal.id,title:C.goal.title}).from(C.goal).where((0,z.Uo)((0,z.eq)(C.goal.workspaceId,a),(0,z.eq)(C.goal.status,"active"))).orderBy((0,A.i)(C.goal.createdAt)).limit(1);return b??null}async function X(a,b,c){let d=(0,N.Z)(c,[b.botToken]);await B.db.insert(C.message).values({id:(0,w.randomUUID)(),workspaceId:a.id,channel:O,fromKind:"agent",fromHandle:"system",text:d.slice(0,4e3)}),await (0,F.vH)(b.botToken,b.chatId,d),(0,H.r)(a.id)}async function Y(a,b,c){P.delete(a.id);let d=c.indexOf(" "),e=(-1===d?c:c.slice(0,d)).toLowerCase(),f=(-1===d?"":c.slice(d+1)).trim(),g="";try{switch(e){case"/help":g=V;break;case"/status":g=await (0,I.PO)(a);break;case"/review":g=await (0,I.mt)(a);break;case"/tasks":g=await (0,I.yk)(a);break;case"/approve":{let b=await (0,I.wz)(a.orgId,a);g=`✅ Plan approved — ${b.made} task(s) queued. Send /start_execution to run 24/7.`;break}case"/start_execution":case"/start":case"/run":{let b=await (0,I.wz)(a.orgId,a);await (0,I.mL)(a.id,!0),g=`▶️ Execution started — ${b.made} task(s) queued, 24/7 ON.`;break}case"/pause":case"/stop":await (0,I.mL)(a.id,!1),g="⏸ 24/7 execution paused.";break;case"/resume":await (0,I.mL)(a.id,!0),g="▶️ 24/7 execution resumed.";break;case"/reject":await (0,I.TR)(a.id,f),g=f?"↩️ Plan sent back to the CEO — reason recorded.":"↩️ Plan sent back to the CEO for revision.";break;case"/new":case"/new-work":case"/new-goal":if(!f){g="Describe the work, e.g. `/new a billing page with checkout`.";break}await B.db.insert(C.message).values({id:(0,w.randomUUID)(),workspaceId:a.id,channel:O,fromKind:"operator",text:f.slice(0,4e3)}),(0,H.r)(a.id),await U(a,b);return;case"/cancel":{let b=await W(a.id);if(!b){g="No active goal to cancel.";break}let c=await (0,J.NF)(a.id,b.id);g=c.ok?`🛑 Cancelled — ${c.title}. Execution stopped; reopen in-app to resume.`:"Couldn't cancel the goal.";break}case"/archive":{let b=await W(a.id);if(!b){g="No active goal to archive.";break}let c=await (0,J.PT)(a.orgId,a.id,b.id);g=c.ok?`📦 Archived — ${c.title}. Zipped to ${c.path}.`:"Couldn't archive the goal.";break}case"/kb":case"/ask-kb":if(!f){g="Ask a question, e.g. `/kb how does auth work?`";break}g=(await (0,M.ed)(a.orgId,f)).text;break;default:g=`Unknown command ${e}.
|
|
54
54
|
|
|
55
|
-
${V}`}}catch(a){console.error("[telegram] command failed:",a),g="⚠️ Command failed — try again."}g&&await X(a,b,g)}async function Z(a,b,c){if(!c.from||String(c.from.id)!==String(b.chatId)||c.message&&String(c.message.chat.id)!==String(b.chatId))return void await (0,F.J4)(b.botToken,c.id);let d=(c.data??"").trim(),e="",f="";try{switch(d){case"approve_plan":{let b=await (0,I.wz)(a.orgId,a);e="✅ Approved",f=`✅ Plan approved — ${b.made} task(s) queued. Send /start_execution to run 24/7.`;break}case"start_exec":{let b=await (0,I.wz)(a.orgId,a);await (0,I.mL)(a.id,!0),e="▶️ Executing",f=`▶️ Execution started — ${b.made} task(s) queued, 24/7 ON.`;break}case"reject_plan":await (0,I.TR)(a.id),P.add(a.id),e="↩️ Sent back",f="↩️ Plan sent back to the CEO. Reply with what to change and I'll record it as the reason.";break;case"approve_design":{let b=await (0,L.RS)(a.orgId,a);e=b.ok?"✅ Approved":"⚠️ Failed",f=b.ok?"✅ Design approved & sent to execution — Grace is writing the full documentation, then Ada turns it into specs, issues & tasks automatically.":`⚠️ ${b.error||"Could not send to execution."}`;break}case"review_design":e="\uD83D\uDCDD Review",f=await (0,L.qw)(a.orgId,a);break;case"reject_design":Q.add(a.id),e="↩️ Changes",f="\uD83D\uDCDD What should change? Reply and I'll send it to Grace in the Design module.";break;case"review":e="\uD83D\uDCDD Review",f=await (0,I.mt)(a);break;case"status":e="\uD83D\uDCCA Status",f=await (0,I.PO)(a);break;case"pause":await (0,I.mL)(a.id,!1),e="⏸ Paused",f="⏸ 24/7 execution paused.";break;case"resume":await (0,I.mL)(a.id,!0),e="▶️ Resumed",f="▶️ 24/7 execution resumed.";break;default:e="Unknown action"}}catch(a){console.error("[telegram] callback failed:",a),f="⚠️ Action failed — try again from the app."}await (0,F.J4)(b.botToken,c.id,e||void 0),c.message&&("approve_plan"===d||"start_exec"===d||"reject_plan"===d||"approve_design"===d)&&await (0,F.S3)(b.botToken,b.chatId,c.message.message_id),f&&await X(a,b,f)}let $="nodejs",_="force-dynamic";async function aa(a){let b=process.env.CONSTELLA_WORKER_SECRET;if(!b||a.headers.get("x-worker-secret")!==b)return v.NextResponse.json({ok:!1,error:"unauthorized"},{status:401});try{let a=await S();return v.NextResponse.json({ok:!0,...a})}catch(a){return v.NextResponse.json({ok:!1,error:String(a instanceof Error?a.message:a)},{status:500})}}let ab=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/telegram/poll/route",pathname:"/api/telegram/poll",filename:"route",bundlePath:"app/api/telegram/poll/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"C:\\Users\\Usuario\\Documents\\constella\\src\\app\\api\\telegram\\poll\\route.ts",nextConfigOutput:"",userland:d,...{}}),{workAsyncStorage:ac,workUnitAsyncStorage:ad,serverHooks:ae}=ab;function af(){return(0,g.patchFetch)({workAsyncStorage:ac,workUnitAsyncStorage:ad})}async function ag(a,b,c){c.requestMeta&&(0,h.setRequestMeta)(a,c.requestMeta),ab.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/telegram/poll/route";"/index"===d&&(d="/");let e=await ab.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,deploymentId:v,params:w,nextConfig:x,parsedUrl:y,isDraftMode:z,prerenderManifest:A,routerServerContext:B,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,resolvedPathname:E,clientReferenceManifest:F,serverActionsManifest:G}=e,H=(0,k.normalizeAppPath)(d),I=!!(A.dynamicRoutes[H]||A.routes[E]),J=async()=>((null==B?void 0:B.render404)?await B.render404(a,b,y,!1):b.end("This page could not be found"),null);if(I&&!z){let a=!!A.routes[E],b=A.dynamicRoutes[H];if(b&&!1===b.fallback&&!a){if(x.adapterPath)return await J();throw new t.NoFallbackError}}let K=null;!I||ab.isDev||z||(K="/index"===(K=E)?"/":K);let L=!0===ab.isDev||!I,M=I&&!L;G&&F&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:F,serverActionsManifest:G});let N=a.method||"GET",O=(0,i.getTracer)(),P=O.getActiveScopeSpan(),Q=!!(null==B?void 0:B.isWrappedByNextServer),R=!!(0,h.getRequestMeta)(a,"minimalMode"),S=(0,h.getRequestMeta)(a,"incrementalCache")||await ab.getIncrementalCache(a,x,A,R);null==S||S.resetRequestCache(),globalThis.__incrementalCache=S;let T={params:w,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:L,incrementalCache:S,cacheLifeProfiles:x.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>ab.onRequestError(a,b,d,e,B)},sharedContext:{buildId:g,deploymentId:v}},U=new l.NodeNextRequest(a),V=new l.NodeNextResponse(b),W=m.NextRequestAdapter.fromNodeNextRequest(U,(0,m.signalFromNodeResponse)(b));try{let e,g=async a=>ab.handle(W,T).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=O.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let f=c.get("next.route");if(f){let b=`${N} ${f}`;a.setAttributes({"next.route":f,"http.route":f,"next.span_name":b}),a.updateName(b),e&&e!==a&&(e.setAttribute("http.route",f),e.updateName(b))}else a.updateName(`${N} ${d}`)}),h=async e=>{var h,i;let j=async({previousCacheEntry:f})=>{try{if(!R&&C&&D&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await g(e);a.fetchMetrics=T.renderOpts.fetchMetrics;let h=T.renderOpts.pendingWaitUntil;h&&c.waitUntil&&(c.waitUntil(h),h=void 0);let i=T.renderOpts.collectedTags;if(!I)return await (0,p.I)(U,V,d,T.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);i&&(b[s.NEXT_CACHE_TAGS_HEADER]=i),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==T.renderOpts.collectedRevalidate&&!(T.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&T.renderOpts.collectedRevalidate,e=void 0===T.renderOpts.collectedExpire||T.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:T.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await ab.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),b}},k=await ab.handleResponse({req:a,nextConfig:x,cacheKey:K,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,responseGenerator:j,waitUntil:c.waitUntil,isMinimalMode:R});if(!I)return null;if((null==k||null==(h=k.value)?void 0:h.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==k||null==(i=k.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});R||b.setHeader("x-nextjs-cache",C?"REVALIDATED":k.isMiss?"MISS":k.isStale?"STALE":"HIT"),z&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let l=(0,q.fromNodeOutgoingHttpHeaders)(k.value.headers);return R&&I||l.delete(s.NEXT_CACHE_TAGS_HEADER),!k.cacheControl||b.getHeader("Cache-Control")||l.get("Cache-Control")||l.set("Cache-Control",(0,r.getCacheControlHeader)(k.cacheControl)),await (0,p.I)(U,V,new Response(k.value.body,{headers:l,status:k.value.status||200})),null};Q&&P?await h(P):(e=O.getActiveScopeSpan(),await O.withPropagatedContext(a.headers,()=>O.trace(n.BaseServerSpan.handleRequest,{spanName:`${N} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":N,"http.target":a.url}},h),void 0,!Q))}catch(b){if(b instanceof t.NoFallbackError||await ab.onRequestError(a,b,{routerKind:"App Router",routePath:H,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),I)throw b;return await (0,p.I)(U,V,new Response(null,{status:500})),null}}},51455:a=>{a.exports=require("node:fs/promises")},55511:a=>{a.exports=require("crypto")},57075:a=>{a.exports=require("node:stream")},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},74075:a=>{a.exports=require("zlib")},74910:(a,b,c)=>{c.d(b,{Hg:()=>aj,a7:()=>ak,sy:()=>am,is:()=>H,fM:()=>I,Sy:()=>G,e9:()=>ap,EQ:()=>an,NM:()=>al,$_:()=>ab,qw:()=>T,DX:()=>W,ME:()=>E,oS:()=>J,RS:()=>K,R6:()=>ai,wP:()=>X,Ni:()=>_,gn:()=>ac,yL:()=>ae,NW:()=>Q,lj:()=>Z,fb:()=>ah,pG:()=>af,I_:()=>L,Fo:()=>N,o3:()=>O,a4:()=>ag,ft:()=>aa,Tu:()=>V,h_:()=>F,PO:()=>U});var d=c(36548),e=c(77598),f=c(50730),g=c(23888),h=c(5557),i=c(12940),j=c(76561),k=c(2148),l=c(55104),m=c(87980),n=c(79017),o=c(66263),p=c(66408),q=c(21046),r=c(44440),s=c(12851),t=c(13171);let u=new Set(["Next.js","Nuxt","Remix","SvelteKit","Astro","Gatsby"]);var v=c(20699),w=c(11168),x=c(96807);function y(a,b){if(!b||/^(https?:)?\/\//i.test(b)||b.startsWith("data:")||b.startsWith("#")||b.startsWith("/"))return null;let c=b.split(/[?#]/)[0].trim();if(!c)return null;let d=a?a.split("/").filter(Boolean):[];for(let a of c.split("/"))if(""!==a&&"."!==a){if(".."===a){if(!d.length)return null;d.pop();continue}d.push(a)}let e=d.join("/");return e.includes("..")||!e.startsWith("design-mock/")?null:e}function z(a,b,c,d){let e=b.replace(/\/[^/]*$/,"");return a.replace(/@import\s+(?:url\(\s*)?["']?([^"')]+)["']?\s*\)?\s*;/gi,(a,b)=>{let f=y(e,String(b));if(!f||!/\.css$/i.test(f))return a;if(d.has(f))return"";d.add(f);let g=c(f);return null==g?`/* design: missing ${f} */`:`/* ${f} */
|
|
55
|
+
${V}`}}catch(a){console.error("[telegram] command failed:",a),g="⚠️ Command failed — try again."}g&&await X(a,b,g)}async function Z(a,b,c){if(!c.from||String(c.from.id)!==String(b.chatId)||c.message&&String(c.message.chat.id)!==String(b.chatId))return void await (0,F.J4)(b.botToken,c.id);let d=(c.data??"").trim(),e="",f="";try{switch(d){case"approve_plan":{let b=await (0,I.wz)(a.orgId,a);e="✅ Approved",f=`✅ Plan approved — ${b.made} task(s) queued. Send /start_execution to run 24/7.`;break}case"start_exec":{let b=await (0,I.wz)(a.orgId,a);await (0,I.mL)(a.id,!0),e="▶️ Executing",f=`▶️ Execution started — ${b.made} task(s) queued, 24/7 ON.`;break}case"reject_plan":await (0,I.TR)(a.id),P.add(a.id),e="↩️ Sent back",f="↩️ Plan sent back to the CEO. Reply with what to change and I'll record it as the reason.";break;case"approve_design":{let b=await (0,L.RS)(a.orgId,a);e=b.ok?"✅ Approved":"⚠️ Failed",f=b.ok?"✅ Design approved & sent to execution — Grace is writing the full documentation, then Ada turns it into specs, issues & tasks automatically.":`⚠️ ${b.error||"Could not send to execution."}`;break}case"review_design":e="\uD83D\uDCDD Review",f=await (0,L.qw)(a.orgId,a);break;case"reject_design":Q.add(a.id),e="↩️ Changes",f="\uD83D\uDCDD What should change? Reply and I'll send it to Grace in the Design module.";break;case"review":e="\uD83D\uDCDD Review",f=await (0,I.mt)(a);break;case"status":e="\uD83D\uDCCA Status",f=await (0,I.PO)(a);break;case"pause":await (0,I.mL)(a.id,!1),e="⏸ Paused",f="⏸ 24/7 execution paused.";break;case"resume":await (0,I.mL)(a.id,!0),e="▶️ Resumed",f="▶️ 24/7 execution resumed.";break;default:e="Unknown action"}}catch(a){console.error("[telegram] callback failed:",a),f="⚠️ Action failed — try again from the app."}await (0,F.J4)(b.botToken,c.id,e||void 0),c.message&&("approve_plan"===d||"start_exec"===d||"reject_plan"===d||"approve_design"===d)&&await (0,F.S3)(b.botToken,b.chatId,c.message.message_id),f&&await X(a,b,f)}let $="nodejs",_="force-dynamic";async function aa(a){let b=process.env.CONSTELLA_WORKER_SECRET;if(!b||a.headers.get("x-worker-secret")!==b)return v.NextResponse.json({ok:!1,error:"unauthorized"},{status:401});try{let a=await S();return v.NextResponse.json({ok:!0,...a})}catch(a){return v.NextResponse.json({ok:!1,error:String(a instanceof Error?a.message:a)},{status:500})}}let ab=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/telegram/poll/route",pathname:"/api/telegram/poll",filename:"route",bundlePath:"app/api/telegram/poll/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"C:\\Users\\Usuario\\Documents\\constella\\src\\app\\api\\telegram\\poll\\route.ts",nextConfigOutput:"",userland:d,...{}}),{workAsyncStorage:ac,workUnitAsyncStorage:ad,serverHooks:ae}=ab;function af(){return(0,g.patchFetch)({workAsyncStorage:ac,workUnitAsyncStorage:ad})}async function ag(a,b,c){c.requestMeta&&(0,h.setRequestMeta)(a,c.requestMeta),ab.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/telegram/poll/route";"/index"===d&&(d="/");let e=await ab.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,deploymentId:v,params:w,nextConfig:x,parsedUrl:y,isDraftMode:z,prerenderManifest:A,routerServerContext:B,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,resolvedPathname:E,clientReferenceManifest:F,serverActionsManifest:G}=e,H=(0,k.normalizeAppPath)(d),I=!!(A.dynamicRoutes[H]||A.routes[E]),J=async()=>((null==B?void 0:B.render404)?await B.render404(a,b,y,!1):b.end("This page could not be found"),null);if(I&&!z){let a=!!A.routes[E],b=A.dynamicRoutes[H];if(b&&!1===b.fallback&&!a){if(x.adapterPath)return await J();throw new t.NoFallbackError}}let K=null;!I||ab.isDev||z||(K="/index"===(K=E)?"/":K);let L=!0===ab.isDev||!I,M=I&&!L;G&&F&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:F,serverActionsManifest:G});let N=a.method||"GET",O=(0,i.getTracer)(),P=O.getActiveScopeSpan(),Q=!!(null==B?void 0:B.isWrappedByNextServer),R=!!(0,h.getRequestMeta)(a,"minimalMode"),S=(0,h.getRequestMeta)(a,"incrementalCache")||await ab.getIncrementalCache(a,x,A,R);null==S||S.resetRequestCache(),globalThis.__incrementalCache=S;let T={params:w,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:L,incrementalCache:S,cacheLifeProfiles:x.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>ab.onRequestError(a,b,d,e,B)},sharedContext:{buildId:g,deploymentId:v}},U=new l.NodeNextRequest(a),V=new l.NodeNextResponse(b),W=m.NextRequestAdapter.fromNodeNextRequest(U,(0,m.signalFromNodeResponse)(b));try{let e,g=async a=>ab.handle(W,T).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=O.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let f=c.get("next.route");if(f){let b=`${N} ${f}`;a.setAttributes({"next.route":f,"http.route":f,"next.span_name":b}),a.updateName(b),e&&e!==a&&(e.setAttribute("http.route",f),e.updateName(b))}else a.updateName(`${N} ${d}`)}),h=async e=>{var h,i;let j=async({previousCacheEntry:f})=>{try{if(!R&&C&&D&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await g(e);a.fetchMetrics=T.renderOpts.fetchMetrics;let h=T.renderOpts.pendingWaitUntil;h&&c.waitUntil&&(c.waitUntil(h),h=void 0);let i=T.renderOpts.collectedTags;if(!I)return await (0,p.I)(U,V,d,T.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);i&&(b[s.NEXT_CACHE_TAGS_HEADER]=i),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==T.renderOpts.collectedRevalidate&&!(T.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&T.renderOpts.collectedRevalidate,e=void 0===T.renderOpts.collectedExpire||T.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:T.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await ab.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),b}},k=await ab.handleResponse({req:a,nextConfig:x,cacheKey:K,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,responseGenerator:j,waitUntil:c.waitUntil,isMinimalMode:R});if(!I)return null;if((null==k||null==(h=k.value)?void 0:h.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==k||null==(i=k.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});R||b.setHeader("x-nextjs-cache",C?"REVALIDATED":k.isMiss?"MISS":k.isStale?"STALE":"HIT"),z&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let l=(0,q.fromNodeOutgoingHttpHeaders)(k.value.headers);return R&&I||l.delete(s.NEXT_CACHE_TAGS_HEADER),!k.cacheControl||b.getHeader("Cache-Control")||l.get("Cache-Control")||l.set("Cache-Control",(0,r.getCacheControlHeader)(k.cacheControl)),await (0,p.I)(U,V,new Response(k.value.body,{headers:l,status:k.value.status||200})),null};Q&&P?await h(P):(e=O.getActiveScopeSpan(),await O.withPropagatedContext(a.headers,()=>O.trace(n.BaseServerSpan.handleRequest,{spanName:`${N} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":N,"http.target":a.url}},h),void 0,!Q))}catch(b){if(b instanceof t.NoFallbackError||await ab.onRequestError(a,b,{routerKind:"App Router",routePath:H,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),I)throw b;return await (0,p.I)(U,V,new Response(null,{status:500})),null}}},51455:a=>{a.exports=require("node:fs/promises")},55511:a=>{a.exports=require("crypto")},57075:a=>{a.exports=require("node:stream")},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},74075:a=>{a.exports=require("zlib")},74651:(a,b,c)=>{c.r(b),c.d(b,{"0001025c89be533c6ae88d481b09f093b98dc8063a":()=>g.requestPlanChanges,"00139cfd8b058e81fd1f5a24e4095013e8a715ec60":()=>h.gn,"001425f60c0da2dd1d0eee8afc70c30f2d6d02d1d7":()=>h.e9,"001d0063b3096499a8ec0f764994e221c6f50cabec":()=>h.ME,"001de959dce6c8f9d53a0db5f3135437133ceb52df":()=>d.lC,"001e0576d5722123766a79fcba07b464a665a26402":()=>h.yL,"003b6bdbd1dd9535700ff0361a2c5e4baf132331b2":()=>d.Hi,"0043750c3df6f86c65e971f123da87ceb51dc5990b":()=>d.Gh,"0050e3a51b9510d1440e75d0ef71a5ed5901dcafaa":()=>d.nl,"0065cf1b3ed4fac1a400f22fdfd8eb79c6f959b308":()=>d.V$,"0066100dc8904c58a270ededd9857f10c67f424e9a":()=>h.wP,"006910fc45d9bd87178dc83b87fb23580d680f1b14":()=>g.approvePlan,"007471b77fdd505158c0ef102abe663876817ba1a9":()=>d.Ac,"0077f2278034c406de1ccda97e8e5a1cb8b4778021":()=>h.PO,"007d859487c6175d33fea61bc0b0b0525404e94ab4":()=>d.Jw,"00822437e4eeea24a8c615e3e2dfaf9ba9cbab0663":()=>d.Vr,"0082d605df6bf54530b3e793569841e033a784aa8f":()=>d.LU,"009312e28b1a452ac54a988cf7947bd49a5f587777":()=>d.kb,"009751d8c00d5cce30bea74b7324f874e344d82c42":()=>g.groomBacklog,"009c5ae209df1bf521e0f4a275155aa91e4c055da0":()=>d.Uw,"00acc06fa50815fb406645f301e885af8c87ff0270":()=>d.zO,"00bf363c39eef8bae9778773e53ed709e10c6f2c9f":()=>d.VH,"00ca910b0a945a229553de0df34b0135aeeb87a51d":()=>d.ts,"00cc8dfdd18e2ae71e708ee33dac193a2c30f1b512":()=>h.Ni,"00cf5008a9aff8a54ca0c6b2a086586cf6c487e248":()=>d.S8,"00efa77c9d731961785a5b1e7f07bb860469145e1c":()=>h.oS,"00f7e3bbdceff614c56d9c0618217f6a37237e9dad":()=>h.Tu,"00fb26efe45ffbcc8d00c2a42ec6f861d86d7e3d1e":()=>h.o3,"00fea79ea40487a21c226cf5b24f305d5e64f4526a":()=>h.I_,"401cb877c53e4448015022e9b01f4182883ef45d73":()=>d.cm,"402327fbf97b3f6a24256d738124d38e8b498305f0":()=>d.m,"40235447972a45e7be663bd2f00f82430e6d4c0271":()=>e.mg,"4033e7726f1645fd69f4a34fdb34b307c97d034641":()=>g.approveIssue,"4038ee006992bbe00c928c2a081d59d03db17e434a":()=>h.R6,"403a6ababd95c4fb61660fec5b83c6dcd865f16c6e":()=>g.planFromConversation,"4047586cae3d36c60610b8172dd5f77a78848f6cf2":()=>h.fb,"404d32bd38a894413e933deedd06e31bfa181a6524":()=>h.h_,"404dd3ea890bd8d8c53efffa4c45fa5c32992979cf":()=>h.NM,"4060d874ebb500e0e00ccb4b93d6305ec6dc34ba0c":()=>g.approveSpec,"40610ea499a895730a6a49548880afb3daa097cc64":()=>d.Cp,"40617eca80dbc17c4fc05884e3336cce12cb2fa80c":()=>h.a4,"4069fcf08d4d4604eb5055a3702d3fbd6e0fbea68d":()=>d.I2,"406ba323fdd094cd6be0fe6a52da6e5a82ed902480":()=>g.rejectSpec,"4075dfc880f582744abc6fd205a1e398e8171d338b":()=>g.setAuto247,"408199f258bc5f07bce1b71b7d09d4730205fa6d05":()=>d.wp,"408e51a879a77d25604c2b85bb002e2373ab8c0ae1":()=>h.lj,"408fe115fb4e6fb989b1aac0f99b3f28a8212293a5":()=>g.advanceIssue,"409118314a7a1407dced0019746ab3104f7f606cc9":()=>h.DX,"40b3031c8c4279dc082ccfde198b7db577a038b4ab":()=>h.is,"40d5b7413e4752fd8fba0cb01132f8fdee0d559bae":()=>d.L0,"40e30755c609a5f0104cb804f584fc0a8e4ee681b5":()=>g.generatePlan,"40e367dc4cfe2c8de5a5cd337230c379082ddf13c8":()=>d.az,"40ea3f661c11a6f8ef2358ad921d6bde489350ce2a":()=>g.startNewWork,"40f71ff46956872e248e34ec53aad9c8776a0a80c9":()=>d.ju,"40fbd1fb24c8548e39971f010ae94d301e3ef53fde":()=>g.rejectIssue,"40ff7bcf6eba2ac7a44d3ed359c8235598c2700580":()=>h.$_,"600a283d3c155b52846ffdf59d78d6fb8408c82a2b":()=>f.I,"6013a509fc0601f5fb3412b8cf3e40d7acccace553":()=>h.RS,"6049fcc984ff3dff10cb80876482ae59126967a274":()=>h.Fo,"6055e32d18d1e47a4180ef8ac3c12189f2fd108244":()=>h.ft,"605952042cd150b4411a52382adbd0d4bdc574e82d":()=>g.groomBacklogFor,"6061a072b77be02b25ff2b1d07ee0156b064a93376":()=>h.qw,"60687b23eb88a4b6d050ea1eff119a716ca285d2f1":()=>f.k,"6084d53ea1253e43f080b2cf0d5c63f3e19b2379cf":()=>h.NW,"60a685a091cc086759e0a7d00c75403864402da012":()=>h.EQ,"60f11f39424b3df2e69f7eef9d8e80488894814d06":()=>e.eA,"60fc13c761fc83ddb2f356490bc36ff0752e8ee7a3":()=>h.pG,"7030d12184597a6da83165a9b71b4d847ac22e61cc":()=>h.a7,"704a45ad07676351351b4cca4b8ab85e3d36edc44b":()=>h.Sy,"7082813cc5d60c4c7e6099074897c0c6b957669cb1":()=>h.sy,"709d782c26c7e7854baca9ee5d66ab588938cab663":()=>h.fM,"70cfbb806c07829324f1ef5574523a9278094c87f1":()=>e.LV,"7cda87ea6eaf270f89f1eabe473a45cb38fb38794a":()=>h.Hg});var d=c(15878),e=c(89258),f=c(87980),g=c(12529),h=c(74910)},74910:(a,b,c)=>{c.d(b,{Hg:()=>aj,a7:()=>ak,sy:()=>am,is:()=>H,fM:()=>I,Sy:()=>G,e9:()=>ap,EQ:()=>an,NM:()=>al,$_:()=>ab,qw:()=>T,DX:()=>W,ME:()=>E,oS:()=>J,RS:()=>K,R6:()=>ai,wP:()=>X,Ni:()=>_,gn:()=>ac,yL:()=>ae,NW:()=>Q,lj:()=>Z,fb:()=>ah,pG:()=>af,I_:()=>L,Fo:()=>N,o3:()=>O,a4:()=>ag,ft:()=>aa,Tu:()=>V,h_:()=>F,PO:()=>U});var d=c(36548),e=c(77598),f=c(50730),g=c(23888),h=c(5557),i=c(12940),j=c(76561),k=c(2148),l=c(55104),m=c(87980),n=c(79017),o=c(66263),p=c(66408),q=c(21046),r=c(44440),s=c(12851),t=c(13171);let u=new Set(["Next.js","Nuxt","Remix","SvelteKit","Astro","Gatsby"]);var v=c(20699),w=c(11168),x=c(96807);function y(a,b){if(!b||/^(https?:)?\/\//i.test(b)||b.startsWith("data:")||b.startsWith("#")||b.startsWith("/"))return null;let c=b.split(/[?#]/)[0].trim();if(!c)return null;let d=a?a.split("/").filter(Boolean):[];for(let a of c.split("/"))if(""!==a&&"."!==a){if(".."===a){if(!d.length)return null;d.pop();continue}d.push(a)}let e=d.join("/");return e.includes("..")||!e.startsWith("design-mock/")?null:e}function z(a,b,c,d){let e=b.replace(/\/[^/]*$/,"");return a.replace(/@import\s+(?:url\(\s*)?["']?([^"')]+)["']?\s*\)?\s*;/gi,(a,b)=>{let f=y(e,String(b));if(!f||!/\.css$/i.test(f))return a;if(d.has(f))return"";d.add(f);let g=c(f);return null==g?`/* design: missing ${f} */`:`/* ${f} */
|
|
56
56
|
`+z(g,f,c,d)})}function A(a,b,c){let d=b.replace(/\/[^/]*$/,""),e=a.replace(/<link\b[^>]*>/gi,a=>{if(!/stylesheet/i.test(a)&&!/href\s*=\s*["'][^"']+\.css/i.test(a))return a;let b=a.match(/href\s*=\s*["']([^"']+)["']/i),e=b?y(d,b[1]):null;if(!e||!/\.css$/i.test(e))return a;let f=c(e);return null==f?`<!-- design: missing ${e} -->`:`<style data-cstla-bundled="${e}">
|
|
57
57
|
${z(f,e,c,new Set([e]))}
|
|
58
58
|
</style>`});return e.replace(/<style\b([^>]*)>([\s\S]*?)<\/style>/gi,(a,d,e)=>/@import/i.test(e)?`<style${d}>${z(e,b,c,new Set)}</style>`:a)}var B=c(99688);let C="design";async function D(a){let b=await i.db.select().from(j.agent).where((0,f.eq)(j.agent.workspaceId,a));return b.find(a=>"grace"===a.handle)??b.find(a=>/front\s?end|\bui\b|\bux\b/i.test(a.role))??b[0]??null}async function E(){let{workspace:a}=await (0,k.nP)();(0,s.I)();let[b]=await i.db.select().from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(b)return{id:b.id,status:b.status};let c=(0,e.randomUUID)();return await i.db.insert(j.designSession).values({id:c,workspaceId:a.id,title:`${a.name} — design`,status:"building",tokens:{}}),{id:c,status:"building"}}async function F(a){let{workspace:b}=await (0,k.nP)();(0,s.I)();let[c]=await i.db.select().from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,b.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);return c?await i.db.update(j.designSession).set({tokens:a,updatedAt:new Date}).where((0,f.eq)(j.designSession.id,c.id)):await i.db.insert(j.designSession).values({id:(0,e.randomUUID)(),workspaceId:b.id,title:`${b.name} — design`,status:"building",tokens:a}),{ok:!0}}async function G(a,b,c){let d=a?.trim(),p=(b??[]).map(a=>a?.path).filter(a=>!!a&&a.startsWith("uploads/")).slice(0,6);if(!d&&!p.length&&!c)return{ok:!1,error:"Describe what you want to prototype or change."};let{org:q,workspace:u}=await (0,k.nP)();(0,s.I)();let y=await D(u.id);if(!y)return{ok:!1,error:"No frontend agent found."};let z=d||(p.length?"(image)":c?"Adjust this element.":"(image)"),A=(0,e.randomUUID)();await i.db.insert(j.message).values({id:A,workspaceId:u.id,channel:C,fromKind:"operator",text:c?`${z}
|
|
@@ -130,4 +130,4 @@ ${c.map(a=>"- "+a).join("\n")||"(scan the project for components / screens / sty
|
|
|
130
130
|
1) Create design-mock/styles/global.css with the design tokens (:root), reset/base and theme ([data-theme]).
|
|
131
131
|
2) Scaffold a skeleton of the main screen(s) under design-mock/screens/ — valid HTML linking ../styles/global.css, with the key sections blocked out as labelled placeholders.
|
|
132
132
|
3) Write design-mock/design-system.md outlining the palette, typography, spacing, core components and the screens to build.
|
|
133
|
-
4) Tell me what you set up and what to build/validate next before approving.`;return G(`Ada is preparing the delivery plan and needs the design prototyped + approved first (zero drift). ${a}`)}async function W(a){let{org:b}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};let c=(0,p.sL)(b.id,a);return null==c?{ok:!1,error:"Screen not found."}:{ok:!0,html:A(c,a,a=>(0,p.sL)(b.id,a)).slice(0,2e6)}}async function X(){let{org:a,workspace:b}=await (0,k.nP)(),c=(0,p.CS)(a.id).filter(a=>a.startsWith("design-mock/")&&/\.(md|markdown)$/i.test(a)&&!/\/README\.md$/i.test(a)).map(a=>({path:a,label:a.replace(/^design-mock\//,"")})).sort((a,b)=>Y(a.path)-Y(b.path)||a.label.localeCompare(b.label));return(0,t.zw)(a.id,b),{docs:c}}function Y(a){return/APPROVED\.md$/i.test(a)?0:/design-system\.md$/i.test(a)?1:2}async function Z(a){let{org:b}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.(md|markdown)$/i.test(a))return{ok:!1,error:"Not a design doc."};let c=(0,p.sL)(b.id,a);return null==c?{ok:!1,error:"Doc not found."}:{ok:!0,body:c.slice(0,5e5)}}let $=".claude/design-presets.json";async function _(){let{org:a}=await (0,k.nP)(),b=(0,p.sL)(a.id,$);if(!b)return{presets:[]};try{let a=JSON.parse(b);return{presets:Array.isArray(a)?a.slice(0,60):[]}}catch{return{presets:[]}}}async function aa(a,b){let{org:c}=await (0,k.nP)(),d=(a??"").trim();if(!d||d.length>6e4)return{ok:!1,error:"Nothing to save."};let{presets:f}=await _(),g=[{id:"p"+(0,e.randomUUID)().slice(0,6),label:(b||"Preset").slice(0,40),html:d},...f].slice(0,60);return(0,p.dx)(c.id,$,JSON.stringify(g,null,2)),{ok:!0}}async function ab(a){let{org:b}=await (0,k.nP)(),{presets:c}=await _();return(0,p.dx)(b.id,$,JSON.stringify(c.filter(b=>b.id!==a),null,2)),{ok:!0}}async function ac(){let{org:a,workspace:b}=await (0,k.nP)(),c=(0,t.zw)(a.id,b);return{screens:c.designMockFiles.filter(a=>/\.html?$/i.test(a)),components:c.designMockFiles.filter(a=>a.startsWith("design-mock/components/"))}}async function ad(a,b,c){let[d]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!d)return;let h=await i.db.select({id:j.designVersion.id}).from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,d.id));await i.db.insert(j.designVersion).values({id:(0,e.randomUUID)(),sessionId:d.id,label:"v"+(h.length+1),note:b.slice(0,300),patch:{files:c}})}async function ae(){let{workspace:a}=await (0,k.nP)();(0,s.I)();let[b]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);return b?{versions:(await i.db.select().from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,b.id)).orderBy((0,g.i)(j.designVersion.createdAt))).map(a=>{let b=a.patch;return{id:a.id,label:a.label,note:a.note,files:b?.files??[],restorable:!!b?.snapshot,createdAt:a.createdAt.getTime()}})}:{versions:[]}}async function af(a,b){return G(`Restore the prototype to ${a} — "${b}". Re-apply that state to the screens under design-mock/screens/ and tell me what changed.`)}async function ag(a){let{org:b,workspace:c}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};(0,s.I)();let d=(0,p.sL)(b.id,a);if(null==d)return{ok:!1,error:"Screen not found."};let[l]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,c.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!l)return{ok:!1,error:"No design session."};let m="Saved v"+((await i.db.select({id:j.designVersion.id}).from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,l.id))).length+1),n=(a.split("/").pop()||a).replace(/\.[a-z]+$/i,"");await i.db.insert(j.designVersion).values({id:(0,e.randomUUID)(),sessionId:l.id,label:m,note:`Checkpoint \xb7 ${n}`,patch:{files:[a],snapshot:d}});try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,label:m}}async function ah(a){let{org:b,workspace:c}=await (0,k.nP)();(0,s.I)();let[d]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,c.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!d)return{ok:!1,error:"No design session."};let[e]=await i.db.select().from(j.designVersion).where((0,f.Uo)((0,f.eq)(j.designVersion.id,a),(0,f.eq)(j.designVersion.sessionId,d.id))).limit(1);if(!e)return{ok:!1,error:"Checkpoint not found."};let l=e.patch,m=l?.files?.[0];if(!l?.snapshot||!m)return{ok:!1,error:"This version isn't a restorable checkpoint."};if(!m.startsWith("design-mock/")||m.includes(".."))return{ok:!1,error:"Bad path."};(0,p.dx)(b.id,m,l.snapshot);try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function ai(a){let{workspace:b}=await (0,k.nP)();(0,s.I)();let[c]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,b.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!c)return{comments:[]};let d=a?(0,f.Uo)((0,f.eq)(j.designComment.sessionId,c.id),(0,f.eq)(j.designComment.pageKey,a)):(0,f.eq)(j.designComment.sessionId,c.id);return{comments:(await i.db.select().from(j.designComment).where(d).orderBy(j.designComment.createdAt)).map(a=>({id:a.id,pageKey:a.pageKey,xp:a.xp,yp:a.yp,body:a.body,reply:a.reply,selection:a.selection,createdAt:a.createdAt.getTime()}))}}async function aj(a,b,c,d,f){let g=d?.trim();if(!g)return{ok:!1,error:"Empty comment."};(0,s.I)();let k=await E(),l=(0,e.randomUUID)();await i.db.insert(j.designComment).values({id:l,sessionId:k.id,pageKey:(a||"").slice(0,300),xp:b,yp:c,body:g.slice(0,2e3),reply:"",selection:f??null});try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,id:l}}async function ak(a,b,c){(0,s.I)();let d=await E(),f=(0,e.randomUUID)(),g=(c||"").trim();await i.db.insert(j.designComment).values({id:f,sessionId:d.id,pageKey:(a||"").slice(0,300),xp:b.x,yp:b.y,body:(g||"(region marked for review)").slice(0,2e3),reply:"",selection:{kind:"markup",rect:b}});try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,id:f}}async function al(a){let{workspace:b}=await (0,k.nP)();(0,s.I)();let[c]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,b.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);c&&await i.db.delete(j.designComment).where((0,f.Uo)((0,f.eq)(j.designComment.id,a),(0,f.eq)(j.designComment.sessionId,c.id)));try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function am(a,b,c){let{org:d}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};let e=(b??"").trim();if(!e)return{ok:!1,error:"Nothing to replace."};let f=(0,p.sL)(d.id,a);if(null==f)return{ok:!1,error:"Screen not found."};let g=f.indexOf(e);if(g<0)return{ok:!1,error:"Couldn't locate that text — ask Grace to apply it."};if(f.indexOf(e,g+1)>=0)return{ok:!1,error:"That text appears more than once — ask Grace to apply it."};(0,p.dx)(d.id,a,f.slice(0,g)+(c??"")+f.slice(g+e.length));try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function an(a,b){let{org:c,workspace:d}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};if(null==b)return{ok:!1,error:"Nothing to commit."};if(b.length>4e6)return{ok:!1,error:"Screen too large."};let e=b,f=e.match(/<body[^>]*>([\s\S]*)<\/body>/i);f&&(e=f[1]),e=e.replace(/<!doctype[^>]*>/gi,"").replace(/<\/?(?:html|head|body)\b[^>]*>/gi,"");let g=(0,p.sL)(c.id,a);if(null==g)return{ok:!1,error:"Screen not found."};let i=g.match(/<body([^>]*)>[\s\S]*<\/body>/i),j=i&&null!=i.index?g.slice(0,i.index)+`<body${i[1]}>`+e+"</body>"+g.slice(i.index+i[0].length):`<!doctype html><html><head><meta charset="utf-8"></head><body>${e}</body></html>`;(0,p.dx)(c.id,a,j);try{await ao(d.id,a)}catch{}try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function ao(a,b){let[c]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!c)return;let d="Manual canvas edit",[h]=await i.db.select().from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,c.id)).orderBy((0,g.i)(j.designVersion.createdAt)).limit(1);if(h&&h.note===d&&Date.now()-h.createdAt.getTime()<9e4){let a=Array.from(new Set([...h.patch?.files??[],b]));await i.db.update(j.designVersion).set({patch:{files:a},createdAt:new Date}).where((0,f.eq)(j.designVersion.id,h.id))}else{let a=await i.db.select({id:j.designVersion.id}).from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,c.id));await i.db.insert(j.designVersion).values({id:(0,e.randomUUID)(),sessionId:c.id,label:"v"+(a.length+1),note:d,patch:{files:[b]}})}}async function ap(){let{org:a,workspace:b}=await (0,k.nP)(),c=(0,t.zw)(a.id,b).designMockFiles.filter(a=>/design-mock\/screens\/.+\.html?$/i.test(a));if(!c.length)return{ok:!1,built:[],error:"No screens to build yet — ask Grace for a screen first."};let d=[];for(let b of c){let c=(0,p.sL)(a.id,b);if(null==c)continue;let{out:e,obfuscated:f}=function(a){let b=/<script\b/i.test(a),c=function(a){let b;return(b=[],a.replace(/<style\b([^>]*)>([\s\S]*?)<\/style>/gi,(a,b,c)=>`<style${b}>${c.replace(/\/\*[\s\S]*?\*\//g,"").replace(/\s+/g," ").replace(/\s*([{};,])\s*/g,"$1").replace(/:\s+/g,":").replace(/;}/g,"}").trim()}</style>`).replace(/<(script|style)\b[\s\S]*?<\/\1>/gi,a=>(b.push(a),`\0${b.length-1}\0`)).replace(/<!--(?!\[if)[\s\S]*?-->/g,"").replace(/(\d+)/g,(a,c)=>b[Number(c)])).trim()}(a);return b||(c=function(a){if(/<script\b/i.test(a))return a;let b=new Set;for(let c of a.matchAll(/class\s*=\s*"([^"]*)"/gi))c[1].split(/\s+/).filter(Boolean).forEach(a=>b.add(a));if(!b.size)return a;let c=new Map;[...b].forEach((a,b)=>c.set(a,function(a){let b="",c=a+1;for(;c>0;)b="abcdefghijklmnopqrstuvwxyz"[--c%26]+b,c=Math.floor(c/26);return b}(b)));let d=a.replace(/class\s*=\s*"([^"]*)"/gi,(a,b)=>`class="${b.split(/\s+/).filter(Boolean).map(a=>c.get(a)??a).join(" ")}"`);return d.replace(/<style\b([^>]*)>([\s\S]*?)<\/style>/gi,(a,b,d)=>{let e=d;for(let[a,b]of c)e=e.replace(RegExp("\\."+a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")+"(?![-_\\w])","g"),"."+b);return`<style${b}>${e}</style>`})}(c)),{out:c,obfuscated:!b}}(A(c,b,b=>(0,p.sL)(a.id,b))),g=`design-mock/dist/${b.split("/").pop()}`;(0,p.dx)(a.id,g,e),d.push({path:g,before:c.length,after:e.length,obfuscated:f})}try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,built:d}}(0,B.D)([E,F,G,H,I,J,K,L,N,O,Q,T,U,V,W,X,Z,_,aa,ab,ac,ae,af,ag,ah,ai,aj,ak,al,am,an,ap]),(0,d.A)(E,"005b10ac4df7ed0f7392e991bb82ed4f88d3b61d74",null),(0,d.A)(F,"4067307ce089b31d3e494ed9c0f93d9847b649e934",null),(0,d.A)(G,"7080b27ff6dfc3db037e16c1bfcb0dbdd6e39da61a",null),(0,d.A)(H,"40c1f693730c73d3ea25cb7fead89fbeddc38941bf",null),(0,d.A)(I,"704f3c299b2a26f4c589dae77dd538aca487aaa71c",null),(0,d.A)(J,"007d2d9dd848b3415490b6f32875e692d898958ab6",null),(0,d.A)(K,"60a086bbd97cfbf602cbe04606aa1b54802fc1d3fe",null),(0,d.A)(L,"00881dc144c821d03ec1349f977507a79eb62c08b9",null),(0,d.A)(N,"60b2749ebc40600e93b4d9b6be93528555dea63350",null),(0,d.A)(O,"00ba0232091ba4ed048391fa668752ce34b548bcf0",null),(0,d.A)(Q,"60816c6010080d0c3b54871286f36bd24e0618aaa6",null),(0,d.A)(T,"60df6fc6cfbfdc1eb8f9a039646193c4d8d1b3ecfa",null),(0,d.A)(U,"00c62021056f8b2c00829a8b7d390353eaabc724a4",null),(0,d.A)(V,"00a3c4b5a13e1dde6efab6d5421a9232dfd87a4689",null),(0,d.A)(W,"40bac470c1253b0cd0dc683537b3cf5462d92020bc",null),(0,d.A)(X,"000e9041aeb30b4c8ca71341990e208d68b7b21b7f",null),(0,d.A)(Z,"40aa8544982f3077cdbc78e57a1bc7a1d078a5035f",null),(0,d.A)(_,"00956b8eaaf169063abde5cb3f59badefbe71915f6",null),(0,d.A)(aa,"6021c456fc57cc4afc301239c8ce96b2f55ebeaab6",null),(0,d.A)(ab,"402081a0915ac82ebc6d340fbf82e3746a4925eb8b",null),(0,d.A)(ac,"000bae14a63337ad112175da81b78bcd62ba42a2df",null),(0,d.A)(ae,"008f3863abc603d341052a4bbab8ce9243ad029880",null),(0,d.A)(af,"60e6e05368a96761ba5c0fb9a1542975b0e1812ac5",null),(0,d.A)(ag,"400df4e1324216021f528585fdf52bcbb465ae43c6",null),(0,d.A)(ah,"40103701dbb018905c3123a247995125d8a7bd4d7a",null),(0,d.A)(ai,"40a8566bc9a80a001d82131f509bd374af991b76ff",null),(0,d.A)(aj,"7cd67f9da791307c34e973ce5935ff3ebdb540ece0",null),(0,d.A)(ak,"7092594720b30422789b60560e0e360acd53a13329",null),(0,d.A)(al,"40b8490ba2b7dd406f11ea61518ad8761bb15ca558",null),(0,d.A)(am,"700861576230a313df69af7bb3b2ad32c90963e9fe",null),(0,d.A)(an,"602d70d47f8248807f19f7af7595ad03cb510362f1",null),(0,d.A)(ap,"000775aa288b626c1a9d42728f9f4ff7d9d3d468d4",null)},76760:a=>{a.exports=require("node:path")},77030:a=>{a.exports=require("node:net")},77598:a=>{a.exports=require("node:crypto")},78474:a=>{a.exports=require("node:events")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[5911,5361,6309,4679,7474,5557,6585,1243,912,415,77,5878,8134,6807,2323,26,1033,6121,907,699],()=>b(b.s=49131));module.exports=c})();
|
|
133
|
+
4) Tell me what you set up and what to build/validate next before approving.`;return G(`Ada is preparing the delivery plan and needs the design prototyped + approved first (zero drift). ${a}`)}async function W(a){let{org:b}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};let c=(0,p.sL)(b.id,a);return null==c?{ok:!1,error:"Screen not found."}:{ok:!0,html:A(c,a,a=>(0,p.sL)(b.id,a)).slice(0,2e6)}}async function X(){let{org:a,workspace:b}=await (0,k.nP)(),c=(0,p.CS)(a.id).filter(a=>a.startsWith("design-mock/")&&/\.(md|markdown)$/i.test(a)&&!/\/README\.md$/i.test(a)).map(a=>({path:a,label:a.replace(/^design-mock\//,"")})).sort((a,b)=>Y(a.path)-Y(b.path)||a.label.localeCompare(b.label));return(0,t.zw)(a.id,b),{docs:c}}function Y(a){return/APPROVED\.md$/i.test(a)?0:/design-system\.md$/i.test(a)?1:2}async function Z(a){let{org:b}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.(md|markdown)$/i.test(a))return{ok:!1,error:"Not a design doc."};let c=(0,p.sL)(b.id,a);return null==c?{ok:!1,error:"Doc not found."}:{ok:!0,body:c.slice(0,5e5)}}let $=".claude/design-presets.json";async function _(){let{org:a}=await (0,k.nP)(),b=(0,p.sL)(a.id,$);if(!b)return{presets:[]};try{let a=JSON.parse(b);return{presets:Array.isArray(a)?a.slice(0,60):[]}}catch{return{presets:[]}}}async function aa(a,b){let{org:c}=await (0,k.nP)(),d=(a??"").trim();if(!d||d.length>6e4)return{ok:!1,error:"Nothing to save."};let{presets:f}=await _(),g=[{id:"p"+(0,e.randomUUID)().slice(0,6),label:(b||"Preset").slice(0,40),html:d},...f].slice(0,60);return(0,p.dx)(c.id,$,JSON.stringify(g,null,2)),{ok:!0}}async function ab(a){let{org:b}=await (0,k.nP)(),{presets:c}=await _();return(0,p.dx)(b.id,$,JSON.stringify(c.filter(b=>b.id!==a),null,2)),{ok:!0}}async function ac(){let{org:a,workspace:b}=await (0,k.nP)(),c=(0,t.zw)(a.id,b);return{screens:c.designMockFiles.filter(a=>/\.html?$/i.test(a)),components:c.designMockFiles.filter(a=>a.startsWith("design-mock/components/"))}}async function ad(a,b,c){let[d]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!d)return;let h=await i.db.select({id:j.designVersion.id}).from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,d.id));await i.db.insert(j.designVersion).values({id:(0,e.randomUUID)(),sessionId:d.id,label:"v"+(h.length+1),note:b.slice(0,300),patch:{files:c}})}async function ae(){let{workspace:a}=await (0,k.nP)();(0,s.I)();let[b]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);return b?{versions:(await i.db.select().from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,b.id)).orderBy((0,g.i)(j.designVersion.createdAt))).map(a=>{let b=a.patch;return{id:a.id,label:a.label,note:a.note,files:b?.files??[],restorable:!!b?.snapshot,createdAt:a.createdAt.getTime()}})}:{versions:[]}}async function af(a,b){return G(`Restore the prototype to ${a} — "${b}". Re-apply that state to the screens under design-mock/screens/ and tell me what changed.`)}async function ag(a){let{org:b,workspace:c}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};(0,s.I)();let d=(0,p.sL)(b.id,a);if(null==d)return{ok:!1,error:"Screen not found."};let[l]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,c.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!l)return{ok:!1,error:"No design session."};let m="Saved v"+((await i.db.select({id:j.designVersion.id}).from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,l.id))).length+1),n=(a.split("/").pop()||a).replace(/\.[a-z]+$/i,"");await i.db.insert(j.designVersion).values({id:(0,e.randomUUID)(),sessionId:l.id,label:m,note:`Checkpoint \xb7 ${n}`,patch:{files:[a],snapshot:d}});try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,label:m}}async function ah(a){let{org:b,workspace:c}=await (0,k.nP)();(0,s.I)();let[d]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,c.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!d)return{ok:!1,error:"No design session."};let[e]=await i.db.select().from(j.designVersion).where((0,f.Uo)((0,f.eq)(j.designVersion.id,a),(0,f.eq)(j.designVersion.sessionId,d.id))).limit(1);if(!e)return{ok:!1,error:"Checkpoint not found."};let l=e.patch,m=l?.files?.[0];if(!l?.snapshot||!m)return{ok:!1,error:"This version isn't a restorable checkpoint."};if(!m.startsWith("design-mock/")||m.includes(".."))return{ok:!1,error:"Bad path."};(0,p.dx)(b.id,m,l.snapshot);try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function ai(a){let{workspace:b}=await (0,k.nP)();(0,s.I)();let[c]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,b.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!c)return{comments:[]};let d=a?(0,f.Uo)((0,f.eq)(j.designComment.sessionId,c.id),(0,f.eq)(j.designComment.pageKey,a)):(0,f.eq)(j.designComment.sessionId,c.id);return{comments:(await i.db.select().from(j.designComment).where(d).orderBy(j.designComment.createdAt)).map(a=>({id:a.id,pageKey:a.pageKey,xp:a.xp,yp:a.yp,body:a.body,reply:a.reply,selection:a.selection,createdAt:a.createdAt.getTime()}))}}async function aj(a,b,c,d,f){let g=d?.trim();if(!g)return{ok:!1,error:"Empty comment."};(0,s.I)();let k=await E(),l=(0,e.randomUUID)();await i.db.insert(j.designComment).values({id:l,sessionId:k.id,pageKey:(a||"").slice(0,300),xp:b,yp:c,body:g.slice(0,2e3),reply:"",selection:f??null});try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,id:l}}async function ak(a,b,c){(0,s.I)();let d=await E(),f=(0,e.randomUUID)(),g=(c||"").trim();await i.db.insert(j.designComment).values({id:f,sessionId:d.id,pageKey:(a||"").slice(0,300),xp:b.x,yp:b.y,body:(g||"(region marked for review)").slice(0,2e3),reply:"",selection:{kind:"markup",rect:b}});try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,id:f}}async function al(a){let{workspace:b}=await (0,k.nP)();(0,s.I)();let[c]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,b.id)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);c&&await i.db.delete(j.designComment).where((0,f.Uo)((0,f.eq)(j.designComment.id,a),(0,f.eq)(j.designComment.sessionId,c.id)));try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function am(a,b,c){let{org:d}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};let e=(b??"").trim();if(!e)return{ok:!1,error:"Nothing to replace."};let f=(0,p.sL)(d.id,a);if(null==f)return{ok:!1,error:"Screen not found."};let g=f.indexOf(e);if(g<0)return{ok:!1,error:"Couldn't locate that text — ask Grace to apply it."};if(f.indexOf(e,g+1)>=0)return{ok:!1,error:"That text appears more than once — ask Grace to apply it."};(0,p.dx)(d.id,a,f.slice(0,g)+(c??"")+f.slice(g+e.length));try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function an(a,b){let{org:c,workspace:d}=await (0,k.nP)();if(!a||!a.startsWith("design-mock/")||a.includes("..")||!/\.html?$/i.test(a))return{ok:!1,error:"Not a design screen."};if(null==b)return{ok:!1,error:"Nothing to commit."};if(b.length>4e6)return{ok:!1,error:"Screen too large."};let e=b,f=e.match(/<body[^>]*>([\s\S]*)<\/body>/i);f&&(e=f[1]),e=e.replace(/<!doctype[^>]*>/gi,"").replace(/<\/?(?:html|head|body)\b[^>]*>/gi,"");let g=(0,p.sL)(c.id,a);if(null==g)return{ok:!1,error:"Screen not found."};let i=g.match(/<body([^>]*)>[\s\S]*<\/body>/i),j=i&&null!=i.index?g.slice(0,i.index)+`<body${i[1]}>`+e+"</body>"+g.slice(i.index+i[0].length):`<!doctype html><html><head><meta charset="utf-8"></head><body>${e}</body></html>`;(0,p.dx)(c.id,a,j);try{await ao(d.id,a)}catch{}try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function ao(a,b){let[c]=await i.db.select({id:j.designSession.id}).from(j.designSession).where((0,f.eq)(j.designSession.workspaceId,a)).orderBy((0,g.i)(j.designSession.createdAt)).limit(1);if(!c)return;let d="Manual canvas edit",[h]=await i.db.select().from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,c.id)).orderBy((0,g.i)(j.designVersion.createdAt)).limit(1);if(h&&h.note===d&&Date.now()-h.createdAt.getTime()<9e4){let a=Array.from(new Set([...h.patch?.files??[],b]));await i.db.update(j.designVersion).set({patch:{files:a},createdAt:new Date}).where((0,f.eq)(j.designVersion.id,h.id))}else{let a=await i.db.select({id:j.designVersion.id}).from(j.designVersion).where((0,f.eq)(j.designVersion.sessionId,c.id));await i.db.insert(j.designVersion).values({id:(0,e.randomUUID)(),sessionId:c.id,label:"v"+(a.length+1),note:d,patch:{files:[b]}})}}async function ap(){let{org:a,workspace:b}=await (0,k.nP)(),c=(0,t.zw)(a.id,b).designMockFiles.filter(a=>/design-mock\/screens\/.+\.html?$/i.test(a));if(!c.length)return{ok:!1,built:[],error:"No screens to build yet — ask Grace for a screen first."};let d=[];for(let b of c){let c=(0,p.sL)(a.id,b);if(null==c)continue;let{out:e,obfuscated:f}=function(a){let b=/<script\b/i.test(a),c=function(a){let b;return(b=[],a.replace(/<style\b([^>]*)>([\s\S]*?)<\/style>/gi,(a,b,c)=>`<style${b}>${c.replace(/\/\*[\s\S]*?\*\//g,"").replace(/\s+/g," ").replace(/\s*([{};,])\s*/g,"$1").replace(/:\s+/g,":").replace(/;}/g,"}").trim()}</style>`).replace(/<(script|style)\b[\s\S]*?<\/\1>/gi,a=>(b.push(a),`\0${b.length-1}\0`)).replace(/<!--(?!\[if)[\s\S]*?-->/g,"").replace(/(\d+)/g,(a,c)=>b[Number(c)])).trim()}(a);return b||(c=function(a){if(/<script\b/i.test(a))return a;let b=new Set;for(let c of a.matchAll(/class\s*=\s*"([^"]*)"/gi))c[1].split(/\s+/).filter(Boolean).forEach(a=>b.add(a));if(!b.size)return a;let c=new Map;[...b].forEach((a,b)=>c.set(a,function(a){let b="",c=a+1;for(;c>0;)b="abcdefghijklmnopqrstuvwxyz"[--c%26]+b,c=Math.floor(c/26);return b}(b)));let d=a.replace(/class\s*=\s*"([^"]*)"/gi,(a,b)=>`class="${b.split(/\s+/).filter(Boolean).map(a=>c.get(a)??a).join(" ")}"`);return d.replace(/<style\b([^>]*)>([\s\S]*?)<\/style>/gi,(a,b,d)=>{let e=d;for(let[a,b]of c)e=e.replace(RegExp("\\."+a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")+"(?![-_\\w])","g"),"."+b);return`<style${b}>${e}</style>`})}(c)),{out:c,obfuscated:!b}}(A(c,b,b=>(0,p.sL)(a.id,b))),g=`design-mock/dist/${b.split("/").pop()}`;(0,p.dx)(a.id,g,e),d.push({path:g,before:c.length,after:e.length,obfuscated:f})}try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0,built:d}}(0,B.D)([E,F,G,H,I,J,K,L,N,O,Q,T,U,V,W,X,Z,_,aa,ab,ac,ae,af,ag,ah,ai,aj,ak,al,am,an,ap]),(0,d.A)(E,"001d0063b3096499a8ec0f764994e221c6f50cabec",null),(0,d.A)(F,"404d32bd38a894413e933deedd06e31bfa181a6524",null),(0,d.A)(G,"704a45ad07676351351b4cca4b8ab85e3d36edc44b",null),(0,d.A)(H,"40b3031c8c4279dc082ccfde198b7db577a038b4ab",null),(0,d.A)(I,"709d782c26c7e7854baca9ee5d66ab588938cab663",null),(0,d.A)(J,"00efa77c9d731961785a5b1e7f07bb860469145e1c",null),(0,d.A)(K,"6013a509fc0601f5fb3412b8cf3e40d7acccace553",null),(0,d.A)(L,"00fea79ea40487a21c226cf5b24f305d5e64f4526a",null),(0,d.A)(N,"6049fcc984ff3dff10cb80876482ae59126967a274",null),(0,d.A)(O,"00fb26efe45ffbcc8d00c2a42ec6f861d86d7e3d1e",null),(0,d.A)(Q,"6084d53ea1253e43f080b2cf0d5c63f3e19b2379cf",null),(0,d.A)(T,"6061a072b77be02b25ff2b1d07ee0156b064a93376",null),(0,d.A)(U,"0077f2278034c406de1ccda97e8e5a1cb8b4778021",null),(0,d.A)(V,"00f7e3bbdceff614c56d9c0618217f6a37237e9dad",null),(0,d.A)(W,"409118314a7a1407dced0019746ab3104f7f606cc9",null),(0,d.A)(X,"0066100dc8904c58a270ededd9857f10c67f424e9a",null),(0,d.A)(Z,"408e51a879a77d25604c2b85bb002e2373ab8c0ae1",null),(0,d.A)(_,"00cc8dfdd18e2ae71e708ee33dac193a2c30f1b512",null),(0,d.A)(aa,"6055e32d18d1e47a4180ef8ac3c12189f2fd108244",null),(0,d.A)(ab,"40ff7bcf6eba2ac7a44d3ed359c8235598c2700580",null),(0,d.A)(ac,"00139cfd8b058e81fd1f5a24e4095013e8a715ec60",null),(0,d.A)(ae,"001e0576d5722123766a79fcba07b464a665a26402",null),(0,d.A)(af,"60fc13c761fc83ddb2f356490bc36ff0752e8ee7a3",null),(0,d.A)(ag,"40617eca80dbc17c4fc05884e3336cce12cb2fa80c",null),(0,d.A)(ah,"4047586cae3d36c60610b8172dd5f77a78848f6cf2",null),(0,d.A)(ai,"4038ee006992bbe00c928c2a081d59d03db17e434a",null),(0,d.A)(aj,"7cda87ea6eaf270f89f1eabe473a45cb38fb38794a",null),(0,d.A)(ak,"7030d12184597a6da83165a9b71b4d847ac22e61cc",null),(0,d.A)(al,"404dd3ea890bd8d8c53efffa4c45fa5c32992979cf",null),(0,d.A)(am,"7082813cc5d60c4c7e6099074897c0c6b957669cb1",null),(0,d.A)(an,"60a685a091cc086759e0a7d00c75403864402da012",null),(0,d.A)(ap,"001425f60c0da2dd1d0eee8afc70c30f2d6d02d1d7",null)},76760:a=>{a.exports=require("node:path")},77030:a=>{a.exports=require("node:net")},77598:a=>{a.exports=require("node:crypto")},78474:a=>{a.exports=require("node:events")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[5911,5361,6309,4679,7474,5557,6585,1243,912,415,77,5878,8134,6807,2323,26,1033,6121,907,699],()=>b(b.s=49131));module.exports=c})();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";(()=>{var a={};a.id=2835,a.ids=[2835],a.modules={261:a=>{a.exports=require("next/dist/shared/lib/router/utils/app-paths")},3295:a=>{a.exports=require("next/dist/server/app-render/after-task-async-storage.external.js")},4326:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>Y,patchFetch:()=>X,routeModule:()=>T,serverHooks:()=>W,workAsyncStorage:()=>U,workUnitAsyncStorage:()=>V});var d={};c.r(d),c.d(d,{GET:()=>R,POST:()=>S,dynamic:()=>M,runtime:()=>L});var e=c(16633),f=c(35526),g=c(80445),h=c(49421),i=c(68279),j=c(22827),k=c(261),l=c(45469),m=c(19923),n=c(17653),o=c(70486),p=c(49496),q=c(16674),r=c(11264),s=c(7001),t=c(86439),u=c(4535),v=c(91736),w=c(77598),x=c(50730),y=c(12940),z=c(76561),A=c(2148);async function B(a,b){let c=/^Bearer\s+(cn_[A-Za-z0-9_-]{8,})$/.exec((a??"").trim());if(!c)return{ok:!1,status:401,error:"missing or malformed bearer token"};let d=(0,w.createHash)("sha256").update(c[1]).digest("hex"),[e]=await y.db.select().from(z.personalAccessToken).where((0,x.eq)(z.personalAccessToken.tokenHash,d));if(!e)return{ok:!1,status:401,error:"invalid token"};try{await y.db.update(z.personalAccessToken).set({lastUsedAt:new Date}).where((0,x.eq)(z.personalAccessToken.id,e.id))}catch{}let f=await (0,A.$x)(e.userId,b??void 0);if(!f)return{ok:!1,status:404,error:"no organization for this token's user"};if(f.archived)return{ok:!1,status:409,error:"organization is archived"};let g=await (0,A.K4)(f.id);return g?{ok:!0,auth:{userId:e.userId,tokenId:e.id,scope:e.scope,org:f,workspace:g}}:{ok:!1,status:404,error:"no workspace for the organization"}}async function C(a){let[b,c,d,[e]]=await Promise.all([y.db.select({status:z.goal.status}).from(z.goal).where((0,x.eq)(z.goal.workspaceId,a.id)),y.db.select({col:z.issue.col}).from(z.issue).where((0,x.eq)(z.issue.workspaceId,a.id)),y.db.select({col:z.task.col}).from(z.task).where((0,x.eq)(z.task.workspaceId,a.id)),y.db.select().from(z.plan).where((0,x.eq)(z.plan.workspaceId,a.id))]),f=a=>a.reduce((a,b)=>(a[b.col]=(a[b.col]??0)+1,a),{});return{workspace:{id:a.id,name:a.name,slug:a.slug},goals:{active:b.filter(a=>"active"===a.status).length,total:b.length},issues:{open:c.filter(a=>"done"!==a.col).length,total:c.length,byCol:f(c)},tasks:{doing:d.filter(a=>"doing"===a.col).length,total:d.length,byCol:f(d)},plan:e?{approved:e.approved,auto247:e.auto247,stage:e.stage}:null}}async function D(a){return await y.db.select({id:z.goal.id,title:z.goal.title,status:z.goal.status,progress:z.goal.progress}).from(z.goal).where((0,x.eq)(z.goal.workspaceId,a))}async function E(a){return await y.db.select({id:z.issue.id,key:z.issue.key,title:z.issue.title,col:z.issue.col,prio:z.issue.prio,points:z.issue.points,moscow:z.issue.moscow,approved:z.issue.approved}).from(z.issue).where((0,x.eq)(z.issue.workspaceId,a))}async function F(a){return await y.db.select({id:z.task.id,key:z.task.key,title:z.task.title,col:z.task.col,prio:z.task.prio}).from(z.task).where((0,x.eq)(z.task.workspaceId,a))}async function G(a){return await y.db.select({id:z.spec.id,key:z.spec.key,title:z.spec.title,status:z.spec.status,approved:z.spec.approved}).from(z.spec).where((0,x.eq)(z.spec.workspaceId,a))}var H=c(87355),I=c(56425),J=c(15563),K=c(28134);let L="nodejs",M="force-dynamic",N=new Map,O=(a,b=200)=>v.NextResponse.json({ok:!0,data:a},{status:b}),P=(a,b)=>v.NextResponse.json({ok:!1,error:b},{status:a});async function Q(a,b,c){var d;let e,f,g=await B(a.headers.get("authorization"),a.headers.get("x-constella-org"));if(!g.ok)return P(g.status,g.error);let{auth:h}=g;if(d=h.tokenId,e=Date.now(),(f=(N.get(d)??[]).filter(a=>e-a<6e4)).push(e),N.set(d,f),f.length>120)return P(429,"rate limit exceeded (120 req/min)");let i=h.workspace,j=b.join("/"),k="write"===h.scope,l=()=>k?null:P(403,"this token has read scope; a write-scope token is required");if("GET"===c)switch(j){case"":case"me":return O({user:h.userId,org:{id:h.org.id,name:h.org.name},workspace:{id:i.id,name:i.name,slug:i.slug},scope:h.scope});case"status":return O(await C(i));case"review":return O({text:await (0,H.mt)(i)});case"goals":return O(await D(i.id));case"issues":return O(await E(i.id));case"tasks":return O(await F(i.id));case"specs":return O(await G(i.id));case"kb":{let b=a.nextUrl.searchParams.get("q")??"";if(!b.trim())return P(400,"missing ?q=");let c=await (0,K.ed)(h.org.id,b);return O({text:c.text,sources:c.sources})}default:return P(404,`unknown GET /${j}`)}let m=await a.json().catch(()=>({}));switch(j){case"plan/approve":return l()??O(await (0,H.wz)(h.org.id,i));case"plan/reject":{let a=l();if(a)return a;return await (0,H.TR)(i.id,"string"==typeof m.reason?m.reason:void 0),O({rejected:!0})}case"execution":{let a=l();if(a)return a;let b=!1!==m.on;return await (0,H.mL)(i.id,b),O({auto247:b})}case"work":{let a=l();if(a)return a;let b="string"==typeof m.brief?m.brief:"",c="string"==typeof m.title?m.title:void 0,d=await (0,J.startNewWorkFor)(h.org.id,i,{brief:b,title:c});return d.ok?O(d):P(400,d.error??"could not start work")}case"kb":{let a="string"==typeof m.q?m.q:"";if(!a.trim())return P(400,"missing body.q");let b=await (0,K.ed)(h.org.id,a);return O({text:b.text,sources:b.sources})}default:if("goals"===b[0]&&3===b.length){let a=l();if(a)return a;let c=b[1];if("cancel"===b[2]){let a=await (0,I.NF)(i.id,c);return a.ok?O(a):P(404,"goal not found")}if("archive"===b[2]){let a=await (0,I.PT)(h.org.id,i.id,c);return a.ok?O(a):P(404,"goal not found")}}return P(404,`unknown POST /${j}`)}}async function R(a,b){try{let{path:c}=await b.params;return await Q(a,c??[],"GET")}catch(a){return P(500,String(a instanceof Error?a.message:a))}}async function S(a,b){try{let{path:c}=await b.params;return await Q(a,c??[],"POST")}catch(a){return P(500,String(a instanceof Error?a.message:a))}}let T=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/v1/[[...path]]/route",pathname:"/api/v1/[[...path]]",filename:"route",bundlePath:"app/api/v1/[[...path]]/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"C:\\Users\\Usuario\\Documents\\constella\\src\\app\\api\\v1\\[[...path]]\\route.ts",nextConfigOutput:"",userland:d,...{}}),{workAsyncStorage:U,workUnitAsyncStorage:V,serverHooks:W}=T;function X(){return(0,g.patchFetch)({workAsyncStorage:U,workUnitAsyncStorage:V})}async function Y(a,b,c){c.requestMeta&&(0,h.setRequestMeta)(a,c.requestMeta),T.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/v1/[[...path]]/route";"/index"===d&&(d="/");let e=await T.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,deploymentId:v,params:w,nextConfig:x,parsedUrl:y,isDraftMode:z,prerenderManifest:A,routerServerContext:B,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,resolvedPathname:E,clientReferenceManifest:F,serverActionsManifest:G}=e,H=(0,k.normalizeAppPath)(d),I=!!(A.dynamicRoutes[H]||A.routes[E]),J=async()=>((null==B?void 0:B.render404)?await B.render404(a,b,y,!1):b.end("This page could not be found"),null);if(I&&!z){let a=!!A.routes[E],b=A.dynamicRoutes[H];if(b&&!1===b.fallback&&!a){if(x.adapterPath)return await J();throw new t.NoFallbackError}}let K=null;!I||T.isDev||z||(K="/index"===(K=E)?"/":K);let L=!0===T.isDev||!I,M=I&&!L;G&&F&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:F,serverActionsManifest:G});let N=a.method||"GET",O=(0,i.getTracer)(),P=O.getActiveScopeSpan(),Q=!!(null==B?void 0:B.isWrappedByNextServer),R=!!(0,h.getRequestMeta)(a,"minimalMode"),S=(0,h.getRequestMeta)(a,"incrementalCache")||await T.getIncrementalCache(a,x,A,R);null==S||S.resetRequestCache(),globalThis.__incrementalCache=S;let U={params:w,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:L,incrementalCache:S,cacheLifeProfiles:x.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>T.onRequestError(a,b,d,e,B)},sharedContext:{buildId:g,deploymentId:v}},V=new l.NodeNextRequest(a),W=new l.NodeNextResponse(b),X=m.NextRequestAdapter.fromNodeNextRequest(V,(0,m.signalFromNodeResponse)(b));try{let e,g=async a=>T.handle(X,U).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=O.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let f=c.get("next.route");if(f){let b=`${N} ${f}`;a.setAttributes({"next.route":f,"http.route":f,"next.span_name":b}),a.updateName(b),e&&e!==a&&(e.setAttribute("http.route",f),e.updateName(b))}else a.updateName(`${N} ${d}`)}),h=async e=>{var h,i;let j=async({previousCacheEntry:f})=>{try{if(!R&&C&&D&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await g(e);a.fetchMetrics=U.renderOpts.fetchMetrics;let h=U.renderOpts.pendingWaitUntil;h&&c.waitUntil&&(c.waitUntil(h),h=void 0);let i=U.renderOpts.collectedTags;if(!I)return await (0,p.I)(V,W,d,U.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);i&&(b[s.NEXT_CACHE_TAGS_HEADER]=i),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==U.renderOpts.collectedRevalidate&&!(U.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&U.renderOpts.collectedRevalidate,e=void 0===U.renderOpts.collectedExpire||U.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:U.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await T.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),b}},k=await T.handleResponse({req:a,nextConfig:x,cacheKey:K,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,responseGenerator:j,waitUntil:c.waitUntil,isMinimalMode:R});if(!I)return null;if((null==k||null==(h=k.value)?void 0:h.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==k||null==(i=k.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});R||b.setHeader("x-nextjs-cache",C?"REVALIDATED":k.isMiss?"MISS":k.isStale?"STALE":"HIT"),z&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let l=(0,q.fromNodeOutgoingHttpHeaders)(k.value.headers);return R&&I||l.delete(s.NEXT_CACHE_TAGS_HEADER),!k.cacheControl||b.getHeader("Cache-Control")||l.get("Cache-Control")||l.set("Cache-Control",(0,r.getCacheControlHeader)(k.cacheControl)),await (0,p.I)(V,W,new Response(k.value.body,{headers:l,status:k.value.status||200})),null};Q&&P?await h(P):(e=O.getActiveScopeSpan(),await O.withPropagatedContext(a.headers,()=>O.trace(n.BaseServerSpan.handleRequest,{spanName:`${N} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":N,"http.target":a.url}},h),void 0,!Q))}catch(b){if(b instanceof t.NoFallbackError||await T.onRequestError(a,b,{routerKind:"App Router",routePath:H,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),I)throw b;return await (0,p.I)(V,W,new Response(null,{status:500})),null}}},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},29021:a=>{a.exports=require("fs")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},38522:a=>{a.exports=require("node:zlib")},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},46466:a=>{a.exports=require("node:stream/promises")},48161:a=>{a.exports=require("node:os")},51455:a=>{a.exports=require("node:fs/promises")},55511:a=>{a.exports=require("crypto")},57075:a=>{a.exports=require("node:stream")},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},74075:a=>{a.exports=require("zlib")},76760:a=>{a.exports=require("node:path")},77030:a=>{a.exports=require("node:net")},77598:a=>{a.exports=require("node:crypto")},78474:a=>{a.exports=require("node:events")},81959:(a,b,c)=>{c.r(b),c.d(b,{"001f94d0bd03f690900ff275fc7bcb81f9d6db5da1":()=>e.Vr,"0033b35723a2f0e68a64e154c1ad7fc143aaa54614":()=>e.lC,"0049165d407101d40a5d00da538a6d71ff6c0cf759":()=>e.VH,"00582b241ca559456a57429e2961de086d53d90623":()=>e.ts,"006c909a46b7f43ab34b0f5c528a5599c55483d3e2":()=>e.LU,"006f70fc5235026e74aa57f7c74fa2a41f520679a0":()=>e.S8,"0078eee6c6a712c6aea28f9bd404d07bd6c8f06300":()=>d.approvePlan,"009318875523f1f33fd010f80e967c123eb9ad62eb":()=>e.nl,"0096ea98aaf52e1293c52c7b4d3da81953f9f42a40":()=>d.groomBacklog,"009a9da1bd0fa61f361f014358ef9b43180692d144":()=>e.Hi,"00b3ada168785f05d91953e196ff9e629394c71f6c":()=>e.zO,"00bcafd8a8e2107bb2939a5e353db5bcf1865921ef":()=>e.Jw,"00c63dd53781d20430fbd0b1b5fdbf72cd4383e759":()=>e.Ac,"00df3ceaa88bb6e2855dfd878b7de60ec140591e32":()=>e.V$,"00e67cf87dadcbcbdf45049da9523da454401958c9":()=>d.requestPlanChanges,"00e8d27c5632be19ba82275be7daab4ca11ac30265":()=>e.Gh,"00f1167df722f92286917fa4940a672407b1c19f95":()=>e.Uw,"00f4b1765195f72a7b12d848bc3a2350f7a0f8cdae":()=>e.kb,"40197202b1575054bdc6f788583699228c62e9b638":()=>d.setAuto247,"401c666cf084eddc0dffbc92690b8485f6bb35bb76":()=>e.I2,"40204beb18ac2a6dd649bd6bac3cd3824475e9bf62":()=>d.startNewWork,"405a19722e7131aeebc719ebaf12c74a1682c69a11":()=>e.az,"405bbb6298711330c0a007ae10eea08b34e1223ca1":()=>e.cm,"405ed4651f47318a4181b8770112f7bc71df0e57a2":()=>d.approveSpec,"40612bb48c7b9899000f07b3256b6a217f9f14c163":()=>d.rejectSpec,"407439429438ecc96bc01ec5c7cfd82b32a53b59b7":()=>e.L0,"407c663df5abe57a45597e626aefe95df23e6946a9":()=>e.Cp,"40ac43be66059aad8695fa35343af7a907394ec850":()=>d.approveIssue,"40b760c8302cb242aa549e9abff4587294fabab477":()=>e.m,"40c679f63e25b10357f3d3231817fcc35b1db6ddfb":()=>f.mg,"40d83b0317effac5a2687de461e5308315108cb910":()=>d.planFromConversation,"40d94739ab3473c06b3faaae4456ea491b787f8ad2":()=>d.generatePlan,"40e28ba0dfac6e7e214062a8b673ca7b4b44c5c87d":()=>e.wp,"40e795413ad61f4779ccdba157080b914a9c8adcd4":()=>d.advanceIssue,"40f88afb175b09ac00d2f0cc2bb7fffb401c667a94":()=>d.rejectIssue,"40fd12491a5c555de5b0eaaa9e4b0f3097e4967851":()=>e.ju,"603c43bef66e43b540b8445b0c3fe4ee8e746a3329":()=>g.k,"603c9b63894b12bccde4b46ffa96519c81bca136a3":()=>d.groomBacklogFor,"60546c3703874a3d7415fa213900e30f539ca5b9d0":()=>f.eA,"6069d55c3f4e1783abfd4728ea381d7c4de7169b17":()=>g.I,"70c9946ce7b4d59b33995bd699fa6d230d232d09ac":()=>f.LV});var d=c(12529),e=c(15878),f=c(89258),g=c(87980)},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[5911,5361,6309,4679,7474,5557,6585,1243,912,415,77,5878,8134,6807,2323,1033,907],()=>b(b.s=4326));module.exports=c})();
|
|
1
|
+
"use strict";(()=>{var a={};a.id=2835,a.ids=[2835],a.modules={261:a=>{a.exports=require("next/dist/shared/lib/router/utils/app-paths")},3295:a=>{a.exports=require("next/dist/server/app-render/after-task-async-storage.external.js")},4326:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>Y,patchFetch:()=>X,routeModule:()=>T,serverHooks:()=>W,workAsyncStorage:()=>U,workUnitAsyncStorage:()=>V});var d={};c.r(d),c.d(d,{GET:()=>R,POST:()=>S,dynamic:()=>M,runtime:()=>L});var e=c(16633),f=c(35526),g=c(80445),h=c(49421),i=c(68279),j=c(22827),k=c(261),l=c(45469),m=c(19923),n=c(17653),o=c(70486),p=c(49496),q=c(16674),r=c(11264),s=c(7001),t=c(86439),u=c(4535),v=c(91736),w=c(77598),x=c(50730),y=c(12940),z=c(76561),A=c(2148);async function B(a,b){let c=/^Bearer\s+(cn_[A-Za-z0-9_-]{8,})$/.exec((a??"").trim());if(!c)return{ok:!1,status:401,error:"missing or malformed bearer token"};let d=(0,w.createHash)("sha256").update(c[1]).digest("hex"),[e]=await y.db.select().from(z.personalAccessToken).where((0,x.eq)(z.personalAccessToken.tokenHash,d));if(!e)return{ok:!1,status:401,error:"invalid token"};try{await y.db.update(z.personalAccessToken).set({lastUsedAt:new Date}).where((0,x.eq)(z.personalAccessToken.id,e.id))}catch{}let f=await (0,A.$x)(e.userId,b??void 0);if(!f)return{ok:!1,status:404,error:"no organization for this token's user"};if(f.archived)return{ok:!1,status:409,error:"organization is archived"};let g=await (0,A.K4)(f.id);return g?{ok:!0,auth:{userId:e.userId,tokenId:e.id,scope:e.scope,org:f,workspace:g}}:{ok:!1,status:404,error:"no workspace for the organization"}}async function C(a){let[b,c,d,[e]]=await Promise.all([y.db.select({status:z.goal.status}).from(z.goal).where((0,x.eq)(z.goal.workspaceId,a.id)),y.db.select({col:z.issue.col}).from(z.issue).where((0,x.eq)(z.issue.workspaceId,a.id)),y.db.select({col:z.task.col}).from(z.task).where((0,x.eq)(z.task.workspaceId,a.id)),y.db.select().from(z.plan).where((0,x.eq)(z.plan.workspaceId,a.id))]),f=a=>a.reduce((a,b)=>(a[b.col]=(a[b.col]??0)+1,a),{});return{workspace:{id:a.id,name:a.name,slug:a.slug},goals:{active:b.filter(a=>"active"===a.status).length,total:b.length},issues:{open:c.filter(a=>"done"!==a.col).length,total:c.length,byCol:f(c)},tasks:{doing:d.filter(a=>"doing"===a.col).length,total:d.length,byCol:f(d)},plan:e?{approved:e.approved,auto247:e.auto247,stage:e.stage}:null}}async function D(a){return await y.db.select({id:z.goal.id,title:z.goal.title,status:z.goal.status,progress:z.goal.progress}).from(z.goal).where((0,x.eq)(z.goal.workspaceId,a))}async function E(a){return await y.db.select({id:z.issue.id,key:z.issue.key,title:z.issue.title,col:z.issue.col,prio:z.issue.prio,points:z.issue.points,moscow:z.issue.moscow,approved:z.issue.approved}).from(z.issue).where((0,x.eq)(z.issue.workspaceId,a))}async function F(a){return await y.db.select({id:z.task.id,key:z.task.key,title:z.task.title,col:z.task.col,prio:z.task.prio}).from(z.task).where((0,x.eq)(z.task.workspaceId,a))}async function G(a){return await y.db.select({id:z.spec.id,key:z.spec.key,title:z.spec.title,status:z.spec.status,approved:z.spec.approved}).from(z.spec).where((0,x.eq)(z.spec.workspaceId,a))}var H=c(87355),I=c(56425),J=c(15563),K=c(28134);let L="nodejs",M="force-dynamic",N=new Map,O=(a,b=200)=>v.NextResponse.json({ok:!0,data:a},{status:b}),P=(a,b)=>v.NextResponse.json({ok:!1,error:b},{status:a});async function Q(a,b,c){var d;let e,f,g=await B(a.headers.get("authorization"),a.headers.get("x-constella-org"));if(!g.ok)return P(g.status,g.error);let{auth:h}=g;if(d=h.tokenId,e=Date.now(),(f=(N.get(d)??[]).filter(a=>e-a<6e4)).push(e),N.set(d,f),f.length>120)return P(429,"rate limit exceeded (120 req/min)");let i=h.workspace,j=b.join("/"),k="write"===h.scope,l=()=>k?null:P(403,"this token has read scope; a write-scope token is required");if("GET"===c)switch(j){case"":case"me":return O({user:h.userId,org:{id:h.org.id,name:h.org.name},workspace:{id:i.id,name:i.name,slug:i.slug},scope:h.scope});case"status":return O(await C(i));case"review":return O({text:await (0,H.mt)(i)});case"goals":return O(await D(i.id));case"issues":return O(await E(i.id));case"tasks":return O(await F(i.id));case"specs":return O(await G(i.id));case"kb":{let b=a.nextUrl.searchParams.get("q")??"";if(!b.trim())return P(400,"missing ?q=");let c=await (0,K.ed)(h.org.id,b);return O({text:c.text,sources:c.sources})}default:return P(404,`unknown GET /${j}`)}let m=await a.json().catch(()=>({}));switch(j){case"plan/approve":return l()??O(await (0,H.wz)(h.org.id,i));case"plan/reject":{let a=l();if(a)return a;return await (0,H.TR)(i.id,"string"==typeof m.reason?m.reason:void 0),O({rejected:!0})}case"execution":{let a=l();if(a)return a;let b=!1!==m.on;return await (0,H.mL)(i.id,b),O({auto247:b})}case"work":{let a=l();if(a)return a;let b="string"==typeof m.brief?m.brief:"",c="string"==typeof m.title?m.title:void 0,d=await (0,J.startNewWorkFor)(h.org.id,i,{brief:b,title:c});return d.ok?O(d):P(400,d.error??"could not start work")}case"kb":{let a="string"==typeof m.q?m.q:"";if(!a.trim())return P(400,"missing body.q");let b=await (0,K.ed)(h.org.id,a);return O({text:b.text,sources:b.sources})}default:if("goals"===b[0]&&3===b.length){let a=l();if(a)return a;let c=b[1];if("cancel"===b[2]){let a=await (0,I.NF)(i.id,c);return a.ok?O(a):P(404,"goal not found")}if("archive"===b[2]){let a=await (0,I.PT)(h.org.id,i.id,c);return a.ok?O(a):P(404,"goal not found")}}return P(404,`unknown POST /${j}`)}}async function R(a,b){try{let{path:c}=await b.params;return await Q(a,c??[],"GET")}catch(a){return P(500,String(a instanceof Error?a.message:a))}}async function S(a,b){try{let{path:c}=await b.params;return await Q(a,c??[],"POST")}catch(a){return P(500,String(a instanceof Error?a.message:a))}}let T=new e.AppRouteRouteModule({definition:{kind:f.RouteKind.APP_ROUTE,page:"/api/v1/[[...path]]/route",pathname:"/api/v1/[[...path]]",filename:"route",bundlePath:"app/api/v1/[[...path]]/route"},distDir:".next",relativeProjectDir:"",resolvedPagePath:"C:\\Users\\Usuario\\Documents\\constella\\src\\app\\api\\v1\\[[...path]]\\route.ts",nextConfigOutput:"",userland:d,...{}}),{workAsyncStorage:U,workUnitAsyncStorage:V,serverHooks:W}=T;function X(){return(0,g.patchFetch)({workAsyncStorage:U,workUnitAsyncStorage:V})}async function Y(a,b,c){c.requestMeta&&(0,h.setRequestMeta)(a,c.requestMeta),T.isDev&&(0,h.addRequestMeta)(a,"devRequestTimingInternalsEnd",process.hrtime.bigint());let d="/api/v1/[[...path]]/route";"/index"===d&&(d="/");let e=await T.prepare(a,b,{srcPage:d,multiZoneDraftMode:!1});if(!e)return b.statusCode=400,b.end("Bad Request"),null==c.waitUntil||c.waitUntil.call(c,Promise.resolve()),null;let{buildId:g,deploymentId:v,params:w,nextConfig:x,parsedUrl:y,isDraftMode:z,prerenderManifest:A,routerServerContext:B,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,resolvedPathname:E,clientReferenceManifest:F,serverActionsManifest:G}=e,H=(0,k.normalizeAppPath)(d),I=!!(A.dynamicRoutes[H]||A.routes[E]),J=async()=>((null==B?void 0:B.render404)?await B.render404(a,b,y,!1):b.end("This page could not be found"),null);if(I&&!z){let a=!!A.routes[E],b=A.dynamicRoutes[H];if(b&&!1===b.fallback&&!a){if(x.adapterPath)return await J();throw new t.NoFallbackError}}let K=null;!I||T.isDev||z||(K="/index"===(K=E)?"/":K);let L=!0===T.isDev||!I,M=I&&!L;G&&F&&(0,j.setManifestsSingleton)({page:d,clientReferenceManifest:F,serverActionsManifest:G});let N=a.method||"GET",O=(0,i.getTracer)(),P=O.getActiveScopeSpan(),Q=!!(null==B?void 0:B.isWrappedByNextServer),R=!!(0,h.getRequestMeta)(a,"minimalMode"),S=(0,h.getRequestMeta)(a,"incrementalCache")||await T.getIncrementalCache(a,x,A,R);null==S||S.resetRequestCache(),globalThis.__incrementalCache=S;let U={params:w,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:L,incrementalCache:S,cacheLifeProfiles:x.cacheLife,waitUntil:c.waitUntil,onClose:a=>{b.on("close",a)},onAfterTaskError:void 0,onInstrumentationRequestError:(b,c,d,e)=>T.onRequestError(a,b,d,e,B)},sharedContext:{buildId:g,deploymentId:v}},V=new l.NodeNextRequest(a),W=new l.NodeNextResponse(b),X=m.NextRequestAdapter.fromNodeNextRequest(V,(0,m.signalFromNodeResponse)(b));try{let e,g=async a=>T.handle(X,U).finally(()=>{if(!a)return;a.setAttributes({"http.status_code":b.statusCode,"next.rsc":!1});let c=O.getRootSpanAttributes();if(!c)return;if(c.get("next.span_type")!==n.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${c.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let f=c.get("next.route");if(f){let b=`${N} ${f}`;a.setAttributes({"next.route":f,"http.route":f,"next.span_name":b}),a.updateName(b),e&&e!==a&&(e.setAttribute("http.route",f),e.updateName(b))}else a.updateName(`${N} ${d}`)}),h=async e=>{var h,i;let j=async({previousCacheEntry:f})=>{try{if(!R&&C&&D&&!f)return b.statusCode=404,b.setHeader("x-nextjs-cache","REVALIDATED"),b.end("This page could not be found"),null;let d=await g(e);a.fetchMetrics=U.renderOpts.fetchMetrics;let h=U.renderOpts.pendingWaitUntil;h&&c.waitUntil&&(c.waitUntil(h),h=void 0);let i=U.renderOpts.collectedTags;if(!I)return await (0,p.I)(V,W,d,U.renderOpts.pendingWaitUntil),null;{let a=await d.blob(),b=(0,q.toNodeOutgoingHttpHeaders)(d.headers);i&&(b[s.NEXT_CACHE_TAGS_HEADER]=i),!b["content-type"]&&a.type&&(b["content-type"]=a.type);let c=void 0!==U.renderOpts.collectedRevalidate&&!(U.renderOpts.collectedRevalidate>=s.INFINITE_CACHE)&&U.renderOpts.collectedRevalidate,e=void 0===U.renderOpts.collectedExpire||U.renderOpts.collectedExpire>=s.INFINITE_CACHE?void 0:U.renderOpts.collectedExpire;return{value:{kind:u.CachedRouteKind.APP_ROUTE,status:d.status,body:Buffer.from(await a.arrayBuffer()),headers:b},cacheControl:{revalidate:c,expire:e}}}}catch(b){throw(null==f?void 0:f.isStale)&&await T.onRequestError(a,b,{routerKind:"App Router",routePath:d,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),b}},k=await T.handleResponse({req:a,nextConfig:x,cacheKey:K,routeKind:f.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:D,responseGenerator:j,waitUntil:c.waitUntil,isMinimalMode:R});if(!I)return null;if((null==k||null==(h=k.value)?void 0:h.kind)!==u.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==k||null==(i=k.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});R||b.setHeader("x-nextjs-cache",C?"REVALIDATED":k.isMiss?"MISS":k.isStale?"STALE":"HIT"),z&&b.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let l=(0,q.fromNodeOutgoingHttpHeaders)(k.value.headers);return R&&I||l.delete(s.NEXT_CACHE_TAGS_HEADER),!k.cacheControl||b.getHeader("Cache-Control")||l.get("Cache-Control")||l.set("Cache-Control",(0,r.getCacheControlHeader)(k.cacheControl)),await (0,p.I)(V,W,new Response(k.value.body,{headers:l,status:k.value.status||200})),null};Q&&P?await h(P):(e=O.getActiveScopeSpan(),await O.withPropagatedContext(a.headers,()=>O.trace(n.BaseServerSpan.handleRequest,{spanName:`${N} ${d}`,kind:i.SpanKind.SERVER,attributes:{"http.method":N,"http.target":a.url}},h),void 0,!Q))}catch(b){if(b instanceof t.NoFallbackError||await T.onRequestError(a,b,{routerKind:"App Router",routePath:H,routeType:"route",revalidateReason:(0,o.c)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,B),I)throw b;return await (0,p.I)(V,W,new Response(null,{status:500})),null}}},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},29021:a=>{a.exports=require("fs")},29294:a=>{a.exports=require("next/dist/server/app-render/work-async-storage.external.js")},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},38522:a=>{a.exports=require("node:zlib")},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},46466:a=>{a.exports=require("node:stream/promises")},47623:(a,b,c)=>{c.r(b),c.d(b,{"0001025c89be533c6ae88d481b09f093b98dc8063a":()=>d.requestPlanChanges,"001de959dce6c8f9d53a0db5f3135437133ceb52df":()=>e.lC,"003b6bdbd1dd9535700ff0361a2c5e4baf132331b2":()=>e.Hi,"0043750c3df6f86c65e971f123da87ceb51dc5990b":()=>e.Gh,"0050e3a51b9510d1440e75d0ef71a5ed5901dcafaa":()=>e.nl,"0065cf1b3ed4fac1a400f22fdfd8eb79c6f959b308":()=>e.V$,"006910fc45d9bd87178dc83b87fb23580d680f1b14":()=>d.approvePlan,"007471b77fdd505158c0ef102abe663876817ba1a9":()=>e.Ac,"007d859487c6175d33fea61bc0b0b0525404e94ab4":()=>e.Jw,"00822437e4eeea24a8c615e3e2dfaf9ba9cbab0663":()=>e.Vr,"0082d605df6bf54530b3e793569841e033a784aa8f":()=>e.LU,"009312e28b1a452ac54a988cf7947bd49a5f587777":()=>e.kb,"009751d8c00d5cce30bea74b7324f874e344d82c42":()=>d.groomBacklog,"009c5ae209df1bf521e0f4a275155aa91e4c055da0":()=>e.Uw,"00acc06fa50815fb406645f301e885af8c87ff0270":()=>e.zO,"00bf363c39eef8bae9778773e53ed709e10c6f2c9f":()=>e.VH,"00ca910b0a945a229553de0df34b0135aeeb87a51d":()=>e.ts,"00cf5008a9aff8a54ca0c6b2a086586cf6c487e248":()=>e.S8,"401cb877c53e4448015022e9b01f4182883ef45d73":()=>e.cm,"402327fbf97b3f6a24256d738124d38e8b498305f0":()=>e.m,"40235447972a45e7be663bd2f00f82430e6d4c0271":()=>f.mg,"4033e7726f1645fd69f4a34fdb34b307c97d034641":()=>d.approveIssue,"403a6ababd95c4fb61660fec5b83c6dcd865f16c6e":()=>d.planFromConversation,"4060d874ebb500e0e00ccb4b93d6305ec6dc34ba0c":()=>d.approveSpec,"40610ea499a895730a6a49548880afb3daa097cc64":()=>e.Cp,"4069fcf08d4d4604eb5055a3702d3fbd6e0fbea68d":()=>e.I2,"406ba323fdd094cd6be0fe6a52da6e5a82ed902480":()=>d.rejectSpec,"4075dfc880f582744abc6fd205a1e398e8171d338b":()=>d.setAuto247,"408199f258bc5f07bce1b71b7d09d4730205fa6d05":()=>e.wp,"408fe115fb4e6fb989b1aac0f99b3f28a8212293a5":()=>d.advanceIssue,"40d5b7413e4752fd8fba0cb01132f8fdee0d559bae":()=>e.L0,"40e30755c609a5f0104cb804f584fc0a8e4ee681b5":()=>d.generatePlan,"40e367dc4cfe2c8de5a5cd337230c379082ddf13c8":()=>e.az,"40ea3f661c11a6f8ef2358ad921d6bde489350ce2a":()=>d.startNewWork,"40f71ff46956872e248e34ec53aad9c8776a0a80c9":()=>e.ju,"40fbd1fb24c8548e39971f010ae94d301e3ef53fde":()=>d.rejectIssue,"600a283d3c155b52846ffdf59d78d6fb8408c82a2b":()=>g.I,"605952042cd150b4411a52382adbd0d4bdc574e82d":()=>d.groomBacklogFor,"60687b23eb88a4b6d050ea1eff119a716ca285d2f1":()=>g.k,"60f11f39424b3df2e69f7eef9d8e80488894814d06":()=>f.eA,"70cfbb806c07829324f1ef5574523a9278094c87f1":()=>f.LV});var d=c(12529),e=c(15878),f=c(89258),g=c(87980)},48161:a=>{a.exports=require("node:os")},51455:a=>{a.exports=require("node:fs/promises")},55511:a=>{a.exports=require("crypto")},57075:a=>{a.exports=require("node:stream")},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},74075:a=>{a.exports=require("zlib")},76760:a=>{a.exports=require("node:path")},77030:a=>{a.exports=require("node:net")},77598:a=>{a.exports=require("node:crypto")},78474:a=>{a.exports=require("node:events")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[5911,5361,6309,4679,7474,5557,6585,1243,912,415,77,5878,8134,6807,2323,1033,907],()=>b(b.s=4326));module.exports=c})();
|
|
@@ -10,5 +10,5 @@ DETECTED CONTEXT (domain + visual intent): ${c.slice(0,16).join(", ")}. Ground t
|
|
|
10
10
|
MOST RELEVANT seeded skills for THIS request — READ the matching \`.claude/skills/<name>.md\` FIRST before building:
|
|
11
11
|
${d.map(a=>`- ${a.name}: ${a.description}`).join("\n")}`:""].filter(Boolean).join("\n")}let n=".claude/design-gate.json";function o(a){let b=(0,d.sL)(a,n);if(!b)return{};try{return JSON.parse(b)||{}}catch{return{}}}function p(a,b){try{(0,d.dx)(a,n,JSON.stringify(b,null,2))}catch{}}function q(a){p(a,{skip:!1})}let r=".claude/design-promoted.json";function s(a){let b=(0,d.sL)(a,r);if(!b)return{};try{return JSON.parse(b)||{}}catch{return{}}}function t(a,b){try{(0,d.dx)(a,r,JSON.stringify(b,null,2))}catch{}}function u(a){let b=a.designMockFiles.some(a=>/design-mock\/screens\/.+\.html?$/i.test(a));return!a.approved&&!b}let v=/\b(tela|telas|screen|screens|p[áa]gina|pagina|page|pages|web|webapp|web-?app|website|site|app|apps|aplicativo|aplica[çc][ãa]o|spa|single-?page|pwa|ui|ux|interface|frontend|front-?end|layout|component|componente|design|visual|dashboard|form|formul[áa]rio|formulario|bot[ãa]o|botao|button|modal|menu|nav|navbar|sidebar|card|landing|hero|gallery|galeria|theme|tema|palette|paleta|typography|tipografia|style|estilo|css|html|responsive|responsiv[oa]|mobile|desktop|tablet|anima[çc][ãa]o|animation|microintera[çc][õo]es|wizard|onboarding|checkout|perfil|profile|settings|configura[çc][õo]es|view|views|render)\b/i;function w(a){return!!a&&v.test(a)}let x=/\b(api|rest|restful|graphql|grpc|cli|command[\s-]?line|terminal|backend|back-?end|micro-?service|microservices|service|library|\bsdk\b|daemon|cron|scheduler|pipeline|etl|database|\bdb\b|infra|infrastructure|devops|webhook|message[\s-]?queue|\bqueue\b|worker|scraper|crawler|\bbot\b|middleware|server[\s-]?side|protocol|compiler|parser|scraping)\b/i;function y(a){return!!a&&x.test(a)&&!w(a)}},21046:(a,b,c)=>{c.d(b,{j:()=>i});var d=c(77598),e=c(50730),f=c(12940),g=c(76561),h=c(28134);async function i(a,b){if(b.text.trim()){try{await f.db.insert(g.decision).values({id:(0,d.randomUUID)(),workspaceId:a,text:b.text.slice(0,1e3),by:b.by??"",source:b.source??"",refKey:b.refKey??"",rationale:b.rationale??"",goalId:b.goalId??null,createdAt:new Date})}catch(a){console.error("[decision] log failed:",a)}(async()=>{try{let[c]=await f.db.select({orgId:g.workspace.orgId}).from(g.workspace).where((0,e.eq)(g.workspace.id,a));c?.orgId&&await (0,h.ru)(c.orgId,[{type:"decision",title:b.text.slice(0,120),summary:b.text.slice(0,1e3),body:b.rationale??"",goalId:b.goalId??null,agentHandle:b.by??"",sourceKind:"decision",sourceRef:b.refKey??""}])}catch{}})()}}},36548:(a,b,c)=>{Object.defineProperty(b,"A",{enumerable:!0,get:function(){return d.registerServerReference}});let d=c(97879)},52052:(a,b,c)=>{c.d(b,{lM:()=>j,s$:()=>k});var d=c(77598),e=c(50730),f=c(12940),g=c(76561),h=c(66408);function i(a){let b=[];for(let c of a.split("\n")){let a=c.match(/^\s*-\s*\[([ xX])\]\s+(.+)$/);a&&b.push({text:a[2].trim().slice(0,200),done:"x"===a[1].toLowerCase()})}return b.slice(0,12)}async function j(a,b,c){let h=i(c);if(!h.length)return;let j=await f.db.select().from(g.taskStep).where((0,e.eq)(g.taskStep.taskId,b)),k=new Map(j.map(a=>[a.text.toLowerCase(),a])),l=j.length;for(let c of h){let h=k.get(c.text.toLowerCase());h?h.done!==c.done&&await f.db.update(g.taskStep).set({done:c.done}).where((0,e.eq)(g.taskStep.id,h.id)):await f.db.insert(g.taskStep).values({id:(0,d.randomUUID)(),workspaceId:a,taskId:b,text:c.text,done:c.done,ord:l++})}}async function k(a,b){let c=await f.db.select().from(g.issue).where((0,e.eq)(g.issue.workspaceId,b)),j=Object.fromEntries((await f.db.select().from(g.spec).where((0,e.eq)(g.spec.workspaceId,b))).map(a=>[a.id,a.summary])),k=new Set((await f.db.select({issueId:g.task.issueId}).from(g.task).where((0,e.eq)(g.task.workspaceId,b))).map(a=>a.issueId).filter(Boolean)),m=0;for(let e of c){if(k.has(e.id))continue;let c=(0,h.sL)(a,`issues/${e.key}.md`)??"",l=c.match(/^\*\*Skills to consult:\*\*\s*(.+)$/m)?.[1]?.trim(),n=l?`
|
|
12
12
|
|
|
13
|
-
Consult these skills BEFORE building (read the matching .claude/skills/<name>.md): ${l}.`:"",o=(((e.specId?j[e.specId]:"")||c).slice(0,2e3)+n).slice(0,2200),p=(0,d.randomUUID)();await f.db.insert(g.task).values({id:p,workspaceId:b,issueId:e.id,goalId:e.goalId,key:e.key,title:e.title,description:o,col:"todo",prio:e.prio,assigneeId:e.assigneeId,createdBy:"agent"});let q=0;for(let a of i(c))await f.db.insert(g.taskStep).values({id:(0,d.randomUUID)(),workspaceId:b,taskId:p,text:a.text,done:a.done,ord:q++});m++}return await l(b),m}async function l(a){let[b]=await f.db.select().from(g.agent).where((0,e.Uo)((0,e.eq)(g.agent.workspaceId,a),(0,e.eq)(g.agent.handle,"barbara"))),c=b??(await f.db.select().from(g.agent).where((0,e.Uo)((0,e.eq)(g.agent.workspaceId,a),(0,e.mj)(g.agent.role,"%Docs%"))))[0];!c||(await f.db.select({id:g.task.id}).from(g.task).where((0,e.Uo)((0,e.eq)(g.task.workspaceId,a),(0,e.eq)(g.task.key,"DOCS-1")))).length||await f.db.insert(g.task).values({id:(0,d.randomUUID)(),workspaceId:a,key:"DOCS-1",title:"Document the project — update DOCS/ to match what was built",description:"Read the real code, specs and structure in this workspace, then write/refresh accurate documentation under DOCS/ (architecture, API, usage, how to run). Replace the scaffold templates with real content grounded in the actual files. Do not invent features.",col:"todo",prio:"low",assigneeId:c.id,createdBy:"agent"})}},66263:(a,b,c)=>{c.d(b,{a:()=>h,r:()=>g});var d=c(78474);let e=globalThis,f=e.__constellaBus??(e.__constellaBus=new d.EventEmitter);function g(a){f.emit("wake",a)}function h(a,b){let c=c=>{c===a&&b()};return f.on("wake",c),()=>{f.off("wake",c)}}f.setMaxListeners(64)},69539:(a,b,c)=>{c.d(b,{dp:()=>o,j2:()=>p});var d=c(20140),e=c(75797),f=c(59814),g=c(12940),h=c(76561);let i=process.env.BETTER_AUTH_URL??"http://localhost:3000";function j(a){return a?.split(",")[0]?.trim()||null}function k(a){if(!a)return null;try{return new URL(a).origin}catch{return null}}function l(a,b){let c=k(b?.trim());c&&a.add(c)}let m=(()=>{let a=new Set;for(let b of[i,process.env.BETTER_AUTH_URL,process.env.NEXT_PUBLIC_BETTER_AUTH_URL,...(process.env.CONSTELLA_TRUSTED_ORIGINS??"").split(",")])l(a,b);return[...a]})();process.env.BETTER_AUTH_SECRET||console.error("[auth] FATAL: BETTER_AUTH_SECRET is required (sessions would be forgeable). Set it in your environment.");let n={};process.env.GITHUB_CLIENT_ID&&process.env.GITHUB_CLIENT_SECRET&&(n.github={clientId:process.env.GITHUB_CLIENT_ID,clientSecret:process.env.GITHUB_CLIENT_SECRET,scope:["repo","read:user"]}),process.env.GOOGLE_CLIENT_ID&&process.env.GOOGLE_CLIENT_SECRET&&(n.google={clientId:process.env.GOOGLE_CLIENT_ID,clientSecret:process.env.GOOGLE_CLIENT_SECRET});let o=Object.keys(n),p=(0,d.l)({baseURL:i,trustedOrigins:function(a){let b=new Set(m);l(b,a?.url);let c=function(a){let b=a?.headers,c=j(b?.get("x-forwarded-host"))??j(b?.get("host"));if(!c)return null;let d=(j(b?.get("x-forwarded-proto"))??(i.startsWith("https://")?"https":"http")).replace(/:$/,"");return/^[a-z][a-z0-9+.-]*$/i.test(d)?k(`${d}://${c}`):null}(a);return c&&b.add(c),[...b]},secret:process.env.BETTER_AUTH_SECRET,database:(0,e.y)(g.db,{provider:"sqlite",schema:{user:h.user,session:h.session,account:h.account,verification:h.verification,twoFactor:h.twoFactor}}),emailAndPassword:{enabled:!0,autoSignIn:!0,requireEmailVerification:!1},socialProviders:n,account:{accountLinking:{enabled:!0,trustedProviders:["github","google"]}},session:{expiresIn:2592e3,additionalFields:{activeOrgId:{type:"string",required:!1}}},plugins:[(0,f.d)()],advanced:{useSecureCookies:i.startsWith("https://")}})},77680:(a,b,c)=>{c.d(b,{Y:()=>j,g:()=>i});var d=c(50730),e=c(76760),f=c(12940),g=c(76561),h=c(66408);async function i(a,b,c,d){let i=(0,h.HZ)(b);for(let b of d){if(!b.path)continue;let d=((0,e.isAbsolute)(b.path)?(0,e.relative)(i,b.path):b.path).replace(/\\/g,"/");if(!(!d||d.startsWith(".."))&&!(d.startsWith(".claude/")||d.startsWith("archives/")||d.startsWith(".git/")))try{await f.db.insert(g.goalFile).values({workspaceId:a,goalId:c,path:d,op:b.op}).onConflictDoUpdate({target:[g.goalFile.goalId,g.goalFile.path],set:{op:b.op,at:new Date}})}catch{}}}async function j(a,b){return(await f.db.select({path:g.goalFile.path}).from(g.goalFile).where((0,d.Uo)((0,d.eq)(g.goalFile.workspaceId,a),(0,d.eq)(g.goalFile.goalId,b)))).map(a=>a.path)}},87980:(a,b,c)=>{c.d(b,{I:()=>l,k:()=>m});var d=c(36548),e=c(77598),f=c(50730),g=c(23888),h=c(12940),i=c(76561),j=c(2148),k=c(66263);async function l(a,b){await h.db.insert(i.event).values({id:(0,e.randomUUID)(),workspaceId:a,runId:b.runId,channel:b.channel??"room",agentId:b.agentId??null,seq:Date.now(),kind:b.kind,target:(b.target??"").slice(0,500),detail:(b.detail??"").slice(0,8e3)}),(0,k.r)(a)}async function m(a,b=0){let{workspace:c}=await (0,j.nP)();return h.db.select().from(i.event).where((0,f.Uo)((0,f.eq)(i.event.workspaceId,c.id),(0,f.eq)(i.event.channel,a),(0,f.gt)(i.event.seq,b))).orderBy((0,g.Y)(i.event.seq)).limit(300)}(0,c(99688).D)([l,m]),(0,d.A)(l,"
|
|
13
|
+
Consult these skills BEFORE building (read the matching .claude/skills/<name>.md): ${l}.`:"",o=(((e.specId?j[e.specId]:"")||c).slice(0,2e3)+n).slice(0,2200),p=(0,d.randomUUID)();await f.db.insert(g.task).values({id:p,workspaceId:b,issueId:e.id,goalId:e.goalId,key:e.key,title:e.title,description:o,col:"todo",prio:e.prio,assigneeId:e.assigneeId,createdBy:"agent"});let q=0;for(let a of i(c))await f.db.insert(g.taskStep).values({id:(0,d.randomUUID)(),workspaceId:b,taskId:p,text:a.text,done:a.done,ord:q++});m++}return await l(b),m}async function l(a){let[b]=await f.db.select().from(g.agent).where((0,e.Uo)((0,e.eq)(g.agent.workspaceId,a),(0,e.eq)(g.agent.handle,"barbara"))),c=b??(await f.db.select().from(g.agent).where((0,e.Uo)((0,e.eq)(g.agent.workspaceId,a),(0,e.mj)(g.agent.role,"%Docs%"))))[0];!c||(await f.db.select({id:g.task.id}).from(g.task).where((0,e.Uo)((0,e.eq)(g.task.workspaceId,a),(0,e.eq)(g.task.key,"DOCS-1")))).length||await f.db.insert(g.task).values({id:(0,d.randomUUID)(),workspaceId:a,key:"DOCS-1",title:"Document the project — update DOCS/ to match what was built",description:"Read the real code, specs and structure in this workspace, then write/refresh accurate documentation under DOCS/ (architecture, API, usage, how to run). Replace the scaffold templates with real content grounded in the actual files. Do not invent features.",col:"todo",prio:"low",assigneeId:c.id,createdBy:"agent"})}},66263:(a,b,c)=>{c.d(b,{a:()=>h,r:()=>g});var d=c(78474);let e=globalThis,f=e.__constellaBus??(e.__constellaBus=new d.EventEmitter);function g(a){f.emit("wake",a)}function h(a,b){let c=c=>{c===a&&b()};return f.on("wake",c),()=>{f.off("wake",c)}}f.setMaxListeners(64)},69539:(a,b,c)=>{c.d(b,{dp:()=>o,j2:()=>p});var d=c(20140),e=c(75797),f=c(59814),g=c(12940),h=c(76561);let i=process.env.BETTER_AUTH_URL??"http://localhost:3000";function j(a){return a?.split(",")[0]?.trim()||null}function k(a){if(!a)return null;try{return new URL(a).origin}catch{return null}}function l(a,b){let c=k(b?.trim());c&&a.add(c)}let m=(()=>{let a=new Set;for(let b of[i,process.env.BETTER_AUTH_URL,process.env.NEXT_PUBLIC_BETTER_AUTH_URL,...(process.env.CONSTELLA_TRUSTED_ORIGINS??"").split(",")])l(a,b);return[...a]})();process.env.BETTER_AUTH_SECRET||console.error("[auth] FATAL: BETTER_AUTH_SECRET is required (sessions would be forgeable). Set it in your environment.");let n={};process.env.GITHUB_CLIENT_ID&&process.env.GITHUB_CLIENT_SECRET&&(n.github={clientId:process.env.GITHUB_CLIENT_ID,clientSecret:process.env.GITHUB_CLIENT_SECRET,scope:["repo","read:user"]}),process.env.GOOGLE_CLIENT_ID&&process.env.GOOGLE_CLIENT_SECRET&&(n.google={clientId:process.env.GOOGLE_CLIENT_ID,clientSecret:process.env.GOOGLE_CLIENT_SECRET});let o=Object.keys(n),p=(0,d.l)({baseURL:i,trustedOrigins:function(a){let b=new Set(m);l(b,a?.url);let c=function(a){let b=a?.headers,c=j(b?.get("x-forwarded-host"))??j(b?.get("host"));if(!c)return null;let d=(j(b?.get("x-forwarded-proto"))??(i.startsWith("https://")?"https":"http")).replace(/:$/,"");return/^[a-z][a-z0-9+.-]*$/i.test(d)?k(`${d}://${c}`):null}(a);return c&&b.add(c),[...b]},secret:process.env.BETTER_AUTH_SECRET,database:(0,e.y)(g.db,{provider:"sqlite",schema:{user:h.user,session:h.session,account:h.account,verification:h.verification,twoFactor:h.twoFactor}}),emailAndPassword:{enabled:!0,autoSignIn:!0,requireEmailVerification:!1},socialProviders:n,account:{accountLinking:{enabled:!0,trustedProviders:["github","google"]}},session:{expiresIn:2592e3,additionalFields:{activeOrgId:{type:"string",required:!1}}},plugins:[(0,f.d)()],advanced:{useSecureCookies:i.startsWith("https://")}})},77680:(a,b,c)=>{c.d(b,{Y:()=>j,g:()=>i});var d=c(50730),e=c(76760),f=c(12940),g=c(76561),h=c(66408);async function i(a,b,c,d){let i=(0,h.HZ)(b);for(let b of d){if(!b.path)continue;let d=((0,e.isAbsolute)(b.path)?(0,e.relative)(i,b.path):b.path).replace(/\\/g,"/");if(!(!d||d.startsWith(".."))&&!(d.startsWith(".claude/")||d.startsWith("archives/")||d.startsWith(".git/")))try{await f.db.insert(g.goalFile).values({workspaceId:a,goalId:c,path:d,op:b.op}).onConflictDoUpdate({target:[g.goalFile.goalId,g.goalFile.path],set:{op:b.op,at:new Date}})}catch{}}}async function j(a,b){return(await f.db.select({path:g.goalFile.path}).from(g.goalFile).where((0,d.Uo)((0,d.eq)(g.goalFile.workspaceId,a),(0,d.eq)(g.goalFile.goalId,b)))).map(a=>a.path)}},87980:(a,b,c)=>{c.d(b,{I:()=>l,k:()=>m});var d=c(36548),e=c(77598),f=c(50730),g=c(23888),h=c(12940),i=c(76561),j=c(2148),k=c(66263);async function l(a,b){await h.db.insert(i.event).values({id:(0,e.randomUUID)(),workspaceId:a,runId:b.runId,channel:b.channel??"room",agentId:b.agentId??null,seq:Date.now(),kind:b.kind,target:(b.target??"").slice(0,500),detail:(b.detail??"").slice(0,8e3)}),(0,k.r)(a)}async function m(a,b=0){let{workspace:c}=await (0,j.nP)();return h.db.select().from(i.event).where((0,f.Uo)((0,f.eq)(i.event.workspaceId,c.id),(0,f.eq)(i.event.channel,a),(0,f.gt)(i.event.seq,b))).orderBy((0,g.Y)(i.event.seq)).limit(300)}(0,c(99688).D)([l,m]),(0,d.A)(l,"600a283d3c155b52846ffdf59d78d6fb8408c82a2b",null),(0,d.A)(m,"60687b23eb88a4b6d050ea1eff119a716ca285d2f1",null)},97879:(a,b,c)=>{a.exports=c(9345).vendored["react-rsc"].ReactServerDOMWebpackServer},99688:(a,b)=>{function c(a){for(let b=0;b<a.length;b++){let c=a[b];if("function"!=typeof c)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof c}.
|
|
14
14
|
Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(b,"D",{enumerable:!0,get:function(){return c}})}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";exports.id=1881,exports.ids=[1881,2392],exports.modules={1186:(a,b,c)=>{c.d(b,{K:()=>e});var d=c(26021);let e=(0,d.createServerReference)("40e1d428a35224b686669e65eb8c74dc34e5ce1d04",d.callServer,void 0,d.findSourceMapURL,"previewFrameableAction")},9450:(a,b,c)=>{c.d(b,{Fy:()=>m,KD:()=>q,Rr:()=>l,TH:()=>s,Xu:()=>r,j0:()=>n,nx:()=>o,zC:()=>p});var d=c(80501),e=c(3770),f=c(96405),g=c(99398),h=c(62758),i=c(88193),j=c(17730),k=c(55593);async function l(){let{org:a,workspace:b}=await (0,f.nP)(),c=await (0,g.ZF)(b.id,a.id);return(0,e.revalidatePath)("/test-dev"),c}async function m(){let{workspace:a}=await (0,f.nP)(),b=await (0,g.n9)(a.id);return(0,e.revalidatePath)("/test-dev"),b}async function n(){let{workspace:a}=await (0,f.nP)();return(0,g.CS)(a.id)}async function o(){let{org:a,workspace:b}=await (0,f.nP)(),c=(0,g.CS)(b.id);if("running"!==c.status&&"starting"!==c.status&&(c=await (0,g.ZF)(b.id,a.id)),!c.url||"running"!==c.status&&"starting"!==c.status)return{ok:!1,error:"The dev server isn't running — start the app first."};let d=await (0,h.nK)(b.id,c.url);return d?{ok:!0,url:d.url}:{ok:!1,error:"Could not start the inspect proxy."}}async function p(){let{workspace:a}=await (0,f.nP)();return(0,h.hA)(a.id),{ok:!0}}async function q(a){if(await (0,f.nP)(),!/^https?:\/\/(127\.0\.0\.1|localhost)(:\d+)?/i.test(a))return{frameable:!0};try{let b=await fetch(a,{redirect:"manual",signal:AbortSignal.timeout(3e3)}),c=(b.headers.get("x-frame-options")||"").toLowerCase(),d=(b.headers.get("content-security-policy")||"").toLowerCase(),e=/frame-ancestors\s+([^;]+)/.exec(d)?.[1]??"",f=c.includes("deny")||c.includes("sameorigin"),g=!!e&&!/(\*|localhost|127\.0\.0\.1)/.test(e);return{frameable:!(f||g)}}catch{return{frameable:!0}}}async function r(a){let{org:b,workspace:c}=await (0,f.nP)(),d=a?.issueId?await (0,i.B)(c.id,a.issueId):void 0,g=await (0,i.z)(c.id,b.id,{goalId:a?.goalId,issueId:a?.issueId,routes:d,by:"operator"});return(0,e.revalidatePath)("/test-dev"),g}async function s(a,b){let{workspace:c}=await (0,f.nP)();return await (0,j.vE)(c.id,{kind:"validation",refType:"validation",refId:a,title:`Validate ${a}`,detail:b.slice(0,500)}),await (0,k.I)(c.id,{kind:"review",text:`Validation requested — ${a}`,detail:b.slice(0,300)}),(0,e.revalidatePath)("/inbox"),{ok:!0}}(0,c(64185).D)([l,m,n,o,p,q,r,s]),(0,d.A)(l,"001c80e5c76a900238fcefc34ad7fb27d2674c43b3",null),(0,d.A)(m,"00d1bff8cab30eda9c022a4bf2bf5b522c0b9c9f87",null),(0,d.A)(n,"00b498e03039c3b92608017ce7cca973d20d814eb9",null),(0,d.A)(o,"00cc6a4a8d7fbc1c44ae2272bd07ec8b2505315ca0",null),(0,d.A)(p,"00dcead2b0a30143fabfb7089cd18130a9e2493036",null),(0,d.A)(q,"40e1d428a35224b686669e65eb8c74dc34e5ce1d04",null),(0,d.A)(r,"40c3b9140f05ada027c6e018f19b0cd88916d79baa",null),(0,d.A)(s,"60eebdcd0502ac56444fb6454b2a523d2998fb16ae",null)},13389:(a,b,c)=>{c.d(b,{ViewChrome:()=>h});var d=c(40201),e=c(77758),f=c(3218),g=c(71955);function h({title:a,sub:b,right:c,icon:i,flush:j,children:k}){let l=(0,g.k)(),m=f.e.find(b=>b.title===a),n=i??m?.icon,o=m?l(`mod.${m.id}`):a;return(0,d.jsxs)("div",{className:"app-view",children:[(0,d.jsxs)("div",{className:"view-head",children:[n&&(0,d.jsx)("div",{className:"vh-icon",children:(0,d.jsx)(e.I,{name:n,size:18})}),(0,d.jsxs)("div",{style:{flex:1,minWidth:0},children:[(0,d.jsx)("div",{className:"view-title",children:o}),b&&(0,d.jsx)("div",{className:"view-sub",children:b})]}),c]}),(0,d.jsx)("div",{className:"view-body",style:j?{padding:0,overflow:"hidden"}:void 0,children:k})]})}},35023:(a,b,c)=>{c.d(b,{R:()=>e});var d=c(26021);let e=(0,d.createServerReference)("001c80e5c76a900238fcefc34ad7fb27d2674c43b3",d.callServer,void 0,d.findSourceMapURL,"startDevServerAction")},41323:(a,b,c)=>{c.d(b,{ViewChrome:()=>d});let d=(0,c(97879).registerClientReference)(function(){throw Error("Attempted to call ViewChrome() from the server but ViewChrome is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"C:\\Users\\Usuario\\Documents\\constella\\src\\components\\shell\\view-chrome.tsx","ViewChrome")},47385:(a,b,c)=>{c.d(b,{l:()=>g});var d=c(46309),e=c(34925);async function f(){return(0,e.e)((await (0,d.cookies)()).get("cn-lang")?.value)}async function g(){let a=await f();return(b,c)=>(0,e.t)(a,b,c)}},51439:(a,b,c)=>{c.d(b,{pM:()=>z,lP:()=>y,Kg:()=>x,eU:()=>B,PG:()=>A});var d=c(80501),e=c(96405),f=c(90127),g=c(59627),h=c(24582);function i(){return(0,h.n)()?"dev":"vps"===(0,g.T)()?"vps":"portable"===(0,g.T)()?"portable":/[\\/]_npx[\\/]/.test((0,f.v)())?"npx":"global"}var j=c(52392),k=c(73024),l=c(76760),m=c(48161),n=c(31421),o=c(37989);let p=()=>new Date().toISOString().replace(/[:.]/g,"-"),q=()=>(0,l.join)((0,o.r$)(),"backups","last-update.json");async function r(){let a=await (0,j.checkForUpdate)(!0),b=i(),c=a.command;if(!a.updateAvailable)return{ok:!0,context:b,command:c,message:"Already up to date."};let d=function(){try{let a=(0,o.r$)(),b=(0,l.join)(a,"backups",p());for(let c of((0,k.mkdirSync)(b,{recursive:!0}),[".env","constella.db","constella.db-wal","constella.db-shm"])){let d=(0,l.join)(a,c);if((0,k.existsSync)(d))try{(0,k.copyFileSync)(d,(0,l.join)(b,c))}catch{}}return b}catch{return null}}()??void 0;if("dev"===b)return{ok:!1,context:b,command:c,backupDir:d,message:"Running from source — update with: git pull && pnpm install && pnpm build"};if("npx"===b)return{ok:!1,context:b,command:c,backupDir:d,message:"npx runs an ephemeral copy — re-run: npx constellai@latest"};if("vps"===b){var e="bash scripts/vps-update.sh";try{(0,k.writeFileSync)(q(),JSON.stringify({status:"running",to:a.latest,at:p()}));let b=(0,o.r$)(),c=process.env.CONSTELLA_PKG_ROOT||process.cwd(),f=(0,l.join)(c,"bin","constella-update.mjs"),g=a.latest?["--version",a.latest]:[];return(0,n.spawn)(process.execPath,[f,"--quiet","--mode","vps","--home",b,...g],{detached:!0,stdio:"ignore",cwd:(0,m.tmpdir)()}).unref(),{ok:!0,started:!0,needsRestart:!0,context:"vps",command:e,backupDir:d,message:`Updating to ${a.latest} and restarting the service — this page reconnects in a few seconds.`}}catch(a){return{ok:!1,context:"vps",command:e,backupDir:d,message:"Couldn't launch the updater: "+String(a instanceof Error?a.message:a)}}}return function(a,b,c,d){try{(0,k.writeFileSync)(q(),JSON.stringify({status:"running",to:a.latest,at:p()}));let e=process.env.CONSTELLA_RUN_MODE||"start",f=process.env.CONSTELLA_LAUNCHER_PID||"0",g=(0,o.r$)(),h=process.env.PORT||"3000",i=process.env.CONSTELLA_PKG_ROOT||process.cwd(),j=(0,l.join)(i,"bin","constella-update.mjs"),r=a.latest?["--version",a.latest]:[];return(0,n.spawn)(process.execPath,[j,"--quiet","--pid",f,"--mode",e,"--home",g,"--port",h,...r],{detached:!0,stdio:"ignore",windowsHide:!0,cwd:(0,m.tmpdir)()}).unref(),{ok:!0,started:!0,needsRestart:!0,context:b,command:c,backupDir:d,message:`Updating to ${a.latest} and restarting — this page reconnects in a few seconds.`}}catch(a){return{ok:!1,context:b,command:c,backupDir:d,message:"Couldn't launch the updater: "+String(a instanceof Error?a.message:a)}}}(a,b,c,d)}var s=c(73591),t=c(54813),u=c(406),v=c(96977);async function w(){let a=await t.db.select({lastPulse:u.agent.lastPulse}).from(u.agent).where((0,s.eq)(u.agent.status,"working")),b=Date.now()-v.fQ;return a.some(a=>null!=a.lastPulse&&new Date(a.lastPulse).getTime()>=b)}async function x(a=!1){return(0,j.checkForUpdate)(a)}async function y(a=!1){let[b,c]=await Promise.all([(0,j.checkForUpdate)(a),w()]);return{info:b,busy:c}}async function z(){return i()}async function A(){return(await (0,e.nP)(),await w())?{ok:!1,started:!1,blocked:!0,context:"",command:"",message:"An agent is working — pause it before updating."}:r()}async function B(){try{return JSON.parse((0,k.readFileSync)(q(),"utf8"))}catch{return{status:"idle"}}}(0,c(64185).D)([x,y,z,A,B]),(0,d.A)(x,"40644e55de636cef1c787d94b0eec56070b94d360d",null),(0,d.A)(y,"40ae3fb3067456973e13f9899fb17d02e903c10635",null),(0,d.A)(z,"008ed9fe976118b805388b321772fcf38c55ff881e",null),(0,d.A)(A,"0098fd0858edaddfb6c02d1de1be8dd97b9a28589d",null),(0,d.A)(B,"00ea39c63126fa6fef31973d3d768a7cb76f836fe2",null)},52392:(a,b,c)=>{c.d(b,{checkForUpdate:()=>m});var d=c(73024),e=c(76760),f=c(90127);let g="constellai",h=null,i=a=>a.replace(/^v/,"").split("-")[0].split(".").map(a=>parseInt(a,10)||0),j=a=>a.replace(/^v/,"").split("-")[1]??"";async function k(a){try{let b=new AbortController,c=setTimeout(()=>b.abort(),3e3),d=await fetch(a,{signal:b.signal,headers:{"user-agent":"constella"}});return clearTimeout(c),d.ok?await d.json():null}catch{return null}}async function l(a){try{let b=new AbortController,c=setTimeout(()=>b.abort(),3e3),d=await fetch(a,{signal:b.signal,headers:{"user-agent":"constella"}});return clearTimeout(c),d.ok?await d.text():null}catch{return null}}async function m(a=!1){let b,c,n=function(){if(process.env.CONSTELLA_VERSION)return process.env.CONSTELLA_VERSION;try{let a=JSON.parse((0,d.readFileSync)((0,e.join)((0,f.v)(),"package.json"),"utf8"));if(a?.version)return a.version}catch{}return"0.0.0"}(),o=`npm install -g ${g}@latest`;if(!a&&h&&Date.now()-h.at<216e5)return h.info;let p=await k(`https://registry.npmjs.org/${g}/latest`),q=p?.version??null,r=!!q&&function(a,b){let c=i(a),d=i(b);for(let a=0;a<3;a++){if((c[a]||0)>(d[a]||0))return!0;if((c[a]||0)<(d[a]||0))return!1}return!j(a)&&!!j(b)}(q,n),s=null;if(r&&q){let a=await l("https://raw.githubusercontent.com/gabriel7silva/constella/main/CHANGELOG.md");s=a?function(a,b){let c=b.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),d=a.match(RegExp(`(^|\\n)##\\s*\\[?${c}\\]?[\\s\\S]*?(?=\\n##\\s|$)`));if(d)return d[0].trim();let e=a.split(/\n##\s/)[1];return e?"## "+e.trim():null}(a,q):null}let t={current:n,latest:q,updateAvailable:r,type:q?(b=i(q),c=i(n),b[0]>c[0]?"major":b[1]>c[1]?"minor":b[2]>c[2]||!j(q)&&j(n)?"patch":null):null,command:o,changelog:s};return h={at:Date.now(),info:t},t}},59627:(a,b,c)=>{c.d(b,{T:()=>e});let d=["start","auth","vps","portable"];function e(){let a=process.env.CONSTELLA_RUN_MODE;return a&&d.includes(a)?a:"start"}},64543:(a,b,c)=>{c.d(b,{_:()=>g});var d=c(50727),e=c(48578),f=c(41323);function g({title:a,sub:b,right:c,icon:h,flush:i,children:j}){return(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(e.b,{title:a}),(0,d.jsx)(f.ViewChrome,{title:a,sub:b,right:c,icon:h,flush:i,children:j})]})}},66151:(a,b,c)=>{c.d(b,{j:()=>e});var d=c(26021);let e=(0,d.createServerReference)("00b498e03039c3b92608017ce7cca973d20d814eb9",d.callServer,void 0,d.findSourceMapURL,"devServerStatusAction")},66408:(a,b,c)=>{c.d(b,{r$:()=>h,EX:()=>p,CS:()=>function a(b,c=""){let d=[];for(let e of l(b,c))if(e.isDir){if(m.has(e.name))continue;d.push(...a(b,e.path))}else d.push(e.path);return d},HZ:()=>j,Ci:()=>l,sL:()=>n,dx:()=>o});var d=c(73024),e=c(76760),f=c(48161),g=c(45570);function h(){return process.env.CONSTELLA_HOME?(0,g.Y)(process.env.CONSTELLA_HOME):(0,e.join)((0,f.homedir)(),".constella")}let i=new Set;function j(a){if(!/^[A-Za-z0-9_-]{6,64}$/.test(a))throw Error("Invalid orgId");let b=(0,e.join)(h(),"organizations",a,"workspace");if(!i.has(a)){i.add(a);try{let c=(0,e.join)(h(),"organizations",a,"constella"),f=!(0,d.existsSync)(b)||0===(0,d.readdirSync)(b).length;if((0,d.existsSync)(c)&&f)try{(0,d.renameSync)(c,b)}catch{(0,d.existsSync)(c)&&((0,d.mkdirSync)(b,{recursive:!0}),0===(0,d.readdirSync)(b).length&&(0,d.cpSync)(c,b,{recursive:!0}))}}catch{}}return b}function k(a,b){let c=(0,e.normalize)((0,e.join)(a,b));if(c!==a&&!c.startsWith(a+e.sep))throw Error("Path escapes workspace: "+b);if((0,d.existsSync)(a)){let f;try{f=d.realpathSync.native(a)}catch{f=a}let g=function(a){let b=a;for(;;){if((0,d.existsSync)(b))try{return d.realpathSync.native(b)}catch{return b}let a=(0,e.dirname)(b);if(a===b)return b;b=a}}(c);if(g!==f&&!g.startsWith(f+e.sep))throw Error("Path escapes workspace (symlink): "+b)}return c}function l(a,b=""){let c=k(j(a),b);return(0,d.existsSync)(c)?(0,d.readdirSync)(c).map(a=>{let f=(0,e.join)(c,a),g=(b?b+"/":"")+a;return{name:a,path:g,isDir:(0,d.statSync)(f).isDirectory()}}).sort((a,b)=>a.isDir===b.isDir?a.name.localeCompare(b.name):a.isDir?-1:1):[]}let m=new Set(["node_modules",".git",".next",".turbo","dist","build","out","coverage",".cache","archives",".testdev",".pnpm-store",".vercel","vendor"]);function n(a,b){let c=k(j(a),b);return(0,d.existsSync)(c)?(0,d.readFileSync)(c,"utf8"):null}function o(a,b,c){let f=k(j(a),b);(0,d.mkdirSync)((0,e.dirname)(f),{recursive:!0}),(0,d.writeFileSync)(f,c,"utf8")}function p(a,b){let c=k(j(a),b);(0,d.existsSync)(c)&&(0,d.rmSync)(c,{recursive:!0,force:!0})}},95777:(a,b,c)=>{c.r(b),c.d(b,{"0044875440d0e500d70bb545f5b7ef7c97908fe28e":()=>d.cT,"008cb10418da2f4293b27c6c5438d9197a6ad7e234":()=>d.Kd,"40c6dc9ec4bbc533c4ce92eb7dad66b0bfece831cd":()=>d.OD,"40fdf8926bc3fb9ab5cdb6c5aa59b419d7ccda7236":()=>d.j0});var d=c(54489)}};
|
|
@@ -19,4 +19,4 @@ ${i}`}}async function I(){let{org:a}=await (0,l.nP)(),b=(0,n.HZ)(a.id);return aw
|
|
|
19
19
|
`+a.findings.slice(0,20).map(a=>`• ${a.file}${a.line?":"+a.line:""} — ${a.kind} (${a.preview})`).join("\n")}),await (0,r.I)(c.id,{kind:"security",text:`Commit blocked — ${a.findings.length} secret risk(s)`,detail:a.findings.slice(0,5).map(a=>`${a.file}: ${a.kind}`).join("; ")}),(0,i.revalidatePath)("/github"),(0,i.revalidatePath)("/inbox"),j}await (0,o.d1)("git",["add","-A"],{cwd:d});let t=await (0,o.d1)("git",["-c","user.email=agents@constella.dev","-c","user.name=Constella Agents","commit","-m",a.message],{cwd:d});if(0===t.code)j.committed=!0,j.sha=(await (0,o.d1)("git",["rev-parse","--short","HEAD"],{cwd:d})).stdout.trim();else if(/nothing to commit|no changes added/i.test(t.stdout+t.stderr))return j.nothing=!0,K(c.id,j,a);else return j.error=h(t.stderr||t.stdout)||"git commit failed",K(c.id,j,a);let v=await (0,o.d1)("git",["remote","get-url","origin"],{cwd:d}),w=0===v.code?v.stdout.trim():"";if(w&&g&&/^https:\/\/github\.com\//i.test(w)){let b=w.replace(/^https:\/\//i,`https://x-access-token:${g}@`),e=await (0,o.d1)("git",["push",b,`HEAD:${f}`],{cwd:d,timeoutMs:12e4});if(j.pushed=0===e.code,!j.pushed&&(j.error=h(e.stderr)||"git push failed",/rejected|non-fast-forward|fetch first|merge conflict|failed to push/i.test(e.stderr)&&await (0,q.vE)(c.id,{kind:"block",refType:"task",refId:`push:${a.repo}:${f}`,title:`Push rejected — ${a.repo}`,detail:`git push to \`${f}\` was rejected (remote conflict / non-fast-forward). Pull + resolve, then push again.
|
|
20
20
|
|
|
21
21
|
${h(e.stderr).slice(0,300)}`})),j.pushed&&a.delegated){let a=await (0,o.d1)("gh",["pr","create","--fill","--head",f],{cwd:d,timeoutMs:6e4,env:{GH_TOKEN:g}}),b=(a.stdout.match(/https:\/\/github\.com\/\S+/)??[])[0];b?j.prUrl=b:0!==a.code&&(j.error=h(a.stderr).slice(0,200)||"gh pr create did not open a PR (is the branch the repo default, or no diff vs base?)")}}else w?g||(j.error="committed locally — connect a GitHub PAT to push"):j.error="committed locally — no 'origin' remote configured to push";return K(c.id,j,a)}async function K(a,b,c){if(b.committed){await j.db.update(k.file).set({gitStatus:""}).where((0,h.Uo)((0,h.eq)(k.file.workspaceId,a),(0,h.ne)(k.file.gitStatus,"")));let d=b.pushed?`pushed to ${c.repo} \xb7 ${c.branch}`:"committed locally";await (0,r.I)(a,{kind:"deploy",text:`Workspace ${d}${b.sha?` (${b.sha})`:""}`,detail:(c.delegated&&b.prUrl?`PR: ${b.prUrl}
|
|
22
|
-
`:"")+c.message})}return b.ok=b.committed,(0,i.revalidatePath)("/github"),b}(0,s.D)([x,y,z,A,B,D,E,F,G,H,I,J]),(0,d.A)(x,"
|
|
22
|
+
`:"")+c.message})}return b.ok=b.committed,(0,i.revalidatePath)("/github"),b}(0,s.D)([x,y,z,A,B,D,E,F,G,H,I,J]),(0,d.A)(x,"0013ec24389666eb28dda0440473d485a7e94630be",null),(0,d.A)(y,"40a42a0f6a53b1390335b565f5df000e9c487caad7",null),(0,d.A)(z,"40f9a4deec4889d00423087316075d5f2c7b5da972",null),(0,d.A)(A,"40ffcbb5485a8db8cf708ba98396b3ba5338c4c501",null),(0,d.A)(B,"00a1626d6cc7d929853137252a7aa3ebeeae3414df",null),(0,d.A)(D,"0099ffdfa64218160bfaa3692ab850ae7b61b785d8",null),(0,d.A)(E,"4011271b56c93cbb7c32fb33dd5ed22f0e92acfdbc",null),(0,d.A)(F,"40737829fafee62da0b87434a3f449c8ed1901c877",null),(0,d.A)(G,"00c2396890274a8419143a80ab10aacea55b5ad0fe",null),(0,d.A)(H,"009807dd505497b68ddc36530b5391d72a32532157",null),(0,d.A)(I,"0038d14e69a64d9413411ff0d96ec917229df8f8f6",null),(0,d.A)(J,"4007145f34d83a250972724b439f9253bd203a94f1",null)},41323:(a,b,c)=>{c.d(b,{ViewChrome:()=>d});let d=(0,c(97879).registerClientReference)(function(){throw Error("Attempted to call ViewChrome() from the server but ViewChrome is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"C:\\Users\\Usuario\\Documents\\constella\\src\\components\\shell\\view-chrome.tsx","ViewChrome")},47385:(a,b,c)=>{c.d(b,{l:()=>g});var d=c(46309),e=c(34925);async function f(){return(0,e.e)((await (0,d.cookies)()).get("cn-lang")?.value)}async function g(){let a=await f();return(b,c)=>(0,e.t)(a,b,c)}},51439:(a,b,c)=>{c.d(b,{pM:()=>z,lP:()=>y,Kg:()=>x,eU:()=>B,PG:()=>A});var d=c(80501),e=c(96405),f=c(90127),g=c(59627),h=c(24582);function i(){return(0,h.n)()?"dev":"vps"===(0,g.T)()?"vps":"portable"===(0,g.T)()?"portable":/[\\/]_npx[\\/]/.test((0,f.v)())?"npx":"global"}var j=c(52392),k=c(73024),l=c(76760),m=c(48161),n=c(31421),o=c(37989);let p=()=>new Date().toISOString().replace(/[:.]/g,"-"),q=()=>(0,l.join)((0,o.r$)(),"backups","last-update.json");async function r(){let a=await (0,j.checkForUpdate)(!0),b=i(),c=a.command;if(!a.updateAvailable)return{ok:!0,context:b,command:c,message:"Already up to date."};let d=function(){try{let a=(0,o.r$)(),b=(0,l.join)(a,"backups",p());for(let c of((0,k.mkdirSync)(b,{recursive:!0}),[".env","constella.db","constella.db-wal","constella.db-shm"])){let d=(0,l.join)(a,c);if((0,k.existsSync)(d))try{(0,k.copyFileSync)(d,(0,l.join)(b,c))}catch{}}return b}catch{return null}}()??void 0;if("dev"===b)return{ok:!1,context:b,command:c,backupDir:d,message:"Running from source — update with: git pull && pnpm install && pnpm build"};if("npx"===b)return{ok:!1,context:b,command:c,backupDir:d,message:"npx runs an ephemeral copy — re-run: npx constellai@latest"};if("vps"===b){var e="bash scripts/vps-update.sh";try{(0,k.writeFileSync)(q(),JSON.stringify({status:"running",to:a.latest,at:p()}));let b=(0,o.r$)(),c=process.env.CONSTELLA_PKG_ROOT||process.cwd(),f=(0,l.join)(c,"bin","constella-update.mjs"),g=a.latest?["--version",a.latest]:[];return(0,n.spawn)(process.execPath,[f,"--quiet","--mode","vps","--home",b,...g],{detached:!0,stdio:"ignore",cwd:(0,m.tmpdir)()}).unref(),{ok:!0,started:!0,needsRestart:!0,context:"vps",command:e,backupDir:d,message:`Updating to ${a.latest} and restarting the service — this page reconnects in a few seconds.`}}catch(a){return{ok:!1,context:"vps",command:e,backupDir:d,message:"Couldn't launch the updater: "+String(a instanceof Error?a.message:a)}}}return function(a,b,c,d){try{(0,k.writeFileSync)(q(),JSON.stringify({status:"running",to:a.latest,at:p()}));let e=process.env.CONSTELLA_RUN_MODE||"start",f=process.env.CONSTELLA_LAUNCHER_PID||"0",g=(0,o.r$)(),h=process.env.PORT||"3000",i=process.env.CONSTELLA_PKG_ROOT||process.cwd(),j=(0,l.join)(i,"bin","constella-update.mjs"),r=a.latest?["--version",a.latest]:[];return(0,n.spawn)(process.execPath,[j,"--quiet","--pid",f,"--mode",e,"--home",g,"--port",h,...r],{detached:!0,stdio:"ignore",windowsHide:!0,cwd:(0,m.tmpdir)()}).unref(),{ok:!0,started:!0,needsRestart:!0,context:b,command:c,backupDir:d,message:`Updating to ${a.latest} and restarting — this page reconnects in a few seconds.`}}catch(a){return{ok:!1,context:b,command:c,backupDir:d,message:"Couldn't launch the updater: "+String(a instanceof Error?a.message:a)}}}(a,b,c,d)}var s=c(73591),t=c(54813),u=c(406),v=c(96977);async function w(){let a=await t.db.select({lastPulse:u.agent.lastPulse}).from(u.agent).where((0,s.eq)(u.agent.status,"working")),b=Date.now()-v.fQ;return a.some(a=>null!=a.lastPulse&&new Date(a.lastPulse).getTime()>=b)}async function x(a=!1){return(0,j.checkForUpdate)(a)}async function y(a=!1){let[b,c]=await Promise.all([(0,j.checkForUpdate)(a),w()]);return{info:b,busy:c}}async function z(){return i()}async function A(){return(await (0,e.nP)(),await w())?{ok:!1,started:!1,blocked:!0,context:"",command:"",message:"An agent is working — pause it before updating."}:r()}async function B(){try{return JSON.parse((0,k.readFileSync)(q(),"utf8"))}catch{return{status:"idle"}}}(0,c(64185).D)([x,y,z,A,B]),(0,d.A)(x,"40644e55de636cef1c787d94b0eec56070b94d360d",null),(0,d.A)(y,"40ae3fb3067456973e13f9899fb17d02e903c10635",null),(0,d.A)(z,"008ed9fe976118b805388b321772fcf38c55ff881e",null),(0,d.A)(A,"0098fd0858edaddfb6c02d1de1be8dd97b9a28589d",null),(0,d.A)(B,"00ea39c63126fa6fef31973d3d768a7cb76f836fe2",null)},52392:(a,b,c)=>{c.d(b,{checkForUpdate:()=>m});var d=c(73024),e=c(76760),f=c(90127);let g="constellai",h=null,i=a=>a.replace(/^v/,"").split("-")[0].split(".").map(a=>parseInt(a,10)||0),j=a=>a.replace(/^v/,"").split("-")[1]??"";async function k(a){try{let b=new AbortController,c=setTimeout(()=>b.abort(),3e3),d=await fetch(a,{signal:b.signal,headers:{"user-agent":"constella"}});return clearTimeout(c),d.ok?await d.json():null}catch{return null}}async function l(a){try{let b=new AbortController,c=setTimeout(()=>b.abort(),3e3),d=await fetch(a,{signal:b.signal,headers:{"user-agent":"constella"}});return clearTimeout(c),d.ok?await d.text():null}catch{return null}}async function m(a=!1){let b,c,n=function(){if(process.env.CONSTELLA_VERSION)return process.env.CONSTELLA_VERSION;try{let a=JSON.parse((0,d.readFileSync)((0,e.join)((0,f.v)(),"package.json"),"utf8"));if(a?.version)return a.version}catch{}return"0.0.0"}(),o=`npm install -g ${g}@latest`;if(!a&&h&&Date.now()-h.at<216e5)return h.info;let p=await k(`https://registry.npmjs.org/${g}/latest`),q=p?.version??null,r=!!q&&function(a,b){let c=i(a),d=i(b);for(let a=0;a<3;a++){if((c[a]||0)>(d[a]||0))return!0;if((c[a]||0)<(d[a]||0))return!1}return!j(a)&&!!j(b)}(q,n),s=null;if(r&&q){let a=await l("https://raw.githubusercontent.com/gabriel7silva/constella/main/CHANGELOG.md");s=a?function(a,b){let c=b.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),d=a.match(RegExp(`(^|\\n)##\\s*\\[?${c}\\]?[\\s\\S]*?(?=\\n##\\s|$)`));if(d)return d[0].trim();let e=a.split(/\n##\s/)[1];return e?"## "+e.trim():null}(a,q):null}let t={current:n,latest:q,updateAvailable:r,type:q?(b=i(q),c=i(n),b[0]>c[0]?"major":b[1]>c[1]?"minor":b[2]>c[2]||!j(q)&&j(n)?"patch":null):null,command:o,changelog:s};return h={at:Date.now(),info:t},t}},59627:(a,b,c)=>{c.d(b,{T:()=>e});let d=["start","auth","vps","portable"];function e(){let a=process.env.CONSTELLA_RUN_MODE;return a&&d.includes(a)?a:"start"}},64543:(a,b,c)=>{c.d(b,{_:()=>g});var d=c(50727),e=c(48578),f=c(41323);function g({title:a,sub:b,right:c,icon:h,flush:i,children:j}){return(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(e.b,{title:a}),(0,d.jsx)(f.ViewChrome,{title:a,sub:b,right:c,icon:h,flush:i,children:j})]})}},84039:(a,b,c)=>{c.d(b,{I:()=>l});var d=c(73024),e=c(76760),f=c(55104);let g=/(^|\/)(\.env(\.[\w.-]+)?|id_[rd]sa\w*|.*\.(pem|key|p12|pfx|keystore|jks|ppk|asc)|credentials?\.json|service[-_]?account[\w.-]*\.json|.*\.(sql|dump|bak|sqlite3?|db)|npm-debug\.log|.*\.local)$/i,h=/(\.env\.(example|sample|template|dist)|\.env-example)$/i,i=[{kind:"AWS access key",re:/\bAKIA[0-9A-Z]{16}\b/},{kind:"GitHub token",re:/\bgh[posru]_[A-Za-z0-9]{30,}\b/},{kind:"GitHub fine-grained PAT",re:/\bgithub_pat_[A-Za-z0-9_]{40,}\b/},{kind:"OpenAI/Anthropic key",re:/\bsk-[A-Za-z0-9_-]{20,}\b/},{kind:"Google API key",re:/\bAIza[0-9A-Za-z_-]{30,}\b/},{kind:"Slack token",re:/\bxox[baprs]-[A-Za-z0-9-]{10,}\b/},{kind:"Private key",re:/-----BEGIN (?:RSA |EC |OPENSSH |DSA |PGP )?PRIVATE KEY-----/},{kind:"JWT",re:/\beyJ[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{6,}\b/},{kind:"DB URL with credentials",re:/\b(?:postgres(?:ql)?|mysql|mongodb(?:\+srv)?|redis|amqp):\/\/[^\s:@/]+:[^\s:@/]+@/i},{kind:"Telegram bot token",re:/\b\d{6,}:[A-Za-z0-9_-]{35,}\b/},{kind:"Hardcoded secret",re:/\b(password|passwd|secret|api[_-]?key|access[_-]?token|auth[_-]?token|client[_-]?secret|private[_-]?key)\b\s*[:=]\s*['"][^'"\n]{6,}['"]/i}],j=/(your[_-]?|xxx+|<[^>]+>|change[_-]?me|example|placeholder|\*{3,}|•|dummy|todo|redacted|\.\.\.)/i,k=/(^|\/)(node_modules|\.git|\.next|dist|build|out|\.turbo|coverage|uploads|archives|\.testdev|vendor)\//;async function l(a){let b=await (0,f.d1)("git",["status","--porcelain","-z","--untracked-files=all"],{cwd:a});if(0!==b.code)return{findings:[],scanned:0,files:0};let c=[],l=b.stdout.split("\0");for(let a=0;a<l.length;a++){let b=l[a];if(!b||b.length<3)continue;let d=b[0],e=b[1],f=b.slice(3);("R"===d||"C"===d||"R"===e||"C"===e)&&a++,"D"!==d&&"D"!==e&&(!f||k.test(f+"/")||c.push(f))}let m=[],n=0;for(let b of c.slice(0,3e3)){g.test(b)&&!h.test(b)&&m.push({file:b,line:0,kind:"must-not-commit file",preview:b.split("/").pop()??b});let c=(0,e.join)(a,b),f=0;try{f=(0,d.statSync)(c).size}catch{continue}if(f>2097152)continue;let k="";try{k=(0,d.readFileSync)(c,"utf8")}catch{continue}if(k.includes("\0"))continue;n++;let l=k.split("\n");for(let a=0;a<l.length&&m.length<300;a++){let c=l[a];if(!(c.length>4e3))for(let{kind:d,re:e}of i){let f=e.exec(c);if(f&&!("Hardcoded secret"===d&&j.test(f[0]))){var o;m.push({file:b,line:a+1,kind:d,preview:(o=f[0]).length<=10?"•••":o.slice(0,4)+"•••"+o.slice(-2)});break}}}}return{findings:m,scanned:n,files:c.length}}}};
|