@superinterface/server 1.0.23 → 1.0.25
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/cache/.tsbuildinfo +1 -1
- package/.next/cache/eslint/.cache_btwyo7 +1 -1
- package/.next/fallback-build-manifest.json +2 -2
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +1 -1
- package/.next/server/app/api/files/[fileId]/contents/route.js +3 -3
- package/.next/server/app/api/files/[fileId]/contents/route.js.nft.json +1 -1
- package/.next/server/app/api/files/route.js +3 -3
- package/.next/server/app/api/files/route.js.nft.json +1 -1
- package/.next/server/app/api/messages/route.js +6 -6
- package/.next/server/app/api/messages/route.js.nft.json +1 -1
- package/.next/server/app/api/tasks/callback/route.js +6 -7
- package/.next/server/app/api/tasks/callback/route.js.nft.json +1 -1
- package/.next/server/app/api/threads/runs/submit-client-tool-outputs/route.js +1 -1
- package/.next/server/app/api/threads/runs/submit-client-tool-outputs/route.js.nft.json +1 -1
- package/.next/server/app/index.html +1 -1
- package/.next/server/app/index.rsc +1 -1
- package/.next/server/chunks/[root-of-the-server]__0c1bc5ed._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__0c1bc5ed._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__228bff78._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__228bff78._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__25ee13bc._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__25ee13bc._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__2945c9e9._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__2945c9e9._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__29635e8e._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__29635e8e._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__29b43490._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__29b43490._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__315f084a._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__315f084a._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__3307123c._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__3307123c._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__40ab45eb._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__40ab45eb._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__441cee00._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__441cee00._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__464a4377._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__464a4377._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__4e536bc0._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__4e536bc0._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__50c5f12c._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__50c5f12c._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__583a7f1c._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__583a7f1c._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__5abf1160._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__5abf1160._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__5d09614a._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__5d09614a._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__62d958e7._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__62d958e7._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__676affb1._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__676affb1._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__6b8ba839._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__6b8ba839._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__72b72b9e._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__72b72b9e._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__83461316._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__83461316._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__9a611d42._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__9a611d42._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__a878c913._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__a878c913._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__b10ec83e._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__b10ec83e._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__c1629392._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__c1629392._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__dd176cb5._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__dd176cb5._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__e7819e95._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__e7819e95._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__eb816e13._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__eb816e13._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__f0dfab03._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__f0dfab03._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__f845ef25._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__f845ef25._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__ff90af03._.js +10 -10
- package/.next/server/chunks/[root-of-the-server]__ff90af03._.js.map +1 -1
- package/.next/server/chunks/c4f00_next_dist_esm_build_templates_app-route_cb746cf4.js +1 -1
- package/.next/server/chunks/c4f00_next_dist_esm_build_templates_app-route_cb746cf4.js.map +1 -1
- package/.next/server/chunks/c4f00_next_dist_esm_build_templates_app-route_f952d9ab.js +1 -1
- package/.next/server/chunks/c4f00_next_dist_esm_build_templates_app-route_f952d9ab.js.map +1 -1
- package/.next/server/chunks/supercorp_superinterface_bebd2c96._.js +3 -3
- package/.next/server/chunks/supercorp_superinterface_bebd2c96._.js.map +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +1 -1
- package/.next/trace +1 -1
- package/dist/app/api/api-keys/[apiKeyId]/route.d.ts +3 -48
- package/dist/app/api/api-keys/[apiKeyId]/route.d.ts.map +1 -1
- package/dist/app/api/api-keys/[apiKeyId]/route.js +3 -3
- package/dist/app/api/api-keys/route.d.ts +2 -24
- package/dist/app/api/api-keys/route.d.ts.map +1 -1
- package/dist/app/api/api-keys/route.js +2 -2
- package/dist/app/api/assistants/[assistantId]/functions/[functionId]/route.d.ts +3 -165
- package/dist/app/api/assistants/[assistantId]/functions/[functionId]/route.d.ts.map +1 -1
- package/dist/app/api/assistants/[assistantId]/functions/[functionId]/route.js +3 -3
- package/dist/app/api/assistants/[assistantId]/functions/route.d.ts +2 -108
- package/dist/app/api/assistants/[assistantId]/functions/route.d.ts.map +1 -1
- package/dist/app/api/assistants/[assistantId]/functions/route.js +2 -2
- package/dist/app/api/assistants/[assistantId]/initial-messages/route.d.ts +2 -34
- package/dist/app/api/assistants/[assistantId]/initial-messages/route.d.ts.map +1 -1
- package/dist/app/api/assistants/[assistantId]/initial-messages/route.js +2 -2
- package/dist/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.d.ts +3 -87
- package/dist/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.d.ts.map +1 -1
- package/dist/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.js +3 -3
- package/dist/app/api/assistants/[assistantId]/mcp-servers/route.d.ts +2 -56
- package/dist/app/api/assistants/[assistantId]/mcp-servers/route.d.ts.map +1 -1
- package/dist/app/api/assistants/[assistantId]/mcp-servers/route.js +2 -2
- package/dist/app/api/assistants/[assistantId]/route.d.ts +4 -117
- package/dist/app/api/assistants/[assistantId]/route.d.ts.map +1 -1
- package/dist/app/api/assistants/[assistantId]/route.js +3 -3
- package/dist/app/api/assistants/route.d.ts +2 -54
- package/dist/app/api/assistants/route.d.ts.map +1 -1
- package/dist/app/api/assistants/route.js +2 -2
- package/dist/app/api/files/[fileId]/contents/route.d.ts +1 -5
- package/dist/app/api/files/[fileId]/contents/route.d.ts.map +1 -1
- package/dist/app/api/files/[fileId]/contents/route.js +1 -1
- package/dist/app/api/files/route.d.ts +1 -7
- package/dist/app/api/files/route.d.ts.map +1 -1
- package/dist/app/api/files/route.js +1 -1
- package/dist/app/api/messages/lib/initialMessagesResponse.d.ts.map +1 -1
- package/dist/app/api/messages/lib/initialMessagesResponse.js +2 -3
- package/dist/app/api/messages/route.d.ts +2 -20
- package/dist/app/api/messages/route.d.ts.map +1 -1
- package/dist/app/api/messages/route.js +2 -2
- package/dist/app/api/providers/[modelProviderId]/assistants/route.d.ts +1 -16
- package/dist/app/api/providers/[modelProviderId]/assistants/route.d.ts.map +1 -1
- package/dist/app/api/providers/[modelProviderId]/assistants/route.js +1 -1
- package/dist/app/api/providers/[modelProviderId]/models/route.d.ts +1 -11
- package/dist/app/api/providers/[modelProviderId]/models/route.d.ts.map +1 -1
- package/dist/app/api/providers/[modelProviderId]/models/route.js +1 -1
- package/dist/app/api/providers/[modelProviderId]/route.d.ts +3 -57
- package/dist/app/api/providers/[modelProviderId]/route.d.ts.map +1 -1
- package/dist/app/api/providers/[modelProviderId]/route.js +3 -3
- package/dist/app/api/providers/route.d.ts +2 -30
- package/dist/app/api/providers/route.d.ts.map +1 -1
- package/dist/app/api/providers/route.js +2 -2
- package/dist/app/api/tasks/[taskId]/route.d.ts +3 -54
- package/dist/app/api/tasks/[taskId]/route.d.ts.map +1 -1
- package/dist/app/api/tasks/[taskId]/route.js +3 -3
- package/dist/app/api/tasks/callback/route.d.ts.map +1 -1
- package/dist/app/api/tasks/callback/route.js +2 -3
- package/dist/app/api/tasks/route.d.ts +2 -28
- package/dist/app/api/tasks/route.d.ts.map +1 -1
- package/dist/app/api/tasks/route.js +2 -2
- package/dist/app/api/threads/runs/submit-client-tool-outputs/route.d.ts +1 -5
- package/dist/app/api/threads/runs/submit-client-tool-outputs/route.d.ts.map +1 -1
- package/dist/app/api/threads/runs/submit-client-tool-outputs/route.js +3 -4
- package/dist/app/api/workspaces/[workspaceId]/route.d.ts +2 -28
- package/dist/app/api/workspaces/[workspaceId]/route.d.ts.map +1 -1
- package/dist/app/api/workspaces/[workspaceId]/route.js +2 -2
- package/dist/app/api/workspaces/route.d.ts +2 -20
- package/dist/app/api/workspaces/route.d.ts.map +1 -1
- package/dist/app/api/workspaces/route.js +2 -2
- package/dist/lib/functions/handleFunction/handleAssistant.d.ts.map +1 -1
- package/dist/lib/functions/handleFunction/handleAssistant.js +2 -3
- package/dist/lib/mcpServers/getToolCallMcpServer.d.ts.map +1 -1
- package/dist/lib/mcpServers/getToolCallMcpServer.js +5 -6
- package/dist/lib/prisma/index.d.ts.map +1 -1
- package/dist/lib/prisma/index.js +19 -5
- package/dist/lib/tools/tools/index.d.ts.map +1 -1
- package/dist/lib/tools/tools/index.js +2 -3
- package/package.json +11 -4
- package/.next/server/chunks/[root-of-the-server]__19865527._.js +0 -3
- package/.next/server/chunks/[root-of-the-server]__19865527._.js.map +0 -1
- package/.next/server/chunks/[root-of-the-server]__27aadac9._.js +0 -3
- package/.next/server/chunks/[root-of-the-server]__27aadac9._.js.map +0 -1
- package/.next/server/chunks/[root-of-the-server]__3ba06f7c._.js +0 -3
- package/.next/server/chunks/[root-of-the-server]__3ba06f7c._.js.map +0 -1
- package/.next/server/chunks/[root-of-the-server]__51977f30._.js +0 -3
- package/.next/server/chunks/[root-of-the-server]__51977f30._.js.map +0 -1
- package/.next/server/chunks/[root-of-the-server]__7f9ca1e3._.js +0 -3
- package/.next/server/chunks/[root-of-the-server]__7f9ca1e3._.js.map +0 -1
- package/.next/server/chunks/[root-of-the-server]__a135e388._.js +0 -3
- package/.next/server/chunks/[root-of-the-server]__a135e388._.js.map +0 -1
- package/dist/app/messages/lib/getWorkspaceId.d.ts +0 -6
- package/dist/app/messages/lib/getWorkspaceId.d.ts.map +0 -1
- package/dist/app/messages/lib/getWorkspaceId.js +0 -3
- package/dist/app/messages/lib/initialMessagesResponse.d.ts +0 -26
- package/dist/app/messages/lib/initialMessagesResponse.d.ts.map +0 -1
- package/dist/app/messages/lib/initialMessagesResponse.js +0 -59
- package/dist/app/messages/lib/serializeThread.d.ts +0 -18
- package/dist/app/messages/lib/serializeThread.d.ts.map +0 -1
- package/dist/app/messages/lib/serializeThread.js +0 -8
- package/dist/app/messages/route.d.ts +0 -31
- package/dist/app/messages/route.d.ts.map +0 -1
- package/dist/app/messages/route.js +0 -585
- package/dist/lib/prismaClient.d.ts +0 -5
- package/dist/lib/prismaClient.d.ts.map +0 -1
- package/dist/lib/prismaClient.js +0 -4
- /package/.next/static/{yTXEit1RwJfgpDwrdt6oQ → jt8inwg6nWaLQZ4qpiSJ-}/_buildManifest.js +0 -0
- /package/.next/static/{yTXEit1RwJfgpDwrdt6oQ → jt8inwg6nWaLQZ4qpiSJ-}/_clientMiddlewareManifest.json +0 -0
- /package/.next/static/{yTXEit1RwJfgpDwrdt6oQ → jt8inwg6nWaLQZ4qpiSJ-}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports=[9949,e=>{"use strict";e.s(["workspaceAccessWhere",()=>n]);var t=e.i(29173),r=e.i(88122);let n=async({publicApiKey:e,prisma:n})=>{let s=await (0,r.getApiKey)({authorization:e?`Bearer ${e}`:null,type:t.ApiKeyType.PUBLIC,prisma:n});return s?{apiKeys:{some:{id:s.id}}}:null}},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},20635,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/action-async-storage.external.js",()=>require("next/dist/server/app-render/action-async-storage.external.js"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},30611,e=>{"use strict";e.s(["cacheHeaders",()=>t]);let t={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type"}},88122,e=>{"use strict";e.s(["getApiKey",()=>r]);var t=e.i(55897);let r=async({authorization:e,type:r,prisma:n})=>{if(!e)return null;let[,s]=e.split("Bearer ");return(0,t.validate)(s)?n.apiKey.findFirst({where:{type:r,value:s}}):null}},75247,e=>{"use strict";e.s(["isArray",()=>t,"isEmpty",()=>o,"isFunction",()=>s,"isObject",()=>r,"isPrimitive",()=>n,"isString",()=>a]);let t=Array.isArray,r=e=>!!e&&e.constructor===Object,n=e=>null==e||"object"!=typeof e&&"function"!=typeof e,s=e=>!!(e&&e.constructor&&e.call&&e.apply),a=e=>"string"==typeof e||e instanceof String,i=e=>{try{return Number(e)===e}catch{return!1}},o=e=>{if(!0===e||!1===e||null==e)return!0;if(i(e))return 0===e;if("[object Date]"===Object.prototype.toString.call(e))return isNaN(e.getTime());if(s(e)||(e=>!!e&&e.constructor===Symbol)(e))return!1;let t=e.length;if(i(t))return 0===t;let r=e.size;return i(r)?0===r:0===Object.keys(e).length}},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},56512,(e,t,r)=>{e.e,t.exports=function(){"use strict";var e="millisecond",t="second",r="minute",n="hour",s="week",a="month",i="quarter",o="year",u="date",l="Invalid Date",c=/^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/,d=/\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,p=function(e,t,r){var n=String(e);return!n||n.length>=t?e:""+Array(t+1-n.length).join(r)+e},f="en",h={};h[f]={name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],r=e%100;return"["+e+(t[(r-20)%10]||t[r]||t[0])+"]"}};var v="$isDayjsObject",y=function(e){return e instanceof $||!(!e||!e[v])},g=function e(t,r,n){var s;if(!t)return f;if("string"==typeof t){var a=t.toLowerCase();h[a]&&(s=a),r&&(h[a]=r,s=a);var i=t.split("-");if(!s&&i.length>1)return e(i[0])}else{var o=t.name;h[o]=t,s=o}return!n&&s&&(f=s),s||!n&&f},m=function(e,t){if(y(e))return e.clone();var r="object"==typeof t?t:{};return r.date=e,r.args=arguments,new $(r)},x={s:p,z:function(e){var t=-e.utcOffset(),r=Math.abs(t);return(t<=0?"+":"-")+p(Math.floor(r/60),2,"0")+":"+p(r%60,2,"0")},m:function e(t,r){if(t.date()<r.date())return-e(r,t);var n=12*(r.year()-t.year())+(r.month()-t.month()),s=t.clone().add(n,a),i=r-s<0,o=t.clone().add(n+(i?-1:1),a);return+(-(n+(r-s)/(i?s-o:o-s))||0)},a:function(e){return e<0?Math.ceil(e)||0:Math.floor(e)},p:function(l){return({M:a,y:o,w:s,d:"day",D:u,h:n,m:r,s:t,ms:e,Q:i})[l]||String(l||"").toLowerCase().replace(/s$/,"")},u:function(e){return void 0===e}};x.l=g,x.i=y,x.w=function(e,t){return m(e,{locale:t.$L,utc:t.$u,x:t.$x,$offset:t.$offset})};var $=function(){function p(e){this.$L=g(e.locale,null,!0),this.parse(e),this.$x=this.$x||e.x||{},this[v]=!0}var f=p.prototype;return f.parse=function(e){this.$d=function(e){var t=e.date,r=e.utc;if(null===t)return new Date(NaN);if(x.u(t))return new Date;if(t instanceof Date)return new Date(t);if("string"==typeof t&&!/Z$/i.test(t)){var n=t.match(c);if(n){var s=n[2]-1||0,a=(n[7]||"0").substring(0,3);return r?new Date(Date.UTC(n[1],s,n[3]||1,n[4]||0,n[5]||0,n[6]||0,a)):new Date(n[1],s,n[3]||1,n[4]||0,n[5]||0,n[6]||0,a)}}return new Date(t)}(e),this.init()},f.init=function(){var e=this.$d;this.$y=e.getFullYear(),this.$M=e.getMonth(),this.$D=e.getDate(),this.$W=e.getDay(),this.$H=e.getHours(),this.$m=e.getMinutes(),this.$s=e.getSeconds(),this.$ms=e.getMilliseconds()},f.$utils=function(){return x},f.isValid=function(){return this.$d.toString()!==l},f.isSame=function(e,t){var r=m(e);return this.startOf(t)<=r&&r<=this.endOf(t)},f.isAfter=function(e,t){return m(e)<this.startOf(t)},f.isBefore=function(e,t){return this.endOf(t)<m(e)},f.$g=function(e,t,r){return x.u(e)?this[t]:this.set(r,e)},f.unix=function(){return Math.floor(this.valueOf()/1e3)},f.valueOf=function(){return this.$d.getTime()},f.startOf=function(e,i){var l=this,c=!!x.u(i)||i,d=x.p(e),p=function(e,t){var r=x.w(l.$u?Date.UTC(l.$y,t,e):new Date(l.$y,t,e),l);return c?r:r.endOf("day")},f=function(e,t){return x.w(l.toDate()[e].apply(l.toDate("s"),(c?[0,0,0,0]:[23,59,59,999]).slice(t)),l)},h=this.$W,v=this.$M,y=this.$D,g="set"+(this.$u?"UTC":"");switch(d){case o:return c?p(1,0):p(31,11);case a:return c?p(1,v):p(0,v+1);case s:var m=this.$locale().weekStart||0,$=(h<m?h+7:h)-m;return p(c?y-$:y+(6-$),v);case"day":case u:return f(g+"Hours",0);case n:return f(g+"Minutes",1);case r:return f(g+"Seconds",2);case t:return f(g+"Milliseconds",3);default:return this.clone()}},f.endOf=function(e){return this.startOf(e,!1)},f.$set=function(s,i){var l,c=x.p(s),d="set"+(this.$u?"UTC":""),p=((l={}).day=d+"Date",l[u]=d+"Date",l[a]=d+"Month",l[o]=d+"FullYear",l[n]=d+"Hours",l[r]=d+"Minutes",l[t]=d+"Seconds",l[e]=d+"Milliseconds",l)[c],f="day"===c?this.$D+(i-this.$W):i;if(c===a||c===o){var h=this.clone().set(u,1);h.$d[p](f),h.init(),this.$d=h.set(u,Math.min(this.$D,h.daysInMonth())).$d}else p&&this.$d[p](f);return this.init(),this},f.set=function(e,t){return this.clone().$set(e,t)},f.get=function(e){return this[x.p(e)]()},f.add=function(e,i){var u,l=this;e=Number(e);var c=x.p(i),d=function(t){var r=m(l);return x.w(r.date(r.date()+Math.round(t*e)),l)};if(c===a)return this.set(a,this.$M+e);if(c===o)return this.set(o,this.$y+e);if("day"===c)return d(1);if(c===s)return d(7);var p=((u={})[r]=6e4,u[n]=36e5,u[t]=1e3,u)[c]||1,f=this.$d.getTime()+e*p;return x.w(f,this)},f.subtract=function(e,t){return this.add(-1*e,t)},f.format=function(e){var t=this,r=this.$locale();if(!this.isValid())return r.invalidDate||l;var n=e||"YYYY-MM-DDTHH:mm:ssZ",s=x.z(this),a=this.$H,i=this.$m,o=this.$M,u=r.weekdays,c=r.months,p=r.meridiem,f=function(e,r,s,a){return e&&(e[r]||e(t,n))||s[r].slice(0,a)},h=function(e){return x.s(a%12||12,e,"0")},v=p||function(e,t,r){var n=e<12?"AM":"PM";return r?n.toLowerCase():n};return n.replace(d,function(e,n){return n||function(e){switch(e){case"YY":return String(t.$y).slice(-2);case"YYYY":return x.s(t.$y,4,"0");case"M":return o+1;case"MM":return x.s(o+1,2,"0");case"MMM":return f(r.monthsShort,o,c,3);case"MMMM":return f(c,o);case"D":return t.$D;case"DD":return x.s(t.$D,2,"0");case"d":return String(t.$W);case"dd":return f(r.weekdaysMin,t.$W,u,2);case"ddd":return f(r.weekdaysShort,t.$W,u,3);case"dddd":return u[t.$W];case"H":return String(a);case"HH":return x.s(a,2,"0");case"h":return h(1);case"hh":return h(2);case"a":return v(a,i,!0);case"A":return v(a,i,!1);case"m":return String(i);case"mm":return x.s(i,2,"0");case"s":return String(t.$s);case"ss":return x.s(t.$s,2,"0");case"SSS":return x.s(t.$ms,3,"0");case"Z":return s}return null}(e)||s.replace(":","")})},f.utcOffset=function(){return-(15*Math.round(this.$d.getTimezoneOffset()/15))},f.diff=function(e,u,l){var c,d=this,p=x.p(u),f=m(e),h=(f.utcOffset()-this.utcOffset())*6e4,v=this-f,y=function(){return x.m(d,f)};switch(p){case o:c=y()/12;break;case a:c=y();break;case i:c=y()/3;break;case s:c=(v-h)/6048e5;break;case"day":c=(v-h)/864e5;break;case n:c=v/36e5;break;case r:c=v/6e4;break;case t:c=v/1e3;break;default:c=v}return l?c:x.a(c)},f.daysInMonth=function(){return this.endOf(a).$D},f.$locale=function(){return h[this.$L]},f.locale=function(e,t){if(!e)return this.$L;var r=this.clone(),n=g(e,t,!0);return n&&(r.$L=n),r},f.clone=function(){return x.w(this.$d,this)},f.toDate=function(){return new Date(this.valueOf())},f.toJSON=function(){return this.isValid()?this.toISOString():null},f.toISOString=function(){return this.$d.toISOString()},f.toString=function(){return this.$d.toUTCString()},p}(),w=$.prototype;return m.prototype=w,[["$ms",e],["$s",t],["$m",r],["$H",n],["$W","day"],["$M",a],["$y",o],["$D",u]].forEach(function(e){w[e[1]]=function(t){return this.$g(t,e[0],e[1])}}),m.extend=function(e,t){return e.$i||(e(t,$,m),e.$i=!0),m},m.locale=g,m.isDayjs=y,m.unix=function(e){return m(1e3*e)},m.en=h[f],m.Ls=h,m.p={},m}()},60942,e=>{"use strict";e.s([])},89342,e=>{"use strict";e.s(["handler",()=>k,"patchFetch",()=>N,"routeModule",()=>O,"serverHooks",()=>E,"workAsyncStorage",()=>D,"workUnitAsyncStorage",()=>C],89342);var t=e.i(5865),r=e.i(43877),n=e.i(77767),s=e.i(92562),a=e.i(66256),i=e.i(5270),o=e.i(90231),u=e.i(82677),l=e.i(51081),c=e.i(89822),d=e.i(9124),p=e.i(39147),f=e.i(40568),h=e.i(87188),v=e.i(93695);e.i(57132);var y=e.i(80739);e.s(["GET",()=>T,"OPTIONS",()=>b,"buildGET",()=>M],82465);var g=e.i(75247),m=e.i(49493),x=e.i(30611),$=e.i(95690),w=e.i(9949),R=e.i(24493),S=e.i(9394);let M=({prisma:e,purposeAssistantsResponse:t=()=>m.NextResponse.json({error:"No file source found"},{status:404})}={})=>async(r,n)=>{let s=(0,R.resolvePrisma)(e),{fileId:a}=await n.params,i=r.nextUrl.searchParams.get("assistantId");if(!(0,g.isString)(i))return m.NextResponse.json({error:"Invalid assistantId"},{status:400});let o=r.nextUrl.searchParams.get("publicApiKey");if(!(0,g.isString)(o))return m.NextResponse.json({error:"Invalid publicApiKey"},{status:400});let u=await (0,w.workspaceAccessWhere)({publicApiKey:o,prisma:s});if(!u)return m.NextResponse.json({error:"Invalid api key"},{status:400});if(!i)return m.NextResponse.json({error:"No assistantId found"},{status:400});let l=await s.assistant.findFirst({where:{id:i,workspace:u},include:{modelProvider:!0,tools:{include:{fileSearchTool:!0,webSearchTool:!0,imageGenerationTool:!0,codeInterpreterTool:!0,computerUseTool:!0}},mcpServers:{include:{computerUseTool:!0,stdioTransport:!0,sseTransport:!0,httpTransport:!0}},functions:!0}});if(!l)return m.NextResponse.json({error:"No assistant found"},{status:400});if((0,S.isOpenaiAssistantsStorageProvider)({storageProviderType:l.storageProviderType})&&!l.openaiAssistantId)return m.NextResponse.json({error:"Assistant setup is not done."},{status:400});let c=(0,$.assistantClientAdapter)({assistant:l,prisma:s}),d=await c.files.retrieve(a);if(!d)return m.NextResponse.json({error:"No file found"},{status:404});if("assistants"===d.purpose)return t({file:d,workspaceAccessWhere:u});let p=await c.files.content(a),f=await p.arrayBuffer();return new m.NextResponse(f,{headers:{...x.cacheHeaders,"Content-Type":p.headers.get("Content-Type")??"application/octet-stream","Content-Disposition":p.headers.get("Content-Disposition")??"inline"}})},T=(...e)=>M({})(...e),b=()=>m.NextResponse.json({},{headers:x.cacheHeaders});var A=e.i(82465);let O=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/files/[fileId]/contents/route",pathname:"/api/files/[fileId]/contents",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/supercorp/superinterface/packages/server/src/app/api/files/[fileId]/contents/route.ts",nextConfigOutput:"",userland:A}),{workAsyncStorage:D,workUnitAsyncStorage:C,serverHooks:E}=O;function N(){return(0,n.patchFetch)({workAsyncStorage:D,workUnitAsyncStorage:C})}async function k(e,t,n){var g;let m="/api/files/[fileId]/contents/route";m=m.replace(/\/index$/,"")||"/";let x=await O.prepare(e,t,{srcPage:m,multiZoneDraftMode:!1});if(!x)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:$,params:w,nextConfig:R,isDraftMode:S,prerenderManifest:M,routerServerContext:T,isOnDemandRevalidate:b,revalidateOnlyGenerated:A,resolvedPathname:D}=x,C=(0,i.normalizeAppPath)(m),E=!!(M.dynamicRoutes[C]||M.routes[D]);if(E&&!S){let e=!!M.routes[D],t=M.dynamicRoutes[C];if(t&&!1===t.fallback&&!e)throw new v.NoFallbackError}let N=null;!E||O.isDev||S||(N="/index"===(N=D)?"/":N);let k=!0===O.isDev||!E,_=E&&!k,j=e.method||"GET",P=(0,a.getTracer)(),I=P.getActiveScopeSpan(),H={params:w,prerenderManifest:M,renderOpts:{experimental:{cacheComponents:!!R.experimental.cacheComponents,authInterrupts:!!R.experimental.authInterrupts},supportsDynamicResponse:k,incrementalCache:(0,s.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:null==(g=R.experimental)?void 0:g.cacheLife,isRevalidate:_,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n)=>O.onRequestError(e,t,n,T)},sharedContext:{buildId:$}},U=new o.NodeNextRequest(e),q=new o.NodeNextResponse(t),L=u.NextRequestAdapter.fromNodeNextRequest(U,(0,u.signalFromNodeResponse)(t));try{let i=async r=>O.handle(L,H).finally(()=>{if(!r)return;r.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let n=P.getRootSpanAttributes();if(!n)return;if(n.get("next.span_type")!==l.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${n.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let s=n.get("next.route");if(s){let e=`${j} ${s}`;r.setAttributes({"next.route":s,"http.route":s,"next.span_name":e}),r.updateName(e)}else r.updateName(`${j} ${e.url}`)}),o=async a=>{var o,u;let l=async({previousCacheEntry:r})=>{try{if(!(0,s.getRequestMeta)(e,"minimalMode")&&b&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await i(a);e.fetchMetrics=H.renderOpts.fetchMetrics;let u=H.renderOpts.pendingWaitUntil;u&&n.waitUntil&&(n.waitUntil(u),u=void 0);let l=H.renderOpts.collectedTags;if(!E)return await (0,d.sendResponse)(U,q,o,H.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,p.toNodeOutgoingHttpHeaders)(o.headers);l&&(t[h.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==H.renderOpts.collectedRevalidate&&!(H.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&H.renderOpts.collectedRevalidate,n=void 0===H.renderOpts.collectedExpire||H.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:H.renderOpts.collectedExpire;return{value:{kind:y.CachedRouteKind.APP_ROUTE,status:o.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await O.onRequestError(e,t,{routerKind:"App Router",routePath:m,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isRevalidate:_,isOnDemandRevalidate:b})},T),t}},v=await O.handleResponse({req:e,nextConfig:R,cacheKey:N,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:M,isRoutePPREnabled:!1,isOnDemandRevalidate:b,revalidateOnlyGenerated:A,responseGenerator:l,waitUntil:n.waitUntil});if(!E)return null;if((null==v||null==(o=v.value)?void 0:o.kind)!==y.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==v||null==(u=v.value)?void 0:u.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});(0,s.getRequestMeta)(e,"minimalMode")||t.setHeader("x-nextjs-cache",b?"REVALIDATED":v.isMiss?"MISS":v.isStale?"STALE":"HIT"),S&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let g=(0,p.fromNodeOutgoingHttpHeaders)(v.value.headers);return(0,s.getRequestMeta)(e,"minimalMode")&&E||g.delete(h.NEXT_CACHE_TAGS_HEADER),!v.cacheControl||t.getHeader("Cache-Control")||g.get("Cache-Control")||g.set("Cache-Control",(0,f.getCacheControlHeader)(v.cacheControl)),await (0,d.sendResponse)(U,q,new Response(v.value.body,{headers:g,status:v.value.status||200})),null};I?await o(I):await P.withPropagatedContext(e.headers,()=>P.trace(l.BaseServerSpan.handleRequest,{spanName:`${j} ${e.url}`,kind:a.SpanKind.SERVER,attributes:{"http.method":j,"http.target":e.url}},o))}catch(t){if(t instanceof v.NoFallbackError||await O.onRequestError(e,t,{routerKind:"App Router",routePath:C,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isRevalidate:_,isOnDemandRevalidate:b})}),E)throw t;return await (0,d.sendResponse)(U,q,new Response(null,{status:500})),null}}},93814,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__00f22293._.js"].map(t=>e.l(t))).then(()=>t(50213)))},70729,e=>{e.v(e=>Promise.resolve().then(()=>e(66680)))}];
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__40ab45eb._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/apiKeys/workspaceAccessWhere.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/cache/cacheHeaders.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/apiKeys/getApiKey.ts","turbopack:///[project]/supercorp/superinterface/node_modules/radash/src/typed.ts","turbopack:///[project]/supercorp/superinterface/node_modules/dayjs/dayjs.min.js","turbopack:///[project]/supercorp/superinterface/node_modules/next/dist/esm/build/templates/app-route.js","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/files/[fileId]/contents/route.ts"],"sourcesContent":["import { ApiKeyType, type PrismaClient } from '@prisma/client'\nimport { getApiKey } from './getApiKey'\n\nexport const workspaceAccessWhere = async ({\n publicApiKey,\n prisma,\n}: {\n publicApiKey: string | null\n prisma: PrismaClient\n}) => {\n const apiKey = await getApiKey({\n authorization: publicApiKey ? `Bearer ${publicApiKey}` : null,\n type: ApiKeyType.PUBLIC,\n prisma,\n })\n\n if (!apiKey) return null\n\n return {\n apiKeys: {\n some: { id: apiKey.id },\n },\n }\n}\n","export const cacheHeaders = {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',\n 'Access-Control-Allow-Headers': 'Content-Type',\n}\n","import { ApiKeyType, ApiKey, type PrismaClient } from '@prisma/client'\nimport { validate } from 'uuid'\n\nexport const getApiKey = async ({\n authorization,\n type,\n prisma,\n}: {\n authorization: string | null\n type: ApiKeyType\n prisma: PrismaClient\n}): Promise<ApiKey | null> => {\n if (!authorization) {\n return null\n }\n\n const [, apiKeyValue] = authorization.split('Bearer ')\n\n if (!validate(apiKeyValue)) {\n return null\n }\n\n return prisma.apiKey.findFirst({\n where: { type, value: apiKeyValue },\n })\n}\n","export const isSymbol = (value: any): value is symbol => {\n return !!value && value.constructor === Symbol\n}\n\nexport const isArray = Array.isArray\n\nexport const isObject = (value: any): value is object => {\n return !!value && value.constructor === Object\n}\n\n/**\n * Checks if the given value is primitive.\n *\n * Primitive Types: number , string , boolean , symbol, bigint, undefined, null\n *\n * @param {*} value value to check\n * @returns {boolean} result\n */\nexport const isPrimitive = (value: any): boolean => {\n return (\n value === undefined ||\n value === null ||\n (typeof value !== 'object' && typeof value !== 'function')\n )\n}\n\nexport const isFunction = (value: any): value is Function => {\n return !!(value && value.constructor && value.call && value.apply)\n}\n\nexport const isString = (value: any): value is string => {\n return typeof value === 'string' || value instanceof String\n}\n\nexport const isInt = (value: any): value is number => {\n return isNumber(value) && value % 1 === 0\n}\n\nexport const isFloat = (value: any): value is number => {\n return isNumber(value) && value % 1 !== 0\n}\n\nexport const isNumber = (value: any): value is number => {\n try {\n return Number(value) === value\n } catch {\n return false\n }\n}\n\nexport const isDate = (value: any): value is Date => {\n return Object.prototype.toString.call(value) === '[object Date]'\n}\n\n/**\n * This is really a _best guess_ promise checking. You\n * should probably use Promise.resolve(value) to be 100%\n * sure you're handling it correctly.\n */\nexport const isPromise = (value: any): value is Promise<any> => {\n if (!value) return false\n if (!value.then) return false\n if (!isFunction(value.then)) return false\n return true\n}\n\nexport const isEmpty = (value: any) => {\n if (value === true || value === false) return true\n if (value === null || value === undefined) return true\n if (isNumber(value)) return value === 0\n if (isDate(value)) return isNaN(value.getTime())\n if (isFunction(value)) return false\n if (isSymbol(value)) return false\n const length = (value as any).length\n if (isNumber(length)) return length === 0\n const size = (value as any).size\n if (isNumber(size)) return size === 0\n const keys = Object.keys(value).length\n return keys === 0\n}\n\nexport const isEqual = <TType>(x: TType, y: TType): boolean => {\n if (Object.is(x, y)) return true\n if (x instanceof Date && y instanceof Date) {\n return x.getTime() === y.getTime()\n }\n if (x instanceof RegExp && y instanceof RegExp) {\n return x.toString() === y.toString()\n }\n if (\n typeof x !== 'object' ||\n x === null ||\n typeof y !== 'object' ||\n y === null\n ) {\n return false\n }\n const keysX = Reflect.ownKeys(x as unknown as object) as (keyof typeof x)[]\n const keysY = Reflect.ownKeys(y as unknown as object)\n if (keysX.length !== keysY.length) return false\n for (let i = 0; i < keysX.length; i++) {\n if (!Reflect.has(y as unknown as object, keysX[i])) return false\n if (!isEqual(x[keysX[i]], y[keysX[i]])) return false\n }\n return true\n}\n","!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(t=\"undefined\"!=typeof globalThis?globalThis:t||self).dayjs=e()}(this,(function(){\"use strict\";var t=1e3,e=6e4,n=36e5,r=\"millisecond\",i=\"second\",s=\"minute\",u=\"hour\",a=\"day\",o=\"week\",c=\"month\",f=\"quarter\",h=\"year\",d=\"date\",l=\"Invalid Date\",$=/^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/,y=/\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,M={name:\"en\",weekdays:\"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday\".split(\"_\"),months:\"January_February_March_April_May_June_July_August_September_October_November_December\".split(\"_\"),ordinal:function(t){var e=[\"th\",\"st\",\"nd\",\"rd\"],n=t%100;return\"[\"+t+(e[(n-20)%10]||e[n]||e[0])+\"]\"}},m=function(t,e,n){var r=String(t);return!r||r.length>=e?t:\"\"+Array(e+1-r.length).join(n)+t},v={s:m,z:function(t){var e=-t.utcOffset(),n=Math.abs(e),r=Math.floor(n/60),i=n%60;return(e<=0?\"+\":\"-\")+m(r,2,\"0\")+\":\"+m(i,2,\"0\")},m:function t(e,n){if(e.date()<n.date())return-t(n,e);var r=12*(n.year()-e.year())+(n.month()-e.month()),i=e.clone().add(r,c),s=n-i<0,u=e.clone().add(r+(s?-1:1),c);return+(-(r+(n-i)/(s?i-u:u-i))||0)},a:function(t){return t<0?Math.ceil(t)||0:Math.floor(t)},p:function(t){return{M:c,y:h,w:o,d:a,D:d,h:u,m:s,s:i,ms:r,Q:f}[t]||String(t||\"\").toLowerCase().replace(/s$/,\"\")},u:function(t){return void 0===t}},g=\"en\",D={};D[g]=M;var p=\"$isDayjsObject\",S=function(t){return t instanceof _||!(!t||!t[p])},w=function t(e,n,r){var i;if(!e)return g;if(\"string\"==typeof e){var s=e.toLowerCase();D[s]&&(i=s),n&&(D[s]=n,i=s);var u=e.split(\"-\");if(!i&&u.length>1)return t(u[0])}else{var a=e.name;D[a]=e,i=a}return!r&&i&&(g=i),i||!r&&g},O=function(t,e){if(S(t))return t.clone();var n=\"object\"==typeof e?e:{};return n.date=t,n.args=arguments,new _(n)},b=v;b.l=w,b.i=S,b.w=function(t,e){return O(t,{locale:e.$L,utc:e.$u,x:e.$x,$offset:e.$offset})};var _=function(){function M(t){this.$L=w(t.locale,null,!0),this.parse(t),this.$x=this.$x||t.x||{},this[p]=!0}var m=M.prototype;return m.parse=function(t){this.$d=function(t){var e=t.date,n=t.utc;if(null===e)return new Date(NaN);if(b.u(e))return new Date;if(e instanceof Date)return new Date(e);if(\"string\"==typeof e&&!/Z$/i.test(e)){var r=e.match($);if(r){var i=r[2]-1||0,s=(r[7]||\"0\").substring(0,3);return n?new Date(Date.UTC(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)):new Date(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)}}return new Date(e)}(t),this.init()},m.init=function(){var t=this.$d;this.$y=t.getFullYear(),this.$M=t.getMonth(),this.$D=t.getDate(),this.$W=t.getDay(),this.$H=t.getHours(),this.$m=t.getMinutes(),this.$s=t.getSeconds(),this.$ms=t.getMilliseconds()},m.$utils=function(){return b},m.isValid=function(){return!(this.$d.toString()===l)},m.isSame=function(t,e){var n=O(t);return this.startOf(e)<=n&&n<=this.endOf(e)},m.isAfter=function(t,e){return O(t)<this.startOf(e)},m.isBefore=function(t,e){return this.endOf(e)<O(t)},m.$g=function(t,e,n){return b.u(t)?this[e]:this.set(n,t)},m.unix=function(){return Math.floor(this.valueOf()/1e3)},m.valueOf=function(){return this.$d.getTime()},m.startOf=function(t,e){var n=this,r=!!b.u(e)||e,f=b.p(t),l=function(t,e){var i=b.w(n.$u?Date.UTC(n.$y,e,t):new Date(n.$y,e,t),n);return r?i:i.endOf(a)},$=function(t,e){return b.w(n.toDate()[t].apply(n.toDate(\"s\"),(r?[0,0,0,0]:[23,59,59,999]).slice(e)),n)},y=this.$W,M=this.$M,m=this.$D,v=\"set\"+(this.$u?\"UTC\":\"\");switch(f){case h:return r?l(1,0):l(31,11);case c:return r?l(1,M):l(0,M+1);case o:var g=this.$locale().weekStart||0,D=(y<g?y+7:y)-g;return l(r?m-D:m+(6-D),M);case a:case d:return $(v+\"Hours\",0);case u:return $(v+\"Minutes\",1);case s:return $(v+\"Seconds\",2);case i:return $(v+\"Milliseconds\",3);default:return this.clone()}},m.endOf=function(t){return this.startOf(t,!1)},m.$set=function(t,e){var n,o=b.p(t),f=\"set\"+(this.$u?\"UTC\":\"\"),l=(n={},n[a]=f+\"Date\",n[d]=f+\"Date\",n[c]=f+\"Month\",n[h]=f+\"FullYear\",n[u]=f+\"Hours\",n[s]=f+\"Minutes\",n[i]=f+\"Seconds\",n[r]=f+\"Milliseconds\",n)[o],$=o===a?this.$D+(e-this.$W):e;if(o===c||o===h){var y=this.clone().set(d,1);y.$d[l]($),y.init(),this.$d=y.set(d,Math.min(this.$D,y.daysInMonth())).$d}else l&&this.$d[l]($);return this.init(),this},m.set=function(t,e){return this.clone().$set(t,e)},m.get=function(t){return this[b.p(t)]()},m.add=function(r,f){var d,l=this;r=Number(r);var $=b.p(f),y=function(t){var e=O(l);return b.w(e.date(e.date()+Math.round(t*r)),l)};if($===c)return this.set(c,this.$M+r);if($===h)return this.set(h,this.$y+r);if($===a)return y(1);if($===o)return y(7);var M=(d={},d[s]=e,d[u]=n,d[i]=t,d)[$]||1,m=this.$d.getTime()+r*M;return b.w(m,this)},m.subtract=function(t,e){return this.add(-1*t,e)},m.format=function(t){var e=this,n=this.$locale();if(!this.isValid())return n.invalidDate||l;var r=t||\"YYYY-MM-DDTHH:mm:ssZ\",i=b.z(this),s=this.$H,u=this.$m,a=this.$M,o=n.weekdays,c=n.months,f=n.meridiem,h=function(t,n,i,s){return t&&(t[n]||t(e,r))||i[n].slice(0,s)},d=function(t){return b.s(s%12||12,t,\"0\")},$=f||function(t,e,n){var r=t<12?\"AM\":\"PM\";return n?r.toLowerCase():r};return r.replace(y,(function(t,r){return r||function(t){switch(t){case\"YY\":return String(e.$y).slice(-2);case\"YYYY\":return b.s(e.$y,4,\"0\");case\"M\":return a+1;case\"MM\":return b.s(a+1,2,\"0\");case\"MMM\":return h(n.monthsShort,a,c,3);case\"MMMM\":return h(c,a);case\"D\":return e.$D;case\"DD\":return b.s(e.$D,2,\"0\");case\"d\":return String(e.$W);case\"dd\":return h(n.weekdaysMin,e.$W,o,2);case\"ddd\":return h(n.weekdaysShort,e.$W,o,3);case\"dddd\":return o[e.$W];case\"H\":return String(s);case\"HH\":return b.s(s,2,\"0\");case\"h\":return d(1);case\"hh\":return d(2);case\"a\":return $(s,u,!0);case\"A\":return $(s,u,!1);case\"m\":return String(u);case\"mm\":return b.s(u,2,\"0\");case\"s\":return String(e.$s);case\"ss\":return b.s(e.$s,2,\"0\");case\"SSS\":return b.s(e.$ms,3,\"0\");case\"Z\":return i}return null}(t)||i.replace(\":\",\"\")}))},m.utcOffset=function(){return 15*-Math.round(this.$d.getTimezoneOffset()/15)},m.diff=function(r,d,l){var $,y=this,M=b.p(d),m=O(r),v=(m.utcOffset()-this.utcOffset())*e,g=this-m,D=function(){return b.m(y,m)};switch(M){case h:$=D()/12;break;case c:$=D();break;case f:$=D()/3;break;case o:$=(g-v)/6048e5;break;case a:$=(g-v)/864e5;break;case u:$=g/n;break;case s:$=g/e;break;case i:$=g/t;break;default:$=g}return l?$:b.a($)},m.daysInMonth=function(){return this.endOf(c).$D},m.$locale=function(){return D[this.$L]},m.locale=function(t,e){if(!t)return this.$L;var n=this.clone(),r=w(t,e,!0);return r&&(n.$L=r),n},m.clone=function(){return b.w(this.$d,this)},m.toDate=function(){return new Date(this.valueOf())},m.toJSON=function(){return this.isValid()?this.toISOString():null},m.toISOString=function(){return this.$d.toISOString()},m.toString=function(){return this.$d.toUTCString()},M}(),k=_.prototype;return O.prototype=k,[[\"$ms\",r],[\"$s\",i],[\"$m\",s],[\"$H\",u],[\"$W\",a],[\"$M\",c],[\"$y\",h],[\"$D\",d]].forEach((function(t){k[t[1]]=function(e){return this.$g(e,t[0],t[1])}})),O.extend=function(t,e){return t.$i||(t(e,_,O),t.$i=!0),O},O.locale=w,O.isDayjs=S,O.unix=function(t){return O(1e3*t)},O.en=D[g],O.Ls=D,O.p={},O}));","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/files/[fileId]/contents/route\",\n pathname: \"/api/files/[fileId]/contents\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/supercorp/superinterface/packages/server/src/app/api/files/[fileId]/contents/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n var _nextConfig_experimental;\n let srcPage = \"/api/files/[fileId]/contents/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isRevalidate = isIsr && !supportsDynamicResponse;\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n cacheComponents: Boolean(nextConfig.experimental.cacheComponents),\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: (_nextConfig_experimental = nextConfig.experimental) == null ? void 0 : _nextConfig_experimental.cacheLife,\n isRevalidate,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${req.url}`);\n }\n });\n };\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!getRequestMeta(req, 'minimalMode') && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!getRequestMeta(req, 'minimalMode')) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(getRequestMeta(req, 'minimalMode') && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${req.url}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n","import type { OpenAI } from 'openai'\nimport { isString } from 'radash'\nimport { type Prisma, type PrismaClient } from '@prisma/client'\nimport { type NextRequest, NextResponse } from 'next/server'\nimport { cacheHeaders } from '@/lib/cache/cacheHeaders'\nimport { assistantClientAdapter } from '@/lib/assistants/assistantClientAdapter'\nimport { workspaceAccessWhere as getWorkspaceAccessWhere } from '@/lib/apiKeys/workspaceAccessWhere'\nimport { resolvePrisma } from '@/lib/prisma'\nimport { isOpenaiAssistantsStorageProvider } from '@/lib/storageProviders/isOpenaiAssistantsStorageProvider'\n\nexport const buildGET =\n ({\n prisma: providedPrisma,\n purposeAssistantsResponse = () =>\n NextResponse.json({ error: 'No file source found' }, { status: 404 }),\n }: {\n prisma?: PrismaClient\n purposeAssistantsResponse?: ({\n file,\n }: {\n file: OpenAI.Files.FileObject\n workspaceAccessWhere: Prisma.WorkspaceWhereInput\n }) => Promise<NextResponse> | NextResponse\n } = {}) =>\n async (\n request: NextRequest,\n props: {\n params: Promise<{\n fileId: string\n }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const params = await props.params\n\n const { fileId } = params\n\n const assistantId = request.nextUrl.searchParams.get('assistantId')\n\n if (!isString(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistantId' },\n { status: 400 },\n )\n }\n\n const publicApiKey = request.nextUrl.searchParams.get('publicApiKey')\n\n if (!isString(publicApiKey)) {\n return NextResponse.json(\n { error: 'Invalid publicApiKey' },\n { status: 400 },\n )\n }\n\n const workspaceAccessWhere = await getWorkspaceAccessWhere({\n publicApiKey,\n prisma,\n })\n\n if (!workspaceAccessWhere) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!assistantId) {\n return NextResponse.json(\n { error: 'No assistantId found' },\n { status: 400 },\n )\n }\n\n const assistant = await prisma.assistant.findFirst({\n where: {\n id: assistantId,\n workspace: workspaceAccessWhere,\n },\n include: {\n modelProvider: true,\n tools: {\n include: {\n fileSearchTool: true,\n webSearchTool: true,\n imageGenerationTool: true,\n codeInterpreterTool: true,\n computerUseTool: true,\n },\n },\n mcpServers: {\n include: {\n computerUseTool: true,\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n functions: true,\n },\n })\n\n if (!assistant) {\n return NextResponse.json({ error: 'No assistant found' }, { status: 400 })\n }\n\n if (\n isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }) &&\n !assistant.openaiAssistantId\n ) {\n return NextResponse.json(\n { error: 'Assistant setup is not done.' },\n { status: 400 },\n )\n }\n\n const assistantClient = assistantClientAdapter({ assistant, prisma })\n\n const file = await assistantClient.files.retrieve(fileId)\n\n if (!file) {\n return NextResponse.json({ error: 'No file found' }, { status: 404 })\n }\n\n if (file.purpose === 'assistants') {\n return purposeAssistantsResponse({ file, workspaceAccessWhere })\n }\n\n const fileContentResponse = await assistantClient.files.content(fileId)\n const fileData = await fileContentResponse.arrayBuffer()\n\n return new NextResponse(fileData, {\n headers: {\n ...cacheHeaders,\n 'Content-Type':\n fileContentResponse.headers.get('Content-Type') ??\n 'application/octet-stream',\n 'Content-Disposition':\n fileContentResponse.headers.get('Content-Disposition') ?? 'inline',\n },\n })\n }\n\nexport const GET = ((...args: Parameters<ReturnType<typeof buildGET>>) =>\n buildGET({})(...args)) as ReturnType<typeof buildGET>\n\nexport const OPTIONS = () =>\n NextResponse.json(\n {},\n {\n headers: cacheHeaders,\n },\n )\n"],"names":[],"mappings":"0EAAA,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAEO,IAAM,EAAuB,MAAO,CACzC,cAAY,QACZ,CAAM,CAIP,IACC,IAAM,EAAS,MAAM,CAAA,EAAA,EAAA,SAAA,AAAS,EAAC,CAC7B,cAAe,EAAe,CAAC,OAAO,EAAE,EAAA,CAAc,CAAG,KACzD,KAAM,EAAA,UAAU,CAAC,MAAM,QACvB,CACF,UAEA,AAAK,EAEE,CACL,CAHE,IAAS,GAGF,CACP,KAAM,CAAE,GAAI,EAAO,EAAG,AAAD,CACvB,CACF,EANoB,IAOtB,gjCCvBO,IAAM,EAAe,CAC1B,8BAA+B,IAC/B,+BAAgC,kCAChC,+BAAgC,cAClC,mDCHA,IAAA,EAAA,EAAA,CAAA,CAAA,OAEO,IAAM,EAAY,MAAO,eAC9B,CAAa,CACb,MAAI,QACJ,CAAM,CAKP,IACC,GAAI,CAAC,EACH,OAAO,KAGT,CAJoB,EAId,EAAG,EAAY,CAAG,EAAc,KAAK,CAAC,iBAE5C,AAAK,CAAA,EAAA,CAAD,CAAC,QAAA,AAAQ,EAAC,GAIP,EAAO,MAAM,CAAC,EAJO,OAIE,CAAC,CAC7B,MAAO,MAAE,EAAM,MAAO,CAAY,CACpC,GALS,IAMX,0ICrBO,IAAM,EAAU,KAAM,CAAA,OAAA,CAAA,AAEhB,EAAY,AAAD,GACf,CAAC,CAD+C,AAC9C,CADE,EACO,EADqC,AACrC,AAAM,GAAN,QAAsB,GAAA,MAAA,CAAA,AAW7B,EAAe,AAAD,KAAyB,IAEhD,AAFS,CAAuC,EAI/C,AAAiB,EAFlB,KAAU,CAEQ,IAFR,KACV,AACQ,GAAuC,EADrC,AACQ,KADR,GACqC,CADrC,AACqC,CAAjB,OAAO,EAI5B,EAAa,AAAC,CAJwB,EAK1C,CAAC,CADmD,AACnD,CAAE,EADC,CACQ,CADwC,CACjD,AAAe,WAAe,EAAA,EAAM,GAAN,CAAM,EAAQ,EAAM,GAAA,EAAA,CAAA,CAAA,AAGjD,EAAW,AAAC,GACC,EAD+B,CAA5C,IAA4C,CAC/B,EAAjB,OAAO,GAAsB,EAAZ,GAA6B,QAAA,MAAA,CAAA,AAW1C,EAAW,AAAC,IACnB,CADmD,CAA5C,CACP,CACK,EAF8C,KAE9C,MAAA,CAAO,KAAK,AAAM,CAAA,CACzB,GADyB,CAAA,CACzB,CACO,OAAA,CAAA,CACT,AACF,EAAA,AAkBa,CApBF,CAAA,AAoBY,AAAC,IAClB,CADO,AAA0B,GACvB,EADuB,EACjC,IAA4B,CAA5B,GAAkB,CAAU,IAAA,IAC5B,EAD0C,GAC1C,IAD0C,CAChC,CACd,EAF8C,CAAA,AAE1C,EAAS,EADS,CACD,EAAH,CAAA,CADc,GACM,CAAA,CADN,AACM,EAAV,EAC5B,CAFgC,CAAA,CAjBiB,AAkBX,CADY,AAE9C,OAF8C,IAAA,CAAA,EAjBD,CAAA,EAA1C,MAAO,CAAA,SAAA,CAAU,QAAS,CAAA,IAAA,CAAK,AAmB3B,GAAe,EAnBiB,AAmB3B,CAnBiC,AAmBjC,IAAU,KAAA,CAAM,EAAM,GAAA,IAAA,EAAS,CAAA,CAAA,AAC/C,GAAI,EAAW,IACX,CAxEmB,AAAD,AAuEF,CAAA,EAtEb,CAAC,CAD+C,AAC9C,GAAS,EADqC,AAC/B,AAAN,GAAA,QAAsB,GAAA,MAAA,AAC1C,CAD0C,CAC1C,AAsEe,GADiB,EACZ,CAAA,EAAU,EADE,EAE9B,GAF8B,AACF,CACtB,AAFwB,EAEd,EADY,AACE,CADF,EACE,GAAA,CAAA,AAC9B,GAAI,EAAS,GAAS,GAAH,CAAA,GAAU,AAAW,CAAA,CAAA,IACxC,AADwC,IAClC,EAAQ,EAAc,GAAA,CAAA,CAAA,OAC5B,AAAI,EAAS,GAAuB,CAAnB,AAAmB,CAAnB,AAAmB,EAAhB,AAAO,EAEpB,AAAS,CAAA,CAFoB,AAEpB,EAAA,AADH,MAAA,CAAO,IAAK,CAAA,GAAO,EAAF,CAAE,GAAA,AAElC,CAFkC,CAElC,qJC/EsM,EAAA,CAAA,CAAlI,EAAO,OAAO,CAAC,AAA2H,MAAvH,KAAkI,aAAa,IAAI,AAAmB,EAAE,cAAc,EAAE,SAAS,EAAE,SAAS,EAAE,OAAe,CAAR,CAAU,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,6FAA6F,EAAE,sFAAiY,CAA3S,CAA6S,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,GAAG,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,EAAshB,CAAphB,CAAshB,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAz6B,CAAC,CAAy6B,IAAp6B,KAAK,SAAS,2DAA2D,KAAK,CAAC,KAAK,OAAO,wFAAwF,KAAK,CAAC,KAAK,QAAQ,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC,KAAK,KAAK,KAAK,KAAK,CAAC,EAAE,EAAE,IAAI,MAAM,IAAI,GAAG,CAAC,AAAF,CAAG,CAAC,EAAE,EAAA,CAAE,CAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAA,AAAE,EAAE,GAAG,CAAC,EAAqoB,IAAI,EAAE,iBAAiB,EAAE,SAAS,CAAC,EAAE,OAAO,aAAa,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAA,AAAE,CAAC,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE,WAAW,GAAG,CAAC,CAAC,EAAE,GAAG,CAAD,CAAG,CAAC,EAAE,IAAI,CAAD,AAAE,CAAC,EAAE,CAAC,EAAE,GAAE,CAAC,CAAE,IAAI,EAAE,EAAE,KAAK,CAAC,KAAK,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,IAAI,CAAD,EAAG,CAAC,CAAE,GAAG,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,KAAK,GAAG,IAAI,EAAE,UAAU,OAAO,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,UAAU,IAAI,EAAE,EAAE,EAAE,EAAj8B,CAAC,CAAk8B,CAAh8B,EAAE,EAAE,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,SAAS,GAAG,EAAE,KAAK,GAAG,CAAC,GAA6B,CAA1B,KAAgC,CAAC,GAAG,EAAE,IAAI,GAAA,CAAG,CAAE,EAA7C,AAA+C,KAA1C,KAAK,CAAC,EAAE,IAAoC,CAAhC,CAAkC,KAAK,IAAI,EAAzC,AAA2C,EAAzC,GAA2C,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,GAAG,EAAE,IAAI,GAAG,MAAM,CAAC,EAAE,EAAE,GAAG,IAAI,EAAE,IAAI,CAAD,CAAG,IAAI,GAAG,EAAE,IAAI,EAAA,CAAE,CAAG,GAAD,AAAG,KAAK,GAAG,EAAE,KAAK,EAAA,CAAE,CAAE,EAAE,EAAE,KAAK,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,GAAG,GAAG,CAAC,GAAG,CAAD,CAAG,CAAC,GAAE,CAAC,CAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,GAAE,CAAC,EAAG,EAAD,AAAG,EAAE,EAAE,GAAE,CAAC,CAAC,GAAG,CAAC,AAAC,EAAE,EAAE,SAAS,CAAC,EAAE,OAAO,EAAE,EAAE,KAAK,IAAI,CAAC,IAAI,EAAE,KAAK,KAAK,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,EAAE,MAAM,CAAA,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAE,KAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAC,CAAA,AAAC,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,EAAE,EAAE,SAAS,CAAC,EAAE,OAAO,KAAK,IAAI,CAAC,CAAC,EAAqb,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,WAAW,SAAS,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,SAAS,CAAC,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,GAAG,CAAC,GAAG,OAAO,EAAE,OAAO,IAAI,KAAK,KAAK,GAAG,EAAE,CAAC,CAAC,GAAG,OAAO,IAAI,KAAK,GAAG,aAAa,KAAK,OAAO,IAAI,KAAK,GAAG,GAAG,UAAU,OAAO,GAAG,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,KAAK,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,GAAA,CAAG,CAAE,SAAS,CAAC,EAAE,GAAG,OAAO,EAAE,IAAI,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,IAAI,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,OAAO,IAAI,KAAK,EAAE,EAAE,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,WAAW,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,CAAC,WAAW,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,WAAW,OAAM,AAAE,CAAD,GAAK,CAAC,EAAE,CAAC,QAAQ,KAAK,CAAC,AAAC,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,WAAW,OAAO,KAAK,KAAK,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,EAAE,EAAE,OAAO,CAAC,WAAW,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,GAAG,IAAI,KAAK,EAAE,EAAE,CAAC,EAAE,GAAG,GAAG,OAAO,EAAE,EAAE,EAAE,KAAK,CAAC,MAAE,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAD,GAAK,CAAC,EAAE,CAAC,MAAM,EAAA,CAAE,CAAE,OAAO,GAAG,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,GAAI,MAAK,EAAE,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAG,MAAK,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,GAAG,SAAS,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,GAAE,CAAC,CAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,EAAG,EAAD,EAAG,CAAC,CAAE,EAAG,KAAK,MAAE,KAAK,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAG,MAAK,EAAE,OAAO,EAAE,EAAE,UAAU,EAAG,MAAK,EAAE,OAAO,EAAE,EAAE,UAAU,EAAG,MAAK,EAAE,OAAO,EAAE,EAAE,eAAe,EAAG,SAAQ,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,OAAO,CAAD,GAAK,CAAC,EAAE,CAAC,MAAM,EAAA,CAAE,CAAE,EAAE,CAAM,CAAL,AAAM,CAAC,CAAL,EAAC,KAAM,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,MAAI,IAAE,IAAI,CAAC,EAAE,EAAE,CAAD,CAAG,IAAI,CAAC,EAAA,AAAE,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,WAAW,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,OAAO,IAAI,CAAC,IAAI,GAAG,IAAI,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,OAAO,IAAI,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,SAAS,CAAC,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,KAAK,KAAK,CAAC,EAAE,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,IAAI,EAAE,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,WAAG,EAAM,IAAF,GAAS,EAAE,GAAG,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,CAAM,CAAL,EAAE,EAAC,CAAG,CAAC,EAAE,GAAC,EAAE,CAAC,CAAC,EAAE,GAAC,GAAE,CAAC,CAAC,EAAE,GAAC,GAAE,CAAC,AAAC,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,GAAG,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,GAAG,OAAO,EAAE,WAAW,EAAE,EAAE,IAAI,EAAE,GAAG,uBAAuB,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,IAAI,CAAD,AAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAA,CAAE,EAAG,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,IAAI,GAAG,EAAE,IAAI,EAAE,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,GAAG,KAAK,KAAK,OAAO,EAAE,EAAE,WAAW,GAAG,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,EAAG,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC,EAAE,OAAO,GAAG,IAAI,KAAK,OAAO,OAAO,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC,EAAG,KAAI,OAAO,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,IAAK,KAAI,IAAI,OAAO,EAAE,CAAE,KAAI,KAAK,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAK,KAAI,MAAM,OAAO,EAAE,EAAE,WAAW,CAAC,EAAE,EAAE,EAAG,KAAI,OAAO,OAAO,EAAE,EAAE,EAAG,KAAI,IAAI,OAAO,EAAE,EAAE,AAAC,KAAI,KAAK,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,IAAK,KAAI,IAAI,OAAO,OAAO,EAAE,EAAE,CAAE,KAAI,KAAK,OAAO,EAAE,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,EAAE,EAAG,KAAI,MAAM,OAAO,EAAE,EAAE,aAAa,CAAC,EAAE,EAAE,CAAC,EAAE,EAAG,KAAI,OAAO,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,AAAC,KAAI,IAAI,OAAO,OAAO,EAAG,KAAI,KAAK,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,IAAK,KAAI,IAAI,OAAO,EAAE,EAAG,KAAI,KAAK,OAAO,EAAE,EAAG,KAAI,IAAI,OAAO,EAAE,EAAE,EAAE,CAAC,EAAG,KAAI,IAAI,OAAO,EAAE,EAAE,EAAE,CAAC,EAAG,KAAI,IAAI,OAAO,OAAO,EAAG,KAAI,KAAK,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,IAAK,KAAI,IAAI,OAAO,OAAO,EAAE,EAAE,CAAE,KAAI,KAAK,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,IAAK,KAAI,MAAM,OAAO,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,IAAK,KAAI,IAAI,OAAO,CAAC,CAAC,OAAO,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,GAAG,EAAG,EAAE,EAAE,SAAS,CAAC,WAAW,QAAO,GAAI,EAAD,GAAM,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,GAAA,CAAG,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,GAAG,IAAI,CAAC,SAAS,EAAA,CAAE,IAAE,CAAE,EAAE,IAAI,CAAC,EAAE,EAAE,WAAW,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,OAAO,GAAG,KAAK,EAAE,EAAE,IAAI,GAAG,KAAM,MAAK,EAAE,EAAE,IAAI,KAAM,MAAK,EAAE,EAAE,IAAI,EAAE,KAAM,MAAK,EAAE,EAAE,CAAC,GAAE,CAAC,CAAE,OAAO,KAAM,KAA9zL,AAAm0L,MAAE,EAAE,CAAC,GAAE,CAAC,CAAE,MAAM,KAAM,MAAK,EAAE,EAAE,EAAx5L,EAA05L,GAAE,KAAM,MAAK,EAAE,EAAE,EAAj7L,EAAm7L,EAAE,CAAj7L,IAAu7L,MAAK,EAAE,EAAE,EAA18L,EAA48L,EAAE,CAA18L,IAAg9L,SAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,WAAW,CAAC,WAAW,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,EAAE,EAAE,OAAO,CAAC,WAAW,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,OAAO,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,OAAO,IAAI,CAAD,CAAG,EAAE,EAAC,CAAC,CAAE,CAAC,EAAE,EAAE,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,CAAC,WAAW,OAAO,IAAI,KAAK,IAAI,CAAC,OAAO,GAAG,EAAE,EAAE,MAAM,CAAC,WAAW,OAAO,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,EAAE,EAAE,WAAW,CAAC,WAAW,OAAO,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,EAAE,EAAE,QAAQ,CAAC,WAAW,OAAO,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,WAAO,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,OAAO,CAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,OAAO,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAI,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAG,EAAD,CAAG,EAAE,EAAE,GAAG,EAAE,EAAE,CAAC,EAAC,CAAC,CAAE,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,0MCAp/N,IAAA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,CAAA,CAAA,OAAA,IAAA,EAAA,EAAA,CAAA,CAAA,iECdA,IAAA,EAAA,EAAA,CAAA,CAAA,OAEA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MAEO,IAAM,EACX,CAAC,CACC,OAAQ,CAAc,2BACtB,EAA4B,IAC1B,EAAA,YAAY,CAAC,IAAI,CAAC,CAAE,MAAO,sBAAuB,EAAG,CAAE,OAAQ,GAAI,EAAE,CASxE,CAAG,CAAC,CAAC,GACN,MACE,EACA,KAMA,IAAM,EAAS,CAAA,EAAA,EAAA,aAAA,AAAa,EAAC,GAGvB,QAAE,CAAM,CAAE,CAFD,EAEI,IAFE,EAAM,MAAM,CAI3B,EAAc,EAAQ,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,eAErD,GAAI,CAAC,CAAA,EAAA,EAAA,QAAA,AAAQ,EAAC,GACZ,OAAO,EAAA,EADmB,UACP,CAAC,IAAI,CACtB,CAAE,MAAO,qBAAsB,EAC/B,CAAE,OAAQ,GAAI,GAIlB,IAAM,EAAe,EAAQ,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,gBAEtD,GAAI,CAAC,CAAA,EAAA,EAAA,QAAA,AAAQ,EAAC,GACZ,OAAO,EAAA,GADoB,SACR,CAAC,IAAI,CACtB,CAAE,MAAO,sBAAuB,EAChC,CAAE,OAAQ,GAAI,GAIlB,IAAM,EAAuB,MAAM,CAAA,EAAA,EAAA,oBAAA,AAAuB,EAAC,cACzD,SACA,CACF,GAEA,GAAI,CAAC,EACH,OAAO,EAAA,WADkB,CACN,CAAC,IAAI,CAAC,CAAE,MAAO,iBAAkB,EAAG,CAAE,OAAQ,GAAI,GAGvE,GAAI,CAAC,EACH,OAAO,EAAA,EADS,UACG,CAAC,IAAI,CACtB,CAAE,MAAO,sBAAuB,EAChC,CAAE,OAAQ,GAAI,GAIlB,IAAM,EAAY,MAAM,EAAO,SAAS,CAAC,SAAS,CAAC,CACjD,MAAO,CACL,GAAI,EACJ,UAAW,CACb,EACA,QAAS,CACP,eAAe,EACf,MAAO,CACL,QAAS,CACP,gBAAgB,EAChB,eAAe,EACf,qBAAqB,EACrB,qBAAqB,EACrB,iBAAiB,CACnB,CACF,EACA,WAAY,CACV,QAAS,CACP,iBAAiB,EACjB,gBAAgB,EAChB,cAAc,EACd,eAAe,CACjB,CACF,EACA,WAAW,CACb,CACF,GAEA,GAAI,CAAC,EACH,OAAO,EADO,AACP,YAAY,CAAC,IAAI,CAAC,CAAE,MAAO,oBAAqB,EAAG,CAAE,OAAQ,GAAI,GAG1E,GACE,CAAA,EAAA,EAAA,iCAAA,AAAiC,EAAC,CAChC,oBAAqB,EAAU,mBAAmB,AACpD,IACA,CAAC,EAAU,iBAAiB,CAE5B,CADA,MACO,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,MAAO,8BAA+B,EACxC,CAAE,OAAQ,GAAI,GAIlB,IAAM,EAAkB,CAAA,EAAA,EAAA,sBAAA,AAAsB,EAAC,WAAE,SAAW,CAAO,GAE7D,EAAO,MAAM,EAAgB,KAAK,CAAC,QAAQ,CAAC,GAElD,GAAI,CAAC,EACH,IADS,GACF,EAAA,YAAY,CAAC,IAAI,CAAC,CAAE,MAAO,eAAgB,EAAG,CAAE,OAAQ,GAAI,GAGrE,GAAqB,cAAc,CAA/B,EAAK,OAAO,CACd,OAAO,EAA0B,MAAE,uBAAM,CAAqB,GAGhE,IAAM,EAAsB,MAAM,EAAgB,KAAK,CAAC,OAAO,CAAC,GAC1D,EAAW,MAAM,EAAoB,WAAW,GAEtD,OAAO,IAAI,EAAA,YAAY,CAAC,EAAU,CAChC,QAAS,CACP,GAAG,EAAA,YAAY,CACf,eACE,EAAoB,OAAO,CAAC,GAAG,CAAC,iBAChC,2BACF,sBACE,EAAoB,OAAO,CAAC,GAAG,CAAC,wBAA0B,QAC9D,CACF,EACF,EAEW,EAAO,CAAC,GAAG,IACtB,EAAS,CAAC,MAAM,GAEL,EAAU,IACrB,EAAA,YAAY,CAAC,IAAI,CACf,CAAC,EACD,CACE,QAAS,EAAA,YAAY,AACvB,GDtIJ,IAAA,EAAA,EAAA,CAAA,CAAA,OAIA,IAAM,EAAc,IAAI,EAAA,mBAAmB,CAAC,CACxC,WAAY,CACR,KAAM,EAAA,SAAS,CAAC,SAAS,CACzB,KAAM,qCACN,SAAU,+BACV,SAAU,QACV,WAAY,EAChB,EACA,QAAS,CAAA,OACT,IADiD,eACc,CAA3C,EACpB,iBAAkB,kGAClB,iBAZqB,GAarB,SAAA,CACJ,GAIM,kBAAE,CAAgB,sBAAE,CAAoB,aAAE,CAAW,CAAE,CAAG,EAChE,SAAS,IACL,MAAO,CAAA,EAAA,EAAA,UAAA,AAAW,EAAC,CACf,wCACA,CACJ,EACJ,CAEO,eAAe,EAAQ,CAAG,CAAE,CAAG,CAAE,CAAG,EACvC,IAAI,EACJ,IAAI,EAAU,qCAKV,EAAU,EAAQ,OAAO,CAAC,WAAY,KAAO,IAMjD,IAAM,EAAgB,MAAM,EAAY,OAAO,CAAC,EAAK,EAAK,SACtD,EACA,mBAHE,CAAA,CAIN,GACA,GAAI,CAAC,EAID,OAHA,EAAI,IADY,MACF,CAAG,IACjB,EAAI,GAAG,CAAC,eACS,MAAjB,CAAwB,CAApB,IAAyB,KAAhB,EAAoB,EAAI,SAAS,CAAC,IAAI,CAAC,EAAK,QAAQ,OAAO,IACjE,KAEX,GAAM,SAAE,CAAO,QAAE,CAAM,YAAE,CAAU,CAAE,aAAW,CAAE,mBAAiB,qBAAE,CAAmB,sBAAE,CAAoB,yBAAE,CAAuB,kBAAE,CAAgB,CAAE,CAAG,EACxJ,EAAoB,CAAA,EAAA,EAAA,gBAAA,AAAgB,EAAC,GACvC,GAAQ,EAAQ,EAAkB,aAAa,CAAC,EAAkB,EAAI,EAAkB,MAAM,CAAC,EAAiB,AAAjB,EACnG,GAAI,GAAS,CAAC,EAAa,CACvB,IAAM,GAAgB,CAAQ,EAAkB,MAAM,CAAC,EAAiB,CAClE,EAAgB,EAAkB,aAAa,CAAC,EAAkB,CACxE,GAAI,IAC+B,IAA3B,EAAc,KADH,GACW,EAAc,CAAC,EACrC,MAAM,IAAI,EAAA,CAD0C,cAC3B,AAGrC,CACA,IAAI,EAAW,MACX,GAAU,EAAY,IAAb,CAAkB,EAAK,EAAD,CAG/B,GAAW,AAAa,OAHqB,KAC7C,EAAW,CAAA,EAEwB,IAAM,CAAA,EAE7C,IAAM,GACgB,IAAtB,EAAY,EAAkB,GAAb,EAEjB,CAAC,EAKK,EAAe,GAAS,CAAC,EACzB,EAAS,EAAI,MAAM,EAAI,MACvB,EAAS,CAAA,EAAA,EAAA,SAAA,AAAS,IAClB,EAAa,EAAO,WAVyE,OAUvD,GACtC,EAAU,QACZ,oBACA,EACA,WAAY,CACR,aAAc,CACV,iBAAiB,CAAQ,EAAW,YAAY,CAAC,eAAe,CAChE,gBAAgB,CAAQ,EAAW,YAAY,CAAC,cAAc,AAClE,0BACA,EACA,iBAAkB,CAAA,EAAA,EAAA,cAAc,AAAd,EAAe,EAAK,oBACtC,kBAAmB,AAAwD,OAAvD,EAA2B,EAAW,YAAA,AAAY,EAAY,KAAK,EAAI,EAAyB,SAAS,CAC7H,eACA,UAAW,EAAI,SAAS,CACxB,QAAS,AAAC,IACN,EAAI,EAAE,CAAC,QAAS,EACpB,EACA,sBAAkB,EAClB,8BAA+B,CAAC,EAAO,EAAU,IAAe,EAAY,cAAc,CAAC,EAAK,EAAO,EAAc,EACzH,EACA,cAAe,SACX,CACJ,CACJ,EACM,EAAc,IAAI,EAAA,eAAe,CAAC,GAClC,EAAc,IAAI,EAAA,gBAAgB,CAAC,GACnC,EAAU,EAAA,kBAAkB,CAAC,mBAAmB,CAAC,EAAa,CAAA,EAAA,EAAA,sBAAA,AAAsB,EAAC,IAC3F,GAAI,CACA,IAAM,EAAoB,MAAO,GACtB,EAAY,MAAM,CAAC,EAAS,GAAS,OAAO,CAAC,KAChD,GAAI,CAAC,EAAM,OACX,EAAK,aAAa,CAAC,CACf,mBAAoB,EAAI,UAAU,CAClC,YAAY,CAChB,GACA,IAAM,EAAqB,EAAO,qBAAqB,GAEvD,GAAI,CAAC,EACD,OAEJ,GAAI,EAAmB,GAAG,CAAC,EAHF,kBAGwB,EAAA,cAAc,CAAC,aAAa,CAAE,YAC3E,QAAQ,IAAI,CAAC,CAAC,2BAA2B,EAAE,EAAmB,GAAG,CAAC,kBAAkB,qEAAqE,CAAC,EAG9J,IAAM,EAAQ,EAAmB,GAAG,CAAC,cACrC,GAAI,EAAO,CACP,IAAM,EAAO,CAAA,EAAG,EAAO,CAAC,EAAE,EAAA,CAAO,CACjC,EAAK,aAAa,CAAC,CACf,aAAc,EACd,aAAc,EACd,iBAAkB,CACtB,GACA,EAAK,UAAU,CAAC,EACpB,MACI,CADG,CACE,UAAU,CAAC,CAAA,EAAG,EAAO,CAAC,EAAE,EAAI,GAAG,CAAA,CAAE,CAE9C,GAEE,EAAiB,MAAO,QACtB,EA0FI,EAzFR,IAAM,EAAoB,MAAO,oBAAE,CAAkB,CAAE,IACnD,GAAI,CACA,GAAI,CAAC,CAAA,EAAA,EAAA,cAAA,AAAc,EAAC,EAAK,gBAAkB,GAAwB,GAA2B,CAAC,EAK3F,OAJA,EAAI,SAD2G,CACjG,CAAG,IAEjB,EAAI,SAAS,CAAC,iBAAkB,eAChC,EAAI,GAAG,CAAC,gCACD,KAEX,IAAM,EAAW,MAAM,EAAkB,GACzC,EAAI,YAAY,CAAG,EAAQ,UAAU,CAAC,YAAY,CAClD,IAAI,EAAmB,EAAQ,UAAU,CAAC,gBAAgB,CAGtD,GACI,EAAI,SAAS,EAAE,CACf,CAFc,CAEV,SAAS,CAAC,GACd,OAAmB,GAG3B,IAAM,EAAY,EAAQ,UAAU,CAAC,aAAa,CAGlD,IAAI,EA6BA,OADA,MAAM,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAa,EAAa,EAAU,EAAQ,UAAU,CAAC,gBAAgB,EACnF,IA7BA,EACP,IAAM,EAAO,MAAM,EAAS,IAAI,GAE1B,EAAU,CAAA,EAAA,EAAA,yBAAA,AAAyB,EAAC,EAAS,OAAO,EACtD,IACA,CAAO,CAAC,EAAA,GADG,mBACmB,CAAC,CAAG,CAAA,EAElC,CAAC,CAAO,CAAC,eAAe,EAAI,EAAK,IAAI,EAAE,CACvC,CAAO,CAAC,eAAe,CAAG,EAAK,IAAA,AAAI,EAEvC,IAAM,EAAa,KAAkD,IAA3C,EAAQ,UAAU,CAAC,mBAAmB,IAAoB,EAAQ,UAAU,CAAC,mBAAmB,EAAI,EAAA,cAAA,AAAc,GAAG,AAAQ,EAAQ,UAAU,CAAC,mBAAmB,CACvL,EAAS,KAA8C,IAAvC,EAAQ,UAAU,CAAC,eAAe,EAAoB,EAAQ,UAAU,CAAC,eAAe,EAAI,EAAA,cAAc,MAAG,EAAY,EAAQ,UAAU,CAAC,eAAe,CAcjL,MAZmB,CAYZ,AAXH,MAAO,CACH,KAAM,EAAA,eAAe,CAAC,SAAS,CAC/B,OAAQ,EAAS,MAAM,CACvB,KAAM,OAAO,IAAI,CAAC,MAAM,EAAK,WAAW,YACxC,CACJ,EACA,aAAc,YACV,SACA,CACJ,CACJ,CAEJ,CAKJ,CAAE,KALS,CAKF,EAAK,CAcV,MAX0B,MAAtB,EAA6B,KAAK,EAAI,EAAmB,OAAA,AAAO,EAAE,CAClE,MAAM,EAAY,cAAc,CAAC,EAAK,EAAK,CACvC,WAAY,aACZ,UAAW,EACX,UAAW,QACX,iBAAkB,CAAA,EAAA,EAAA,mBAAA,AAAmB,EAAC,cAClC,uBACA,CACJ,EACJ,EAAG,GAED,CACV,CACJ,EACM,EAAa,MAAM,EAAY,cAAc,CAAC,KAChD,aACA,WACA,EACA,UAAW,EAAA,SAAS,CAAC,SAAS,CAC9B,YAAY,oBACZ,EACA,mBAAmB,uBACnB,0BACA,oBACA,EACA,UAAW,EAAI,SAAS,AAC5B,GAEA,GAAI,CAAC,EACD,KADQ,EACD,KAEX,GAAI,CAAe,MAAd,CAAqB,EAAS,AAA0C,GAA9C,IAAK,EAAoB,EAAW,KAAA,AAAK,EAAY,KAAK,EAAI,EAAkB,IAAI,IAAM,EAAA,eAAe,CAAC,SAAS,CAE9I,CAFgJ,KAE1I,OAAO,cAAc,CAAC,AAAI,MAAM,CAAC,kDAAkD,EAAgB,MAAd,CAAqB,EAAS,AAA2C,GAA/C,IAAK,EAAqB,EAAW,KAAK,AAAL,EAAiB,KAAK,EAAI,EAAmB,IAAI,CAAA,CAAE,EAAG,oBAAqB,CACjO,MAAO,OACP,YAAY,EACZ,aAAc,EAClB,EAEA,CAAC,CAAA,EAAA,EAAA,cAAc,AAAd,EAAe,EAAK,gBAAgB,AACrC,EAAI,SAAS,CAAC,iBAAkB,EAAuB,cAAgB,EAAW,MAAM,CAAG,OAAS,EAAW,OAAO,CAAG,QAAU,OAGnI,GACA,EAAI,QADS,CACA,CAAC,gBAAiB,2DAEnC,IAAM,EAAU,CAAA,EAAA,EAAA,2BAAA,AAA2B,EAAC,EAAW,KAAK,CAAC,OAAO,EAapE,MAZM,AAAF,CAAE,AAAD,EAAC,EAAA,cAAA,AAAc,EAAC,EAAK,gBAAkB,GACxC,EAD6C,AACrC,GADwC,GAClC,CAAC,EAAA,sBAAsB,GAIrC,EAAW,YAAY,EAAK,EAAD,AAAK,SAAS,CAAC,kBAAqB,EAAD,AAAS,GAAG,CAAC,kBAAkB,AAC7F,EAAQ,GAAG,CAAC,gBAAiB,CAAA,EAAA,EAAA,qBAAA,AAAqB,EAAC,EAAW,YAAY,GAE9E,MAAM,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAa,EAAa,IAAI,SAAS,EAAW,KAAK,CAAC,IAAI,CAAE,SAC7E,EACA,OAAQ,EAAW,KAAK,CAAC,MAAM,EAAI,GACvC,IACO,IACX,EAGI,EACA,MAAM,EAAe,EADT,CAGZ,MAAM,EAAO,qBAAqB,CAAC,EAAI,OAAO,CAAE,IAAI,EAAO,KAAK,CAAC,EAAA,cAAc,CAAC,aAAa,CAAE,CACvF,SAAU,CAAA,EAAG,EAAO,CAAC,EAAE,EAAI,GAAG,CAAA,CAAE,CAChC,KAAM,EAAA,QAAQ,CAAC,MAAM,CACrB,WAAY,CACR,cAAe,EACf,cAAe,EAAI,GAAG,AAC1B,CACJ,EAAG,GAEf,CAAE,MAAO,EAAK,CAcV,GAbI,AAAE,CAAD,YAAgB,EAAA,eAAe,EAChC,CADmC,KAC7B,EAAY,cAAc,CAAC,EAAK,EAAK,CACvC,WAAY,aACZ,UAAW,EACX,UAAW,QACX,iBAAkB,CAAA,EAAA,EAAA,mBAAA,AAAmB,EAAC,CAClC,oCACA,CACJ,EACJ,GAIA,EAAO,MAAM,EAKjB,OAHA,MAAM,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAa,EAAa,IAAI,SAAS,KAAM,CAC5D,OAAQ,GACZ,IACO,IACX,CACJ,EAEA,qCAAqC","ignoreList":[4,5]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},20635,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/action-async-storage.external.js",()=>require("next/dist/server/app-render/action-async-storage.external.js"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},30611,e=>{"use strict";e.s(["cacheHeaders",()=>t]);let t={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type"}},88122,e=>{"use strict";e.s(["getApiKey",()=>r]);var t=e.i(55897);let r=async({authorization:e,type:r,prisma:s})=>{if(!e)return null;let[,a]=e.split("Bearer ");return(0,t.validate)(a)?s.apiKey.findFirst({where:{type:r,value:a}}):null}},67083,e=>{"use strict";e.s(["isJSON",()=>t]);let t=e=>{try{return JSON.parse(e),!0}catch(e){return!1}}},40145,1065,e=>{"use strict";e.s(["serializeApiMcpServer",()=>t],40145);let t=({mcpServer:e})=>({id:e.id,transportType:e.transportType,sseTransport:e.sseTransport?(({sseTransport:e})=>({id:e.id,url:e.url,headers:e.headers,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()}))({sseTransport:e.sseTransport}):null,httpTransport:e.httpTransport?(({httpTransport:e})=>({id:e.id,url:e.url,headers:e.headers,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()}))({httpTransport:e.httpTransport}):null,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()});e.s(["mcpServerSchema",()=>p],1065);var r=e.i(13669),s=e.i(29173),a=e.i(67083);let n=r.z.object({command:r.z.string().min(1),args:r.z.string().min(1)}),i=r.z.object({url:r.z.string().min(1).url(),headers:r.z.string().min(1).refine(a.isJSON,{message:"Must be a valid JSON string."})}),o=r.z.object({url:r.z.string().min(1).url(),headers:r.z.string().min(1).refine(a.isJSON,{message:"Must be a valid JSON string."})}),p=r.z.object({transportType:r.z.nativeEnum(s.TransportType).refine(e=>e!==s.TransportType.STDIO,{message:`transportType cannot be ${s.TransportType.STDIO}`}),sseTransport:i.nullable().optional(),httpTransport:o.nullable().optional()}).superRefine((e,t)=>{if(e.transportType===s.TransportType.STDIO){t.addIssue({code:r.z.ZodIssueCode.custom,message:`Transport type ${s.TransportType.STDIO} is not allowed.`});let a=n.safeParse(e.stdioTransport);a.success||a.error.issues.forEach(e=>t.addIssue({...e,path:["stdioTransport",...e.path]}))}else if(e.transportType===s.TransportType.SSE){let r=i.safeParse(e.sseTransport);if(r.success)return;r.error.issues.forEach(e=>t.addIssue({...e,path:["sseTransport",...e.path]}))}else if(e.transportType===s.TransportType.HTTP){let r=o.safeParse(e.httpTransport);if(r.success)return;r.error.issues.forEach(e=>t.addIssue({...e,path:["httpTransport",...e.path]}))}})},98917,e=>{"use strict";e.s([])},29190,e=>{"use strict";e.s(["handler",()=>D,"patchFetch",()=>_,"routeModule",()=>H,"serverHooks",()=>q,"workAsyncStorage",()=>M,"workUnitAsyncStorage",()=>z],29190);var t=e.i(5865),r=e.i(43877),s=e.i(77767),a=e.i(92562),n=e.i(66256),i=e.i(5270),o=e.i(90231),p=e.i(82677),d=e.i(51081),l=e.i(89822),u=e.i(9124),c=e.i(39147),h=e.i(40568),v=e.i(87188),T=e.i(93695);e.i(57132);var x=e.i(80739);e.s(["DELETE",()=>j,"GET",()=>I,"OPTIONS",()=>b,"PATCH",()=>P,"buildDELETE",()=>O,"buildGET",()=>N,"buildPATCH",()=>C],28403);var m=e.i(11053),f=e.i(29173),R=e.i(49493),y=e.i(30611),g=e.i(24493),S=e.i(88122),w=e.i(55897),A=e.i(40145),E=e.i(1065);let N=({prisma:e}={})=>async(t,r)=>{let s=(0,g.resolvePrisma)(e),{assistantId:a,mcpServerId:n}=await r.params,i=(await (0,m.headers)()).get("authorization");if(!i)return R.NextResponse.json({error:"No authorization header found"},{status:400});let o=await (0,S.getApiKey)({type:f.ApiKeyType.PRIVATE,authorization:i,prisma:s});if(!o)return R.NextResponse.json({error:"Invalid api key"},{status:400});if(!(0,w.validate)(a))return R.NextResponse.json({error:"Invalid assistant id"},{status:400});if(!(0,w.validate)(n))return R.NextResponse.json({error:"Invalid MCP server id"},{status:400});let p=await s.mcpServer.findFirst({where:{id:n,assistant:{id:a,workspaceId:o.workspaceId}},include:{sseTransport:!0,httpTransport:!0}});return p?R.NextResponse.json({mcpServer:(0,A.serializeApiMcpServer)({mcpServer:p})},{headers:y.cacheHeaders}):R.NextResponse.json({error:"No MCP server found"},{status:400})},I=N(),C=({prisma:e}={})=>async(t,r)=>{let s=(0,g.resolvePrisma)(e),{assistantId:a,mcpServerId:n}=await r.params,i=(await (0,m.headers)()).get("authorization");if(!i)return R.NextResponse.json({error:"No authorization header found"},{status:400});let o=await (0,S.getApiKey)({authorization:i,type:f.ApiKeyType.PRIVATE,prisma:s});if(!o)return R.NextResponse.json({error:"Invalid api key"},{status:400});if(!(0,w.validate)(a))return R.NextResponse.json({error:"Invalid assistant id"},{status:400});if(!(0,w.validate)(n))return R.NextResponse.json({error:"Invalid MCP server id"},{status:400});let p=await t.json(),d=E.mcpServerSchema.safeParse(p);if(!d.success)return R.NextResponse.json({error:"Invalid payload"},{status:400});let{transportType:l,sseTransport:u,httpTransport:c}=d.data;if(!await s.mcpServer.findFirst({where:{id:n,assistant:{id:a,workspaceId:o.workspaceId}}}))return R.NextResponse.json({error:"No MCP server found"},{status:400});let h=await s.mcpServer.update({where:{id:n},data:{transportType:l,...l===f.TransportType.SSE?{sseTransport:{update:{url:u.url,headers:JSON.parse(u.headers)}}}:{},...l===f.TransportType.HTTP?{httpTransport:{update:{url:c.url,headers:JSON.parse(c.headers)}}}:{}},include:{sseTransport:!0,httpTransport:!0}});return R.NextResponse.json({mcpServer:(0,A.serializeApiMcpServer)({mcpServer:h})},{headers:y.cacheHeaders})},P=C(),O=({prisma:e}={})=>async(t,r)=>{let s=(0,g.resolvePrisma)(e),{assistantId:a,mcpServerId:n}=await r.params,i=(await (0,m.headers)()).get("authorization");if(!i)return R.NextResponse.json({error:"No authorization header found"},{status:400});let o=await (0,S.getApiKey)({authorization:i,type:f.ApiKeyType.PRIVATE,prisma:s});if(!o)return R.NextResponse.json({error:"Invalid api key"},{status:400});if(!(0,w.validate)(a))return R.NextResponse.json({error:"Invalid assistant id"},{status:400});if(!(0,w.validate)(n))return R.NextResponse.json({error:"Invalid MCP server id"},{status:400});if(!await s.mcpServer.findFirst({where:{id:n,assistant:{id:a,workspaceId:o.workspaceId}}}))return R.NextResponse.json({error:"No MCP server found"},{status:400});let p=await s.mcpServer.delete({where:{id:n},include:{sseTransport:!0,httpTransport:!0}});return R.NextResponse.json({mcpServer:(0,A.serializeApiMcpServer)({mcpServer:p})},{headers:y.cacheHeaders})},j=O(),b=()=>R.NextResponse.json({},{headers:y.cacheHeaders});var k=e.i(28403);let H=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route",pathname:"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.ts",nextConfigOutput:"",userland:k}),{workAsyncStorage:M,workUnitAsyncStorage:z,serverHooks:q}=H;function _(){return(0,s.patchFetch)({workAsyncStorage:M,workUnitAsyncStorage:z})}async function D(e,t,s){var m;let f="/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route";f=f.replace(/\/index$/,"")||"/";let R=await H.prepare(e,t,{srcPage:f,multiZoneDraftMode:!1});if(!R)return t.statusCode=400,t.end("Bad Request"),null==s.waitUntil||s.waitUntil.call(s,Promise.resolve()),null;let{buildId:y,params:g,nextConfig:S,isDraftMode:w,prerenderManifest:A,routerServerContext:E,isOnDemandRevalidate:N,revalidateOnlyGenerated:I,resolvedPathname:C}=R,P=(0,i.normalizeAppPath)(f),O=!!(A.dynamicRoutes[P]||A.routes[C]);if(O&&!w){let e=!!A.routes[C],t=A.dynamicRoutes[P];if(t&&!1===t.fallback&&!e)throw new T.NoFallbackError}let j=null;!O||H.isDev||w||(j="/index"===(j=C)?"/":j);let b=!0===H.isDev||!O,k=O&&!b,M=e.method||"GET",z=(0,n.getTracer)(),q=z.getActiveScopeSpan(),_={params:g,prerenderManifest:A,renderOpts:{experimental:{cacheComponents:!!S.experimental.cacheComponents,authInterrupts:!!S.experimental.authInterrupts},supportsDynamicResponse:b,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:null==(m=S.experimental)?void 0:m.cacheLife,isRevalidate:k,waitUntil:s.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,s)=>H.onRequestError(e,t,s,E)},sharedContext:{buildId:y}},D=new o.NodeNextRequest(e),U=new o.NodeNextResponse(t),K=p.NextRequestAdapter.fromNodeNextRequest(D,(0,p.signalFromNodeResponse)(t));try{let i=async r=>H.handle(K,_).finally(()=>{if(!r)return;r.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let s=z.getRootSpanAttributes();if(!s)return;if(s.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${s.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=s.get("next.route");if(a){let e=`${M} ${a}`;r.setAttributes({"next.route":a,"http.route":a,"next.span_name":e}),r.updateName(e)}else r.updateName(`${M} ${e.url}`)}),o=async n=>{var o,p;let d=async({previousCacheEntry:r})=>{try{if(!(0,a.getRequestMeta)(e,"minimalMode")&&N&&I&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await i(n);e.fetchMetrics=_.renderOpts.fetchMetrics;let p=_.renderOpts.pendingWaitUntil;p&&s.waitUntil&&(s.waitUntil(p),p=void 0);let d=_.renderOpts.collectedTags;if(!O)return await (0,u.sendResponse)(D,U,o,_.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,c.toNodeOutgoingHttpHeaders)(o.headers);d&&(t[v.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==_.renderOpts.collectedRevalidate&&!(_.renderOpts.collectedRevalidate>=v.INFINITE_CACHE)&&_.renderOpts.collectedRevalidate,s=void 0===_.renderOpts.collectedExpire||_.renderOpts.collectedExpire>=v.INFINITE_CACHE?void 0:_.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:o.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:s}}}}catch(t){throw(null==r?void 0:r.isStale)&&await H.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,l.getRevalidateReason)({isRevalidate:k,isOnDemandRevalidate:N})},E),t}},T=await H.handleResponse({req:e,nextConfig:S,cacheKey:j,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:N,revalidateOnlyGenerated:I,responseGenerator:d,waitUntil:s.waitUntil});if(!O)return null;if((null==T||null==(o=T.value)?void 0:o.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==T||null==(p=T.value)?void 0:p.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});(0,a.getRequestMeta)(e,"minimalMode")||t.setHeader("x-nextjs-cache",N?"REVALIDATED":T.isMiss?"MISS":T.isStale?"STALE":"HIT"),w&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let m=(0,c.fromNodeOutgoingHttpHeaders)(T.value.headers);return(0,a.getRequestMeta)(e,"minimalMode")&&O||m.delete(v.NEXT_CACHE_TAGS_HEADER),!T.cacheControl||t.getHeader("Cache-Control")||m.get("Cache-Control")||m.set("Cache-Control",(0,h.getCacheControlHeader)(T.cacheControl)),await (0,u.sendResponse)(D,U,new Response(T.value.body,{headers:m,status:T.value.status||200})),null};q?await o(q):await z.withPropagatedContext(e.headers,()=>z.trace(d.BaseServerSpan.handleRequest,{spanName:`${M} ${e.url}`,kind:n.SpanKind.SERVER,attributes:{"http.method":M,"http.target":e.url}},o))}catch(t){if(t instanceof T.NoFallbackError||await H.onRequestError(e,t,{routerKind:"App Router",routePath:P,routeType:"route",revalidateReason:(0,l.getRevalidateReason)({isRevalidate:k,isOnDemandRevalidate:N})}),O)throw t;return await (0,u.sendResponse)(D,U,new Response(null,{status:500})),null}}}];
|
|
1
|
+
module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},20635,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/action-async-storage.external.js",()=>require("next/dist/server/app-render/action-async-storage.external.js"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},30611,e=>{"use strict";e.s(["cacheHeaders",()=>t]);let t={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type"}},88122,e=>{"use strict";e.s(["getApiKey",()=>r]);var t=e.i(55897);let r=async({authorization:e,type:r,prisma:s})=>{if(!e)return null;let[,a]=e.split("Bearer ");return(0,t.validate)(a)?s.apiKey.findFirst({where:{type:r,value:a}}):null}},67083,e=>{"use strict";e.s(["isJSON",()=>t]);let t=e=>{try{return JSON.parse(e),!0}catch(e){return!1}}},40145,1065,e=>{"use strict";e.s(["serializeApiMcpServer",()=>t],40145);let t=({mcpServer:e})=>({id:e.id,transportType:e.transportType,sseTransport:e.sseTransport?(({sseTransport:e})=>({id:e.id,url:e.url,headers:e.headers,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()}))({sseTransport:e.sseTransport}):null,httpTransport:e.httpTransport?(({httpTransport:e})=>({id:e.id,url:e.url,headers:e.headers,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()}))({httpTransport:e.httpTransport}):null,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()});e.s(["mcpServerSchema",()=>p],1065);var r=e.i(13669),s=e.i(29173),a=e.i(67083);let n=r.z.object({command:r.z.string().min(1),args:r.z.string().min(1)}),i=r.z.object({url:r.z.string().min(1).url(),headers:r.z.string().min(1).refine(a.isJSON,{message:"Must be a valid JSON string."})}),o=r.z.object({url:r.z.string().min(1).url(),headers:r.z.string().min(1).refine(a.isJSON,{message:"Must be a valid JSON string."})}),p=r.z.object({transportType:r.z.nativeEnum(s.TransportType).refine(e=>e!==s.TransportType.STDIO,{message:`transportType cannot be ${s.TransportType.STDIO}`}),sseTransport:i.nullable().optional(),httpTransport:o.nullable().optional()}).superRefine((e,t)=>{if(e.transportType===s.TransportType.STDIO){t.addIssue({code:r.z.ZodIssueCode.custom,message:`Transport type ${s.TransportType.STDIO} is not allowed.`});let a=n.safeParse(e.stdioTransport);a.success||a.error.issues.forEach(e=>t.addIssue({...e,path:["stdioTransport",...e.path]}))}else if(e.transportType===s.TransportType.SSE){let r=i.safeParse(e.sseTransport);if(r.success)return;r.error.issues.forEach(e=>t.addIssue({...e,path:["sseTransport",...e.path]}))}else if(e.transportType===s.TransportType.HTTP){let r=o.safeParse(e.httpTransport);if(r.success)return;r.error.issues.forEach(e=>t.addIssue({...e,path:["httpTransport",...e.path]}))}})},98917,e=>{"use strict";e.s([])},29190,e=>{"use strict";e.s(["handler",()=>D,"patchFetch",()=>_,"routeModule",()=>H,"serverHooks",()=>q,"workAsyncStorage",()=>M,"workUnitAsyncStorage",()=>z],29190);var t=e.i(5865),r=e.i(43877),s=e.i(77767),a=e.i(92562),n=e.i(66256),i=e.i(5270),o=e.i(90231),p=e.i(82677),d=e.i(51081),l=e.i(89822),u=e.i(9124),c=e.i(39147),h=e.i(40568),v=e.i(87188),T=e.i(93695);e.i(57132);var x=e.i(80739);e.s(["DELETE",()=>j,"GET",()=>I,"OPTIONS",()=>b,"PATCH",()=>P,"buildDELETE",()=>O,"buildGET",()=>N,"buildPATCH",()=>C],28403);var m=e.i(11053),f=e.i(29173),R=e.i(49493),y=e.i(30611),g=e.i(24493),S=e.i(88122),w=e.i(55897),A=e.i(40145),E=e.i(1065);let N=({prisma:e}={})=>async(t,r)=>{let s=(0,g.resolvePrisma)(e),{assistantId:a,mcpServerId:n}=await r.params,i=(await (0,m.headers)()).get("authorization");if(!i)return R.NextResponse.json({error:"No authorization header found"},{status:400});let o=await (0,S.getApiKey)({type:f.ApiKeyType.PRIVATE,authorization:i,prisma:s});if(!o)return R.NextResponse.json({error:"Invalid api key"},{status:400});if(!(0,w.validate)(a))return R.NextResponse.json({error:"Invalid assistant id"},{status:400});if(!(0,w.validate)(n))return R.NextResponse.json({error:"Invalid MCP server id"},{status:400});let p=await s.mcpServer.findFirst({where:{id:n,assistant:{id:a,workspaceId:o.workspaceId}},include:{sseTransport:!0,httpTransport:!0}});return p?R.NextResponse.json({mcpServer:(0,A.serializeApiMcpServer)({mcpServer:p})},{headers:y.cacheHeaders}):R.NextResponse.json({error:"No MCP server found"},{status:400})},I=(...e)=>N()(...e),C=({prisma:e}={})=>async(t,r)=>{let s=(0,g.resolvePrisma)(e),{assistantId:a,mcpServerId:n}=await r.params,i=(await (0,m.headers)()).get("authorization");if(!i)return R.NextResponse.json({error:"No authorization header found"},{status:400});let o=await (0,S.getApiKey)({authorization:i,type:f.ApiKeyType.PRIVATE,prisma:s});if(!o)return R.NextResponse.json({error:"Invalid api key"},{status:400});if(!(0,w.validate)(a))return R.NextResponse.json({error:"Invalid assistant id"},{status:400});if(!(0,w.validate)(n))return R.NextResponse.json({error:"Invalid MCP server id"},{status:400});let p=await t.json(),d=E.mcpServerSchema.safeParse(p);if(!d.success)return R.NextResponse.json({error:"Invalid payload"},{status:400});let{transportType:l,sseTransport:u,httpTransport:c}=d.data;if(!await s.mcpServer.findFirst({where:{id:n,assistant:{id:a,workspaceId:o.workspaceId}}}))return R.NextResponse.json({error:"No MCP server found"},{status:400});let h=await s.mcpServer.update({where:{id:n},data:{transportType:l,...l===f.TransportType.SSE?{sseTransport:{update:{url:u.url,headers:JSON.parse(u.headers)}}}:{},...l===f.TransportType.HTTP?{httpTransport:{update:{url:c.url,headers:JSON.parse(c.headers)}}}:{}},include:{sseTransport:!0,httpTransport:!0}});return R.NextResponse.json({mcpServer:(0,A.serializeApiMcpServer)({mcpServer:h})},{headers:y.cacheHeaders})},P=(...e)=>C()(...e),O=({prisma:e}={})=>async(t,r)=>{let s=(0,g.resolvePrisma)(e),{assistantId:a,mcpServerId:n}=await r.params,i=(await (0,m.headers)()).get("authorization");if(!i)return R.NextResponse.json({error:"No authorization header found"},{status:400});let o=await (0,S.getApiKey)({authorization:i,type:f.ApiKeyType.PRIVATE,prisma:s});if(!o)return R.NextResponse.json({error:"Invalid api key"},{status:400});if(!(0,w.validate)(a))return R.NextResponse.json({error:"Invalid assistant id"},{status:400});if(!(0,w.validate)(n))return R.NextResponse.json({error:"Invalid MCP server id"},{status:400});if(!await s.mcpServer.findFirst({where:{id:n,assistant:{id:a,workspaceId:o.workspaceId}}}))return R.NextResponse.json({error:"No MCP server found"},{status:400});let p=await s.mcpServer.delete({where:{id:n},include:{sseTransport:!0,httpTransport:!0}});return R.NextResponse.json({mcpServer:(0,A.serializeApiMcpServer)({mcpServer:p})},{headers:y.cacheHeaders})},j=(...e)=>O()(...e),b=()=>R.NextResponse.json({},{headers:y.cacheHeaders});var k=e.i(28403);let H=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route",pathname:"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.ts",nextConfigOutput:"",userland:k}),{workAsyncStorage:M,workUnitAsyncStorage:z,serverHooks:q}=H;function _(){return(0,s.patchFetch)({workAsyncStorage:M,workUnitAsyncStorage:z})}async function D(e,t,s){var m;let f="/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route";f=f.replace(/\/index$/,"")||"/";let R=await H.prepare(e,t,{srcPage:f,multiZoneDraftMode:!1});if(!R)return t.statusCode=400,t.end("Bad Request"),null==s.waitUntil||s.waitUntil.call(s,Promise.resolve()),null;let{buildId:y,params:g,nextConfig:S,isDraftMode:w,prerenderManifest:A,routerServerContext:E,isOnDemandRevalidate:N,revalidateOnlyGenerated:I,resolvedPathname:C}=R,P=(0,i.normalizeAppPath)(f),O=!!(A.dynamicRoutes[P]||A.routes[C]);if(O&&!w){let e=!!A.routes[C],t=A.dynamicRoutes[P];if(t&&!1===t.fallback&&!e)throw new T.NoFallbackError}let j=null;!O||H.isDev||w||(j="/index"===(j=C)?"/":j);let b=!0===H.isDev||!O,k=O&&!b,M=e.method||"GET",z=(0,n.getTracer)(),q=z.getActiveScopeSpan(),_={params:g,prerenderManifest:A,renderOpts:{experimental:{cacheComponents:!!S.experimental.cacheComponents,authInterrupts:!!S.experimental.authInterrupts},supportsDynamicResponse:b,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:null==(m=S.experimental)?void 0:m.cacheLife,isRevalidate:k,waitUntil:s.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,s)=>H.onRequestError(e,t,s,E)},sharedContext:{buildId:y}},D=new o.NodeNextRequest(e),U=new o.NodeNextResponse(t),K=p.NextRequestAdapter.fromNodeNextRequest(D,(0,p.signalFromNodeResponse)(t));try{let i=async r=>H.handle(K,_).finally(()=>{if(!r)return;r.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let s=z.getRootSpanAttributes();if(!s)return;if(s.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${s.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=s.get("next.route");if(a){let e=`${M} ${a}`;r.setAttributes({"next.route":a,"http.route":a,"next.span_name":e}),r.updateName(e)}else r.updateName(`${M} ${e.url}`)}),o=async n=>{var o,p;let d=async({previousCacheEntry:r})=>{try{if(!(0,a.getRequestMeta)(e,"minimalMode")&&N&&I&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await i(n);e.fetchMetrics=_.renderOpts.fetchMetrics;let p=_.renderOpts.pendingWaitUntil;p&&s.waitUntil&&(s.waitUntil(p),p=void 0);let d=_.renderOpts.collectedTags;if(!O)return await (0,u.sendResponse)(D,U,o,_.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,c.toNodeOutgoingHttpHeaders)(o.headers);d&&(t[v.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==_.renderOpts.collectedRevalidate&&!(_.renderOpts.collectedRevalidate>=v.INFINITE_CACHE)&&_.renderOpts.collectedRevalidate,s=void 0===_.renderOpts.collectedExpire||_.renderOpts.collectedExpire>=v.INFINITE_CACHE?void 0:_.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:o.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:s}}}}catch(t){throw(null==r?void 0:r.isStale)&&await H.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,l.getRevalidateReason)({isRevalidate:k,isOnDemandRevalidate:N})},E),t}},T=await H.handleResponse({req:e,nextConfig:S,cacheKey:j,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:N,revalidateOnlyGenerated:I,responseGenerator:d,waitUntil:s.waitUntil});if(!O)return null;if((null==T||null==(o=T.value)?void 0:o.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==T||null==(p=T.value)?void 0:p.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});(0,a.getRequestMeta)(e,"minimalMode")||t.setHeader("x-nextjs-cache",N?"REVALIDATED":T.isMiss?"MISS":T.isStale?"STALE":"HIT"),w&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let m=(0,c.fromNodeOutgoingHttpHeaders)(T.value.headers);return(0,a.getRequestMeta)(e,"minimalMode")&&O||m.delete(v.NEXT_CACHE_TAGS_HEADER),!T.cacheControl||t.getHeader("Cache-Control")||m.get("Cache-Control")||m.set("Cache-Control",(0,h.getCacheControlHeader)(T.cacheControl)),await (0,u.sendResponse)(D,U,new Response(T.value.body,{headers:m,status:T.value.status||200})),null};q?await o(q):await z.withPropagatedContext(e.headers,()=>z.trace(d.BaseServerSpan.handleRequest,{spanName:`${M} ${e.url}`,kind:n.SpanKind.SERVER,attributes:{"http.method":M,"http.target":e.url}},o))}catch(t){if(t instanceof T.NoFallbackError||await H.onRequestError(e,t,{routerKind:"App Router",routePath:P,routeType:"route",revalidateReason:(0,l.getRevalidateReason)({isRevalidate:k,isOnDemandRevalidate:N})}),O)throw t;return await (0,u.sendResponse)(D,U,new Response(null,{status:500})),null}}}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__441cee00._.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/cache/cacheHeaders.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/apiKeys/getApiKey.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/misc/isJSON.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/mcpServers/serializeApiMcpServer.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/mcpServers/mcpServerSchema.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.ts","turbopack:///[project]/supercorp/superinterface/node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["export const cacheHeaders = {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',\n 'Access-Control-Allow-Headers': 'Content-Type',\n}\n","import { ApiKeyType, ApiKey, type PrismaClient } from '@prisma/client'\nimport { validate } from 'uuid'\n\nexport const getApiKey = async ({\n authorization,\n type,\n prisma,\n}: {\n authorization: string | null\n type: ApiKeyType\n prisma: PrismaClient\n}): Promise<ApiKey | null> => {\n if (!authorization) {\n return null\n }\n\n const [, apiKeyValue] = authorization.split('Bearer ')\n\n if (!validate(apiKeyValue)) {\n return null\n }\n\n return prisma.apiKey.findFirst({\n where: { type, value: apiKeyValue },\n })\n}\n","export const isJSON = (value: string) => {\n try {\n JSON.parse(value)\n return true\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (e) {\n return false\n }\n}\n","import type { Prisma, SseTransport, HttpTransport } from '@prisma/client'\n\nconst serializeApiSseTransport = ({\n sseTransport,\n}: {\n sseTransport: SseTransport\n}) => ({\n id: sseTransport.id,\n url: sseTransport.url,\n headers: sseTransport.headers,\n createdAt: sseTransport.createdAt.toISOString(),\n updatedAt: sseTransport.updatedAt.toISOString(),\n})\n\nconst serializeApiHttpTransport = ({\n httpTransport,\n}: {\n httpTransport: HttpTransport\n}) => ({\n id: httpTransport.id,\n url: httpTransport.url,\n headers: httpTransport.headers,\n createdAt: httpTransport.createdAt.toISOString(),\n updatedAt: httpTransport.updatedAt.toISOString(),\n})\n\nexport const serializeApiMcpServer = ({\n mcpServer,\n}: {\n mcpServer: Prisma.McpServerGetPayload<{\n include: {\n sseTransport: true\n httpTransport: true\n }\n }>\n}) => ({\n id: mcpServer.id,\n transportType: mcpServer.transportType,\n sseTransport: mcpServer.sseTransport\n ? serializeApiSseTransport({\n sseTransport: mcpServer.sseTransport,\n })\n : null,\n httpTransport: mcpServer.httpTransport\n ? serializeApiHttpTransport({\n httpTransport: mcpServer.httpTransport,\n })\n : null,\n createdAt: mcpServer.createdAt.toISOString(),\n updatedAt: mcpServer.updatedAt.toISOString(),\n})\n","import { z } from 'zod'\nimport { TransportType } from '@prisma/client'\nimport { isJSON } from '@/lib/misc/isJSON'\n\nconst stdioTransportSchema = z.object({\n command: z.string().min(1),\n args: z.string().min(1),\n})\n\nconst sseTransportSchema = z.object({\n url: z.string().min(1).url(),\n headers: z.string().min(1).refine(isJSON, {\n message: 'Must be a valid JSON string.',\n }),\n})\n\nconst httpTransportSchema = z.object({\n url: z.string().min(1).url(),\n headers: z.string().min(1).refine(isJSON, {\n message: 'Must be a valid JSON string.',\n }),\n})\n\nexport const baseSchema = z.object({\n transportType: z\n .nativeEnum(TransportType)\n .refine((t) => t !== TransportType.STDIO, {\n message: `transportType cannot be ${TransportType.STDIO}`,\n }),\n sseTransport: sseTransportSchema.nullable().optional(),\n httpTransport: httpTransportSchema.nullable().optional(),\n})\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const superRefine = (values: any, ctx: any) => {\n if (values.transportType === TransportType.STDIO) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Transport type ${TransportType.STDIO} is not allowed.`,\n })\n\n const result = stdioTransportSchema.safeParse(values.stdioTransport)\n\n if (result.success) return\n\n result.error.issues.forEach((issue) =>\n ctx.addIssue({\n ...issue,\n path: ['stdioTransport', ...issue.path],\n }),\n )\n } else if (values.transportType === TransportType.SSE) {\n const result = sseTransportSchema.safeParse(values.sseTransport)\n\n if (result.success) return\n\n result.error.issues.forEach((issue) =>\n ctx.addIssue({\n ...issue,\n path: ['sseTransport', ...issue.path],\n }),\n )\n } else if (values.transportType === TransportType.HTTP) {\n const result = httpTransportSchema.safeParse(values.httpTransport)\n\n if (result.success) return\n\n result.error.issues.forEach((issue) =>\n ctx.addIssue({\n ...issue,\n path: ['httpTransport', ...issue.path],\n }),\n )\n }\n}\n\nexport const mcpServerSchema = baseSchema.superRefine(superRefine)\n","import { headers } from 'next/headers'\nimport { ApiKeyType, TransportType, type PrismaClient } from '@prisma/client'\nimport { NextResponse, type NextRequest } from 'next/server'\nimport { cacheHeaders } from '@/lib/cache/cacheHeaders'\nimport { resolvePrisma } from '@/lib/prisma'\nimport { getApiKey } from '@/lib/apiKeys/getApiKey'\nimport { validate } from 'uuid'\nimport { serializeApiMcpServer } from '@/lib/mcpServers/serializeApiMcpServer'\nimport { mcpServerSchema } from '@/lib/mcpServers/mcpServerSchema'\n\nexport const buildGET =\n ({ prisma: providedPrisma }: { prisma?: PrismaClient } = {}) =>\n async (\n _request: NextRequest,\n props: {\n params: Promise<{ assistantId: string; mcpServerId: string }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const { assistantId, mcpServerId } = await props.params\n\n const headersList = await headers()\n const authorization = headersList.get('authorization')\n if (!authorization) {\n return NextResponse.json(\n { error: 'No authorization header found' },\n { status: 400 },\n )\n }\n\n const privateApiKey = await getApiKey({\n type: ApiKeyType.PRIVATE,\n authorization,\n prisma,\n })\n\n if (!privateApiKey) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!validate(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistant id' },\n { status: 400 },\n )\n }\n\n if (!validate(mcpServerId)) {\n return NextResponse.json(\n { error: 'Invalid MCP server id' },\n { status: 400 },\n )\n }\n\n const mcpServer = await prisma.mcpServer.findFirst({\n where: {\n id: mcpServerId,\n assistant: {\n id: assistantId,\n workspaceId: privateApiKey.workspaceId,\n },\n },\n include: {\n sseTransport: true,\n httpTransport: true,\n },\n })\n\n if (!mcpServer) {\n return NextResponse.json(\n { error: 'No MCP server found' },\n { status: 400 },\n )\n }\n\n return NextResponse.json(\n {\n mcpServer: serializeApiMcpServer({ mcpServer }),\n },\n { headers: cacheHeaders },\n )\n }\n\nexport const GET = buildGET()\n\nexport const buildPATCH =\n ({ prisma: providedPrisma }: { prisma?: PrismaClient } = {}) =>\n async (\n request: NextRequest,\n props: {\n params: Promise<{ assistantId: string; mcpServerId: string }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const { assistantId, mcpServerId } = await props.params\n\n const headersList = await headers()\n const authorization = headersList.get('authorization')\n if (!authorization) {\n return NextResponse.json(\n { error: 'No authorization header found' },\n { status: 400 },\n )\n }\n\n const privateApiKey = await getApiKey({\n authorization,\n type: ApiKeyType.PRIVATE,\n prisma,\n })\n\n if (!privateApiKey) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!validate(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistant id' },\n { status: 400 },\n )\n }\n\n if (!validate(mcpServerId)) {\n return NextResponse.json(\n { error: 'Invalid MCP server id' },\n { status: 400 },\n )\n }\n\n const body = await request.json()\n\n const parsed = mcpServerSchema.safeParse(body)\n\n if (!parsed.success) {\n return NextResponse.json({ error: 'Invalid payload' }, { status: 400 })\n }\n\n const { transportType, sseTransport, httpTransport } = parsed.data\n\n const mcpServer = await prisma.mcpServer.findFirst({\n where: {\n id: mcpServerId,\n assistant: {\n id: assistantId,\n workspaceId: privateApiKey.workspaceId,\n },\n },\n })\n\n if (!mcpServer) {\n return NextResponse.json(\n { error: 'No MCP server found' },\n { status: 400 },\n )\n }\n\n const updatedMcpServer = await prisma.mcpServer.update({\n where: {\n id: mcpServerId,\n },\n data: {\n transportType,\n ...(transportType === TransportType.SSE\n ? {\n sseTransport: {\n update: {\n url: sseTransport!.url,\n headers: JSON.parse(sseTransport!.headers),\n },\n },\n }\n : {}),\n ...(transportType === TransportType.HTTP\n ? {\n httpTransport: {\n update: {\n url: httpTransport!.url,\n headers: JSON.parse(httpTransport!.headers),\n },\n },\n }\n : {}),\n },\n include: {\n sseTransport: true,\n httpTransport: true,\n },\n })\n\n return NextResponse.json(\n {\n mcpServer: serializeApiMcpServer({ mcpServer: updatedMcpServer }),\n },\n { headers: cacheHeaders },\n )\n }\n\nexport const PATCH = buildPATCH()\n\nexport const buildDELETE =\n ({ prisma: providedPrisma }: { prisma?: PrismaClient } = {}) =>\n async (\n _request: NextRequest,\n props: {\n params: Promise<{ assistantId: string; mcpServerId: string }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const { assistantId, mcpServerId } = await props.params\n\n const headersList = await headers()\n const authorization = headersList.get('authorization')\n if (!authorization) {\n return NextResponse.json(\n { error: 'No authorization header found' },\n { status: 400 },\n )\n }\n\n const privateApiKey = await getApiKey({\n authorization,\n type: ApiKeyType.PRIVATE,\n prisma,\n })\n\n if (!privateApiKey) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!validate(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistant id' },\n { status: 400 },\n )\n }\n\n if (!validate(mcpServerId)) {\n return NextResponse.json(\n { error: 'Invalid MCP server id' },\n { status: 400 },\n )\n }\n\n const mcpServer = await prisma.mcpServer.findFirst({\n where: {\n id: mcpServerId,\n assistant: {\n id: assistantId,\n workspaceId: privateApiKey.workspaceId,\n },\n },\n })\n\n if (!mcpServer) {\n return NextResponse.json(\n { error: 'No MCP server found' },\n { status: 400 },\n )\n }\n\n const deletedMcpServer = await prisma.mcpServer.delete({\n where: { id: mcpServerId },\n include: {\n sseTransport: true,\n httpTransport: true,\n },\n })\n\n return NextResponse.json(\n {\n mcpServer: serializeApiMcpServer({ mcpServer: deletedMcpServer }),\n },\n { headers: cacheHeaders },\n )\n }\n\nexport const DELETE = buildDELETE()\n\nexport const OPTIONS = () =>\n NextResponse.json(\n {},\n {\n headers: cacheHeaders,\n },\n )\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route\",\n pathname: \"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n var _nextConfig_experimental;\n let srcPage = \"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isRevalidate = isIsr && !supportsDynamicResponse;\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n cacheComponents: Boolean(nextConfig.experimental.cacheComponents),\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: (_nextConfig_experimental = nextConfig.experimental) == null ? void 0 : _nextConfig_experimental.cacheLife,\n isRevalidate,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${req.url}`);\n }\n });\n };\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!getRequestMeta(req, 'minimalMode') && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!getRequestMeta(req, 'minimalMode')) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(getRequestMeta(req, 'minimalMode') && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${req.url}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n"],"names":[],"mappings":"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","ignoreList":[6]}
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/cache/cacheHeaders.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/apiKeys/getApiKey.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/misc/isJSON.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/mcpServers/serializeApiMcpServer.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/mcpServers/mcpServerSchema.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.ts","turbopack:///[project]/supercorp/superinterface/node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["export const cacheHeaders = {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',\n 'Access-Control-Allow-Headers': 'Content-Type',\n}\n","import { ApiKeyType, ApiKey, type PrismaClient } from '@prisma/client'\nimport { validate } from 'uuid'\n\nexport const getApiKey = async ({\n authorization,\n type,\n prisma,\n}: {\n authorization: string | null\n type: ApiKeyType\n prisma: PrismaClient\n}): Promise<ApiKey | null> => {\n if (!authorization) {\n return null\n }\n\n const [, apiKeyValue] = authorization.split('Bearer ')\n\n if (!validate(apiKeyValue)) {\n return null\n }\n\n return prisma.apiKey.findFirst({\n where: { type, value: apiKeyValue },\n })\n}\n","export const isJSON = (value: string) => {\n try {\n JSON.parse(value)\n return true\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (e) {\n return false\n }\n}\n","import type { Prisma, SseTransport, HttpTransport } from '@prisma/client'\n\nconst serializeApiSseTransport = ({\n sseTransport,\n}: {\n sseTransport: SseTransport\n}) => ({\n id: sseTransport.id,\n url: sseTransport.url,\n headers: sseTransport.headers,\n createdAt: sseTransport.createdAt.toISOString(),\n updatedAt: sseTransport.updatedAt.toISOString(),\n})\n\nconst serializeApiHttpTransport = ({\n httpTransport,\n}: {\n httpTransport: HttpTransport\n}) => ({\n id: httpTransport.id,\n url: httpTransport.url,\n headers: httpTransport.headers,\n createdAt: httpTransport.createdAt.toISOString(),\n updatedAt: httpTransport.updatedAt.toISOString(),\n})\n\nexport const serializeApiMcpServer = ({\n mcpServer,\n}: {\n mcpServer: Prisma.McpServerGetPayload<{\n include: {\n sseTransport: true\n httpTransport: true\n }\n }>\n}) => ({\n id: mcpServer.id,\n transportType: mcpServer.transportType,\n sseTransport: mcpServer.sseTransport\n ? serializeApiSseTransport({\n sseTransport: mcpServer.sseTransport,\n })\n : null,\n httpTransport: mcpServer.httpTransport\n ? serializeApiHttpTransport({\n httpTransport: mcpServer.httpTransport,\n })\n : null,\n createdAt: mcpServer.createdAt.toISOString(),\n updatedAt: mcpServer.updatedAt.toISOString(),\n})\n","import { z } from 'zod'\nimport { TransportType } from '@prisma/client'\nimport { isJSON } from '@/lib/misc/isJSON'\n\nconst stdioTransportSchema = z.object({\n command: z.string().min(1),\n args: z.string().min(1),\n})\n\nconst sseTransportSchema = z.object({\n url: z.string().min(1).url(),\n headers: z.string().min(1).refine(isJSON, {\n message: 'Must be a valid JSON string.',\n }),\n})\n\nconst httpTransportSchema = z.object({\n url: z.string().min(1).url(),\n headers: z.string().min(1).refine(isJSON, {\n message: 'Must be a valid JSON string.',\n }),\n})\n\nexport const baseSchema = z.object({\n transportType: z\n .nativeEnum(TransportType)\n .refine((t) => t !== TransportType.STDIO, {\n message: `transportType cannot be ${TransportType.STDIO}`,\n }),\n sseTransport: sseTransportSchema.nullable().optional(),\n httpTransport: httpTransportSchema.nullable().optional(),\n})\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const superRefine = (values: any, ctx: any) => {\n if (values.transportType === TransportType.STDIO) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Transport type ${TransportType.STDIO} is not allowed.`,\n })\n\n const result = stdioTransportSchema.safeParse(values.stdioTransport)\n\n if (result.success) return\n\n result.error.issues.forEach((issue) =>\n ctx.addIssue({\n ...issue,\n path: ['stdioTransport', ...issue.path],\n }),\n )\n } else if (values.transportType === TransportType.SSE) {\n const result = sseTransportSchema.safeParse(values.sseTransport)\n\n if (result.success) return\n\n result.error.issues.forEach((issue) =>\n ctx.addIssue({\n ...issue,\n path: ['sseTransport', ...issue.path],\n }),\n )\n } else if (values.transportType === TransportType.HTTP) {\n const result = httpTransportSchema.safeParse(values.httpTransport)\n\n if (result.success) return\n\n result.error.issues.forEach((issue) =>\n ctx.addIssue({\n ...issue,\n path: ['httpTransport', ...issue.path],\n }),\n )\n }\n}\n\nexport const mcpServerSchema = baseSchema.superRefine(superRefine)\n","import { headers } from 'next/headers'\nimport { ApiKeyType, TransportType, type PrismaClient } from '@prisma/client'\nimport { NextResponse, type NextRequest } from 'next/server'\nimport { cacheHeaders } from '@/lib/cache/cacheHeaders'\nimport { resolvePrisma } from '@/lib/prisma'\nimport { getApiKey } from '@/lib/apiKeys/getApiKey'\nimport { validate } from 'uuid'\nimport { serializeApiMcpServer } from '@/lib/mcpServers/serializeApiMcpServer'\nimport { mcpServerSchema } from '@/lib/mcpServers/mcpServerSchema'\n\nexport const buildGET =\n ({ prisma: providedPrisma }: { prisma?: PrismaClient } = {}) =>\n async (\n _request: NextRequest,\n props: {\n params: Promise<{ assistantId: string; mcpServerId: string }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const { assistantId, mcpServerId } = await props.params\n\n const headersList = await headers()\n const authorization = headersList.get('authorization')\n if (!authorization) {\n return NextResponse.json(\n { error: 'No authorization header found' },\n { status: 400 },\n )\n }\n\n const privateApiKey = await getApiKey({\n type: ApiKeyType.PRIVATE,\n authorization,\n prisma,\n })\n\n if (!privateApiKey) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!validate(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistant id' },\n { status: 400 },\n )\n }\n\n if (!validate(mcpServerId)) {\n return NextResponse.json(\n { error: 'Invalid MCP server id' },\n { status: 400 },\n )\n }\n\n const mcpServer = await prisma.mcpServer.findFirst({\n where: {\n id: mcpServerId,\n assistant: {\n id: assistantId,\n workspaceId: privateApiKey.workspaceId,\n },\n },\n include: {\n sseTransport: true,\n httpTransport: true,\n },\n })\n\n if (!mcpServer) {\n return NextResponse.json(\n { error: 'No MCP server found' },\n { status: 400 },\n )\n }\n\n return NextResponse.json(\n {\n mcpServer: serializeApiMcpServer({ mcpServer }),\n },\n { headers: cacheHeaders },\n )\n }\n\nexport const GET = ((...args: Parameters<ReturnType<typeof buildGET>>) =>\n buildGET()(...args)) as ReturnType<typeof buildGET>\n\nexport const buildPATCH =\n ({ prisma: providedPrisma }: { prisma?: PrismaClient } = {}) =>\n async (\n request: NextRequest,\n props: {\n params: Promise<{ assistantId: string; mcpServerId: string }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const { assistantId, mcpServerId } = await props.params\n\n const headersList = await headers()\n const authorization = headersList.get('authorization')\n if (!authorization) {\n return NextResponse.json(\n { error: 'No authorization header found' },\n { status: 400 },\n )\n }\n\n const privateApiKey = await getApiKey({\n authorization,\n type: ApiKeyType.PRIVATE,\n prisma,\n })\n\n if (!privateApiKey) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!validate(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistant id' },\n { status: 400 },\n )\n }\n\n if (!validate(mcpServerId)) {\n return NextResponse.json(\n { error: 'Invalid MCP server id' },\n { status: 400 },\n )\n }\n\n const body = await request.json()\n\n const parsed = mcpServerSchema.safeParse(body)\n\n if (!parsed.success) {\n return NextResponse.json({ error: 'Invalid payload' }, { status: 400 })\n }\n\n const { transportType, sseTransport, httpTransport } = parsed.data\n\n const mcpServer = await prisma.mcpServer.findFirst({\n where: {\n id: mcpServerId,\n assistant: {\n id: assistantId,\n workspaceId: privateApiKey.workspaceId,\n },\n },\n })\n\n if (!mcpServer) {\n return NextResponse.json(\n { error: 'No MCP server found' },\n { status: 400 },\n )\n }\n\n const updatedMcpServer = await prisma.mcpServer.update({\n where: {\n id: mcpServerId,\n },\n data: {\n transportType,\n ...(transportType === TransportType.SSE\n ? {\n sseTransport: {\n update: {\n url: sseTransport!.url,\n headers: JSON.parse(sseTransport!.headers),\n },\n },\n }\n : {}),\n ...(transportType === TransportType.HTTP\n ? {\n httpTransport: {\n update: {\n url: httpTransport!.url,\n headers: JSON.parse(httpTransport!.headers),\n },\n },\n }\n : {}),\n },\n include: {\n sseTransport: true,\n httpTransport: true,\n },\n })\n\n return NextResponse.json(\n {\n mcpServer: serializeApiMcpServer({ mcpServer: updatedMcpServer }),\n },\n { headers: cacheHeaders },\n )\n }\n\nexport const PATCH = ((...args: Parameters<ReturnType<typeof buildPATCH>>) =>\n buildPATCH()(...args)) as ReturnType<typeof buildPATCH>\n\nexport const buildDELETE =\n ({ prisma: providedPrisma }: { prisma?: PrismaClient } = {}) =>\n async (\n _request: NextRequest,\n props: {\n params: Promise<{ assistantId: string; mcpServerId: string }>\n },\n ) => {\n const prisma = resolvePrisma(providedPrisma)\n const { assistantId, mcpServerId } = await props.params\n\n const headersList = await headers()\n const authorization = headersList.get('authorization')\n if (!authorization) {\n return NextResponse.json(\n { error: 'No authorization header found' },\n { status: 400 },\n )\n }\n\n const privateApiKey = await getApiKey({\n authorization,\n type: ApiKeyType.PRIVATE,\n prisma,\n })\n\n if (!privateApiKey) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!validate(assistantId)) {\n return NextResponse.json(\n { error: 'Invalid assistant id' },\n { status: 400 },\n )\n }\n\n if (!validate(mcpServerId)) {\n return NextResponse.json(\n { error: 'Invalid MCP server id' },\n { status: 400 },\n )\n }\n\n const mcpServer = await prisma.mcpServer.findFirst({\n where: {\n id: mcpServerId,\n assistant: {\n id: assistantId,\n workspaceId: privateApiKey.workspaceId,\n },\n },\n })\n\n if (!mcpServer) {\n return NextResponse.json(\n { error: 'No MCP server found' },\n { status: 400 },\n )\n }\n\n const deletedMcpServer = await prisma.mcpServer.delete({\n where: { id: mcpServerId },\n include: {\n sseTransport: true,\n httpTransport: true,\n },\n })\n\n return NextResponse.json(\n {\n mcpServer: serializeApiMcpServer({ mcpServer: deletedMcpServer }),\n },\n { headers: cacheHeaders },\n )\n }\n\nexport const DELETE = ((...args: Parameters<ReturnType<typeof buildDELETE>>) =>\n buildDELETE()(...args)) as ReturnType<typeof buildDELETE>\n\nexport const OPTIONS = () =>\n NextResponse.json(\n {},\n {\n headers: cacheHeaders,\n },\n )\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route\",\n pathname: \"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n var _nextConfig_experimental;\n let srcPage = \"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isRevalidate = isIsr && !supportsDynamicResponse;\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n cacheComponents: Boolean(nextConfig.experimental.cacheComponents),\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: (_nextConfig_experimental = nextConfig.experimental) == null ? void 0 : _nextConfig_experimental.cacheLife,\n isRevalidate,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${req.url}`);\n }\n });\n };\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!getRequestMeta(req, 'minimalMode') && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!getRequestMeta(req, 'minimalMode')) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(getRequestMeta(req, 'minimalMode') && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${req.url}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n"],"names":[],"mappings":"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","ignoreList":[6]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[18622,(e,a,r)=>{a.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},20635,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/action-async-storage.external.js",()=>require("next/dist/server/app-render/action-async-storage.external.js"))},93695,(e,a,r)=>{a.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},30611,e=>{"use strict";e.s(["cacheHeaders",()=>a]);let a={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type"}},88122,e=>{"use strict";e.s(["getApiKey",()=>r]);var a=e.i(55897);let r=async({authorization:e,type:r,prisma:t})=>{if(!e)return null;let[,n]=e.split("Bearer ");return(0,a.validate)(n)?t.apiKey.findFirst({where:{type:r,value:n}}):null}},67083,e=>{"use strict";e.s(["isJSON",()=>a]);let a=e=>{try{return JSON.parse(e),!0}catch(e){return!1}}},20460,74787,64538,e=>{"use strict";e.s(["serializeApiFunction",()=>r],20460);var a=e.i(29173);let r=({fn:e})=>({id:e.id,openapiSpec:e.openapiSpec,handler:(({handler:e})=>({type:e.type,...e.type===a.HandlerType.REQUEST?{requestHandler:{url:e.requestHandler.url,method:e.requestHandler.method,headers:e.requestHandler.headers,body:e.requestHandler.body}}:{},...e.type===a.HandlerType.FIRECRAWL?{firecrawlHandler:{type:e.firecrawlHandler.type,apiKey:e.firecrawlHandler.apiKey,body:e.firecrawlHandler.body}}:{},...e.type===a.HandlerType.REPLICATE?{replicateHandler:{type:e.replicateHandler.type,apiKey:e.replicateHandler.apiKey,identifier:e.replicateHandler.identifier,body:e.replicateHandler.body}}:{},...e.type===a.HandlerType.CLIENT_TOOL?{clientToolHandler:{type:e.clientToolHandler.type,name:e.clientToolHandler.name,arguments:e.clientToolHandler.arguments}}:{},...e.type===a.HandlerType.ASSISTANT?{assistantHandler:{assistantId:e.assistantHandler.assistantId}}:{},...e.type===a.HandlerType.LIST_TASKS?{listTasksHandler:{keyTemplate:e.listTasksHandler.keyTemplate}}:{},...e.type===a.HandlerType.CREATE_TASK?{createTaskHandler:{keyTemplate:e.createTaskHandler.keyTemplate}}:{},...e.type===a.HandlerType.UPDATE_TASK?{updateTaskHandler:{keyTemplate:e.updateTaskHandler.keyTemplate}}:{},...e.type===a.HandlerType.DELETE_TASK?{deleteTaskHandler:{keyTemplate:e.deleteTaskHandler.keyTemplate}}:{}}))({handler:e.handler}),createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()});e.s(["functionSchema",()=>u],74787);var t=e.i(13669),n=e.i(67083);let s=t.z.object({method:t.z.nativeEnum(a.MethodType),url:t.z.string().min(1).url(),headers:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."}),body:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),l=t.z.object({type:t.z.nativeEnum(a.FirecrawlHandlerType),apiKey:t.z.string().min(1),body:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),i=t.z.object({assistantId:t.z.string().min(1)}),d=t.z.object({type:t.z.nativeEnum(a.ReplicateHandlerType),identifier:t.z.string().min(1),apiKey:t.z.string().min(1),body:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),o=t.z.object({type:t.z.nativeEnum(a.ClientToolHandlerType),name:t.z.string().min(1),arguments:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),p=t.z.object({keyTemplate:t.z.string()}),u=t.z.object({openapiSpec:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."}),handler:t.z.object({type:t.z.nativeEnum(a.HandlerType),requestHandler:s.nullable().optional(),firecrawlHandler:l.nullable().optional(),assistantHandler:i.nullable().optional(),replicateHandler:d.nullable().optional(),clientToolHandler:o.nullable().optional(),createTaskHandler:p.nullable().optional(),listTasksHandler:p.nullable().optional(),updateTaskHandler:p.nullable().optional(),deleteTaskHandler:p.nullable().optional()})}).superRefine((e,r)=>{if(e.handler.type===a.HandlerType.REQUEST){let a=s.safeParse(e.handler.requestHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","requestHandler",...e.path]}))}if(e.handler.type===a.HandlerType.FIRECRAWL){let a=l.safeParse(e.handler.firecrawlHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","firecrawlHandler",...e.path]}))}if(e.handler.type===a.HandlerType.ASSISTANT){let a=i.safeParse(e.handler.assistantHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","assistantHandler",...e.path]}))}if(e.handler.type===a.HandlerType.REPLICATE){let a=d.safeParse(e.handler.replicateHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","replicateHandler",...e.path]}))}if(e.handler.type===a.HandlerType.CLIENT_TOOL){let a=o.safeParse(e.handler.clientToolHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","clientToolHandler",...e.path]}))}if(e.handler.type===a.HandlerType.CREATE_TASK){let a=p.safeParse(e.handler.createTaskHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","createTaskHandler",...e.path]}))}if(e.handler.type===a.HandlerType.LIST_TASKS){let a=p.safeParse(e.handler.listTasksHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","listTasksHandler",...e.path]}))}if(e.handler.type===a.HandlerType.UPDATE_TASK){let a=p.safeParse(e.handler.updateTaskHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","updateTaskHandler",...e.path]}))}if(e.handler.type===a.HandlerType.DELETE_TASK){let a=p.safeParse(e.handler.deleteTaskHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","deleteTaskHandler",...e.path]}))}});e.s(["handlerPrismaInput",()=>h],64538);class c extends Error{static defaultMessage="Validation failed.";constructor(e=c.defaultMessage){super(e),this.name=this.constructor.name}}let h=async({parsedInput:e,action:r,assistant:t,prisma:n})=>{if(e.handler.type===a.HandlerType.REQUEST){if(!e.handler.requestHandler)throw new c("Request handler is required.");return{requestHandler:{[r]:{method:e.handler.requestHandler.method,url:e.handler.requestHandler.url,headers:JSON.parse(e.handler.requestHandler.headers),body:JSON.parse(e.handler.requestHandler.body)}}}}if(e.handler.type===a.HandlerType.FIRECRAWL){if(!e.handler.firecrawlHandler)throw new c("Firecrawl handler is required.");return{firecrawlHandler:{[r]:{type:e.handler.firecrawlHandler.type,apiKey:e.handler.firecrawlHandler.apiKey,body:JSON.parse(e.handler.firecrawlHandler.body)}}}}if(e.handler.type===a.HandlerType.ASSISTANT){if(!e.handler.assistantHandler)throw new c("Assistant handler is required.");let a=await n.assistant.findFirst({where:{id:e.handler.assistantHandler.assistantId,workspaceId:t.workspaceId}});if(!a)throw new c("Assistant not found.");return{assistantHandler:{[r]:{assistantId:a.id}}}}if(e.handler.type===a.HandlerType.REPLICATE){if(!e.handler.replicateHandler)throw new c("Replicate handler is required.");return{replicateHandler:{[r]:{type:e.handler.replicateHandler.type,apiKey:e.handler.replicateHandler.apiKey,identifier:e.handler.replicateHandler.identifier,body:JSON.parse(e.handler.replicateHandler.body)}}}}if(e.handler.type===a.HandlerType.CLIENT_TOOL){if(!e.handler.clientToolHandler)throw new c("Client tool handler is required.");return{clientToolHandler:{[r]:{type:e.handler.clientToolHandler.type,name:e.handler.clientToolHandler.name,arguments:JSON.parse(e.handler.clientToolHandler.arguments)}}}}else if(e.handler.type===a.HandlerType.CREATE_TASK){if(!e.handler.createTaskHandler)throw new c("Task handler is required.");return{createTaskHandler:{[r]:{keyTemplate:e.handler.createTaskHandler.keyTemplate}}}}else if(e.handler.type===a.HandlerType.LIST_TASKS){if(!e.handler.listTasksHandler)throw new c("Task handler is required.");return{listTasksHandler:{[r]:{keyTemplate:e.handler.listTasksHandler.keyTemplate}}}}else if(e.handler.type===a.HandlerType.UPDATE_TASK){if(!e.handler.updateTaskHandler)throw new c("Task handler is required.");return{updateTaskHandler:{[r]:{keyTemplate:e.handler.updateTaskHandler.keyTemplate}}}}else if(e.handler.type===a.HandlerType.DELETE_TASK){if(!e.handler.deleteTaskHandler)throw new c("Task handler is required.");return{deleteTaskHandler:{[r]:{keyTemplate:e.handler.deleteTaskHandler.keyTemplate}}}}else throw new c("Handler type not supported.")}},79437,e=>{"use strict";e.s([])},65466,e=>{"use strict";e.s(["handler",()=>z,"patchFetch",()=>_,"routeModule",()=>P,"serverHooks",()=>K,"workAsyncStorage",()=>q,"workUnitAsyncStorage",()=>j],65466);var a=e.i(5865),r=e.i(43877),t=e.i(77767),n=e.i(92562),s=e.i(66256),l=e.i(5270),i=e.i(90231),d=e.i(82677),o=e.i(51081),p=e.i(89822),u=e.i(9124),c=e.i(39147),h=e.i(40568),T=e.i(87188),y=e.i(93695);e.i(57132);var H=e.i(80739);e.s(["GET",()=>I,"OPTIONS",()=>O,"POST",()=>N,"buildGET",()=>v,"buildPOST",()=>b],8980);var f=e.i(49493),m=e.i(29173),w=e.i(11053),E=e.i(30611),k=e.i(24493),R=e.i(88122),g=e.i(20460),S=e.i(74787),A=e.i(64538);async function x(e){let{assistant:a,parsedInput:r,include:t,prisma:n}=e;return n.function.create({data:{openapiSpec:JSON.parse(r.openapiSpec),assistantId:a.id,handler:{create:{type:r.handler.type,...await (0,A.handlerPrismaInput)({parsedInput:r,action:"create",assistant:a,prisma:n})}}},include:t})}let v=({prisma:e}={})=>async(a,r)=>{let t=(0,k.resolvePrisma)(e),{assistantId:n}=await r.params,s=(await (0,w.headers)()).get("authorization");if(!s)return f.NextResponse.json({error:"No authorization header found"},{status:400});let l=await (0,R.getApiKey)({type:m.ApiKeyType.PRIVATE,authorization:s,prisma:t});if(!l)return f.NextResponse.json({error:"Invalid api key"},{status:400});let i=await t.assistant.findFirst({where:{id:n,workspaceId:l.workspaceId},include:{functions:{include:{handler:{include:{requestHandler:!0,firecrawlHandler:!0,replicateHandler:!0,clientToolHandler:!0,assistantHandler:!0,createTaskHandler:!0,listTasksHandler:!0,updateTaskHandler:!0,deleteTaskHandler:!0}}},orderBy:{createdAt:"desc"}}}});return i?f.NextResponse.json({functions:i.functions.map(e=>(0,g.serializeApiFunction)({fn:e}))},{headers:E.cacheHeaders}):f.NextResponse.json({error:"No assistant found"},{status:400})},I=v(),b=({prisma:e}={})=>async(a,r)=>{let t=(0,k.resolvePrisma)(e),{assistantId:n}=await r.params,s=(await (0,w.headers)()).get("authorization");if(!s)return f.NextResponse.json({error:"No authorization header found"},{status:400});let l=await (0,R.getApiKey)({authorization:s,type:m.ApiKeyType.PRIVATE,prisma:t});if(!l)return f.NextResponse.json({error:"Invalid api key"},{status:400});let i=await t.assistant.findFirst({where:{id:n,workspaceId:l.workspaceId}});if(!i)return f.NextResponse.json({error:"No assistant found"},{status:400});let d=await a.json(),o=S.functionSchema.safeParse(d);if(!o.success)return console.error("Function creation error:",o.error),f.NextResponse.json({error:"Invalid payload"},{status:400});let p=await x({parsedInput:o.data,assistant:i,include:{handler:{include:{requestHandler:!0,firecrawlHandler:!0,replicateHandler:!0,clientToolHandler:!0,assistantHandler:!0,createTaskHandler:!0,listTasksHandler:!0,updateTaskHandler:!0,deleteTaskHandler:!0}}},prisma:t});return f.NextResponse.json({function:(0,g.serializeApiFunction)({fn:p})},{headers:E.cacheHeaders})},N=b(),O=()=>f.NextResponse.json({},{headers:E.cacheHeaders});var C=e.i(8980);let P=new a.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/assistants/[assistantId]/functions/route",pathname:"/api/assistants/[assistantId]/functions",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/functions/route.ts",nextConfigOutput:"",userland:C}),{workAsyncStorage:q,workUnitAsyncStorage:j,serverHooks:K}=P;function _(){return(0,t.patchFetch)({workAsyncStorage:q,workUnitAsyncStorage:j})}async function z(e,a,t){var f;let m="/api/assistants/[assistantId]/functions/route";m=m.replace(/\/index$/,"")||"/";let w=await P.prepare(e,a,{srcPage:m,multiZoneDraftMode:!1});if(!w)return a.statusCode=400,a.end("Bad Request"),null==t.waitUntil||t.waitUntil.call(t,Promise.resolve()),null;let{buildId:E,params:k,nextConfig:R,isDraftMode:g,prerenderManifest:S,routerServerContext:A,isOnDemandRevalidate:x,revalidateOnlyGenerated:v,resolvedPathname:I}=w,b=(0,l.normalizeAppPath)(m),N=!!(S.dynamicRoutes[b]||S.routes[I]);if(N&&!g){let e=!!S.routes[I],a=S.dynamicRoutes[b];if(a&&!1===a.fallback&&!e)throw new y.NoFallbackError}let O=null;!N||P.isDev||g||(O="/index"===(O=I)?"/":O);let C=!0===P.isDev||!N,q=N&&!C,j=e.method||"GET",K=(0,s.getTracer)(),_=K.getActiveScopeSpan(),z={params:k,prerenderManifest:S,renderOpts:{experimental:{cacheComponents:!!R.experimental.cacheComponents,authInterrupts:!!R.experimental.authInterrupts},supportsDynamicResponse:C,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:null==(f=R.experimental)?void 0:f.cacheLife,isRevalidate:q,waitUntil:t.waitUntil,onClose:e=>{a.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(a,r,t)=>P.onRequestError(e,a,t,A)},sharedContext:{buildId:E}},L=new i.NodeNextRequest(e),M=new i.NodeNextResponse(a),U=d.NextRequestAdapter.fromNodeNextRequest(L,(0,d.signalFromNodeResponse)(a));try{let l=async r=>P.handle(U,z).finally(()=>{if(!r)return;r.setAttributes({"http.status_code":a.statusCode,"next.rsc":!1});let t=K.getRootSpanAttributes();if(!t)return;if(t.get("next.span_type")!==o.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${t.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=t.get("next.route");if(n){let e=`${j} ${n}`;r.setAttributes({"next.route":n,"http.route":n,"next.span_name":e}),r.updateName(e)}else r.updateName(`${j} ${e.url}`)}),i=async s=>{var i,d;let o=async({previousCacheEntry:r})=>{try{if(!(0,n.getRequestMeta)(e,"minimalMode")&&x&&v&&!r)return a.statusCode=404,a.setHeader("x-nextjs-cache","REVALIDATED"),a.end("This page could not be found"),null;let i=await l(s);e.fetchMetrics=z.renderOpts.fetchMetrics;let d=z.renderOpts.pendingWaitUntil;d&&t.waitUntil&&(t.waitUntil(d),d=void 0);let o=z.renderOpts.collectedTags;if(!N)return await (0,u.sendResponse)(L,M,i,z.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),a=(0,c.toNodeOutgoingHttpHeaders)(i.headers);o&&(a[T.NEXT_CACHE_TAGS_HEADER]=o),!a["content-type"]&&e.type&&(a["content-type"]=e.type);let r=void 0!==z.renderOpts.collectedRevalidate&&!(z.renderOpts.collectedRevalidate>=T.INFINITE_CACHE)&&z.renderOpts.collectedRevalidate,t=void 0===z.renderOpts.collectedExpire||z.renderOpts.collectedExpire>=T.INFINITE_CACHE?void 0:z.renderOpts.collectedExpire;return{value:{kind:H.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:a},cacheControl:{revalidate:r,expire:t}}}}catch(a){throw(null==r?void 0:r.isStale)&&await P.onRequestError(e,a,{routerKind:"App Router",routePath:m,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isRevalidate:q,isOnDemandRevalidate:x})},A),a}},y=await P.handleResponse({req:e,nextConfig:R,cacheKey:O,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:S,isRoutePPREnabled:!1,isOnDemandRevalidate:x,revalidateOnlyGenerated:v,responseGenerator:o,waitUntil:t.waitUntil});if(!N)return null;if((null==y||null==(i=y.value)?void 0:i.kind)!==H.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==y||null==(d=y.value)?void 0:d.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});(0,n.getRequestMeta)(e,"minimalMode")||a.setHeader("x-nextjs-cache",x?"REVALIDATED":y.isMiss?"MISS":y.isStale?"STALE":"HIT"),g&&a.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let f=(0,c.fromNodeOutgoingHttpHeaders)(y.value.headers);return(0,n.getRequestMeta)(e,"minimalMode")&&N||f.delete(T.NEXT_CACHE_TAGS_HEADER),!y.cacheControl||a.getHeader("Cache-Control")||f.get("Cache-Control")||f.set("Cache-Control",(0,h.getCacheControlHeader)(y.cacheControl)),await (0,u.sendResponse)(L,M,new Response(y.value.body,{headers:f,status:y.value.status||200})),null};_?await i(_):await K.withPropagatedContext(e.headers,()=>K.trace(o.BaseServerSpan.handleRequest,{spanName:`${j} ${e.url}`,kind:s.SpanKind.SERVER,attributes:{"http.method":j,"http.target":e.url}},i))}catch(a){if(a instanceof y.NoFallbackError||await P.onRequestError(e,a,{routerKind:"App Router",routePath:b,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isRevalidate:q,isOnDemandRevalidate:x})}),N)throw a;return await (0,u.sendResponse)(L,M,new Response(null,{status:500})),null}}}];
|
|
1
|
+
module.exports=[18622,(e,a,r)=>{a.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},20635,(e,a,r)=>{a.exports=e.x("next/dist/server/app-render/action-async-storage.external.js",()=>require("next/dist/server/app-render/action-async-storage.external.js"))},93695,(e,a,r)=>{a.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},30611,e=>{"use strict";e.s(["cacheHeaders",()=>a]);let a={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type"}},88122,e=>{"use strict";e.s(["getApiKey",()=>r]);var a=e.i(55897);let r=async({authorization:e,type:r,prisma:t})=>{if(!e)return null;let[,n]=e.split("Bearer ");return(0,a.validate)(n)?t.apiKey.findFirst({where:{type:r,value:n}}):null}},67083,e=>{"use strict";e.s(["isJSON",()=>a]);let a=e=>{try{return JSON.parse(e),!0}catch(e){return!1}}},20460,74787,64538,e=>{"use strict";e.s(["serializeApiFunction",()=>r],20460);var a=e.i(29173);let r=({fn:e})=>({id:e.id,openapiSpec:e.openapiSpec,handler:(({handler:e})=>({type:e.type,...e.type===a.HandlerType.REQUEST?{requestHandler:{url:e.requestHandler.url,method:e.requestHandler.method,headers:e.requestHandler.headers,body:e.requestHandler.body}}:{},...e.type===a.HandlerType.FIRECRAWL?{firecrawlHandler:{type:e.firecrawlHandler.type,apiKey:e.firecrawlHandler.apiKey,body:e.firecrawlHandler.body}}:{},...e.type===a.HandlerType.REPLICATE?{replicateHandler:{type:e.replicateHandler.type,apiKey:e.replicateHandler.apiKey,identifier:e.replicateHandler.identifier,body:e.replicateHandler.body}}:{},...e.type===a.HandlerType.CLIENT_TOOL?{clientToolHandler:{type:e.clientToolHandler.type,name:e.clientToolHandler.name,arguments:e.clientToolHandler.arguments}}:{},...e.type===a.HandlerType.ASSISTANT?{assistantHandler:{assistantId:e.assistantHandler.assistantId}}:{},...e.type===a.HandlerType.LIST_TASKS?{listTasksHandler:{keyTemplate:e.listTasksHandler.keyTemplate}}:{},...e.type===a.HandlerType.CREATE_TASK?{createTaskHandler:{keyTemplate:e.createTaskHandler.keyTemplate}}:{},...e.type===a.HandlerType.UPDATE_TASK?{updateTaskHandler:{keyTemplate:e.updateTaskHandler.keyTemplate}}:{},...e.type===a.HandlerType.DELETE_TASK?{deleteTaskHandler:{keyTemplate:e.deleteTaskHandler.keyTemplate}}:{}}))({handler:e.handler}),createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString()});e.s(["functionSchema",()=>u],74787);var t=e.i(13669),n=e.i(67083);let s=t.z.object({method:t.z.nativeEnum(a.MethodType),url:t.z.string().min(1).url(),headers:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."}),body:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),l=t.z.object({type:t.z.nativeEnum(a.FirecrawlHandlerType),apiKey:t.z.string().min(1),body:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),i=t.z.object({assistantId:t.z.string().min(1)}),d=t.z.object({type:t.z.nativeEnum(a.ReplicateHandlerType),identifier:t.z.string().min(1),apiKey:t.z.string().min(1),body:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),o=t.z.object({type:t.z.nativeEnum(a.ClientToolHandlerType),name:t.z.string().min(1),arguments:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."})}),p=t.z.object({keyTemplate:t.z.string()}),u=t.z.object({openapiSpec:t.z.string().min(1).refine(n.isJSON,{message:"Must be a valid JSON string."}),handler:t.z.object({type:t.z.nativeEnum(a.HandlerType),requestHandler:s.nullable().optional(),firecrawlHandler:l.nullable().optional(),assistantHandler:i.nullable().optional(),replicateHandler:d.nullable().optional(),clientToolHandler:o.nullable().optional(),createTaskHandler:p.nullable().optional(),listTasksHandler:p.nullable().optional(),updateTaskHandler:p.nullable().optional(),deleteTaskHandler:p.nullable().optional()})}).superRefine((e,r)=>{if(e.handler.type===a.HandlerType.REQUEST){let a=s.safeParse(e.handler.requestHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","requestHandler",...e.path]}))}if(e.handler.type===a.HandlerType.FIRECRAWL){let a=l.safeParse(e.handler.firecrawlHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","firecrawlHandler",...e.path]}))}if(e.handler.type===a.HandlerType.ASSISTANT){let a=i.safeParse(e.handler.assistantHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","assistantHandler",...e.path]}))}if(e.handler.type===a.HandlerType.REPLICATE){let a=d.safeParse(e.handler.replicateHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","replicateHandler",...e.path]}))}if(e.handler.type===a.HandlerType.CLIENT_TOOL){let a=o.safeParse(e.handler.clientToolHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","clientToolHandler",...e.path]}))}if(e.handler.type===a.HandlerType.CREATE_TASK){let a=p.safeParse(e.handler.createTaskHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","createTaskHandler",...e.path]}))}if(e.handler.type===a.HandlerType.LIST_TASKS){let a=p.safeParse(e.handler.listTasksHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","listTasksHandler",...e.path]}))}if(e.handler.type===a.HandlerType.UPDATE_TASK){let a=p.safeParse(e.handler.updateTaskHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","updateTaskHandler",...e.path]}))}if(e.handler.type===a.HandlerType.DELETE_TASK){let a=p.safeParse(e.handler.deleteTaskHandler);if(a.success)return;a.error.issues.forEach(e=>r.addIssue({...e,path:["handler","deleteTaskHandler",...e.path]}))}});e.s(["handlerPrismaInput",()=>h],64538);class c extends Error{static defaultMessage="Validation failed.";constructor(e=c.defaultMessage){super(e),this.name=this.constructor.name}}let h=async({parsedInput:e,action:r,assistant:t,prisma:n})=>{if(e.handler.type===a.HandlerType.REQUEST){if(!e.handler.requestHandler)throw new c("Request handler is required.");return{requestHandler:{[r]:{method:e.handler.requestHandler.method,url:e.handler.requestHandler.url,headers:JSON.parse(e.handler.requestHandler.headers),body:JSON.parse(e.handler.requestHandler.body)}}}}if(e.handler.type===a.HandlerType.FIRECRAWL){if(!e.handler.firecrawlHandler)throw new c("Firecrawl handler is required.");return{firecrawlHandler:{[r]:{type:e.handler.firecrawlHandler.type,apiKey:e.handler.firecrawlHandler.apiKey,body:JSON.parse(e.handler.firecrawlHandler.body)}}}}if(e.handler.type===a.HandlerType.ASSISTANT){if(!e.handler.assistantHandler)throw new c("Assistant handler is required.");let a=await n.assistant.findFirst({where:{id:e.handler.assistantHandler.assistantId,workspaceId:t.workspaceId}});if(!a)throw new c("Assistant not found.");return{assistantHandler:{[r]:{assistantId:a.id}}}}if(e.handler.type===a.HandlerType.REPLICATE){if(!e.handler.replicateHandler)throw new c("Replicate handler is required.");return{replicateHandler:{[r]:{type:e.handler.replicateHandler.type,apiKey:e.handler.replicateHandler.apiKey,identifier:e.handler.replicateHandler.identifier,body:JSON.parse(e.handler.replicateHandler.body)}}}}if(e.handler.type===a.HandlerType.CLIENT_TOOL){if(!e.handler.clientToolHandler)throw new c("Client tool handler is required.");return{clientToolHandler:{[r]:{type:e.handler.clientToolHandler.type,name:e.handler.clientToolHandler.name,arguments:JSON.parse(e.handler.clientToolHandler.arguments)}}}}else if(e.handler.type===a.HandlerType.CREATE_TASK){if(!e.handler.createTaskHandler)throw new c("Task handler is required.");return{createTaskHandler:{[r]:{keyTemplate:e.handler.createTaskHandler.keyTemplate}}}}else if(e.handler.type===a.HandlerType.LIST_TASKS){if(!e.handler.listTasksHandler)throw new c("Task handler is required.");return{listTasksHandler:{[r]:{keyTemplate:e.handler.listTasksHandler.keyTemplate}}}}else if(e.handler.type===a.HandlerType.UPDATE_TASK){if(!e.handler.updateTaskHandler)throw new c("Task handler is required.");return{updateTaskHandler:{[r]:{keyTemplate:e.handler.updateTaskHandler.keyTemplate}}}}else if(e.handler.type===a.HandlerType.DELETE_TASK){if(!e.handler.deleteTaskHandler)throw new c("Task handler is required.");return{deleteTaskHandler:{[r]:{keyTemplate:e.handler.deleteTaskHandler.keyTemplate}}}}else throw new c("Handler type not supported.")}},79437,e=>{"use strict";e.s([])},65466,e=>{"use strict";e.s(["handler",()=>z,"patchFetch",()=>_,"routeModule",()=>P,"serverHooks",()=>K,"workAsyncStorage",()=>q,"workUnitAsyncStorage",()=>j],65466);var a=e.i(5865),r=e.i(43877),t=e.i(77767),n=e.i(92562),s=e.i(66256),l=e.i(5270),i=e.i(90231),d=e.i(82677),o=e.i(51081),p=e.i(89822),u=e.i(9124),c=e.i(39147),h=e.i(40568),T=e.i(87188),y=e.i(93695);e.i(57132);var H=e.i(80739);e.s(["GET",()=>I,"OPTIONS",()=>O,"POST",()=>N,"buildGET",()=>v,"buildPOST",()=>b],8980);var f=e.i(49493),m=e.i(29173),w=e.i(11053),E=e.i(30611),k=e.i(24493),R=e.i(88122),g=e.i(20460),S=e.i(74787),A=e.i(64538);async function x(e){let{assistant:a,parsedInput:r,include:t,prisma:n}=e;return n.function.create({data:{openapiSpec:JSON.parse(r.openapiSpec),assistantId:a.id,handler:{create:{type:r.handler.type,...await (0,A.handlerPrismaInput)({parsedInput:r,action:"create",assistant:a,prisma:n})}}},include:t})}let v=({prisma:e}={})=>async(a,r)=>{let t=(0,k.resolvePrisma)(e),{assistantId:n}=await r.params,s=(await (0,w.headers)()).get("authorization");if(!s)return f.NextResponse.json({error:"No authorization header found"},{status:400});let l=await (0,R.getApiKey)({type:m.ApiKeyType.PRIVATE,authorization:s,prisma:t});if(!l)return f.NextResponse.json({error:"Invalid api key"},{status:400});let i=await t.assistant.findFirst({where:{id:n,workspaceId:l.workspaceId},include:{functions:{include:{handler:{include:{requestHandler:!0,firecrawlHandler:!0,replicateHandler:!0,clientToolHandler:!0,assistantHandler:!0,createTaskHandler:!0,listTasksHandler:!0,updateTaskHandler:!0,deleteTaskHandler:!0}}},orderBy:{createdAt:"desc"}}}});return i?f.NextResponse.json({functions:i.functions.map(e=>(0,g.serializeApiFunction)({fn:e}))},{headers:E.cacheHeaders}):f.NextResponse.json({error:"No assistant found"},{status:400})},I=(...e)=>v()(...e),b=({prisma:e}={})=>async(a,r)=>{let t=(0,k.resolvePrisma)(e),{assistantId:n}=await r.params,s=(await (0,w.headers)()).get("authorization");if(!s)return f.NextResponse.json({error:"No authorization header found"},{status:400});let l=await (0,R.getApiKey)({authorization:s,type:m.ApiKeyType.PRIVATE,prisma:t});if(!l)return f.NextResponse.json({error:"Invalid api key"},{status:400});let i=await t.assistant.findFirst({where:{id:n,workspaceId:l.workspaceId}});if(!i)return f.NextResponse.json({error:"No assistant found"},{status:400});let d=await a.json(),o=S.functionSchema.safeParse(d);if(!o.success)return console.error("Function creation error:",o.error),f.NextResponse.json({error:"Invalid payload"},{status:400});let p=await x({parsedInput:o.data,assistant:i,include:{handler:{include:{requestHandler:!0,firecrawlHandler:!0,replicateHandler:!0,clientToolHandler:!0,assistantHandler:!0,createTaskHandler:!0,listTasksHandler:!0,updateTaskHandler:!0,deleteTaskHandler:!0}}},prisma:t});return f.NextResponse.json({function:(0,g.serializeApiFunction)({fn:p})},{headers:E.cacheHeaders})},N=(...e)=>b()(...e),O=()=>f.NextResponse.json({},{headers:E.cacheHeaders});var C=e.i(8980);let P=new a.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/assistants/[assistantId]/functions/route",pathname:"/api/assistants/[assistantId]/functions",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/supercorp/superinterface/packages/server/src/app/api/assistants/[assistantId]/functions/route.ts",nextConfigOutput:"",userland:C}),{workAsyncStorage:q,workUnitAsyncStorage:j,serverHooks:K}=P;function _(){return(0,t.patchFetch)({workAsyncStorage:q,workUnitAsyncStorage:j})}async function z(e,a,t){var f;let m="/api/assistants/[assistantId]/functions/route";m=m.replace(/\/index$/,"")||"/";let w=await P.prepare(e,a,{srcPage:m,multiZoneDraftMode:!1});if(!w)return a.statusCode=400,a.end("Bad Request"),null==t.waitUntil||t.waitUntil.call(t,Promise.resolve()),null;let{buildId:E,params:k,nextConfig:R,isDraftMode:g,prerenderManifest:S,routerServerContext:A,isOnDemandRevalidate:x,revalidateOnlyGenerated:v,resolvedPathname:I}=w,b=(0,l.normalizeAppPath)(m),N=!!(S.dynamicRoutes[b]||S.routes[I]);if(N&&!g){let e=!!S.routes[I],a=S.dynamicRoutes[b];if(a&&!1===a.fallback&&!e)throw new y.NoFallbackError}let O=null;!N||P.isDev||g||(O="/index"===(O=I)?"/":O);let C=!0===P.isDev||!N,q=N&&!C,j=e.method||"GET",K=(0,s.getTracer)(),_=K.getActiveScopeSpan(),z={params:k,prerenderManifest:S,renderOpts:{experimental:{cacheComponents:!!R.experimental.cacheComponents,authInterrupts:!!R.experimental.authInterrupts},supportsDynamicResponse:C,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:null==(f=R.experimental)?void 0:f.cacheLife,isRevalidate:q,waitUntil:t.waitUntil,onClose:e=>{a.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(a,r,t)=>P.onRequestError(e,a,t,A)},sharedContext:{buildId:E}},L=new i.NodeNextRequest(e),M=new i.NodeNextResponse(a),U=d.NextRequestAdapter.fromNodeNextRequest(L,(0,d.signalFromNodeResponse)(a));try{let l=async r=>P.handle(U,z).finally(()=>{if(!r)return;r.setAttributes({"http.status_code":a.statusCode,"next.rsc":!1});let t=K.getRootSpanAttributes();if(!t)return;if(t.get("next.span_type")!==o.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${t.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=t.get("next.route");if(n){let e=`${j} ${n}`;r.setAttributes({"next.route":n,"http.route":n,"next.span_name":e}),r.updateName(e)}else r.updateName(`${j} ${e.url}`)}),i=async s=>{var i,d;let o=async({previousCacheEntry:r})=>{try{if(!(0,n.getRequestMeta)(e,"minimalMode")&&x&&v&&!r)return a.statusCode=404,a.setHeader("x-nextjs-cache","REVALIDATED"),a.end("This page could not be found"),null;let i=await l(s);e.fetchMetrics=z.renderOpts.fetchMetrics;let d=z.renderOpts.pendingWaitUntil;d&&t.waitUntil&&(t.waitUntil(d),d=void 0);let o=z.renderOpts.collectedTags;if(!N)return await (0,u.sendResponse)(L,M,i,z.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),a=(0,c.toNodeOutgoingHttpHeaders)(i.headers);o&&(a[T.NEXT_CACHE_TAGS_HEADER]=o),!a["content-type"]&&e.type&&(a["content-type"]=e.type);let r=void 0!==z.renderOpts.collectedRevalidate&&!(z.renderOpts.collectedRevalidate>=T.INFINITE_CACHE)&&z.renderOpts.collectedRevalidate,t=void 0===z.renderOpts.collectedExpire||z.renderOpts.collectedExpire>=T.INFINITE_CACHE?void 0:z.renderOpts.collectedExpire;return{value:{kind:H.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:a},cacheControl:{revalidate:r,expire:t}}}}catch(a){throw(null==r?void 0:r.isStale)&&await P.onRequestError(e,a,{routerKind:"App Router",routePath:m,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isRevalidate:q,isOnDemandRevalidate:x})},A),a}},y=await P.handleResponse({req:e,nextConfig:R,cacheKey:O,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:S,isRoutePPREnabled:!1,isOnDemandRevalidate:x,revalidateOnlyGenerated:v,responseGenerator:o,waitUntil:t.waitUntil});if(!N)return null;if((null==y||null==(i=y.value)?void 0:i.kind)!==H.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==y||null==(d=y.value)?void 0:d.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});(0,n.getRequestMeta)(e,"minimalMode")||a.setHeader("x-nextjs-cache",x?"REVALIDATED":y.isMiss?"MISS":y.isStale?"STALE":"HIT"),g&&a.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let f=(0,c.fromNodeOutgoingHttpHeaders)(y.value.headers);return(0,n.getRequestMeta)(e,"minimalMode")&&N||f.delete(T.NEXT_CACHE_TAGS_HEADER),!y.cacheControl||a.getHeader("Cache-Control")||f.get("Cache-Control")||f.set("Cache-Control",(0,h.getCacheControlHeader)(y.cacheControl)),await (0,u.sendResponse)(L,M,new Response(y.value.body,{headers:f,status:y.value.status||200})),null};_?await i(_):await K.withPropagatedContext(e.headers,()=>K.trace(o.BaseServerSpan.handleRequest,{spanName:`${j} ${e.url}`,kind:s.SpanKind.SERVER,attributes:{"http.method":j,"http.target":e.url}},i))}catch(a){if(a instanceof y.NoFallbackError||await P.onRequestError(e,a,{routerKind:"App Router",routePath:b,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isRevalidate:q,isOnDemandRevalidate:x})}),N)throw a;return await (0,u.sendResponse)(L,M,new Response(null,{status:500})),null}}}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__464a4377._.js.map
|