constellai 0.3.3 → 0.3.5
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 +44 -44
- 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 +3 -3
- 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 +2 -2
- 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 +2 -2
- 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 +3 -3
- 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 +1 -1
- 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 +2 -2
- 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.js.nft.json +1 -1
- package/.next/server/app/(auth)/login/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(auth)/onboarding/page.js +2 -2
- package/.next/server/app/(auth)/onboarding/page.js.nft.json +1 -1
- package/.next/server/app/(auth)/onboarding/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_global-error/page.js +1 -1
- package/.next/server/app/_global-error/page.js.nft.json +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 +3 -3
- package/.next/server/app/_global-error.segments/_full.segment.rsc +3 -3
- 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 +2 -2
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found/page.js +1 -1
- package/.next/server/app/_not-found/page.js.nft.json +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/sync/file/route.js +2 -2
- package/.next/server/app/api/telegram/poll/route.js +2 -2
- package/.next/server/app/api/v1/[[...path]]/route.js +1 -1
- package/.next/server/chunks/1249.js +7 -7
- package/.next/server/chunks/1845.js +1 -1
- package/.next/server/chunks/212.js +1 -0
- package/.next/server/chunks/259.js +1 -1
- package/.next/server/chunks/260.js +1 -1
- package/.next/server/chunks/2867.js +1 -1
- package/.next/server/chunks/2960.js +1 -1
- package/.next/server/chunks/3131.js +1 -1
- package/.next/server/chunks/3234.js +1 -1
- package/.next/server/chunks/4979.js +2 -2
- package/.next/server/chunks/6381.js +15 -0
- package/.next/server/chunks/6431.js +1 -1
- package/.next/server/chunks/6853.js +12 -0
- package/.next/server/chunks/6954.js +1 -0
- package/.next/server/chunks/7589.js +1 -1
- package/.next/server/chunks/7989.js +1 -1
- package/.next/server/chunks/8561.js +1 -1
- package/.next/server/chunks/8623.js +1 -1
- package/.next/server/chunks/8762.js +417 -15
- package/.next/server/chunks/8823.js +1 -1
- package/.next/server/chunks/9215.js +4 -0
- package/.next/server/chunks/9229.js +1 -0
- package/.next/server/chunks/9310.js +21 -0
- package/.next/server/chunks/9783.js +1 -1
- package/.next/server/middleware-build-manifest.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/2692-7fee6e06b3c93940.js +1 -0
- package/.next/static/chunks/2997-ec8b18227849683e.js +1 -0
- package/.next/static/chunks/3219-b4941c7ff967e904.js +1 -0
- package/.next/static/chunks/6602-f26d109fd94cee1d.js +4 -0
- package/.next/static/chunks/8370-2733742abf5f3ddf.js +12 -0
- package/.next/static/chunks/{5332-84d9a65aa5d16106.js → 9112-c37628abc8a164cd.js} +1 -1
- package/.next/static/chunks/app/(app)/activity/{page-0f51a22d4f2207b2.js → page-29e80a32c02f376b.js} +1 -1
- package/.next/static/chunks/app/(app)/agents/[handle]/page-83277413debb3b25.js +1 -0
- package/.next/static/chunks/app/(app)/code/page-1f954f7688bc24e4.js +1 -0
- package/.next/static/chunks/app/(app)/config/page-eee4f8736608afa5.js +1 -0
- package/.next/static/chunks/app/(app)/costs/page-0beac688917eaa30.js +1 -0
- package/.next/static/chunks/app/(app)/cron/{page-ab35783e4341f6b7.js → page-a4dd65c78173b872.js} +1 -1
- package/.next/static/chunks/app/(app)/dashboard/page-519a934ccfcce6fa.js +1 -0
- package/.next/static/chunks/app/(app)/design/{page-fcee2dfd5c7e3a4b.js → page-238be90d78d22780.js} +3 -3
- package/.next/static/chunks/app/(app)/docs/[id]/page-e29afa1ba1a086e1.js +1 -0
- package/.next/static/chunks/app/(app)/docs/page-b4462f9ca2118f8b.js +1 -0
- package/.next/static/chunks/app/(app)/github/page-cf8501e45fe38663.js +1 -0
- package/.next/static/chunks/app/(app)/goals/page-75c36155c162df5b.js +1 -0
- package/.next/static/chunks/app/(app)/inbox/page-f40bdb457609ddad.js +12 -0
- package/.next/static/chunks/app/(app)/knowledge/page-dc5dd15e4f0ad22e.js +1 -0
- package/.next/static/chunks/app/(app)/layout-408976a4d35f06a8.js +1 -0
- package/.next/static/chunks/app/(app)/models/page-a54e0b8ffed0085c.js +1 -0
- package/.next/static/chunks/app/(app)/notifications/page-1f84d74bc53c2c6c.js +12 -0
- package/.next/static/chunks/app/(app)/org/page-d17c62b7a668b399.js +12 -0
- package/.next/static/chunks/app/(app)/organizations/page-b55445f226cf8c61.js +1 -0
- package/.next/static/chunks/app/(app)/{page-54a99a54295a40be.js → page-c7dd52ecc2da529d.js} +1 -1
- package/.next/static/chunks/app/(app)/planner/page-920e439e6f88c238.js +1 -0
- package/.next/static/chunks/app/(app)/plugins/{page-e75d982132825b07.js → page-d10239fcbabdf4fa.js} +1 -1
- package/.next/static/chunks/app/(app)/pm/page-61ad11558f241cf1.js +1 -0
- package/.next/static/chunks/app/(app)/prepare-deploy/page-8d25f86b26ab0d2e.js +1 -0
- package/.next/static/chunks/app/(app)/profile/page-236673e1a8c1e6c6.js +1 -0
- package/.next/static/chunks/app/(app)/pulse/{page-1a63c4ed76db48f5.js → page-f2c6049a967b93a3.js} +1 -1
- package/.next/static/chunks/app/(app)/reports/[id]/{page-ab35783e4341f6b7.js → page-a4dd65c78173b872.js} +1 -1
- package/.next/static/chunks/app/(app)/reports/page-5c07fa3a8b5ba553.js +1 -0
- package/.next/static/chunks/app/(app)/routines/page-0193e84e6a60a06a.js +1 -0
- package/.next/static/chunks/app/(app)/search/{page-d30f1c44c95e14a3.js → page-07e037c487f14c35.js} +1 -1
- package/.next/static/chunks/app/(app)/security/{page-4640d72a0b360f05.js → page-71e5d992b5ddf79a.js} +1 -1
- package/.next/static/chunks/app/(app)/skills/page-72691864856c9906.js +1 -0
- package/.next/static/chunks/app/(app)/tasks/page-5c9ca8f83d4c904f.js +1 -0
- package/.next/static/chunks/app/(app)/test-dev/page-5aee630d9bc73a0b.js +1 -0
- package/.next/static/chunks/app/(app)/update/page-2c9bcdb65bd2f597.js +1 -0
- package/.next/static/chunks/app/(auth)/login/page-50033813b56469ee.js +1 -0
- package/.next/static/chunks/app/(auth)/onboarding/{page-0cd7cd9fa146a927.js → page-075fd9673f7ab241.js} +1 -1
- package/.next/static/chunks/app/_not-found/page-dc38b02aebeab535.js +1 -0
- package/.next/trace-build +1 -1
- package/CHANGELOG.md +45 -3
- package/README.md +1 -1
- package/README.pt-BR.md +1 -1
- package/bin/constella-update.mjs +44 -0
- package/docs/UPDATE.md +38 -7
- package/package.json +1 -1
- package/scripts/vps-install.sh +25 -0
- package/scripts/vps-update.sh +24 -0
- package/.next/server/chunks/3174.js +0 -12
- package/.next/server/chunks/3334.js +0 -1
- package/.next/server/chunks/3439.js +0 -4
- package/.next/server/chunks/478.js +0 -1
- package/.next/server/chunks/5086.js +0 -417
- package/.next/server/chunks/8195.js +0 -21
- package/.next/server/chunks/8244.js +0 -1
- package/.next/static/chunks/3219-9684aa1c634212de.js +0 -1
- package/.next/static/chunks/386-0f2b8d23016cf4d0.js +0 -1
- package/.next/static/chunks/4909-9f16a714c78ed30d.js +0 -4
- package/.next/static/chunks/5664-3cb5735f1b5bbde1.js +0 -1
- package/.next/static/chunks/8370-7ec9e9bf414f8f2d.js +0 -12
- package/.next/static/chunks/app/(app)/agents/[handle]/page-14805dd54a1333e8.js +0 -1
- package/.next/static/chunks/app/(app)/code/page-7ebd6923ac440103.js +0 -1
- package/.next/static/chunks/app/(app)/config/page-47b5b62b73050673.js +0 -1
- package/.next/static/chunks/app/(app)/costs/page-969eba498344314d.js +0 -1
- package/.next/static/chunks/app/(app)/dashboard/page-59521ad116c60a88.js +0 -1
- package/.next/static/chunks/app/(app)/docs/[id]/page-b3451b21d7d2127b.js +0 -1
- package/.next/static/chunks/app/(app)/docs/page-3a34eec67591ce3e.js +0 -1
- package/.next/static/chunks/app/(app)/github/page-a0117637dc143821.js +0 -1
- package/.next/static/chunks/app/(app)/goals/page-d1cb2552625ccadb.js +0 -1
- package/.next/static/chunks/app/(app)/inbox/page-dbfc885cd61f9b9f.js +0 -12
- package/.next/static/chunks/app/(app)/knowledge/page-29df476a9c2f930c.js +0 -1
- package/.next/static/chunks/app/(app)/layout-2b6b23e82fbf0211.js +0 -1
- package/.next/static/chunks/app/(app)/models/page-ea54a5d167cd3cc2.js +0 -1
- package/.next/static/chunks/app/(app)/notifications/page-ef1ac55efadb2a1a.js +0 -12
- package/.next/static/chunks/app/(app)/org/page-a7c734b8d86f7641.js +0 -12
- package/.next/static/chunks/app/(app)/organizations/page-4bcec3010a9d9119.js +0 -1
- package/.next/static/chunks/app/(app)/planner/page-adfd05afc6ddcbef.js +0 -1
- package/.next/static/chunks/app/(app)/pm/page-773626398c10fdb7.js +0 -1
- package/.next/static/chunks/app/(app)/prepare-deploy/page-01f767248e7fa2a7.js +0 -1
- package/.next/static/chunks/app/(app)/profile/page-cb2450679785db1a.js +0 -1
- package/.next/static/chunks/app/(app)/reports/page-b0bcc85ad4afecf5.js +0 -1
- package/.next/static/chunks/app/(app)/routines/page-c0ce223d128a9010.js +0 -1
- package/.next/static/chunks/app/(app)/skills/page-87a71bd0a6b0f262.js +0 -1
- package/.next/static/chunks/app/(app)/tasks/page-a34a5658aff509ec.js +0 -1
- package/.next/static/chunks/app/(app)/test-dev/page-842f8771d36e964b.js +0 -1
- package/.next/static/chunks/app/(app)/update/page-64467fa6d8ed737e.js +0 -1
- package/.next/static/chunks/app/(auth)/login/page-82964b720ff11bab.js +0 -1
- package/.next/static/chunks/app/_not-found/page-489c316e4356f1b7.js +0 -1
- /package/.next/static/{Fx06n4huXV42eQUI-Lty0 → vaEtsAmUuKf_DngRqwRUn}/_buildManifest.js +0 -0
- /package/.next/static/{Fx06n4huXV42eQUI-Lty0 → vaEtsAmUuKf_DngRqwRUn}/_ssgManifest.js +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";(()=>{var a={};a.id=4094,a.ids=[4094],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")},5006:a=>{a.exports=import("@playwright/test")},9842:(a,b,c)=>{c.d(b,{IZ:()=>k,Ix:()=>j,ZF:()=>m,h6:()=>n,w1:()=>l});var d=c(1782),e=c(76760),f=c(80280),g=c(25533),h=c(18612),i=c(54033);function j(a,b){if(!b)return null;let c=(0,h.HZ)(a),d=((0,e.isAbsolute)(b)?(0,e.relative)(c,b):b).replace(/\\/g,"/");return!d||d.startsWith("..")||d.startsWith(".git/")||d.startsWith(".claude/")||d.startsWith("archives/")?null:d}async function k(a,b,c){let e=(0,d.Uo)((0,d.eq)(g.fileLock.workspaceId,a),(0,d.eq)(g.fileLock.path,b)),[h]=await f.db.select().from(g.fileLock).where(e);if(h){let a=!!c.taskId&&h.taskId===c.taskId,b=!h.taskId&&!!c.agentId&&h.agentId===c.agentId;return a||b?(await f.db.update(g.fileLock).set({heartbeatAt:new Date}).where(e),{ok:!0}):{ok:!1,heldBy:{handle:h.agentHandle,taskId:h.taskId}}}try{return await f.db.insert(g.fileLock).values({workspaceId:a,path:b,taskId:c.taskId||"",agentId:c.agentId||"",agentHandle:c.handle||"",acquiredAt:new Date,heartbeatAt:new Date}),{ok:!0}}catch{let[a]=await f.db.select().from(g.fileLock).where(e);if(a&&(a.taskId===c.taskId||a.agentId===c.agentId))return{ok:!0};return{ok:!1,heldBy:a?{handle:a.agentHandle,taskId:a.taskId}:void 0}}}async function l(a,b){if(b)try{let c=await f.db.select({path:g.fileLock.path}).from(g.fileLock).where((0,d.Uo)((0,d.eq)(g.fileLock.workspaceId,a),(0,d.eq)(g.fileLock.taskId,b)));for(let e of(await f.db.delete(g.fileLock).where((0,d.Uo)((0,d.eq)(g.fileLock.workspaceId,a),(0,d.eq)(g.fileLock.taskId,b))),c))await (0,i.W_)(a,"task",`lock:${e.path}`)}catch{}}async function m(a=3e5){try{await f.db.delete(g.fileLock).where((0,d.lt)(g.fileLock.heartbeatAt,new Date(Date.now()-a)))}catch{}}async function n(a){try{return await f.db.select({path:g.fileLock.path,agentHandle:g.fileLock.agentHandle,taskId:g.fileLock.taskId}).from(g.fileLock).where((0,d.eq)(g.fileLock.workspaceId,a))}catch{return[]}}},
|
|
1
|
+
"use strict";(()=>{var a={};a.id=4094,a.ids=[4094],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")},5006:a=>{a.exports=import("@playwright/test")},9842:(a,b,c)=>{c.d(b,{IZ:()=>k,Ix:()=>j,ZF:()=>m,h6:()=>n,w1:()=>l});var d=c(1782),e=c(76760),f=c(80280),g=c(25533),h=c(18612),i=c(54033);function j(a,b){if(!b)return null;let c=(0,h.HZ)(a),d=((0,e.isAbsolute)(b)?(0,e.relative)(c,b):b).replace(/\\/g,"/");return!d||d.startsWith("..")||d.startsWith(".git/")||d.startsWith(".claude/")||d.startsWith("archives/")?null:d}async function k(a,b,c){let e=(0,d.Uo)((0,d.eq)(g.fileLock.workspaceId,a),(0,d.eq)(g.fileLock.path,b)),[h]=await f.db.select().from(g.fileLock).where(e);if(h){let a=!!c.taskId&&h.taskId===c.taskId,b=!h.taskId&&!!c.agentId&&h.agentId===c.agentId;return a||b?(await f.db.update(g.fileLock).set({heartbeatAt:new Date}).where(e),{ok:!0}):{ok:!1,heldBy:{handle:h.agentHandle,taskId:h.taskId}}}try{return await f.db.insert(g.fileLock).values({workspaceId:a,path:b,taskId:c.taskId||"",agentId:c.agentId||"",agentHandle:c.handle||"",acquiredAt:new Date,heartbeatAt:new Date}),{ok:!0}}catch{let[a]=await f.db.select().from(g.fileLock).where(e);if(a&&(a.taskId===c.taskId||a.agentId===c.agentId))return{ok:!0};return{ok:!1,heldBy:a?{handle:a.agentHandle,taskId:a.taskId}:void 0}}}async function l(a,b){if(b)try{let c=await f.db.select({path:g.fileLock.path}).from(g.fileLock).where((0,d.Uo)((0,d.eq)(g.fileLock.workspaceId,a),(0,d.eq)(g.fileLock.taskId,b)));for(let e of(await f.db.delete(g.fileLock).where((0,d.Uo)((0,d.eq)(g.fileLock.workspaceId,a),(0,d.eq)(g.fileLock.taskId,b))),c))await (0,i.W_)(a,"task",`lock:${e.path}`)}catch{}}async function m(a=3e5){try{await f.db.delete(g.fileLock).where((0,d.lt)(g.fileLock.heartbeatAt,new Date(Date.now()-a)))}catch{}}async function n(a){try{return await f.db.select({path:g.fileLock.path,agentHandle:g.fileLock.agentHandle,taskId:g.fileLock.taskId}).from(g.fileLock).where((0,d.eq)(g.fileLock.workspaceId,a))}catch{return[]}}},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")},31260:(a,b,c)=>{c.r(b),c.d(b,{"000538e55e8863eaca825d1e70174f3b72909185dd":()=>d.S8,"0008fef7b5b0a23492aed2eae98ac089bc86a3749a":()=>d.kb,"000fcfa407fbc51cd18133f3da1a459d4af6a9cc5d":()=>d.lC,"0018a0b5673bbc76c6d3f1cd6227d9049cd889b4dd":()=>d.Vr,"001ed4036bfa17b014cd406df39e211a50abdd9a98":()=>d.ts,"001f4dcdd1414de6334ce51e096abef12cce715d5f":()=>d.Gh,"0031ec1fcd2b5c12cb587c24d3bbcfdc45eb9dc8de":()=>d.Ac,"005af5ec007b7a6b841445fecaae31d2f1f7cad0aa":()=>d.nl,"005f347999dc4767ce93bb5bbebb2851b83bdb9327":()=>d.zO,"0082098556d4302c4ed6e0da7abc7b94fe4af2e882":()=>d.LU,"00a70c56acf4c711aa29d2631a0222418222d1d062":()=>d.VH,"00c30495871ff89d3218dddc9898738136dce97eb7":()=>d.Jw,"00dd33de1b3f55c4c1cbb341355d491ec6ea77ef4e":()=>d.V$,"00eb5c7c203b16c670c3f42ff424497240d7aaa63e":()=>d.Hi,"00ecc40b1a1f7711705174bdf2c7b6328f702a4267":()=>d.Uw,"400a3dd0ee8892f66a2e5604d6581fd23aa7a3cea5":()=>d.m,"400cb1f7d10be86025c029db9f8bae23f7c7496000":()=>d.cm,"401d32cbbd01c648cd56431798e978dfb425ec9e0b":()=>d.ju,"4026c880b44f2f21469a370f44f00cea0f670f3177":()=>d.I2,"4066e2a6e63fba23fc4c7e9e862f4f153d28402e09":()=>d.wp,"407bc313c8bc4b1e7c1c1364fcd5b440b84872e9f8":()=>d.az,"40942bd62c47b06c00ffb8344c05ad1b197e87f0f4":()=>g.AO,"40a0f7f5fe75a32505a82aac16e0807cfdf7d344a1":()=>g.uR,"40b9cc92ffb5f4bf229890566ae068edf9090218a8":()=>g.iw,"40c072a0683ed78fc4617b255c94c2e1a237fcbc75":()=>g.xf,"40cbef8c22d0da6e4a36a8672c3bcb5fe20b5490a8":()=>d.Cp,"40dc8e68ecfa17e5b1a121e933261a7040870dd962":()=>g.Po,"40e73a917991bf0aac3c46efce7b609433595db67f":()=>e.mg,"40e8df75e45bb28a0912a0d3788e77e37f502b8092":()=>g.EC,"40eb39b1171f1395549f8ea5615c2ec3f79f8e6206":()=>g.WU,"40ef6a371c8208468fa32c33091775b5aeb9c2ea9d":()=>g.x1,"40f3f2d02634be4fdb0104759d54900ef00b744064":()=>d.L0,"6063c4c04607bdff1f0b6dc3e695d6d838fa41dc0f":()=>g.aO,"60c90060eb97b05811e1cc6d6b7612c92c3560e129":()=>f.I,"60d913024db5bfa98065eac4cd36d9448b6edf6bc9":()=>e.eA,"60f0bea5ddad11025dc93938ce3faf0f92f28b665a":()=>f.k,"700e75ff9f4413bd6246cd5b30074325cb53225a6a":()=>e.LV});var d=c(27989),e=c(76862),f=c(78848),g=c(56493)},31421:a=>{a.exports=require("node:child_process")},33873:a=>{a.exports=require("path")},37067:a=>{a.exports=require("node:http")},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},46466:a=>{a.exports=require("node:stream/promises")},47860:(a,b,c)=>{c.d(b,{CJ:()=>k,fQ:()=>i,hW:()=>j});var d=c(80280),e=c(25533),f=c(1782),g=c(55511),h=c(18612);let i=9e4;async function j(a,b,c={}){let h=new Date,i=c.ok??!0;return await d.db.insert(e.pulse).values({id:(0,g.randomUUID)(),workspaceId:a,agentId:b,at:h,ok:i,latencyMs:c.latencyMs??0,note:c.note??""}),await d.db.update(e.agent).set({lastPulse:h,health:i?"alive":"stale"}).where((0,f.eq)(e.agent.id,b)),h}async function k(a,b){let c=await d.db.query.agent.findMany({where:(0,f.eq)(e.agent.workspaceId,a)}),g=[];for(let a of c){let{intervalSec:c,maxMissed:i}=function(a,b){let c=(0,h.sL)(a,`.claude/agents/${b}/pulse.md`)??"";return{intervalSec:parseInt(c.match(/intervalSec:\s*(\d+)/)?.[1]??"30",10)||30,maxMissed:parseInt(c.match(/maxMissed:\s*(\d+)/)?.[1]??"2",10)||2}}(b,a.handle),j=c*i*1e3,k=3*j,l=function(a,b,c){if(!a)return"down";let d=Date.now()-a.getTime();return d<=b?"alive":d<=c?"stale":"down"}(a.lastPulse??null,j,k);l!==a.health&&await d.db.update(e.agent).set({health:l}).where((0,f.eq)(e.agent.id,a.id)),g.push({a,health:l})}let i=new Date().toISOString(),j=`# Agent status
|
|
2
2
|
|
|
3
3
|
_Updated by the pulse sweep at ${i}._
|
|
4
4
|
|
|
@@ -9,7 +9,7 @@ _Updated by the pulse sweep at ${i}._
|
|
|
9
9
|
- Updated: ${i}
|
|
10
10
|
- Agents: ${g.length} (alive ${k.alive} \xb7 stale ${k.stale} \xb7 down ${k.down})
|
|
11
11
|
- Workspace config: ${l?"present":"MISSING"}
|
|
12
|
-
`;try{(0,h.dx)(b,"Reports/agent-status.md",j),(0,h.dx)(b,"Reports/system-health.md",m)}catch{}}},48161:a=>{a.exports=require("node:os")},51455:a=>{a.exports=require("node:fs/promises")},55511:a=>{a.exports=require("crypto")},56493:(a,b,c)=>{c.d(b,{aO:()=>H,AO:()=>M,EC:()=>O,uR:()=>L,Po:()=>J,iw:()=>P,xf:()=>Q,x1:()=>I,WU:()=>N});var d=c(52813),e=c(77598),f=c(1782),g=c(83550),h=c(80280),i=c(25533),j=c(95896),k=c(28969),l=c(55614),m=c(3188);async function n(a,b,c=12e3){let d=new AbortController,e=setTimeout(()=>d.abort(),c);try{let c,e=await fetch(a,{headers:b,signal:d.signal}),f=await e.text();try{c=JSON.parse(f)}catch{c=void 0}return{ok:e.ok,status:e.status,json:c,error:e.ok?void 0:f.slice(0,200)||e.statusText}}catch(a){return{ok:!1,status:0,error:a instanceof Error?a.message:String(a)}}finally{clearTimeout(e)}}function o(a){return a&&"object"==typeof a?Array.isArray(a.data)?a.data.length:Array.isArray(a.models)?a.models.length:0:0}async function p(a,b){let c=a.defaultAdapter;if(c.startsWith("cli_")){let a=(0,m.hW)(c);return await (0,m.$g)(a)?{ok:!0,count:(m.w5[c]??m.w5.cli_claude_code).length}:{ok:!1,count:0,error:`${a} CLI not found on PATH`}}if("local_ollama"===c||"ollama"===a.id||"ollama_openai"===a.id){let b=a.baseUrl||"http://127.0.0.1:11434",c=await n(b.replace(/\/$/,"")+"/api/tags",{});return c.ok?{ok:!0,count:o(c.json)}:{ok:!1,count:0,error:c.error||"Ollama not reachable at "+b}}if("local_runtime"===a.category){let c=a.baseUrl||"http://127.0.0.1:8080",d=await n(c.replace(/\/$/,"")+"/v1/models",b?{Authorization:"Bearer "+b}:{});return d.ok?{ok:!0,count:o(d.json)}:{ok:!1,count:0,error:d.error||"local runtime not reachable"}}if(!b)return{ok:!1,count:0,error:"no API key in vault — connect with a key first"};if("http_anthropic"===c||"anthropic"===a.id){let a=await n("https://api.anthropic.com/v1/models",{"x-api-key":b,"anthropic-version":"2023-06-01"});return a.ok?{ok:!0,count:o(a.json)}:{ok:!1,count:0,error:a.error||"auth failed ("+a.status+")"}}let d=(a.baseUrl||"https://api.openai.com/v1").replace(/\/$/,""),e=d.endsWith("/models")?d:d+(d.includes("/v1")?"/models":"/v1/models"),f=await n(e,{Authorization:"Bearer "+b});return f.ok?{ok:!0,count:o(f.json)}:{ok:!1,count:0,error:f.error||"auth failed ("+f.status+")"}}var q=c(73024),r=c(76760),s=c(18612);let t={anthropic:"anthropic",openai:"openai",google_gemini:"google",xai_grok:"xai",deepseek:"deepseek",cohere:"cohere",groq:"groq",nvidia_nim:"nvidia",together:"togetherai",fireworks:"fireworks-ai",cerebras:"cerebras",perplexity:"perplexity",openrouter:"openrouter",mistral:"mistral",moonshot:"moonshotai",dashscope:"alibaba",zhipu:"zhipuai",azure_openai:"azure",aws_bedrock:"amazon-bedrock",vertex_ai:"google-vertex",claude_code:"anthropic",gemini_cli:"google"};function u(a){return t[a]?t[a]:a.replace(/_(grok|gemini|nim|cli|openai|api|server|rt)$/g,"").replace(/_/g,"-")}let v={anthropic:["sonnet-4","sonnet","opus-4","opus"],openai:["gpt-5.2","gpt-5.1","gpt-5","gpt-4.1","o4"],google:["gemini-3-pro","gemini-3","gemini-2.5-pro","pro"],xai:["grok-4","grok-3","grok"],groq:["llama-4","llama-3.3","llama-3.1"],deepseek:["deepseek-chat","deepseek-v3","deepseek-reasoner"],mistral:["mistral-large","mistral-medium"],openrouter:["claude-sonnet","gpt-5","gemini"]},w=(a,b,c,d,e,f,g,h)=>({id:a,name:b,context:c,outputLimit:d,inputCost:e,outputCost:f,caps:{reasoning:!!g.reasoning,tools:!!g.tools,vision:!!g.vision},released:h}),x={anthropic:[w("claude-opus-4-8","Claude Opus 4.8",1e6,64e3,5,25,{reasoning:!0,tools:!0,vision:!0},"2026-02-01"),w("claude-opus-4-7","Claude Opus 4.7",1e6,64e3,5,25,{reasoning:!0,tools:!0,vision:!0},"2025-12-01"),w("claude-sonnet-4-6","Claude Sonnet 4.6",1e6,64e3,3,15,{reasoning:!0,tools:!0,vision:!0},"2026-01-15"),w("claude-haiku-4-5","Claude Haiku 4.5",2e5,32e3,1,5,{tools:!0,vision:!0},"2025-10-01")],openai:[w("gpt-5.2","GPT-5.2",4e5,128e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2026-03-01"),w("gpt-5.1","GPT-5.1",4e5,128e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2025-12-01"),w("gpt-5","GPT-5",4e5,128e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2025-08-01"),w("o4-mini","o4-mini",2e5,1e5,1.1,4.4,{reasoning:!0,tools:!0},"2025-04-01")],google:[w("gemini-3-pro","Gemini 3 Pro",2e6,64e3,2,12,{reasoning:!0,tools:!0,vision:!0},"2026-02-01"),w("gemini-3-flash","Gemini 3 Flash",1e6,64e3,.3,2.5,{tools:!0,vision:!0},"2026-02-01"),w("gemini-2.5-pro","Gemini 2.5 Pro",2e6,64e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2025-06-01")],xai:[w("grok-4.3","Grok 4.3",256e3,64e3,3,15,{reasoning:!0,tools:!0,vision:!0},"2026-02-01"),w("grok-4","Grok 4",256e3,64e3,3,15,{reasoning:!0,tools:!0,vision:!0},"2025-09-01"),w("grok-3","Grok 3",131072,32e3,3,15,{tools:!0,vision:!0},"2025-02-01")],deepseek:[w("deepseek-chat","DeepSeek Chat",128e3,8e3,.27,1.1,{tools:!0},"2025-12-01"),w("deepseek-reasoner","DeepSeek Reasoner",128e3,64e3,.55,2.19,{reasoning:!0,tools:!0},"2025-12-01")],groq:[w("llama-4-scout","Llama 4 Scout",131072,8e3,.11,.34,{tools:!0,vision:!0},"2025-04-01"),w("llama-3.3-70b","Llama 3.3 70B",131072,32e3,.59,.79,{tools:!0},"2024-12-01")]},y=null;function z(){return(0,r.join)((0,s.r$)(),"cache","models-dev.json")}async function A(){try{let a=await fetch("https://models.dev/api.json",{signal:AbortSignal.timeout(1e4),headers:{accept:"application/json"}});if(!a.ok)return null;let b=await a.json();if(!b||"object"!=typeof b)return null;let c={};for(let[a,d]of Object.entries(b)){let b=d?.models,e=function(a){if(!a||"object"!=typeof a)return[];let b=[];for(let[c,d]of Object.entries(a)){let a=d??{},e=String(a.id??c),f=e.includes("/")?e.split("/").pop():e;if(!f)continue;let g=a.modalities??{},h=Array.isArray(g.input)?g.input:[],i=a.limit??{},j=a.cost??{},k={reasoning:!0===a.reasoning,tools:!0===a.tool_call,vision:!0===a.attachment||h.includes("image")};b.push({id:f,name:String(a.name??f),context:Number(i.context??0)||0,outputLimit:Number(i.output??0)||0,inputCost:Number(j.input??0)||0,outputCost:Number(j.output??0)||0,caps:k,released:"string"==typeof a.release_date?a.release_date:""})}return b}(b);e.length&&(c[a]=e)}return Object.keys(c).length?c:null}catch{return null}}async function B(){if(y&&Date.now()-y.at<864e5)return y.data;let a=function(){try{let a=z();if(!(0,q.existsSync)(a))return null;let b=JSON.parse((0,q.readFileSync)(a,"utf8"));if(!b?.data||"object"!=typeof b.data)return null;return{at:Number(b.at??(0,q.statSync)(a).mtimeMs),data:b.data}}catch{return null}}();if(a&&Date.now()-a.at<864e5)return y=a,a.data;let b=await A();if(b){y={at:Date.now(),data:b};try{(0,q.mkdirSync)((0,r.join)((0,s.r$)(),"cache"),{recursive:!0}),(0,q.writeFileSync)(z(),JSON.stringify({at:Date.now(),data:b}),"utf8")}catch{}return b}return a?(y=a,a.data):{}}async function C(a){let b=u(a),c=await B();return c[b]?.length?c[b]:x[b]??[]}async function D(a,b,c=9e3){try{let d=await fetch(a,{headers:b,signal:AbortSignal.timeout(c)});if(!d.ok)return null;return await d.json()}catch{return null}}async function E(a){let{catalogId:b,adapter:c,baseUrl:d,apiKey:e}=a;if(c.startsWith("cli_"))return"cli_opencode"===c?(await (0,m.ZB)("opencode")).map(a=>({id:a})):"cli_aider"===c?(await (0,m.ZB)("aider")).map(a=>({id:a})):null;if(/ollama/i.test(b)||c.includes("ollama")){let a=(d||"http://127.0.0.1:11434").replace(/\/$/,"").replace(/\/v1$/,""),b=await D(`${a}/api/tags`,{});return b?(b.models??[]).map(a=>({id:String(a.name??"")})).filter(a=>a.id):[]}if(!d)return null;let f=d.replace(/\/$/,""),g="http_anthropic"===c||"anthropic"===b,h=g?"https://api.anthropic.com/v1/models":f.endsWith("/models")?f:f+(f.includes("/v1")?"/models":"/v1/models"),i=g?e?{"x-api-key":e,"anthropic-version":"2023-06-01"}:{}:e?{authorization:`Bearer ${e}`}:{},j=await D(h,i);return j?(Array.isArray(j.data)?j.data:Array.isArray(j.models)?j.models:[]).map(a=>{let b=String(a.id??a.name??"");if(!b)return null;let c={id:b};"string"==typeof a.display_name?c.name=a.display_name:"string"==typeof a.name&&(c.name=a.name),"number"==typeof a.context_length&&(c.context=a.context_length);let d=a.pricing;if(d){let a=Number(d.prompt),b=Number(d.completion);Number.isFinite(a)&&a>0&&(c.inputCost=1e6*a),Number.isFinite(b)&&b>0&&(c.outputCost=1e6*b)}return c}).filter(a=>!!a).slice(0,200):[]}async function F(){let a=await B(),b=new Map;for(let c of Object.values(a))for(let a of c){let c=a.id.toLowerCase();b.has(c)||b.set(c,a)}return b}async function G(a,b){let c=await C(a);if(!b||0===b.length)return c;let d=new Map;for(let a of c)d.set(a.id.toLowerCase(),a);let e=await F(),f=a=>{let b=a.toLowerCase(),c=a.includes("/")?a.split("/").pop().toLowerCase():b;return d.get(b)??d.get(c)??e.get(b)??e.get(c)},g=[];for(let a of b){let b=f(a.id);g.push({id:a.id,name:a.name||b?.name||a.id,context:a.context??b?.context??0,outputLimit:b?.outputLimit??0,inputCost:a.inputCost??b?.inputCost??0,outputCost:a.outputCost??b?.outputCost??0,caps:b?.caps??{reasoning:!1,tools:!1,vision:!1},released:b?.released??""})}return g}async function H(a,b){let{workspace:c}=await (0,j.nP)(),d=(0,l.kH)(a);if(!d)return;let f=(0,e.randomUUID)();await h.db.insert(i.provider).values({id:f,workspaceId:c.id,catalogId:a,adapter:d.defaultAdapter,kind:"cli"===d.category?"cli":"local_runtime"===d.category?"local":"cloud",auth:d.connectionTypes.includes("api_key")?"api_key":d.connectionTypes[0],status:"needs_sync",syncStatus:d.supportsModelSync?"implemented":"manual"}),b&&await (0,k.IW)(c.id,`${a}_api_key`,b,f),(0,g.revalidatePath)("/models"),await I(f)}async function I(a){let b,{workspace:c}=await (0,j.nP)(),[d]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,c.id)));if(!d)return{ok:!1,error:"not found"};let e=(0,l.kH)(d.catalogId);if(!e)return{ok:!1,error:"unknown provider"};let n=await (0,k.r6)(c.id,`${d.catalogId}_api_key`),o=await p(e,n),q=null;if("cli"===e.category){let a=(0,m.hW)(e.defaultAdapter);b=(q=await (0,m.$g)(a).catch(()=>null))?await (0,m.Kp)(a).catch(()=>"unknown"):"needs_login"}else b="local_runtime"===e.category?o.ok?"ready":"unknown":n&&o.ok?"ready":"needs_key";return await h.db.update(i.provider).set({status:o.ok?"connected":"error",modelCount:o.count,lastSync:new Date,cliVersion:q,authState:b}).where((0,f.eq)(i.provider.id,a)),o.ok&&await J(a).catch(()=>{}),(0,g.revalidatePath)("/models"),o}async function J(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));if(!c)return{ok:!1,count:0,error:"not found"};let d=await K(c);return(0,g.revalidatePath)("/models"),d}async function K(a){let b,c,d,g=(0,l.kH)(a.catalogId);if(!g)return{ok:!1,count:0,error:"unknown provider"};let j=await (0,k.r6)(a.workspaceId,`${a.catalogId}_api_key`),n="cli"===g.category;try{b=await E({catalogId:a.catalogId,adapter:a.adapter,baseUrl:g.baseUrl,apiKey:j})}catch{b=null}if(n){let e=(0,m.hW)(a.adapter);d=(c=await (0,m.$g)(e).catch(()=>null))?await (0,m.Kp)(e).catch(()=>"unknown"):"needs_login",null===b&&(b=(m.w5[a.adapter]??[]).filter(a=>"(default)"!==a).map(a=>({id:a})))}if(null===b)return{ok:!0,count:0};let o=await G(a.catalogId,b),p=new Date,q=o.length?function(a,b){if(!b.length)return"";let c=v[u(a)];if(c)for(let a of c){let c=b.filter(b=>b.id.toLowerCase().includes(a));if(c.length)return c.sort((a,b)=>(b.released||"").localeCompare(a.released||"")),c[0].id}let d=b.filter(a=>a.released);return d.length?(d.sort((a,b)=>b.released.localeCompare(a.released)),d[0].id):b[0].id}(a.catalogId,o):null;if(o.length)await h.db.delete(i.providerModel).where((0,f.eq)(i.providerModel.providerId,a.id)),await h.db.insert(i.providerModel).values(o.map(b=>({id:(0,e.randomUUID)(),workspaceId:a.workspaceId,providerId:a.id,catalogId:a.catalogId,modelId:b.id,name:b.name,context:b.context,outputLimit:b.outputLimit,inputCost:b.inputCost,outputCost:b.outputCost,caps:b.caps,released:b.released,isDefault:b.id===q,lastSeen:p})));else if(!n)return{ok:!1,count:0,error:"no models returned"};let r=n&&!c?"needs_sync":"connected";return await h.db.update(i.provider).set({status:r,modelCount:o.length||(n?a.modelCount:0),lastSync:p,defaultModel:q||a.defaultModel,...n?{cliVersion:c??null,authState:d??null}:{}}).where((0,f.eq)(i.provider.id,a.id)),{ok:!0,count:o.length}}async function L(a=12){let b,c=new Date(Date.now()-60*a*6e4);try{b=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.status,"connected"),(0,f.or)((0,f.kZ)(i.provider.lastSync),(0,f.lt)(i.provider.lastSync,c))))}catch{return{refreshed:0}}let d=0;for(let a of b.slice(0,50))try{let b=await K(a);b.ok&&b.count>0&&d++}catch{}return{refreshed:d}}async function M(a){let{workspace:b}=await (0,j.nP)(),c=(await h.db.select().from(i.providerModel).where((0,f.Uo)((0,f.eq)(i.providerModel.providerId,a),(0,f.eq)(i.providerModel.workspaceId,b.id)))).map(a=>({id:a.modelId,name:a.name,context:a.context,outputLimit:a.outputLimit,inputCost:a.inputCost,outputCost:a.outputCost,caps:a.caps??{reasoning:!1,tools:!1,vision:!1},released:a.released,isDefault:a.isDefault}));return c.sort((a,b)=>Number(b.isDefault)-Number(a.isDefault)||(b.released||"").localeCompare(a.released||"")||a.name.localeCompare(b.name)),{models:c}}async function N(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));if(!c)return{ok:!1,error:"not found"};let d=(0,l.kH)(c.catalogId);if(!d)return{ok:!1,error:"unknown provider"};let e=await (0,k.r6)(b.id,`${c.catalogId}_api_key`),m=await p(d,e);return await h.db.update(i.provider).set({status:m.ok?"connected":"error"}).where((0,f.eq)(i.provider.id,a)),(0,g.revalidatePath)("/models"),{ok:m.ok,error:m.error}}async function O(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));if(!c)return{models:[],error:"not found"};let d=(0,l.kH)(c.catalogId);if(!d?.baseUrl)return{models:[],error:"no public endpoint for this provider"};let e=await (0,k.r6)(b.id,`${c.catalogId}_api_key`),g=d.baseUrl.replace(/\/$/,"");try{let a=/ollama/i.test(c.catalogId)||c.adapter.includes("ollama")?`${g.replace(/\/v1$/,"")}/api/tags`:`${g}/models`,b=await fetch(a,{headers:e?{authorization:`Bearer ${e}`}:{},signal:AbortSignal.timeout(8e3)});if(!b.ok)return{models:[],error:`endpoint ${b.status}`};let d=await b.json();return{models:(d.data??d.models??[]).map(a=>a.id??a.name??"").filter(Boolean).slice(0,80)}}catch(b){let a=String(b instanceof Error?b.message:b);return{models:[],error:/abort|fetch failed|ECONN/i.test(a)?"endpoint unreachable":a}}}async function P(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));c&&await (0,k.Kh)(b.id,`${c.catalogId}_api_key`),await h.db.delete(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id))),(0,g.revalidatePath)("/models")}async function Q(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));c&&(await (0,k.Kh)(b.id,`${c.catalogId}_api_key`),await h.db.update(i.provider).set({auth:"none",status:"needs_sync",modelCount:0}).where((0,f.eq)(i.provider.id,a)),(0,g.revalidatePath)("/models"))}(0,c(29635).D)([H,I,J,L,M,N,O,P,Q]),(0,d.A)(H,"602c37790e97bc1504b991123267e14b6b876d9572",null),(0,d.A)(I,"409e1308b3400804a39abe1187b45c4216cb1dc1bc",null),(0,d.A)(J,"40d25df2aef03f20f3f6d22911d5e656a18ff3865e",null),(0,d.A)(L,"40fd4c7e376405b607f0b5bbf22cea4daaa78ef878",null),(0,d.A)(M,"40cae6ca72d49d4588d84cb2c59de457c7157a788a",null),(0,d.A)(N,"40a7371fe0b2319ab344164d505a275918d2b488ea",null),(0,d.A)(O,"405061dc6346f5a7f9985340a32516015cf4963640",null),(0,d.A)(P,"40b9490d6adb9fbe142e3fd463e09a3820aeafcd14",null),(0,d.A)(Q,"40046656a90abff559d871d0a93d7c61f8a990b68f",null)},57075:a=>{a.exports=require("node:stream")},61419:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>aM,patchFetch:()=>aL,routeModule:()=>aH,serverHooks:()=>aK,workAsyncStorage:()=>aI,workUnitAsyncStorage:()=>aJ});var d={};c.r(d),c.d(d,{POST:()=>aG});var e=c(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(80280),x=c(25533),y=c(1782),z=c(89611),A=c(55511),B=c(47860),C=c(3188),D=c(34302),E=c(26288),F=c(82550),G=c(6404),H=c(99546),I=c(12867),J=c(6873);let K=["developer.mozilla.org","web.dev","owasp.org","cheatsheetseries.owasp.org","www.w3.org","docs.python.org","nodejs.org","go.dev","doc.rust-lang.org","kubernetes.io","docs.docker.com","www.npmjs.com","pypi.org"];async function L(a,b,c,d){var e;let f;try{f=new URL(c)}catch{return{ok:!1,reason:"invalid url"}}if("https:"!==f.protocol&&"http:"!==f.protocol)return{ok:!1,reason:"non-http url"};let g=new Set([...K,...(0,J.et)(b)].map(a=>a.toLowerCase()));if(!function(a,b){let c=a.toLowerCase().replace(/\.$/,"");for(let a of b)if(c===a||c.endsWith("."+a))return!0;return!1}(f.host,g))return{ok:!1,reason:`host not on the official-docs allowlist (${f.host})`};let h="";try{let a=new AbortController,b=setTimeout(()=>a.abort(),15e3),c=await fetch(f.toString(),{signal:a.signal,redirect:"follow",headers:{"user-agent":"Constella-Research/1.0",accept:"text/html,application/xhtml+xml,*/*"}});if(clearTimeout(b),!c.ok)return{ok:!1,reason:`http ${c.status}`};if(!/text\/|html|xml|json/i.test(c.headers.get("content-type")??""))return{ok:!1,reason:"non-text content"};h=(await c.text()).slice(0,15e5)}catch(a){return{ok:!1,reason:String(a instanceof Error?a.message:a).slice(0,120)}}let{title:i,text:j}=(e=h,{title:e.match(/<title[^>]*>([\s\S]*?)<\/title>/i)?.[1]?.replace(/\s+/g," ").trim()??"",text:e.replace(/<script[\s\S]*?<\/script>/gi," ").replace(/<style[\s\S]*?<\/style>/gi," ").replace(/<\/(p|div|li|h[1-6]|tr|section|article)>/gi,"\n").replace(/<[^>]+>/g," ").replace(/ /g," ").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'|’|‘/g,"'").replace(/"|“|”/g,'"').replace(/[ \t]+/g," ").replace(/\n{3,}/g,"\n\n").trim()});return j.length<80?{ok:!1,reason:"empty page"}:(await (0,I.ru)(a,[{type:"doc",title:(i||`${f.host}${f.pathname}`).slice(0,200),summary:j.slice(0,1e3),body:`Official documentation — researched and cached for reuse.
|
|
12
|
+
`;try{(0,h.dx)(b,"Reports/agent-status.md",j),(0,h.dx)(b,"Reports/system-health.md",m)}catch{}}},48161:a=>{a.exports=require("node:os")},51455:a=>{a.exports=require("node:fs/promises")},55511:a=>{a.exports=require("crypto")},56493:(a,b,c)=>{c.d(b,{aO:()=>H,AO:()=>M,EC:()=>O,uR:()=>L,Po:()=>J,iw:()=>P,xf:()=>Q,x1:()=>I,WU:()=>N});var d=c(52813),e=c(77598),f=c(1782),g=c(83550),h=c(80280),i=c(25533),j=c(95896),k=c(28969),l=c(55614),m=c(3188);async function n(a,b,c=12e3){let d=new AbortController,e=setTimeout(()=>d.abort(),c);try{let c,e=await fetch(a,{headers:b,signal:d.signal}),f=await e.text();try{c=JSON.parse(f)}catch{c=void 0}return{ok:e.ok,status:e.status,json:c,error:e.ok?void 0:f.slice(0,200)||e.statusText}}catch(a){return{ok:!1,status:0,error:a instanceof Error?a.message:String(a)}}finally{clearTimeout(e)}}function o(a){return a&&"object"==typeof a?Array.isArray(a.data)?a.data.length:Array.isArray(a.models)?a.models.length:0:0}async function p(a,b){let c=a.defaultAdapter;if(c.startsWith("cli_")){let a=(0,m.hW)(c);return await (0,m.$g)(a)?{ok:!0,count:(m.w5[c]??m.w5.cli_claude_code).length}:{ok:!1,count:0,error:`${a} CLI not found on PATH`}}if("local_ollama"===c||"ollama"===a.id||"ollama_openai"===a.id){let b=a.baseUrl||"http://127.0.0.1:11434",c=await n(b.replace(/\/$/,"")+"/api/tags",{});return c.ok?{ok:!0,count:o(c.json)}:{ok:!1,count:0,error:c.error||"Ollama not reachable at "+b}}if("local_runtime"===a.category){let c=a.baseUrl||"http://127.0.0.1:8080",d=await n(c.replace(/\/$/,"")+"/v1/models",b?{Authorization:"Bearer "+b}:{});return d.ok?{ok:!0,count:o(d.json)}:{ok:!1,count:0,error:d.error||"local runtime not reachable"}}if(!b)return{ok:!1,count:0,error:"no API key in vault — connect with a key first"};if("http_anthropic"===c||"anthropic"===a.id){let a=await n("https://api.anthropic.com/v1/models",{"x-api-key":b,"anthropic-version":"2023-06-01"});return a.ok?{ok:!0,count:o(a.json)}:{ok:!1,count:0,error:a.error||"auth failed ("+a.status+")"}}let d=(a.baseUrl||"https://api.openai.com/v1").replace(/\/$/,""),e=d.endsWith("/models")?d:d+(d.includes("/v1")?"/models":"/v1/models"),f=await n(e,{Authorization:"Bearer "+b});return f.ok?{ok:!0,count:o(f.json)}:{ok:!1,count:0,error:f.error||"auth failed ("+f.status+")"}}var q=c(73024),r=c(76760),s=c(18612);let t={anthropic:"anthropic",openai:"openai",google_gemini:"google",xai_grok:"xai",deepseek:"deepseek",cohere:"cohere",groq:"groq",nvidia_nim:"nvidia",together:"togetherai",fireworks:"fireworks-ai",cerebras:"cerebras",perplexity:"perplexity",openrouter:"openrouter",mistral:"mistral",moonshot:"moonshotai",dashscope:"alibaba",zhipu:"zhipuai",azure_openai:"azure",aws_bedrock:"amazon-bedrock",vertex_ai:"google-vertex",claude_code:"anthropic",gemini_cli:"google"};function u(a){return t[a]?t[a]:a.replace(/_(grok|gemini|nim|cli|openai|api|server|rt)$/g,"").replace(/_/g,"-")}let v={anthropic:["sonnet-4","sonnet","opus-4","opus"],openai:["gpt-5.2","gpt-5.1","gpt-5","gpt-4.1","o4"],google:["gemini-3-pro","gemini-3","gemini-2.5-pro","pro"],xai:["grok-4","grok-3","grok"],groq:["llama-4","llama-3.3","llama-3.1"],deepseek:["deepseek-chat","deepseek-v3","deepseek-reasoner"],mistral:["mistral-large","mistral-medium"],openrouter:["claude-sonnet","gpt-5","gemini"]},w=(a,b,c,d,e,f,g,h)=>({id:a,name:b,context:c,outputLimit:d,inputCost:e,outputCost:f,caps:{reasoning:!!g.reasoning,tools:!!g.tools,vision:!!g.vision},released:h}),x={anthropic:[w("claude-opus-4-8","Claude Opus 4.8",1e6,64e3,5,25,{reasoning:!0,tools:!0,vision:!0},"2026-02-01"),w("claude-opus-4-7","Claude Opus 4.7",1e6,64e3,5,25,{reasoning:!0,tools:!0,vision:!0},"2025-12-01"),w("claude-sonnet-4-6","Claude Sonnet 4.6",1e6,64e3,3,15,{reasoning:!0,tools:!0,vision:!0},"2026-01-15"),w("claude-haiku-4-5","Claude Haiku 4.5",2e5,32e3,1,5,{tools:!0,vision:!0},"2025-10-01")],openai:[w("gpt-5.2","GPT-5.2",4e5,128e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2026-03-01"),w("gpt-5.1","GPT-5.1",4e5,128e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2025-12-01"),w("gpt-5","GPT-5",4e5,128e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2025-08-01"),w("o4-mini","o4-mini",2e5,1e5,1.1,4.4,{reasoning:!0,tools:!0},"2025-04-01")],google:[w("gemini-3-pro","Gemini 3 Pro",2e6,64e3,2,12,{reasoning:!0,tools:!0,vision:!0},"2026-02-01"),w("gemini-3-flash","Gemini 3 Flash",1e6,64e3,.3,2.5,{tools:!0,vision:!0},"2026-02-01"),w("gemini-2.5-pro","Gemini 2.5 Pro",2e6,64e3,1.25,10,{reasoning:!0,tools:!0,vision:!0},"2025-06-01")],xai:[w("grok-4.3","Grok 4.3",256e3,64e3,3,15,{reasoning:!0,tools:!0,vision:!0},"2026-02-01"),w("grok-4","Grok 4",256e3,64e3,3,15,{reasoning:!0,tools:!0,vision:!0},"2025-09-01"),w("grok-3","Grok 3",131072,32e3,3,15,{tools:!0,vision:!0},"2025-02-01")],deepseek:[w("deepseek-chat","DeepSeek Chat",128e3,8e3,.27,1.1,{tools:!0},"2025-12-01"),w("deepseek-reasoner","DeepSeek Reasoner",128e3,64e3,.55,2.19,{reasoning:!0,tools:!0},"2025-12-01")],groq:[w("llama-4-scout","Llama 4 Scout",131072,8e3,.11,.34,{tools:!0,vision:!0},"2025-04-01"),w("llama-3.3-70b","Llama 3.3 70B",131072,32e3,.59,.79,{tools:!0},"2024-12-01")]},y=null;function z(){return(0,r.join)((0,s.r$)(),"cache","models-dev.json")}async function A(){try{let a=await fetch("https://models.dev/api.json",{signal:AbortSignal.timeout(1e4),headers:{accept:"application/json"}});if(!a.ok)return null;let b=await a.json();if(!b||"object"!=typeof b)return null;let c={};for(let[a,d]of Object.entries(b)){let b=d?.models,e=function(a){if(!a||"object"!=typeof a)return[];let b=[];for(let[c,d]of Object.entries(a)){let a=d??{},e=String(a.id??c),f=e.includes("/")?e.split("/").pop():e;if(!f)continue;let g=a.modalities??{},h=Array.isArray(g.input)?g.input:[],i=a.limit??{},j=a.cost??{},k={reasoning:!0===a.reasoning,tools:!0===a.tool_call,vision:!0===a.attachment||h.includes("image")};b.push({id:f,name:String(a.name??f),context:Number(i.context??0)||0,outputLimit:Number(i.output??0)||0,inputCost:Number(j.input??0)||0,outputCost:Number(j.output??0)||0,caps:k,released:"string"==typeof a.release_date?a.release_date:""})}return b}(b);e.length&&(c[a]=e)}return Object.keys(c).length?c:null}catch{return null}}async function B(){if(y&&Date.now()-y.at<864e5)return y.data;let a=function(){try{let a=z();if(!(0,q.existsSync)(a))return null;let b=JSON.parse((0,q.readFileSync)(a,"utf8"));if(!b?.data||"object"!=typeof b.data)return null;return{at:Number(b.at??(0,q.statSync)(a).mtimeMs),data:b.data}}catch{return null}}();if(a&&Date.now()-a.at<864e5)return y=a,a.data;let b=await A();if(b){y={at:Date.now(),data:b};try{(0,q.mkdirSync)((0,r.join)((0,s.r$)(),"cache"),{recursive:!0}),(0,q.writeFileSync)(z(),JSON.stringify({at:Date.now(),data:b}),"utf8")}catch{}return b}return a?(y=a,a.data):{}}async function C(a){let b=u(a),c=await B();return c[b]?.length?c[b]:x[b]??[]}async function D(a,b,c=9e3){try{let d=await fetch(a,{headers:b,signal:AbortSignal.timeout(c)});if(!d.ok)return null;return await d.json()}catch{return null}}async function E(a){let{catalogId:b,adapter:c,baseUrl:d,apiKey:e}=a;if(c.startsWith("cli_"))return"cli_opencode"===c?(await (0,m.ZB)("opencode")).map(a=>({id:a})):"cli_aider"===c?(await (0,m.ZB)("aider")).map(a=>({id:a})):null;if(/ollama/i.test(b)||c.includes("ollama")){let a=(d||"http://127.0.0.1:11434").replace(/\/$/,"").replace(/\/v1$/,""),b=await D(`${a}/api/tags`,{});return b?(b.models??[]).map(a=>({id:String(a.name??"")})).filter(a=>a.id):[]}if(!d)return null;let f=d.replace(/\/$/,""),g="http_anthropic"===c||"anthropic"===b,h=g?"https://api.anthropic.com/v1/models":f.endsWith("/models")?f:f+(f.includes("/v1")?"/models":"/v1/models"),i=g?e?{"x-api-key":e,"anthropic-version":"2023-06-01"}:{}:e?{authorization:`Bearer ${e}`}:{},j=await D(h,i);return j?(Array.isArray(j.data)?j.data:Array.isArray(j.models)?j.models:[]).map(a=>{let b=String(a.id??a.name??"");if(!b)return null;let c={id:b};"string"==typeof a.display_name?c.name=a.display_name:"string"==typeof a.name&&(c.name=a.name),"number"==typeof a.context_length&&(c.context=a.context_length);let d=a.pricing;if(d){let a=Number(d.prompt),b=Number(d.completion);Number.isFinite(a)&&a>0&&(c.inputCost=1e6*a),Number.isFinite(b)&&b>0&&(c.outputCost=1e6*b)}return c}).filter(a=>!!a).slice(0,200):[]}async function F(){let a=await B(),b=new Map;for(let c of Object.values(a))for(let a of c){let c=a.id.toLowerCase();b.has(c)||b.set(c,a)}return b}async function G(a,b){let c=await C(a);if(!b||0===b.length)return c;let d=new Map;for(let a of c)d.set(a.id.toLowerCase(),a);let e=await F(),f=a=>{let b=a.toLowerCase(),c=a.includes("/")?a.split("/").pop().toLowerCase():b;return d.get(b)??d.get(c)??e.get(b)??e.get(c)},g=[];for(let a of b){let b=f(a.id);g.push({id:a.id,name:a.name||b?.name||a.id,context:a.context??b?.context??0,outputLimit:b?.outputLimit??0,inputCost:a.inputCost??b?.inputCost??0,outputCost:a.outputCost??b?.outputCost??0,caps:b?.caps??{reasoning:!1,tools:!1,vision:!1},released:b?.released??""})}return g}async function H(a,b){let{workspace:c}=await (0,j.nP)(),d=(0,l.kH)(a);if(!d)return;let f=(0,e.randomUUID)();await h.db.insert(i.provider).values({id:f,workspaceId:c.id,catalogId:a,adapter:d.defaultAdapter,kind:"cli"===d.category?"cli":"local_runtime"===d.category?"local":"cloud",auth:d.connectionTypes.includes("api_key")?"api_key":d.connectionTypes[0],status:"needs_sync",syncStatus:d.supportsModelSync?"implemented":"manual"}),b&&await (0,k.IW)(c.id,`${a}_api_key`,b,f),(0,g.revalidatePath)("/models"),await I(f)}async function I(a){let b,{workspace:c}=await (0,j.nP)(),[d]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,c.id)));if(!d)return{ok:!1,error:"not found"};let e=(0,l.kH)(d.catalogId);if(!e)return{ok:!1,error:"unknown provider"};let n=await (0,k.r6)(c.id,`${d.catalogId}_api_key`),o=await p(e,n),q=null;if("cli"===e.category){let a=(0,m.hW)(e.defaultAdapter);b=(q=await (0,m.$g)(a).catch(()=>null))?await (0,m.Kp)(a).catch(()=>"unknown"):"needs_login"}else b="local_runtime"===e.category?o.ok?"ready":"unknown":n&&o.ok?"ready":"needs_key";return await h.db.update(i.provider).set({status:o.ok?"connected":"error",modelCount:o.count,lastSync:new Date,cliVersion:q,authState:b}).where((0,f.eq)(i.provider.id,a)),o.ok&&await J(a).catch(()=>{}),(0,g.revalidatePath)("/models"),o}async function J(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));if(!c)return{ok:!1,count:0,error:"not found"};let d=await K(c);return(0,g.revalidatePath)("/models"),d}async function K(a){let b,c,d,g=(0,l.kH)(a.catalogId);if(!g)return{ok:!1,count:0,error:"unknown provider"};let j=await (0,k.r6)(a.workspaceId,`${a.catalogId}_api_key`),n="cli"===g.category;try{b=await E({catalogId:a.catalogId,adapter:a.adapter,baseUrl:g.baseUrl,apiKey:j})}catch{b=null}if(n){let e=(0,m.hW)(a.adapter);d=(c=await (0,m.$g)(e).catch(()=>null))?await (0,m.Kp)(e).catch(()=>"unknown"):"needs_login",null===b&&(b=(m.w5[a.adapter]??[]).filter(a=>"(default)"!==a).map(a=>({id:a})))}if(null===b)return{ok:!0,count:0};let o=await G(a.catalogId,b),p=new Date,q=o.length?function(a,b){if(!b.length)return"";let c=v[u(a)];if(c)for(let a of c){let c=b.filter(b=>b.id.toLowerCase().includes(a));if(c.length)return c.sort((a,b)=>(b.released||"").localeCompare(a.released||"")),c[0].id}let d=b.filter(a=>a.released);return d.length?(d.sort((a,b)=>b.released.localeCompare(a.released)),d[0].id):b[0].id}(a.catalogId,o):null;if(o.length)await h.db.delete(i.providerModel).where((0,f.eq)(i.providerModel.providerId,a.id)),await h.db.insert(i.providerModel).values(o.map(b=>({id:(0,e.randomUUID)(),workspaceId:a.workspaceId,providerId:a.id,catalogId:a.catalogId,modelId:b.id,name:b.name,context:b.context,outputLimit:b.outputLimit,inputCost:b.inputCost,outputCost:b.outputCost,caps:b.caps,released:b.released,isDefault:b.id===q,lastSeen:p})));else if(!n)return{ok:!1,count:0,error:"no models returned"};let r=n&&!c?"needs_sync":"connected";return await h.db.update(i.provider).set({status:r,modelCount:o.length||(n?a.modelCount:0),lastSync:p,defaultModel:q||a.defaultModel,...n?{cliVersion:c??null,authState:d??null}:{}}).where((0,f.eq)(i.provider.id,a.id)),{ok:!0,count:o.length}}async function L(a=12){let b,c=new Date(Date.now()-60*a*6e4);try{b=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.status,"connected"),(0,f.or)((0,f.kZ)(i.provider.lastSync),(0,f.lt)(i.provider.lastSync,c))))}catch{return{refreshed:0}}let d=0;for(let a of b.slice(0,50))try{let b=await K(a);b.ok&&b.count>0&&d++}catch{}return{refreshed:d}}async function M(a){let{workspace:b}=await (0,j.nP)(),c=(await h.db.select().from(i.providerModel).where((0,f.Uo)((0,f.eq)(i.providerModel.providerId,a),(0,f.eq)(i.providerModel.workspaceId,b.id)))).map(a=>({id:a.modelId,name:a.name,context:a.context,outputLimit:a.outputLimit,inputCost:a.inputCost,outputCost:a.outputCost,caps:a.caps??{reasoning:!1,tools:!1,vision:!1},released:a.released,isDefault:a.isDefault}));return c.sort((a,b)=>Number(b.isDefault)-Number(a.isDefault)||(b.released||"").localeCompare(a.released||"")||a.name.localeCompare(b.name)),{models:c}}async function N(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));if(!c)return{ok:!1,error:"not found"};let d=(0,l.kH)(c.catalogId);if(!d)return{ok:!1,error:"unknown provider"};let e=await (0,k.r6)(b.id,`${c.catalogId}_api_key`),m=await p(d,e);return await h.db.update(i.provider).set({status:m.ok?"connected":"error"}).where((0,f.eq)(i.provider.id,a)),(0,g.revalidatePath)("/models"),{ok:m.ok,error:m.error}}async function O(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));if(!c)return{models:[],error:"not found"};let d=(0,l.kH)(c.catalogId);if(!d?.baseUrl)return{models:[],error:"no public endpoint for this provider"};let e=await (0,k.r6)(b.id,`${c.catalogId}_api_key`),g=d.baseUrl.replace(/\/$/,"");try{let a=/ollama/i.test(c.catalogId)||c.adapter.includes("ollama")?`${g.replace(/\/v1$/,"")}/api/tags`:`${g}/models`,b=await fetch(a,{headers:e?{authorization:`Bearer ${e}`}:{},signal:AbortSignal.timeout(8e3)});if(!b.ok)return{models:[],error:`endpoint ${b.status}`};let d=await b.json();return{models:(d.data??d.models??[]).map(a=>a.id??a.name??"").filter(Boolean).slice(0,80)}}catch(b){let a=String(b instanceof Error?b.message:b);return{models:[],error:/abort|fetch failed|ECONN/i.test(a)?"endpoint unreachable":a}}}async function P(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));c&&await (0,k.Kh)(b.id,`${c.catalogId}_api_key`),await h.db.delete(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id))),(0,g.revalidatePath)("/models")}async function Q(a){let{workspace:b}=await (0,j.nP)(),[c]=await h.db.select().from(i.provider).where((0,f.Uo)((0,f.eq)(i.provider.id,a),(0,f.eq)(i.provider.workspaceId,b.id)));c&&(await (0,k.Kh)(b.id,`${c.catalogId}_api_key`),await h.db.update(i.provider).set({auth:"none",status:"needs_sync",modelCount:0}).where((0,f.eq)(i.provider.id,a)),(0,g.revalidatePath)("/models"))}(0,c(29635).D)([H,I,J,L,M,N,O,P,Q]),(0,d.A)(H,"6063c4c04607bdff1f0b6dc3e695d6d838fa41dc0f",null),(0,d.A)(I,"40ef6a371c8208468fa32c33091775b5aeb9c2ea9d",null),(0,d.A)(J,"40dc8e68ecfa17e5b1a121e933261a7040870dd962",null),(0,d.A)(L,"40a0f7f5fe75a32505a82aac16e0807cfdf7d344a1",null),(0,d.A)(M,"40942bd62c47b06c00ffb8344c05ad1b197e87f0f4",null),(0,d.A)(N,"40eb39b1171f1395549f8ea5615c2ec3f79f8e6206",null),(0,d.A)(O,"40e8df75e45bb28a0912a0d3788e77e37f502b8092",null),(0,d.A)(P,"40b9cc92ffb5f4bf229890566ae068edf9090218a8",null),(0,d.A)(Q,"40c072a0683ed78fc4617b255c94c2e1a237fcbc75",null)},57075:a=>{a.exports=require("node:stream")},61419:(a,b,c)=>{c.r(b),c.d(b,{handler:()=>aM,patchFetch:()=>aL,routeModule:()=>aH,serverHooks:()=>aK,workAsyncStorage:()=>aI,workUnitAsyncStorage:()=>aJ});var d={};c.r(d),c.d(d,{POST:()=>aG});var e=c(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(80280),x=c(25533),y=c(1782),z=c(89611),A=c(55511),B=c(47860),C=c(3188),D=c(34302),E=c(26288),F=c(82550),G=c(6404),H=c(99546),I=c(12867),J=c(6873);let K=["developer.mozilla.org","web.dev","owasp.org","cheatsheetseries.owasp.org","www.w3.org","docs.python.org","nodejs.org","go.dev","doc.rust-lang.org","kubernetes.io","docs.docker.com","www.npmjs.com","pypi.org"];async function L(a,b,c,d){var e;let f;try{f=new URL(c)}catch{return{ok:!1,reason:"invalid url"}}if("https:"!==f.protocol&&"http:"!==f.protocol)return{ok:!1,reason:"non-http url"};let g=new Set([...K,...(0,J.et)(b)].map(a=>a.toLowerCase()));if(!function(a,b){let c=a.toLowerCase().replace(/\.$/,"");for(let a of b)if(c===a||c.endsWith("."+a))return!0;return!1}(f.host,g))return{ok:!1,reason:`host not on the official-docs allowlist (${f.host})`};let h="";try{let a=new AbortController,b=setTimeout(()=>a.abort(),15e3),c=await fetch(f.toString(),{signal:a.signal,redirect:"follow",headers:{"user-agent":"Constella-Research/1.0",accept:"text/html,application/xhtml+xml,*/*"}});if(clearTimeout(b),!c.ok)return{ok:!1,reason:`http ${c.status}`};if(!/text\/|html|xml|json/i.test(c.headers.get("content-type")??""))return{ok:!1,reason:"non-text content"};h=(await c.text()).slice(0,15e5)}catch(a){return{ok:!1,reason:String(a instanceof Error?a.message:a).slice(0,120)}}let{title:i,text:j}=(e=h,{title:e.match(/<title[^>]*>([\s\S]*?)<\/title>/i)?.[1]?.replace(/\s+/g," ").trim()??"",text:e.replace(/<script[\s\S]*?<\/script>/gi," ").replace(/<style[\s\S]*?<\/style>/gi," ").replace(/<\/(p|div|li|h[1-6]|tr|section|article)>/gi,"\n").replace(/<[^>]+>/g," ").replace(/ /g," ").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'|’|‘/g,"'").replace(/"|“|”/g,'"').replace(/[ \t]+/g," ").replace(/\n{3,}/g,"\n\n").trim()});return j.length<80?{ok:!1,reason:"empty page"}:(await (0,I.ru)(a,[{type:"doc",title:(i||`${f.host}${f.pathname}`).slice(0,200),summary:j.slice(0,1e3),body:`Official documentation — researched and cached for reuse.
|
|
13
13
|
Source: ${f.toString()}
|
|
14
14
|
|
|
15
15
|
${j.slice(0,8e3)}`,sourceKind:"research",sourceRef:f.toString(),confidence:60,agentHandle:d?.agentHandle,goalId:d?.goalId??null,issueId:d?.issueId??null,taskId:d?.taskId??null}]).catch(()=>{}),{ok:!0,chars:j.length,title:i})}var M=c(58875),N=c(9842),O=c(62524),P=c(54033),Q=c(77598),R=c(73024),S=c(76760),T=c(73136),U=c(31421),V=c(18612),W=c(78848),X=c(43075),Y=c(20850),Z=c(88639);async function $(a,b,c){let d=await a.newPage();try{return await d.evaluate(async a=>{let b=a=>new Promise((b,c)=>{let d=new Image;d.onload=()=>b(d),d.onerror=c,d.src=a}),[c,d]=await Promise.all([b(a[0]),b(a[1])]),e=a=>{let b=document.createElement("canvas");b.width=1280,b.height=800;let c=b.getContext("2d");return c.drawImage(a,0,0,1280,800),c.getImageData(0,0,1280,800).data},f=e(c),g=e(d),h=0;for(let a=0;a<f.length;a+=4)(Math.abs(f[a]-g[a])>32||Math.abs(f[a+1]-g[a+1])>32||Math.abs(f[a+2]-g[a+2])>32)&&h++;return h/1024e3},[`data:image/png;base64,${b}`,`data:image/png;base64,${c}`])}catch{return null}finally{try{await d.close()}catch{}}}let _=["/.env","/.env.local","/.git/config","/config.json","/admin","/api"],aa=/(sk-[a-z0-9]{20,}|AKIA[0-9A-Z]{16}|-----BEGIN (?:RSA |EC )?PRIVATE KEY-----|password["']?\s*[:=]\s*["'][^"']{4,})/i,ab=null;function ac(a,b,c,d="",e=""){(0,W.I)(a,{runId:b,channel:"testdev",agentId:null,kind:c,target:d,detail:e}),(0,X.r)(a)}async function ad(a,b,d={}){let e,f=(0,Q.randomUUID)();await w.db.insert(x.testRun).values({id:f,workspaceId:a,goalId:d.goalId??null,issueId:d.issueId??null,status:"running",by:d.by??"operator"}),ac(a,f,"thinking","Starting Test Dev…");let g=async(b,c,d)=>(await w.db.update(x.testRun).set({status:b,summary:c.slice(0,600),findings:JSON.stringify(d).slice(0,2e4),finishedAt:new Date}).where((0,y.eq)(x.testRun.id,f)),ac(a,f,"done",`${b} \xb7 ${d.length} finding(s)`),{id:f,status:b,summary:c,findings:d}),h=(0,Y.Vd)(a);if(!h&&d.noBoot)return g("inconclusive","Dev server not running — start it in Test Dev to gate task completion.",[]);if(!h){ac(a,f,"thinking","Booting project dev server…");let c=await (0,Y.ZF)(a,b);if(!c.running||!c.url)return g("inconclusive","No runnable project / dev server didn't boot — nothing to test yet.",[{severity:"low",kind:"boot",route:"-",message:c.logs.slice(-3).map(a=>a.t).join(" | ")||"no project"}]);h=c.url}if("running"!==(0,Y.CS)(a).status)return g("inconclusive","Dev server is still starting — try again shortly.",[{severity:"low",kind:"boot",route:"-",message:"server not reachable yet"}]);let i=(d.routes&&d.routes.length?d.routes:["/"]).slice(0,8);try{({chromium:e}=await Promise.resolve().then(c.bind(c,5006)))}catch{return g("inconclusive","Playwright not available — install it (`npx playwright install chromium`) to enable browser tests.",[])}let j=[],k=(0,S.join)((0,V.HZ)(b),".testdev");try{(0,R.mkdirSync)(k,{recursive:!0})}catch{}let l=null;try{l=await e.launch({headless:!0})}catch(c){ac(a,f,"thinking","Installing the test browser (chromium, one-time ~150MB)…");let b=await (!ab&&(ab=new Promise(a=>{try{let b="win32"===process.platform?"npx.cmd":"npx",c=(0,U.spawn)(b,["playwright","install","chromium"],{stdio:"ignore",windowsHide:!0}),d=setTimeout(()=>{try{c.kill()}catch{}a(!1)},3e5);c.on("exit",b=>{clearTimeout(d),a(0===b)}),c.on("error",()=>{clearTimeout(d),a(!1)})}catch{a(!1)}})),ab);if(b)try{l=await e.launch({headless:!0})}catch{}if(!l)return g("inconclusive",b?"Couldn't launch chromium after install — try again.":"Couldn't install/launch chromium. Run `npx playwright install chromium` in the install dir, then retry.",[{severity:"low",kind:"boot",route:"-",message:String(c instanceof Error?c.message:c).slice(0,200)}])}try{let c=await l.newContext({viewport:{width:1280,height:800}}),d=await c.newPage();d.on("console",a=>{let b=a.type();"error"===b?j.push({severity:"high",kind:"console",route:d.url(),message:a.text().slice(0,300)}):"warning"===b&&j.push({severity:"low",kind:"console",route:d.url(),message:a.text().slice(0,300)})}),d.on("pageerror",a=>j.push({severity:"high",kind:"pageerror",route:d.url(),message:String(a.message??a).slice(0,300)})),d.on("requestfailed",a=>{let b=a.failure()?.errorText??"";/ERR_ABORTED/.test(b)||j.push({severity:"med",kind:"request",route:d.url(),message:`${a.method()} ${a.url().slice(0,160)} — ${b}`})});let e=(0,Z.hp)(b),g=!!e.served&&!!e.target,m=(0,S.join)(k,"baseline");if(g)try{(0,R.mkdirSync)(m,{recursive:!0})}catch{}for(let l of i){ac(a,f,"text",`navigate ${l}`);try{let a=await d.goto(h+l,{waitUntil:"domcontentloaded",timeout:2e4});a&&a.status()>=500&&j.push({severity:"high",kind:"request",route:l,message:`${l} → HTTP ${a.status()}`}),await d.waitForTimeout(800);let i=d.locator("button:visible:not([disabled])").first();if(await i.count())try{await i.click({timeout:2e3}),await d.waitForTimeout(500)}catch{}let n=await d.content();aa.test(n)&&j.push({severity:"high",kind:"security",route:l,message:"Possible secret/credential present in served HTML/JS."});let o=l.replace(/[^a-z0-9]/gi,"_")||"root";try{await d.screenshot({path:(0,S.join)(k,`${f}-${o}.png`)})}catch{}if(g)try{let a=(0,S.join)(m,`${o}.png`);if(!(0,R.existsSync)(a)){let d="/"===l?"index.html":l.replace(/^\//,"").replace(/\/+$/,"")+".html",f=(0,S.join)((0,V.HZ)(b),e.target,d);if((0,R.existsSync)(f)){let b=await c.newPage();try{await b.goto((0,T.pathToFileURL)(f).href,{waitUntil:"domcontentloaded",timeout:15e3}),await b.waitForTimeout(400),await b.screenshot({path:a})}finally{try{await b.close()}catch{}}}}if((0,R.existsSync)(a)){let b=await d.screenshot(),e=await $(c,(0,R.readFileSync)(a).toString("base64"),b.toString("base64"));if(null!=e){let a=Math.round(100*e);e>.5?j.push({severity:"high",kind:"fidelity",route:l,message:`Visual fidelity: ${a}% of the screen differs from the APPROVED design — it doesn't match; build ${l} to the design (zero drift).`}):e>.12&&j.push({severity:"med",kind:"fidelity",route:l,message:`Visual drift: ${a}% differs from the approved design at ${l}.`})}}}catch{}}catch(a){j.push({severity:"med",kind:"request",route:l,message:`navigation failed: ${String(a instanceof Error?a.message:a).slice(0,160)}`})}}for(let a of _)try{let b=await fetch(h+a,{redirect:"manual",signal:AbortSignal.timeout(4e3)});if(200===b.status){let c=await b.text().catch(()=>"");("/api"!==a&&c.length>0||aa.test(c))&&j.push({severity:"high",kind:"security",route:a,message:`${a} returns 200 with content unauthenticated.`})}}catch{}await c.close()}finally{try{await l.close()}catch{}}let m=j.filter(a=>"high"===a.severity),n=m.length?"fail":"pass",o="fail"===n?`${m.length} blocking issue(s): ${m.slice(0,3).map(a=>`${a.kind} @ ${a.route}`).join(", ")}`:`Passed — ${j.length} note(s), no blocking issues. Navigated ${i.length} route(s).`;return(0,I.ru)(b,[{type:"test",title:`Test Dev — ${n}`,summary:o,goalId:d.goalId??null,issueId:d.issueId??null,agentHandle:"agent"===d.by?"edsger":"operator",sourceKind:"test",sourceRef:f}]).catch(()=>{}),g(n,o,j)}async function ae(a,b){let[c]=await w.db.select().from(x.issue).where((0,y.eq)(x.issue.id,b)),d=new Set(["/"]);if(c){let a=(c.title+" "+(c.key??"")).match(/\/[a-z0-9\-/]{2,}/gi);a&&a.slice(0,4).forEach(a=>d.add(a))}return[...d]}var af=c(90860),ag=c(10333),ah=c(863),ai=c(1591);let aj=["code-review-practices","review-code-perf-security","owasp-top-10","secrets-management","appsec-fundamentals"];async function ak(a,b,c,d,e){let f=[...new Set(e.filter(Boolean))].slice(0,40);if(!f.length)return{ran:!1,blocking:!1,findings:[]};let g=(0,Q.randomUUID)();await (0,W.I)(b.id,{runId:g,channel:"security",agentId:c.id,kind:"thinking",target:`${c.name} is reviewing ${d}…`});let h=await w.db.select({name:x.skill.name,instructions:x.skill.instructions,summary:x.skill.summary}).from(x.agentSkill).innerJoin(x.skill,(0,y.eq)(x.agentSkill.skillId,x.skill.id)).where((0,y.Uo)((0,y.eq)(x.agentSkill.agentId,c.id),(0,y.RV)(x.skill.name,aj))),i=h.length?`
|
|
@@ -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")},3295:a=>{a.exports=require("next/dist/server/app-render/after-task-async-storage.external.js")},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")},29635:(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
|
-
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}})},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},48161:a=>{a.exports=require("node:os")},51063:(a,b,c)=>{c.d(b,{dp:()=>o,j2:()=>p});var d=c(18706),e=c(21594),f=c(79743),g=c(80280),h=c(25533);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://")}})},51455:a=>{a.exports=require("node:fs/promises")},52813:(a,b,c)=>{Object.defineProperty(b,"A",{enumerable:!0,get:function(){return d.registerServerReference}});let d=c(62060)},62060:(a,b,c)=>{a.exports=c(53488).vendored["react-rsc"].ReactServerDOMWebpackServer},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},76760:a=>{a.exports=require("node:path")},76862:(a,b,c)=>{c.d(b,{LV:()=>v,eA:()=>w,mg:()=>x});var d=c(52813),e=c(77598),f=c(1782),g=c(83550),h=c(80280),i=c(25533),j=c(95896),k=c(18612),l=c(64619);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(29635).D)([v,w,x]),(0,d.A)(v,"700d9e5428bda6c4b953e511f1fab9bb77dc8b50e0",null),(0,d.A)(w,"6008e6afb5884710aaaae699139aac177b4b62f8d0",null),(0,d.A)(x,"40353e520652a8224e8ad28436fa1e61a96ed87043",null)},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")},95145:(a,b,c)=>{c.r(b),c.d(b,{"40353e520652a8224e8ad28436fa1e61a96ed87043":()=>d.mg,"6008e6afb5884710aaaae699139aac177b4b62f8d0":()=>d.eA,"700d9e5428bda6c4b953e511f1fab9bb77dc8b50e0":()=>d.LV});var d=c(76862)},95896:(a,b,c)=>{c.d(b,{$x:()=>k,Ht:()=>j,K4:()=>l,O5:()=>m,nP:()=>n});var d=c(79676),e=c(17971),f=c(1782),g=c(80280),h=c(25533),i=c(51063);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}}},96872:(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(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(76862);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}}},99146:(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(90937),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}}}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[3050,658,9676,1845,7971,3550,4804,1572,4619],()=>b(b.s=96872));module.exports=c})();
|
|
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")},3295:a=>{a.exports=require("next/dist/server/app-render/after-task-async-storage.external.js")},10846:a=>{a.exports=require("next/dist/compiled/next-server/app-page.runtime.prod.js")},17793:(a,b,c)=>{c.r(b),c.d(b,{"40e73a917991bf0aac3c46efce7b609433595db67f":()=>d.mg,"60d913024db5bfa98065eac4cd36d9448b6edf6bc9":()=>d.eA,"700e75ff9f4413bd6246cd5b30074325cb53225a6a":()=>d.LV});var d=c(76862)},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")},29635:(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
|
+
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}})},44870:a=>{a.exports=require("next/dist/compiled/next-server/app-route.runtime.prod.js")},48161:a=>{a.exports=require("node:os")},51063:(a,b,c)=>{c.d(b,{dp:()=>o,j2:()=>p});var d=c(18706),e=c(21594),f=c(79743),g=c(80280),h=c(25533);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://")}})},51455:a=>{a.exports=require("node:fs/promises")},52813:(a,b,c)=>{Object.defineProperty(b,"A",{enumerable:!0,get:function(){return d.registerServerReference}});let d=c(62060)},62060:(a,b,c)=>{a.exports=c(53488).vendored["react-rsc"].ReactServerDOMWebpackServer},63033:a=>{a.exports=require("next/dist/server/app-render/work-unit-async-storage.external.js")},73024:a=>{a.exports=require("node:fs")},76760:a=>{a.exports=require("node:path")},76862:(a,b,c)=>{c.d(b,{LV:()=>v,eA:()=>w,mg:()=>x});var d=c(52813),e=c(77598),f=c(1782),g=c(83550),h=c(80280),i=c(25533),j=c(95896),k=c(18612),l=c(64619);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(29635).D)([v,w,x]),(0,d.A)(v,"700e75ff9f4413bd6246cd5b30074325cb53225a6a",null),(0,d.A)(w,"60d913024db5bfa98065eac4cd36d9448b6edf6bc9",null),(0,d.A)(x,"40e73a917991bf0aac3c46efce7b609433595db67f",null)},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")},95896:(a,b,c)=>{c.d(b,{$x:()=>k,Ht:()=>j,K4:()=>l,O5:()=>m,nP:()=>n});var d=c(79676),e=c(17971),f=c(1782),g=c(80280),h=c(25533),i=c(51063);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}}},96872:(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(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(76862);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}}},99146:(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(90937),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}}}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[3050,658,9676,1845,7971,3550,4804,1572,4619],()=>b(b.s=96872));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
|
-
`))}},16050:(a,b,c)=>{c.d(b,{Ml:()=>e});let d={github:!0,telegram:!0,ollama:!0,webhooks:!0};function e(a,b){return({...d,...a??{}})[b]??!0}},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},
|
|
41
|
+
`))}},16050:(a,b,c)=>{c.d(b,{Ml:()=>e});let d={github:!0,telegram:!0,ollama:!0,webhooks:!0};function e(a,b){return({...d,...a??{}})[b]??!0}},19121:a=>{a.exports=require("next/dist/server/app-render/action-async-storage.external.js")},20287:(a,b,c)=>{c.r(b),c.d(b,{"000089ba14b42533398abdb41e570d2405b97bf2a8":()=>g.groomBacklog,"000538e55e8863eaca825d1e70174f3b72909185dd":()=>d.S8,"0008fef7b5b0a23492aed2eae98ac089bc86a3749a":()=>d.kb,"000fcfa407fbc51cd18133f3da1a459d4af6a9cc5d":()=>d.lC,"00183937ee05ae4cbf391a1b51cfc16c2f861738f1":()=>h.Tu,"0018a0b5673bbc76c6d3f1cd6227d9049cd889b4dd":()=>d.Vr,"001e19b6d2f892fbdf995a9e284a074a277fe0ca06":()=>h.yL,"001ed4036bfa17b014cd406df39e211a50abdd9a98":()=>d.ts,"001f4dcdd1414de6334ce51e096abef12cce715d5f":()=>d.Gh,"0020f5b4bf1a2118e24c852c54d400f1927cc1582d":()=>h.oS,"0029bb6209b7625897f6acdf3d35b4ef5b219d578e":()=>g.requestPlanChanges,"002ab6492658649f1fb72f63e6548882c486996697":()=>h.wP,"0030c8d446fa5d6a9f06f28d2f0e13d616d8359bf0":()=>h.ME,"0031ec1fcd2b5c12cb587c24d3bbcfdc45eb9dc8de":()=>d.Ac,"004216f7ac78a8a71bd8262563d0e0115f46de3334":()=>h.Ni,"005af5ec007b7a6b841445fecaae31d2f1f7cad0aa":()=>d.nl,"005f347999dc4767ce93bb5bbebb2851b83bdb9327":()=>d.zO,"0067a12792ed6794fa23d38e8fa831aa63e9674549":()=>h.I_,"0082098556d4302c4ed6e0da7abc7b94fe4af2e882":()=>d.LU,"0084808234a98b8a67c04157bfa772eee8ad2821f2":()=>h.gn,"00868fe54fb579add0f212e1f823d564328d7d5432":()=>h.PO,"00a7004dfc810d6e90f45ba9bd04c2eca003d5e093":()=>g.approvePlan,"00a70c56acf4c711aa29d2631a0222418222d1d062":()=>d.VH,"00c30495871ff89d3218dddc9898738136dce97eb7":()=>d.Jw,"00cf3df6ec75d6c06c3f41a1936b72df167e738c9b":()=>h.e9,"00dd33de1b3f55c4c1cbb341355d491ec6ea77ef4e":()=>d.V$,"00eb5c7c203b16c670c3f42ff424497240d7aaa63e":()=>d.Hi,"00ecc40b1a1f7711705174bdf2c7b6328f702a4267":()=>d.Uw,"00fdd395e7e9c9c038392b53f9181a93e78d57cd50":()=>h.o3,"400a3dd0ee8892f66a2e5604d6581fd23aa7a3cea5":()=>d.m,"400b23af4cfe05bae4f2b307de3beba8c3ab1ab148":()=>h.NM,"400cb1f7d10be86025c029db9f8bae23f7c7496000":()=>d.cm,"400f1502baff617e4723ca3981ce687c276c48b759":()=>g.approveIssue,"4011d6f9217de94ea7c6dc94551d744b7282fab975":()=>h.a4,"401d32cbbd01c648cd56431798e978dfb425ec9e0b":()=>d.ju,"4026c880b44f2f21469a370f44f00cea0f670f3177":()=>d.I2,"40393c94959615d5e12fedd0ada3b520569ba610da":()=>h.is,"4046442bdc21d1e6839fe89a0eaa873baf2538c3ff":()=>g.setAuto247,"404b1d63339057a37248bc6add59407f0d209693be":()=>h.fb,"4066e2a6e63fba23fc4c7e9e862f4f153d28402e09":()=>d.wp,"4079e2b639aee160d1b4b0d6a899d39e3484a05c32":()=>h.DX,"407bc313c8bc4b1e7c1c1364fcd5b440b84872e9f8":()=>d.az,"407e9aa8711c5ef7e274c016f412637c44a483fd40":()=>g.rejectIssue,"407ed923314dd0345588038a18fe9b55c8a8fbc857":()=>g.rejectSpec,"408e9862e1393f93d3ce5c54d77c7dcad8cafc8290":()=>h.R6,"40a70fb05d3ee3689af4c2d699110c95c7f196e401":()=>h.lj,"40c8d005e334f79c3d49673bd0c6cd2f849273b72e":()=>g.approveSpec,"40cbef8c22d0da6e4a36a8672c3bcb5fe20b5490a8":()=>d.Cp,"40e2634e29447d1a79a4589d0209147cc35e3a4f8b":()=>h.h_,"40e41f281f5ba97fe6181c0b4eb66011755ea7502c":()=>g.startNewWork,"40e73a917991bf0aac3c46efce7b609433595db67f":()=>e.mg,"40e9eeca52e7c9ad6dad0edc93d6c93b24f979ffde":()=>g.planFromConversation,"40f3f2d02634be4fdb0104759d54900ef00b744064":()=>d.L0,"40f64d6f4af4f3090b9970dfb540b3c1763668edd7":()=>h.$_,"40f9cd3fc6c6d8cae96897a561300a7232d723d346":()=>g.generatePlan,"40fd61509391be62062cf7a8fc99f5a2fbd01608d0":()=>g.advanceIssue,"6013b9ca137da82342d0d4d0ce0222660ac4be328d":()=>h.NW,"60274e3c8fcd8421d02f318a50057ea2e101dbf0eb":()=>h.pG,"607191661d0d0d7c456c788d618d4f4c7bcf886ea3":()=>h.qw,"607bbf2173faf70ab65a0403634d2c347f9e25d8cd":()=>h.ft,"608afcbccbaff8e6c4a43052c351055e65a62dd352":()=>g.groomBacklogFor,"60b14ad3fdf5a4a8694b12fddfc076accfa2720306":()=>h.EQ,"60c90060eb97b05811e1cc6d6b7612c92c3560e129":()=>f.I,"60d913024db5bfa98065eac4cd36d9448b6edf6bc9":()=>e.eA,"60de34b03ecc854dfa8ebeb317ac7fca683e593e25":()=>h.RS,"60e06e44b9e20604b541280ee75f85a4b780e9ebbe":()=>h.Fo,"60f0bea5ddad11025dc93938ce3faf0f92f28b665a":()=>f.k,"700e75ff9f4413bd6246cd5b30074325cb53225a6a":()=>e.LV,"70283dc35f63e3f9641ea7be1ba25eaccb45a10788":()=>h.Sy,"702bc1eae659f800327a97d7da88ca3c13bd6d6018":()=>h.fM,"708bd03c8aa9d1ae57e07b573e36fd0cb7e567921c":()=>h.sy,"70f883f3483c03cb82e81e32abfaf98fc2ce69063f":()=>h.a7,"7cfb4d8cc417db796a81842a078878af7d9f3cb8d1":()=>h.Hg});var d=c(27989),e=c(76862),f=c(78848),g=c(56053),h=c(63390)},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")},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")},63390:(a,b,c)=>{c.d(b,{Hg:()=>ai,a7:()=>aj,sy:()=>al,is:()=>H,fM:()=>I,Sy:()=>G,e9:()=>ao,EQ:()=>am,NM:()=>ak,$_:()=>aa,qw:()=>S,DX:()=>V,ME:()=>E,oS:()=>J,RS:()=>K,R6:()=>ah,wP:()=>W,Ni:()=>$,gn:()=>ab,yL:()=>ad,NW:()=>P,lj:()=>Y,fb:()=>ag,pG:()=>ae,I_:()=>L,Fo:()=>M,o3:()=>N,a4:()=>af,ft:()=>_,Tu:()=>U,h_:()=>F,PO:()=>T});var d=c(52813),e=c(77598),f=c(1782),g=c(7852),h=c(83550),i=c(80280),j=c(25533),k=c(95896),l=c(3188),m=c(78848),n=c(10333),o=c(43075),p=c(18612),q=c(99546),r=c(90860),s=c(13239),t=c(88639);let u=new Set(["Next.js","Nuxt","Remix","SvelteKit","Astro","Gatsby"]);var v=c(1591),w=c(99956),x=c(6873);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} */
|
|
42
42
|
`+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}">
|
|
43
43
|
${z(f,e,c,new Set([e]))}
|
|
44
44
|
</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(29635);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}
|
|
@@ -116,7 +116,7 @@ ${c.map(a=>"- "+a).join("\n")||"(scan the project for components / screens / sty
|
|
|
116
116
|
1) Create design-mock/styles/global.css with the design tokens (:root), reset/base and theme ([data-theme]).
|
|
117
117
|
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.
|
|
118
118
|
3) Write design-mock/design-system.md outlining the palette, typography, spacing, core components and the screens to build.
|
|
119
|
-
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 V(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 W(){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)=>X(a.path)-X(b.path)||a.label.localeCompare(b.label));return(0,t.zw)(a.id,b),{docs:c}}function X(a){return/APPROVED\.md$/i.test(a)?0:/design-system\.md$/i.test(a)?1:2}async function Y(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 Z=".claude/design-presets.json";async function $(){let{org:a}=await (0,k.nP)(),b=(0,p.sL)(a.id,Z);if(!b)return{presets:[]};try{let a=JSON.parse(b);return{presets:Array.isArray(a)?a.slice(0,60):[]}}catch{return{presets:[]}}}async function _(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,Z,JSON.stringify(g,null,2)),{ok:!0}}async function aa(a){let{org:b}=await (0,k.nP)(),{presets:c}=await $();return(0,p.dx)(b.id,Z,JSON.stringify(c.filter(b=>b.id!==a),null,2)),{ok:!0}}async function ab(){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 ac(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 ad(){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 ae(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 af(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 ag(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 ah(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 ai(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 aj(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 ak(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 al(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 am(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 an(d.id,a)}catch{}try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function an(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 ao(){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,M,N,P,S,T,U,V,W,Y,$,_,aa,ab,ad,ae,af,ag,ah,ai,aj,ak,al,am,ao]),(0,d.A)(E,"005eb4893b1e512faf4421ca4b7e75fff599074e17",null),(0,d.A)(F,"40e66a004301dc99f15f2608fac3a6560de975f851",null),(0,d.A)(G,"700f964a4b50becaacdd88e7650b66718f5cd8dc7b",null),(0,d.A)(H,"40104e3f5d98ea464ee672c32c0300f24fbfb7956f",null),(0,d.A)(I,"7021668545dfe92417d5a7a2e640816b5f9179c339",null),(0,d.A)(J,"0070ebdbc96d2494dec393065dc20d3e1428946b54",null),(0,d.A)(K,"60749086c507cd288a6467eaf4ddb4ba491c9b0370",null),(0,d.A)(L,"003426238e2afd09e1ff683df65d7cf57f365f0962",null),(0,d.A)(M,"60b6b0192e59a6db12c7e8037e4b827a7367795aab",null),(0,d.A)(N,"002c0373eb489ecbc946c950c8ea8d521c7213317f",null),(0,d.A)(P,"6094c9c31617426b089c8127d6fbdbb84090a8e2c9",null),(0,d.A)(S,"600159a7c0a9148c31ba4aab639d38dd75e689cdf8",null),(0,d.A)(T,"00caf518bdee64b8e365f2de8f5e807f028e55958d",null),(0,d.A)(U,"00b6085e87c60d69c98335e7ef04a5574220b4f025",null),(0,d.A)(V,"40af5dbd3aa35380e77900d419d87a5476ee59d61f",null),(0,d.A)(W,"0037eb6e1f803a7499d013ecaab6117032935d1b72",null),(0,d.A)(Y,"4085d74d131ad9bf899770cb28b2a74b5e4fb3b400",null),(0,d.A)($,"004ce9f8e7df6b350e290d12470ef196a750e4149d",null),(0,d.A)(_,"60417785708caded29d4ec16beff83b97071aa8eab",null),(0,d.A)(aa,"40314400968043e4211eb1a33f0411b6a4e81073db",null),(0,d.A)(ab,"0054aed3bbc6eb774bcc077faa643b1a3f215b8d8d",null),(0,d.A)(ad,"00c5d56da7decbec8096882f7d50264b3ae26069b7",null),(0,d.A)(ae,"6099335f5d628ec80a08eea59ddc024ae4003b6cf3",null),(0,d.A)(af,"40a365881044a266aad4ddc3f3542bdbd40ea80976",null),(0,d.A)(ag,"401537863fc299cde8711d47d73c711da22420fd28",null),(0,d.A)(ah,"40fb2f95350f09e70822a896e6c4d2e813adb423f9",null),(0,d.A)(ai,"7c037277c7fba4ca0e413ee86c0199e0ee063957b3",null),(0,d.A)(aj,"70f2d351d4b0f68980846fd1cd3eb10734aaf8baa9",null),(0,d.A)(ak,"40dcf3ab7a2818d71a2bce6c8764a1ea4a4c8f9117",null),(0,d.A)(al,"70fa9b591b64643dc3e52f6796aa779c5130236060",null),(0,d.A)(am,"60022aad2416c9dfe4508966ca25588590c11049dd",null),(0,d.A)(ao,"00b0424273db45fdd1ed9819fbf3a0261297582ed7",null)},69020:(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(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(77598),x=c(73024),y=c(76760),z=c(1782),A=c(7852),B=c(80280),C=c(25533),D=c(18612),E=c(16050),F=c(78874),G=c(1591),H=c(43075),I=c(55479),J=c(18661),K=c(96930),L=c(63390),M=c(12867),N=c(48938);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)||(R.add(d.botToken),(0,F.A3)(d.botToken).catch(()=>{}));let e=a.telegram?.offset??0,f=await (0,F.SD)(d.botToken,e),g=e;for(let a of f){g=Math.max(g,a.update_id+1);try{await T(c,d,a)}catch(a){console.error("[telegram] ingest failed:",a)}}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:
|
|
119
|
+
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 V(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 W(){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)=>X(a.path)-X(b.path)||a.label.localeCompare(b.label));return(0,t.zw)(a.id,b),{docs:c}}function X(a){return/APPROVED\.md$/i.test(a)?0:/design-system\.md$/i.test(a)?1:2}async function Y(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 Z=".claude/design-presets.json";async function $(){let{org:a}=await (0,k.nP)(),b=(0,p.sL)(a.id,Z);if(!b)return{presets:[]};try{let a=JSON.parse(b);return{presets:Array.isArray(a)?a.slice(0,60):[]}}catch{return{presets:[]}}}async function _(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,Z,JSON.stringify(g,null,2)),{ok:!0}}async function aa(a){let{org:b}=await (0,k.nP)(),{presets:c}=await $();return(0,p.dx)(b.id,Z,JSON.stringify(c.filter(b=>b.id!==a),null,2)),{ok:!0}}async function ab(){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 ac(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 ad(){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 ae(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 af(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 ag(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 ah(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 ai(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 aj(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 ak(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 al(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 am(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 an(d.id,a)}catch{}try{(0,h.revalidatePath)("/design")}catch{}return{ok:!0}}async function an(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 ao(){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,M,N,P,S,T,U,V,W,Y,$,_,aa,ab,ad,ae,af,ag,ah,ai,aj,ak,al,am,ao]),(0,d.A)(E,"0030c8d446fa5d6a9f06f28d2f0e13d616d8359bf0",null),(0,d.A)(F,"40e2634e29447d1a79a4589d0209147cc35e3a4f8b",null),(0,d.A)(G,"70283dc35f63e3f9641ea7be1ba25eaccb45a10788",null),(0,d.A)(H,"40393c94959615d5e12fedd0ada3b520569ba610da",null),(0,d.A)(I,"702bc1eae659f800327a97d7da88ca3c13bd6d6018",null),(0,d.A)(J,"0020f5b4bf1a2118e24c852c54d400f1927cc1582d",null),(0,d.A)(K,"60de34b03ecc854dfa8ebeb317ac7fca683e593e25",null),(0,d.A)(L,"0067a12792ed6794fa23d38e8fa831aa63e9674549",null),(0,d.A)(M,"60e06e44b9e20604b541280ee75f85a4b780e9ebbe",null),(0,d.A)(N,"00fdd395e7e9c9c038392b53f9181a93e78d57cd50",null),(0,d.A)(P,"6013b9ca137da82342d0d4d0ce0222660ac4be328d",null),(0,d.A)(S,"607191661d0d0d7c456c788d618d4f4c7bcf886ea3",null),(0,d.A)(T,"00868fe54fb579add0f212e1f823d564328d7d5432",null),(0,d.A)(U,"00183937ee05ae4cbf391a1b51cfc16c2f861738f1",null),(0,d.A)(V,"4079e2b639aee160d1b4b0d6a899d39e3484a05c32",null),(0,d.A)(W,"002ab6492658649f1fb72f63e6548882c486996697",null),(0,d.A)(Y,"40a70fb05d3ee3689af4c2d699110c95c7f196e401",null),(0,d.A)($,"004216f7ac78a8a71bd8262563d0e0115f46de3334",null),(0,d.A)(_,"607bbf2173faf70ab65a0403634d2c347f9e25d8cd",null),(0,d.A)(aa,"40f64d6f4af4f3090b9970dfb540b3c1763668edd7",null),(0,d.A)(ab,"0084808234a98b8a67c04157bfa772eee8ad2821f2",null),(0,d.A)(ad,"001e19b6d2f892fbdf995a9e284a074a277fe0ca06",null),(0,d.A)(ae,"60274e3c8fcd8421d02f318a50057ea2e101dbf0eb",null),(0,d.A)(af,"4011d6f9217de94ea7c6dc94551d744b7282fab975",null),(0,d.A)(ag,"404b1d63339057a37248bc6add59407f0d209693be",null),(0,d.A)(ah,"408e9862e1393f93d3ce5c54d77c7dcad8cafc8290",null),(0,d.A)(ai,"7cfb4d8cc417db796a81842a078878af7d9f3cb8d1",null),(0,d.A)(aj,"70f883f3483c03cb82e81e32abfaf98fc2ce69063f",null),(0,d.A)(ak,"400b23af4cfe05bae4f2b307de3beba8c3ab1ab148",null),(0,d.A)(al,"708bd03c8aa9d1ae57e07b573e36fd0cb7e567921c",null),(0,d.A)(am,"60b14ad3fdf5a4a8694b12fddfc076accfa2720306",null),(0,d.A)(ao,"00cf3df6ec75d6c06c3f41a1936b72df167e738c9b",null)},69020:(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(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(77598),x=c(73024),y=c(76760),z=c(1782),A=c(7852),B=c(80280),C=c(25533),D=c(18612),E=c(16050),F=c(78874),G=c(1591),H=c(43075),I=c(55479),J=c(18661),K=c(96930),L=c(63390),M=c(12867),N=c(48938);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)||(R.add(d.botToken),(0,F.A3)(d.botToken).catch(()=>{}));let e=a.telegram?.offset??0,f=await (0,F.SD)(d.botToken,e),g=e;for(let a of f){g=Math.max(g,a.update_id+1);try{await T(c,d,a)}catch(a){console.error("[telegram] ingest failed:",a)}}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:
|
|
120
120
|
/status — quick status
|
|
121
121
|
/review — full plan / issues / tasks summary
|
|
122
122
|
/tasks — what's in flight right now
|
|
@@ -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")},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")},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")},80380:(a,b,c)=>{c.r(b),c.d(b,{"002ec012533e91d74d3596cacc28fb29672dd2d424":()=>d.requestPlanChanges,"0032b07ecf3687db80464df2df4ff472ab8dd2ee50":()=>e.Uw,"0059411adec0d4d17e2f5256f8e3e9c094b68f7a5d":()=>e.VH,"007783648cc654590e09944d6548ae421be8af0f9e":()=>e.Hi,"0080b36ce77bd81dbf083ce6b21a310a7e151283c1":()=>e.nl,"00816c62c15b1b2b1e47c3ecc06ff2772f24b304d5":()=>e.zO,"008e820e62d3981d50f937f7998d4a052cfcdf8606":()=>e.Vr,"009cfe5203f9514f533a1534560d1974968a5175a2":()=>e.kb,"00a1eddd57e3dc09273aacc07984fd7f8a1954e84c":()=>e.Jw,"00b3534ff1a9f4bbc4526faf731b949fd42df6a42d":()=>e.Gh,"00b3b52cb7833f87653e869ab0da35b470165ab3f2":()=>d.groomBacklog,"00bbcb36f3ec5d03200563e9d6d7854d3ba9470677":()=>e.LU,"00c51c2b6950ef7f834ba431a695cc3622568d8cd8":()=>e.lC,"00cdd6efe0d93dce17eb396e9a29c63e22e984e916":()=>e.Ac,"00d19b870af4ff13b735c92d0f9975509d0fe99484":()=>e.ts,"00e486855e50f0dd74b7d17c6b9fd5d4f2a47ebe1b":()=>e.V$,"00e565233acd1b1622979ff2cf891f01f7021a1b7a":()=>d.approvePlan,"00f7ef824c9d5d9ece3ffd154aa2020e67abe2d97d":()=>e.S8,"40353e520652a8224e8ad28436fa1e61a96ed87043":()=>f.mg,"4040f166eec5ea57ea575d9d9c381347e68abe1328":()=>d.startNewWork,"404de78d48c7a08195046dd144742454e2bda67c9c":()=>d.approveSpec,"404f3952eaf160e47e56225cc6fcac5bd13eedd1d4":()=>e.wp,"406391094e0e56b6206dc31a4e337db67713f221bd":()=>e.az,"40747886657d57fe4ec7bb6e930420729ce0501fd8":()=>d.setAuto247,"407489fe7f99bc0e499c7f1ab258fc05e4c06bb07b":()=>e.m,"407c3e9df9b0d1da40b0b033574d67de5b2dbab44b":()=>d.advanceIssue,"407e76c79e36677578f1327d2f785d64c352713479":()=>d.rejectIssue,"40933768e7809f7eb198ab6ffe0955c3d64fb1a288":()=>d.planFromConversation,"409483dd86b3a500619c574d5486d6fe760b53accd":()=>d.approveIssue,"409889669d46218f902094aeecfb2b06fb3b04350b":()=>e.ju,"40994cd4f9accdbb46817b1a6dab2789f5e540cca6":()=>e.I2,"40a953d8beabc1d04711604ead11ff43872039018b":()=>e.cm,"40b624c64bbcfb0074e428661bb821bbff7b09a155":()=>e.Cp,"40b9f423165fc1bd787ea6c1079de9f2c3abab7157":()=>d.generatePlan,"40bafadd426209f1065283cb854fdd1f4af1846026":()=>e.L0,"40ce2a1d1b3f5a652afcd597a20bc8bfc5e240f8e2":()=>d.rejectSpec,"6008e6afb5884710aaaae699139aac177b4b62f8d0":()=>f.eA,"601b583d70097128ea8208f56230640112a36ed0b4":()=>d.groomBacklogFor,"606172ae2b4f1bd8d53a80749741c48cdb043bc24f":()=>g.I,"60ac6b802b4ac5f1a28c3dbdb5ff9f27e10a8e3dcf":()=>g.k,"700d9e5428bda6c4b953e511f1fab9bb77dc8b50e0":()=>f.LV});var d=c(56053),e=c(27989),f=c(76862),g=c(78848)},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")},95396:(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(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(77598),x=c(1782),y=c(80280),z=c(25533),A=c(95896);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(55479),I=c(18661),J=c(96930),K=c(12867);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}}}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[3050,658,9676,1845,7971,3550,4804,4679,1572,4619,9969,7989,2867,6873,850,2960,8823],()=>b(b.s=95396));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")},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")},27582:(a,b,c)=>{c.r(b),c.d(b,{"000089ba14b42533398abdb41e570d2405b97bf2a8":()=>d.groomBacklog,"000538e55e8863eaca825d1e70174f3b72909185dd":()=>e.S8,"0008fef7b5b0a23492aed2eae98ac089bc86a3749a":()=>e.kb,"000fcfa407fbc51cd18133f3da1a459d4af6a9cc5d":()=>e.lC,"0018a0b5673bbc76c6d3f1cd6227d9049cd889b4dd":()=>e.Vr,"001ed4036bfa17b014cd406df39e211a50abdd9a98":()=>e.ts,"001f4dcdd1414de6334ce51e096abef12cce715d5f":()=>e.Gh,"0029bb6209b7625897f6acdf3d35b4ef5b219d578e":()=>d.requestPlanChanges,"0031ec1fcd2b5c12cb587c24d3bbcfdc45eb9dc8de":()=>e.Ac,"005af5ec007b7a6b841445fecaae31d2f1f7cad0aa":()=>e.nl,"005f347999dc4767ce93bb5bbebb2851b83bdb9327":()=>e.zO,"0082098556d4302c4ed6e0da7abc7b94fe4af2e882":()=>e.LU,"00a7004dfc810d6e90f45ba9bd04c2eca003d5e093":()=>d.approvePlan,"00a70c56acf4c711aa29d2631a0222418222d1d062":()=>e.VH,"00c30495871ff89d3218dddc9898738136dce97eb7":()=>e.Jw,"00dd33de1b3f55c4c1cbb341355d491ec6ea77ef4e":()=>e.V$,"00eb5c7c203b16c670c3f42ff424497240d7aaa63e":()=>e.Hi,"00ecc40b1a1f7711705174bdf2c7b6328f702a4267":()=>e.Uw,"400a3dd0ee8892f66a2e5604d6581fd23aa7a3cea5":()=>e.m,"400cb1f7d10be86025c029db9f8bae23f7c7496000":()=>e.cm,"400f1502baff617e4723ca3981ce687c276c48b759":()=>d.approveIssue,"401d32cbbd01c648cd56431798e978dfb425ec9e0b":()=>e.ju,"4026c880b44f2f21469a370f44f00cea0f670f3177":()=>e.I2,"4046442bdc21d1e6839fe89a0eaa873baf2538c3ff":()=>d.setAuto247,"4066e2a6e63fba23fc4c7e9e862f4f153d28402e09":()=>e.wp,"407bc313c8bc4b1e7c1c1364fcd5b440b84872e9f8":()=>e.az,"407e9aa8711c5ef7e274c016f412637c44a483fd40":()=>d.rejectIssue,"407ed923314dd0345588038a18fe9b55c8a8fbc857":()=>d.rejectSpec,"40c8d005e334f79c3d49673bd0c6cd2f849273b72e":()=>d.approveSpec,"40cbef8c22d0da6e4a36a8672c3bcb5fe20b5490a8":()=>e.Cp,"40e41f281f5ba97fe6181c0b4eb66011755ea7502c":()=>d.startNewWork,"40e73a917991bf0aac3c46efce7b609433595db67f":()=>f.mg,"40e9eeca52e7c9ad6dad0edc93d6c93b24f979ffde":()=>d.planFromConversation,"40f3f2d02634be4fdb0104759d54900ef00b744064":()=>e.L0,"40f9cd3fc6c6d8cae96897a561300a7232d723d346":()=>d.generatePlan,"40fd61509391be62062cf7a8fc99f5a2fbd01608d0":()=>d.advanceIssue,"608afcbccbaff8e6c4a43052c351055e65a62dd352":()=>d.groomBacklogFor,"60c90060eb97b05811e1cc6d6b7612c92c3560e129":()=>g.I,"60d913024db5bfa98065eac4cd36d9448b6edf6bc9":()=>f.eA,"60f0bea5ddad11025dc93938ce3faf0f92f28b665a":()=>g.k,"700e75ff9f4413bd6246cd5b30074325cb53225a6a":()=>f.LV});var d=c(56053),e=c(27989),f=c(76862),g=c(78848)},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")},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")},86439:a=>{a.exports=require("next/dist/shared/lib/no-fallback-error.external")},87550:a=>{a.exports=require("better-sqlite3")},95396:(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(55750),f=c(69743),g=c(38214),h=c(72584),i=c(65510),j=c(25026),k=c(261),l=c(26936),m=c(91226),n=c(75994),o=c(34185),p=c(57047),q=c(93277),r=c(51195),s=c(22204),t=c(86439),u=c(26242),v=c(24647),w=c(77598),x=c(1782),y=c(80280),z=c(25533),A=c(95896);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(55479),I=c(18661),J=c(96930),K=c(12867);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}}}};var b=require("../../../../webpack-runtime.js");b.C(a);var c=b.X(0,[3050,658,9676,1845,7971,3550,4804,4679,1572,4619,9969,7989,2867,6873,850,2960,8823],()=>b(b.s=95396));module.exports=c})();
|