ai-agent-router 0.1.21 → 0.2.1
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/app-path-routes-manifest.json +14 -0
- package/.next/build-manifest.json +2 -2
- package/.next/fallback-build-manifest.json +2 -2
- package/.next/routes-manifest.json +84 -0
- package/.next/server/app/_global-error/page.js +1 -1
- package/.next/server/app/_global-error/page.js.nft.json +1 -1
- package/.next/server/app/_global-error.html +2 -2
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found/page.js +1 -1
- package/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +2 -2
- package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/api/config/route.js.nft.json +1 -1
- package/.next/server/app/api/gateway/[...path]/route.js.nft.json +1 -1
- package/.next/server/app/api/gateway/models/route.js.nft.json +1 -1
- package/.next/server/app/api/gateway/route.js.nft.json +1 -1
- package/.next/server/app/api/ide/claude/apply/route.js.nft.json +1 -1
- package/.next/server/app/api/ide/claude/available-models/route.js.nft.json +1 -1
- package/.next/server/app/api/ide/claude/save/route.js.nft.json +1 -1
- package/.next/server/app/api/ide/claude/status/route.js.nft.json +1 -1
- package/.next/server/app/api/ide/claude/test/route.js +1 -1
- package/.next/server/app/api/ide/claude/test/route.js.nft.json +1 -1
- package/.next/server/app/api/ide/openclaw/apply/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/apply/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/apply/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/apply/route.js +7 -0
- package/.next/server/app/api/ide/openclaw/apply/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/apply/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/apply/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/openclaw/available-models/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/available-models/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/available-models/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/available-models/route.js +7 -0
- package/.next/server/app/api/ide/openclaw/available-models/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/available-models/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/available-models/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/openclaw/preview/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/preview/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/preview/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/preview/route.js +7 -0
- package/.next/server/app/api/ide/openclaw/preview/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/preview/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/preview/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/openclaw/restore/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/restore/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/restore/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/restore/route.js +6 -0
- package/.next/server/app/api/ide/openclaw/restore/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/restore/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/restore/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/openclaw/save/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/save/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/save/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/save/route.js +7 -0
- package/.next/server/app/api/ide/openclaw/save/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/save/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/save/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/openclaw/status/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/status/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/status/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/status/route.js +7 -0
- package/.next/server/app/api/ide/openclaw/status/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/status/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/status/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/openclaw/test/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/openclaw/test/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/openclaw/test/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/openclaw/test/route.js +6 -0
- package/.next/server/app/api/ide/openclaw/test/route.js.map +5 -0
- package/.next/server/app/api/ide/openclaw/test/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/openclaw/test/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/apply/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/apply/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/apply/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/apply/route.js +7 -0
- package/.next/server/app/api/ide/opencode/apply/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/apply/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/apply/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/available-models/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/available-models/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/available-models/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/available-models/route.js +7 -0
- package/.next/server/app/api/ide/opencode/available-models/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/available-models/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/available-models/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/preview/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/preview/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/preview/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/preview/route.js +7 -0
- package/.next/server/app/api/ide/opencode/preview/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/preview/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/preview/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/restore/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/restore/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/restore/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/restore/route.js +6 -0
- package/.next/server/app/api/ide/opencode/restore/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/restore/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/restore/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/save/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/save/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/save/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/save/route.js +7 -0
- package/.next/server/app/api/ide/opencode/save/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/save/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/save/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/status/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/status/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/status/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/status/route.js +7 -0
- package/.next/server/app/api/ide/opencode/status/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/status/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/status/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/ide/opencode/test/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/ide/opencode/test/route/build-manifest.json +11 -0
- package/.next/server/app/api/ide/opencode/test/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/ide/opencode/test/route.js +6 -0
- package/.next/server/app/api/ide/opencode/test/route.js.map +5 -0
- package/.next/server/app/api/ide/opencode/test/route.js.nft.json +1 -0
- package/.next/server/app/api/ide/opencode/test/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/logs/route.js.nft.json +1 -1
- package/.next/server/app/api/models/route.js.nft.json +1 -1
- package/.next/server/app/api/providers/route.js.nft.json +1 -1
- package/.next/server/app/api/providers/test/route.js.nft.json +1 -1
- package/.next/server/app/api/service/force-stop/route.js.nft.json +1 -1
- package/.next/server/app/api/service/start/route.js.nft.json +1 -1
- package/.next/server/app/api/service/status/route.js.nft.json +1 -1
- package/.next/server/app/api/service/stop/route.js.nft.json +1 -1
- package/.next/server/app/ide/page.js +1 -1
- package/.next/server/app/ide/page.js.nft.json +1 -1
- package/.next/server/app/ide/page_client-reference-manifest.js +1 -1
- package/.next/server/app/ide.html +1 -1
- package/.next/server/app/ide.rsc +3 -3
- package/.next/server/app/ide.segments/_full.segment.rsc +3 -3
- package/.next/server/app/ide.segments/_head.segment.rsc +1 -1
- package/.next/server/app/ide.segments/_index.segment.rsc +2 -2
- package/.next/server/app/ide.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/ide.segments/ide/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/ide.segments/ide.segment.rsc +1 -1
- package/.next/server/app/index.html +1 -1
- package/.next/server/app/index.rsc +2 -2
- package/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/index.segments/_full.segment.rsc +2 -2
- package/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/server/app/index.segments/_index.segment.rsc +2 -2
- package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/logs/page.js +1 -1
- package/.next/server/app/logs/page.js.nft.json +1 -1
- package/.next/server/app/logs/page_client-reference-manifest.js +1 -1
- package/.next/server/app/logs.html +1 -1
- package/.next/server/app/logs.rsc +3 -3
- package/.next/server/app/logs.segments/_full.segment.rsc +3 -3
- package/.next/server/app/logs.segments/_head.segment.rsc +1 -1
- package/.next/server/app/logs.segments/_index.segment.rsc +2 -2
- package/.next/server/app/logs.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/logs.segments/logs/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/logs.segments/logs.segment.rsc +1 -1
- package/.next/server/app/models/page.js +1 -1
- package/.next/server/app/models/page.js.nft.json +1 -1
- package/.next/server/app/models/page_client-reference-manifest.js +1 -1
- package/.next/server/app/models.html +1 -1
- package/.next/server/app/models.rsc +2 -2
- package/.next/server/app/models.segments/_full.segment.rsc +2 -2
- package/.next/server/app/models.segments/_head.segment.rsc +1 -1
- package/.next/server/app/models.segments/_index.segment.rsc +2 -2
- package/.next/server/app/models.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/models.segments/models/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/models.segments/models.segment.rsc +1 -1
- package/.next/server/app/page.js +1 -1
- package/.next/server/app/page.js.nft.json +1 -1
- package/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/server/app/providers/page.js +1 -1
- package/.next/server/app/providers/page.js.nft.json +1 -1
- package/.next/server/app/providers/page_client-reference-manifest.js +1 -1
- package/.next/server/app/providers.html +1 -1
- package/.next/server/app/providers.rsc +2 -2
- package/.next/server/app/providers.segments/_full.segment.rsc +2 -2
- package/.next/server/app/providers.segments/_head.segment.rsc +1 -1
- package/.next/server/app/providers.segments/_index.segment.rsc +2 -2
- package/.next/server/app/providers.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/providers.segments/providers/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/providers.segments/providers.segment.rsc +1 -1
- package/.next/server/app-paths-manifest.json +14 -0
- package/.next/server/chunks/[root-of-the-server]__001d5756._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__001d5756._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__05f8578b._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__05f8578b._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__1480f018._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__1480f018._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__1909f3aa._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__1909f3aa._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__1d4b7fc5._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__1d4b7fc5._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__372ef2bf._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__372ef2bf._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__3aaf963c._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__3aaf963c._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__43810962._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__43810962._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__55cd88b8._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__55cd88b8._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__5e8276bc._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__5e8276bc._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__6ce199d2._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__6ce199d2._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__760eaa16._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__760eaa16._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__772134c6._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__772134c6._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__7b77f523._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__7b77f523._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__7c298a19._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__7c298a19._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__85540228._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__85540228._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__94fe8d3c._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__94fe8d3c._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__97622908._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__97622908._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__a02e6618._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__a02e6618._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__a32a20a7._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__a32a20a7._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__af5b556a._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__af5b556a._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__c1b4b601._.js +18 -18
- package/.next/server/chunks/[root-of-the-server]__c1b4b601._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__cafe113e._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__cafe113e._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__ccfc7f1d._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__ccfc7f1d._.js.map +1 -1
- package/.next/server/chunks/[root-of-the-server]__dc8b0bed._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__dc8b0bed._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__f8949f88._.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__f8949f88._.js.map +1 -1
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_apply_route_actions_2cb9e4b4.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_apply_route_actions_2cb9e4b4.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_preview_route_actions_9814a8e4.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_preview_route_actions_9814a8e4.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_restore_route_actions_10ad8f9d.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_restore_route_actions_10ad8f9d.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_save_route_actions_044ad081.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_save_route_actions_044ad081.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_status_route_actions_ed9786d2.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_status_route_actions_ed9786d2.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_test_route_actions_ce2cb808.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_openclaw_test_route_actions_ce2cb808.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_apply_route_actions_6c422244.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_apply_route_actions_6c422244.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_preview_route_actions_256c82e0.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_preview_route_actions_256c82e0.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_restore_route_actions_371993d3.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_restore_route_actions_371993d3.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_save_route_actions_6e4c9c41.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_save_route_actions_6e4c9c41.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_status_route_actions_498ad77b.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_status_route_actions_498ad77b.js.map +1 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_test_route_actions_c71be510.js +3 -0
- package/.next/server/chunks/_next-internal_server_app_api_ide_opencode_test_route_actions_c71be510.js.map +1 -0
- package/.next/server/chunks/ce889_server_app_api_ide_openclaw_available-models_route_actions_e568e70b.js +3 -0
- package/.next/server/chunks/ce889_server_app_api_ide_openclaw_available-models_route_actions_e568e70b.js.map +1 -0
- package/.next/server/chunks/ce889_server_app_api_ide_opencode_available-models_route_actions_95230db3.js +3 -0
- package/.next/server/chunks/ce889_server_app_api_ide_opencode_available-models_route_actions_95230db3.js.map +1 -0
- package/.next/server/chunks/ssr/{[root-of-the-server]__bec95712._.js → [root-of-the-server]__81937253._.js} +2 -2
- package/.next/server/chunks/ssr/{[root-of-the-server]__bec95712._.js.map → [root-of-the-server]__81937253._.js.map} +1 -1
- package/.next/server/chunks/ssr/{[root-of-the-server]__71c85955._.js → [root-of-the-server]__976ad963._.js} +2 -2
- package/.next/server/chunks/ssr/{[root-of-the-server]__71c85955._.js.map → [root-of-the-server]__976ad963._.js.map} +1 -1
- package/.next/server/chunks/ssr/src_app_ide_page_tsx_8962793b._.js +1 -1
- package/.next/server/chunks/ssr/src_app_ide_page_tsx_8962793b._.js.map +1 -1
- package/.next/server/chunks/ssr/src_app_logs_page_tsx_7b7b7b83._.js +1 -1
- package/.next/server/chunks/ssr/src_app_logs_page_tsx_7b7b7b83._.js.map +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +2 -2
- package/.next/static/chunks/0f120c117962200b.css +1 -0
- package/.next/static/chunks/64f547b3bcd3aef4.js +1 -0
- package/.next/static/chunks/{81c904164fe81379.js → 7c8b7cbb3339f139.js} +1 -1
- package/.next/static/chunks/8ed839b2e4948968.js +1 -0
- package/.next/types/routes.d.ts +15 -1
- package/.next/types/validator.ts +126 -0
- package/README.md +100 -111
- package/dist/.next/dev/types/validator.js +56 -0
- package/dist/.next/types/validator.js +56 -0
- package/dist/src/app/api/gateway/[...path]/route.js +1 -1
- package/dist/src/app/api/gateway/route.js +1 -1
- package/dist/src/app/api/ide/claude/apply/route.js +42 -31
- package/dist/src/app/api/ide/claude/status/route.js +6 -1
- package/dist/src/app/api/ide/openclaw/apply/route.js +92 -0
- package/dist/src/app/api/ide/openclaw/available-models/route.js +46 -0
- package/dist/src/app/api/ide/openclaw/build-config.js +101 -0
- package/dist/src/app/api/ide/openclaw/preview/route.js +49 -0
- package/dist/src/app/api/ide/openclaw/restore/route.js +24 -0
- package/dist/src/app/api/ide/openclaw/save/route.js +54 -0
- package/dist/src/app/api/ide/openclaw/status/route.js +139 -0
- package/dist/src/app/api/ide/openclaw/test/route.js +158 -0
- package/dist/src/app/api/ide/opencode/apply/route.js +89 -0
- package/dist/src/app/api/ide/opencode/available-models/route.js +46 -0
- package/dist/src/app/api/ide/opencode/build-config.js +54 -0
- package/dist/src/app/api/ide/opencode/preview/route.js +36 -0
- package/dist/src/app/api/ide/opencode/restore/route.js +40 -0
- package/dist/src/app/api/ide/opencode/save/route.js +123 -0
- package/dist/src/app/api/ide/opencode/status/route.js +106 -0
- package/dist/src/app/api/ide/opencode/test/route.js +136 -0
- package/dist/src/app/api/logs/route.js +2 -2
- package/dist/src/app/api/models/route.js +5 -5
- package/dist/src/app/api/providers/route.js +4 -4
- package/dist/src/app/api/providers/test/route.js +1 -1
- package/dist/src/app/api/service/start/route.js +1 -1
- package/dist/src/app/api/service/status/route.js +1 -1
- package/dist/src/app/api/service/stop/route.js +1 -1
- package/dist/src/app/ide/page.js +591 -81
- package/dist/src/app/logs/page.js +15 -1
- package/dist/src/cli/index.js +218 -20
- package/dist/src/db/database.js +56 -5
- package/dist/src/db/queries.js +6 -6
- package/dist/src/server/logger.js +22 -4
- package/package.json +2 -1
- package/src/app/api/gateway/[...path]/route.ts +1 -1
- package/src/app/api/gateway/route.ts +1 -1
- package/src/app/api/ide/claude/apply/route.ts +46 -31
- package/src/app/api/ide/claude/status/route.ts +12 -2
- package/src/app/api/ide/openclaw/apply/route.ts +103 -0
- package/src/app/api/ide/openclaw/available-models/route.ts +59 -0
- package/src/app/api/ide/openclaw/build-config.ts +152 -0
- package/src/app/api/ide/openclaw/preview/route.ts +57 -0
- package/src/app/api/ide/openclaw/restore/route.ts +27 -0
- package/src/app/api/ide/openclaw/save/route.ts +67 -0
- package/src/app/api/ide/openclaw/status/route.ts +178 -0
- package/src/app/api/ide/openclaw/test/route.ts +194 -0
- package/src/app/api/ide/opencode/apply/route.ts +92 -0
- package/src/app/api/ide/opencode/available-models/route.ts +59 -0
- package/src/app/api/ide/opencode/build-config.ts +69 -0
- package/src/app/api/ide/opencode/preview/route.ts +40 -0
- package/src/app/api/ide/opencode/restore/route.ts +52 -0
- package/src/app/api/ide/opencode/save/route.ts +131 -0
- package/src/app/api/ide/opencode/status/route.ts +128 -0
- package/src/app/api/ide/opencode/test/route.ts +145 -0
- package/src/app/api/logs/route.ts +2 -2
- package/src/app/api/models/route.ts +5 -5
- package/src/app/api/providers/route.ts +4 -4
- package/src/app/api/providers/test/route.ts +1 -1
- package/src/app/api/service/start/route.ts +1 -1
- package/src/app/api/service/status/route.ts +1 -1
- package/src/app/api/service/stop/route.ts +1 -1
- package/src/app/globals.css +17 -0
- package/src/app/ide/page.tsx +1535 -132
- package/src/app/logs/page.tsx +17 -5
- package/src/cli/index.ts +228 -25
- package/src/db/database.ts +60 -8
- package/src/db/queries.ts +6 -6
- package/src/server/logger.ts +19 -4
- package/.next/static/chunks/6418ca50028376b7.css +0 -1
- package/.next/static/chunks/9ec3b97741b6575e.js +0 -1
- /package/.next/static/{PkfqdzwOZgX-UhSNUuhdp → dYin74gcpdlg8TGoGv-_d}/_buildManifest.js +0 -0
- /package/.next/static/{PkfqdzwOZgX-UhSNUuhdp → dYin74gcpdlg8TGoGv-_d}/_clientMiddlewareManifest.json +0 -0
- /package/.next/static/{PkfqdzwOZgX-UhSNUuhdp → dYin74gcpdlg8TGoGv-_d}/_ssgManifest.js +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},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"))},26994,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),u=e.i(87718),d=e.i(95169),
|
|
1
|
+
module.exports=[93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},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"))},26994,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),u=e.i(87718),d=e.i(95169),c=e.i(47587),p=e.i(66012),x=e.i(70101),h=e.i(26937),f=e.i(10372),R=e.i(93695);e.i(52474);var v=e.i(220),g=e.i(89171),y=e.i(22734),E=e.i(14747),A=e.i(46786),m=e.i(71560),w=e.i(97731);let C=(0,E.join)((0,A.homedir)(),".claude"),N=(0,E.join)(C,"settings.json"),O=(0,E.join)(C,"settings.json.aar.bak");async function _(e){try{let t,{haiku:r,sonnet:a,opus:n,default:s,reasoning:i}=await e.json();if(void 0===r||void 0===a||void 0===n||void 0===s||void 0===i)return g.NextResponse.json({error:"Missing required fields: haiku, sonnet, opus, default, reasoning"},{status:400});let o=await T(),l=await S(),u={haiku:r,sonnet:a,opus:n,default:s,reasoning:i},d=b(o,l,u),c=function(){try{if((0,y.existsSync)(N)){let e=(0,y.readFileSync)(N,"utf-8"),t=!1;try{let r=JSON.parse(e);t="aar"===r.router_provider}catch{t=!1}return t||(0,y.writeFileSync)(O,e,"utf-8"),{success:!0,existed:!0,isFromAar:t}}return{success:!0,existed:!1,isFromAar:!1}}catch(e){return{success:!1,existed:!1,isFromAar:!1,error:`Backup failed: ${e.message}`}}}();if(!c.success)return g.NextResponse.json({error:c.error},{status:500});if((0,y.existsSync)(C)||(0,y.mkdirSync)(C,{recursive:!0}),(0,y.existsSync)(N))try{let e=JSON.parse((0,y.readFileSync)(N,"utf-8"));t={...e,env:{...e.env||{},...d},router_provider:"aar"}}catch{t=P(o,l,u)}else t=P(o,l,u);let p=function(e){try{let t=JSON.stringify(e,null,2);return JSON.parse(t),(0,y.writeFileSync)(N,t,"utf-8"),{success:!0}}catch(e){return{success:!1,error:`Validation or write failed: ${e.message}`}}}(t);if(!p.success)return g.NextResponse.json({error:p.error},{status:500});return g.NextResponse.json({success:!0,message:"Configuration applied successfully",config:t,backup:c.existed?"Created backup":"No existing config to backup",previousWasFromAar:c.existed&&c.isFromAar})}catch(e){return console.error("IDE Apply API error:",e),g.NextResponse.json({error:e.message||"Internal server error",stack:void 0},{status:500})}}async function T(){await (0,m.getDatabase)();let e=await (0,w.getConfig)("port"),t=e?.value||"1357";return`http://localhost:${t}`}async function S(){await (0,m.getDatabase)();let e=await (0,w.getConfig)("api_key");return e?.value||"your-gateway-api-key"}function b(e,t,r){return{ANTHROPIC_AUTH_TOKEN:t,ANTHROPIC_BASE_URL:e,ANTHROPIC_DEFAULT_HAIKU_MODEL:r.haiku,ANTHROPIC_DEFAULT_OPUS_MODEL:r.opus,ANTHROPIC_DEFAULT_SONNET_MODEL:r.sonnet,ANTHROPIC_MODEL:r.default,ANTHROPIC_REASONING_MODEL:r.reasoning,API_TIMEOUT_MS:"3000000",CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC:1,hasCompletedOnboarding:!0}}function P(e,t,r){return{router_provider:"aar",env:b(e,t,r)}}e.s(["POST",()=>_],8245);var k=e.i(8245);let I=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/ide/claude/apply/route",pathname:"/api/ide/claude/apply",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/ide/claude/apply/route.ts",nextConfigOutput:"",userland:k}),{workAsyncStorage:j,workUnitAsyncStorage:D,serverHooks:H}=I;function U(){return(0,a.patchFetch)({workAsyncStorage:j,workUnitAsyncStorage:D})}async function q(e,t,a){I.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let g="/api/ide/claude/apply/route";g=g.replace(/\/index$/,"")||"/";let y=await I.prepare(e,t,{srcPage:g,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:E,params:A,nextConfig:m,parsedUrl:w,isDraftMode:C,prerenderManifest:N,routerServerContext:O,isOnDemandRevalidate:_,revalidateOnlyGenerated:T,resolvedPathname:S,clientReferenceManifest:b,serverActionsManifest:P}=y,k=(0,o.normalizeAppPath)(g),j=!!(N.dynamicRoutes[k]||N.routes[S]),D=async()=>((null==O?void 0:O.render404)?await O.render404(e,t,w,!1):t.end("This page could not be found"),null);if(j&&!C){let e=!!N.routes[S],t=N.dynamicRoutes[k];if(t&&!1===t.fallback&&!e){if(m.experimental.adapterPath)return await D();throw new R.NoFallbackError}}let H=null;!j||I.isDev||C||(H="/index"===(H=S)?"/":H);let U=!0===I.isDev||!j,q=j&&!U;P&&b&&(0,i.setManifestsSingleton)({page:g,clientReferenceManifest:b,serverActionsManifest:P});let F=e.method||"GET",M=(0,s.getTracer)(),L=M.getActiveScopeSpan(),$={params:A,prerenderManifest:N,renderOpts:{experimental:{authInterrupts:!!m.experimental.authInterrupts},cacheComponents:!!m.cacheComponents,supportsDynamicResponse:U,incrementalCache:(0,n.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:m.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>I.onRequestError(e,t,a,n,O)},sharedContext:{buildId:E}},K=new l.NodeNextRequest(e),B=new l.NodeNextResponse(t),G=u.NextRequestAdapter.fromNodeNextRequest(K,(0,u.signalFromNodeResponse)(t));try{let i=async e=>I.handle(G,$).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=M.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=r.get("next.route");if(a){let t=`${F} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t)}else e.updateName(`${F} ${g}`)}),o=!!(0,n.getRequestMeta)(e,"minimalMode"),l=async n=>{var s,l;let u=async({previousCacheEntry:r})=>{try{if(!o&&_&&T&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await i(n);e.fetchMetrics=$.renderOpts.fetchMetrics;let l=$.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let u=$.renderOpts.collectedTags;if(!j)return await (0,p.sendResponse)(K,B,s,$.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,x.toNodeOutgoingHttpHeaders)(s.headers);u&&(t[f.NEXT_CACHE_TAGS_HEADER]=u),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==$.renderOpts.collectedRevalidate&&!($.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&$.renderOpts.collectedRevalidate,a=void 0===$.renderOpts.collectedExpire||$.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:$.renderOpts.collectedExpire;return{value:{kind:v.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await I.onRequestError(e,t,{routerKind:"App Router",routePath:g,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:_})},!1,O),t}},d=await I.handleResponse({req:e,nextConfig:m,cacheKey:H,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:N,isRoutePPREnabled:!1,isOnDemandRevalidate:_,revalidateOnlyGenerated:T,responseGenerator:u,waitUntil:a.waitUntil,isMinimalMode:o});if(!j)return null;if((null==d||null==(s=d.value)?void 0:s.kind)!==v.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(l=d.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});o||t.setHeader("x-nextjs-cache",_?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),C&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let R=(0,x.fromNodeOutgoingHttpHeaders)(d.value.headers);return o&&j||R.delete(f.NEXT_CACHE_TAGS_HEADER),!d.cacheControl||t.getHeader("Cache-Control")||R.get("Cache-Control")||R.set("Cache-Control",(0,h.getCacheControlHeader)(d.cacheControl)),await (0,p.sendResponse)(K,B,new Response(d.value.body,{headers:R,status:d.value.status||200})),null};L?await l(L):await M.withPropagatedContext(e.headers,()=>M.trace(d.BaseServerSpan.handleRequest,{spanName:`${F} ${g}`,kind:s.SpanKind.SERVER,attributes:{"http.method":F,"http.target":e.url}},l))}catch(t){if(t instanceof R.NoFallbackError||await I.onRequestError(e,t,{routerKind:"App Router",routePath:k,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:_})},!1,O),j)throw t;return await (0,p.sendResponse)(K,B,new Response(null,{status:500})),null}}e.s(["handler",()=>q,"patchFetch",()=>U,"routeModule",()=>I,"serverHooks",()=>H,"workAsyncStorage",()=>j,"workUnitAsyncStorage",()=>D],26994)}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__5e8276bc._.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/app/api/ide/claude/apply/route.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import { NextRequest, NextResponse } from 'next/server';\nimport { existsSync, readFileSync, writeFileSync, copyFileSync, mkdirSync } from 'fs';\nimport { join } from 'path';\nimport { homedir } from 'os';\nimport { getDatabase } from '@/db/database';\nimport { getConfig } from '@/db/queries';\n\n// Claude settings.json 文件路径\nconst CLAUDE_DIR = join(homedir(), '.claude');\nconst SETTINGS_FILE = join(CLAUDE_DIR, 'settings.json');\nconst BACKUP_FILE = join(CLAUDE_DIR, 'settings.json.aar.bak');\n\n// 默认模型映射\nconst DEFAULT_MODEL_MAPPING = {\n haiku: 'GLM-4.5-air',\n sonnet: 'MiniMax-M2.1',\n opus: 'GLM-4.7',\n default: 'GLM-4.7',\n} as const;\n\n/**\n * 应用 Claude IDE 配置\n */\nexport async function POST(request: NextRequest) {\n try {\n const body = await request.json();\n const { haiku, sonnet, opus, default: defaultModel, reasoning: reasoningModel } = body;\n\n // 验证请求参数 - haiku, sonnet, opus, default, reasoning 都需要\n if (haiku === undefined || sonnet === undefined || opus === undefined || defaultModel === undefined || reasoningModel === undefined) {\n return NextResponse.json(\n { error: 'Missing required fields: haiku, sonnet, opus, default, reasoning' },\n { status: 400 }\n );\n }\n\n // 获取当前网关地址和API Key(从数据库读取)\n const gatewayAddress = await getGatewayAddress();\n const gatewayApiKey = await getGatewayApiKey();\n\n // 生成配置对象\n const modelMapping = { haiku, sonnet, opus, default: defaultModel, reasoning: reasoningModel };\n const config = generateClaudeConfig(gatewayAddress, gatewayApiKey, modelMapping);\n\n // 备份原有配置\n const backupResult = backupOriginalConfig();\n if (!backupResult.success) {\n return NextResponse.json(\n { error: backupResult.error },\n { status: 500 }\n );\n }\n\n // 确保目录存在\n if (!existsSync(CLAUDE_DIR)) {\n mkdirSync(CLAUDE_DIR, { recursive: true });\n }\n\n // 验证并写入新配置\n const validationResult = validateAndWriteConfig(config);\n if (!validationResult.success) {\n return NextResponse.json(\n { error: validationResult.error },\n { status: 500 }\n );\n }\n\n return NextResponse.json({\n success: true,\n message: 'Configuration applied successfully',\n config,\n backup: backupResult.existed ? 'Created backup' : 'No existing config to backup',\n previousWasFromAar: backupResult.existed && backupResult.isFromAar,\n });\n } catch (error: any) {\n console.error('IDE Apply API error:', error);\n return NextResponse.json(\n { error: error.message || 'Internal server error', stack: process.env.NODE_ENV === 'development' ? error.stack : undefined },\n { status: 500 }\n );\n }\n}\n\n/**\n * 获取当前网关地址(从数据库读取)\n */\nasync function getGatewayAddress(): Promise<string> {\n await getDatabase();\n // 默认端口 1357\n const portConfig = await getConfig('port');\n const port = portConfig?.value || '1357';\n return `http://localhost:${port}`;\n}\n\n/**\n * 获取当前网关 API Key(从数据库读取)\n */\nasync function getGatewayApiKey(): Promise<string> {\n await getDatabase();\n const apiKeyConfig = await getConfig('api_key');\n return apiKeyConfig?.value || 'your-gateway-api-key';\n}\n\n/**\n * 生成 Claude 配置\n */\nfunction generateClaudeConfig(\n gatewayAddress: string,\n gatewayApiKey: string,\n modelMapping: { haiku: string; sonnet: string; opus: string; default: string; reasoning: string }\n): any {\n return {\n // 路由提供者标识,标识配置来自当前工具 aar\n router_provider: 'aar',\n env: {\n ANTHROPIC_AUTH_TOKEN: gatewayApiKey,\n ANTHROPIC_BASE_URL: gatewayAddress,\n ANTHROPIC_DEFAULT_HAIKU_MODEL: modelMapping.haiku,\n ANTHROPIC_DEFAULT_OPUS_MODEL: modelMapping.opus,\n ANTHROPIC_DEFAULT_SONNET_MODEL: modelMapping.sonnet,\n ANTHROPIC_MODEL: modelMapping.default,\n ANTHROPIC_REASONING_MODEL: modelMapping.reasoning,\n API_TIMEOUT_MS: '3000000',\n CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC: 1,\n hasCompletedOnboarding: true,\n },\n };\n}\n\n/**\n * 备份原有配置\n * 返回原有配置是否来自当前工具(router_provider === 'aar')\n */\nfunction backupOriginalConfig(): { success: boolean; existed: boolean; isFromAar: boolean; error?: string } {\n try {\n // 检查原有配置是否存在\n const existing = existsSync(SETTINGS_FILE);\n\n if (existing) {\n // 读取原有配置\n const originalConfig = readFileSync(SETTINGS_FILE, 'utf-8');\n\n // 解析配置检查 router_provider\n let isFromAar = false;\n try {\n const parsedConfig = JSON.parse(originalConfig);\n isFromAar = parsedConfig.router_provider === 'aar';\n } catch (error) {\n // 解析失败,不影响备份操作\n isFromAar = false;\n }\n\n // 写入备份文件\n writeFileSync(BACKUP_FILE, originalConfig, 'utf-8');\n\n return { success: true, existed: true, isFromAar };\n }\n\n return { success: true, existed: false, isFromAar: false };\n } catch (error: any) {\n return {\n success: false,\n existed: false,\n isFromAar: false,\n error: `Backup failed: ${error.message}`,\n };\n }\n}\n\n/**\n * 验证并写入配置\n */\nfunction validateAndWriteConfig(config: any): { success: boolean; error?: string } {\n try {\n // 序列化为 JSON 验证格式\n const jsonString = JSON.stringify(config, null, 2);\n\n // 验证是否能解析\n JSON.parse(jsonString);\n\n // 写入文件\n writeFileSync(SETTINGS_FILE, jsonString, 'utf-8');\n\n return { success: true };\n } catch (error: any) {\n return {\n success: false,\n error: `Validation or write failed: ${error.message}`,\n };\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 { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setManifestsSingleton } from \"next/dist/esm/server/app-render/manifests-singleton\";\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/ide/claude/apply/route\",\n pathname: \"/api/ide/claude/apply\",\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]/src/app/api/ide/claude/apply/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 if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/ide/claude/apply/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, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\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 if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\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 isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest\n });\n }\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 authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext, silenceLog)=>routeModule.onRequestError(req, error, errorContext, silenceLog, 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} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && 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 const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, 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 isMinimalMode\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 (!isMinimalMode) {\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 (!(isMinimalMode && 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, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n 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} ${srcPage}`,\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 const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\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":[1]}
|
|
1
|
+
{"version":3,"sources":["../../../src/app/api/ide/claude/apply/route.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import { NextRequest, NextResponse } from 'next/server';\nimport { existsSync, readFileSync, writeFileSync, copyFileSync, mkdirSync } from 'fs';\nimport { join } from 'path';\nimport { homedir } from 'os';\nimport { getDatabase } from '@/db/database';\nimport { getConfig } from '@/db/queries';\n\n// Claude settings.json 文件路径\nconst CLAUDE_DIR = join(homedir(), '.claude');\nconst SETTINGS_FILE = join(CLAUDE_DIR, 'settings.json');\nconst BACKUP_FILE = join(CLAUDE_DIR, 'settings.json.aar.bak');\n\n// 默认模型映射\nconst DEFAULT_MODEL_MAPPING = {\n haiku: 'GLM-4.5-air',\n sonnet: 'MiniMax-M2.1',\n opus: 'GLM-4.7',\n default: 'GLM-4.7',\n} as const;\n\n/**\n * 应用 Claude IDE 配置\n */\nexport async function POST(request: NextRequest) {\n try {\n const body = await request.json();\n const { haiku, sonnet, opus, default: defaultModel, reasoning: reasoningModel } = body;\n\n // 验证请求参数 - haiku, sonnet, opus, default, reasoning 都需要\n if (haiku === undefined || sonnet === undefined || opus === undefined || defaultModel === undefined || reasoningModel === undefined) {\n return NextResponse.json(\n { error: 'Missing required fields: haiku, sonnet, opus, default, reasoning' },\n { status: 400 }\n );\n }\n\n // 获取当前网关地址和API Key(从数据库读取)\n const gatewayAddress = await getGatewayAddress();\n const gatewayApiKey = await getGatewayApiKey();\n\n const modelMapping = { haiku, sonnet, opus, default: defaultModel, reasoning: reasoningModel };\n const aarEnv = buildAarEnv(gatewayAddress, gatewayApiKey, modelMapping);\n\n const backupResult = backupOriginalConfig();\n if (!backupResult.success) {\n return NextResponse.json(\n { error: backupResult.error },\n { status: 500 }\n );\n }\n\n if (!existsSync(CLAUDE_DIR)) {\n mkdirSync(CLAUDE_DIR, { recursive: true });\n }\n\n let configToWrite: any;\n if (existsSync(SETTINGS_FILE)) {\n try {\n const existing = JSON.parse(readFileSync(SETTINGS_FILE, 'utf-8'));\n configToWrite = {\n ...existing,\n env: { ...(existing.env || {}), ...aarEnv },\n router_provider: 'aar',\n };\n } catch {\n configToWrite = generateClaudeConfig(gatewayAddress, gatewayApiKey, modelMapping);\n }\n } else {\n configToWrite = generateClaudeConfig(gatewayAddress, gatewayApiKey, modelMapping);\n }\n\n const validationResult = validateAndWriteConfig(configToWrite);\n if (!validationResult.success) {\n return NextResponse.json(\n { error: validationResult.error },\n { status: 500 }\n );\n }\n\n return NextResponse.json({\n success: true,\n message: 'Configuration applied successfully',\n config: configToWrite,\n backup: backupResult.existed ? 'Created backup' : 'No existing config to backup',\n previousWasFromAar: backupResult.existed && backupResult.isFromAar,\n });\n } catch (error: any) {\n console.error('IDE Apply API error:', error);\n return NextResponse.json(\n { error: error.message || 'Internal server error', stack: process.env.NODE_ENV === 'development' ? error.stack : undefined },\n { status: 500 }\n );\n }\n}\n\n/**\n * 获取当前网关地址(从数据库读取)\n */\nasync function getGatewayAddress(): Promise<string> {\n await getDatabase();\n // 默认端口 1357\n const portConfig = await getConfig('port');\n const port = portConfig?.value || '1357';\n return `http://localhost:${port}`;\n}\n\n/**\n * 获取当前网关 API Key(从数据库读取)\n */\nasync function getGatewayApiKey(): Promise<string> {\n await getDatabase();\n const apiKeyConfig = await getConfig('api_key');\n return apiKeyConfig?.value || 'your-gateway-api-key';\n}\n\n/** 仅生成 AAR 相关的 env 字段,用于合并到现有配置 */\nfunction buildAarEnv(\n gatewayAddress: string,\n gatewayApiKey: string,\n modelMapping: { haiku: string; sonnet: string; opus: string; default: string; reasoning: string }\n): Record<string, unknown> {\n return {\n ANTHROPIC_AUTH_TOKEN: gatewayApiKey,\n ANTHROPIC_BASE_URL: gatewayAddress,\n ANTHROPIC_DEFAULT_HAIKU_MODEL: modelMapping.haiku,\n ANTHROPIC_DEFAULT_OPUS_MODEL: modelMapping.opus,\n ANTHROPIC_DEFAULT_SONNET_MODEL: modelMapping.sonnet,\n ANTHROPIC_MODEL: modelMapping.default,\n ANTHROPIC_REASONING_MODEL: modelMapping.reasoning,\n API_TIMEOUT_MS: '3000000',\n CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC: 1,\n hasCompletedOnboarding: true,\n };\n}\n\n/** 生成完整 Claude 配置(仅在无现有文件时使用) */\nfunction generateClaudeConfig(\n gatewayAddress: string,\n gatewayApiKey: string,\n modelMapping: { haiku: string; sonnet: string; opus: string; default: string; reasoning: string }\n): any {\n return {\n router_provider: 'aar',\n env: buildAarEnv(gatewayAddress, gatewayApiKey, modelMapping),\n };\n}\n\n/**\n * 备份原有配置\n * 仅在当前配置不是 AAR 时写入备份,这样「还原」才能恢复到应用 AAR 前的状态\n */\nfunction backupOriginalConfig(): { success: boolean; existed: boolean; isFromAar: boolean; error?: string } {\n try {\n const existing = existsSync(SETTINGS_FILE);\n\n if (existing) {\n const originalConfig = readFileSync(SETTINGS_FILE, 'utf-8');\n\n let isFromAar = false;\n try {\n const parsedConfig = JSON.parse(originalConfig);\n isFromAar = parsedConfig.router_provider === 'aar';\n } catch {\n isFromAar = false;\n }\n\n if (!isFromAar) {\n writeFileSync(BACKUP_FILE, originalConfig, 'utf-8');\n }\n\n return { success: true, existed: true, isFromAar };\n }\n\n return { success: true, existed: false, isFromAar: false };\n } catch (error: any) {\n return {\n success: false,\n existed: false,\n isFromAar: false,\n error: `Backup failed: ${error.message}`,\n };\n }\n}\n\n/**\n * 验证并写入配置\n */\nfunction validateAndWriteConfig(config: any): { success: boolean; error?: string } {\n try {\n // 序列化为 JSON 验证格式\n const jsonString = JSON.stringify(config, null, 2);\n\n // 验证是否能解析\n JSON.parse(jsonString);\n\n // 写入文件\n writeFileSync(SETTINGS_FILE, jsonString, 'utf-8');\n\n return { success: true };\n } catch (error: any) {\n return {\n success: false,\n error: `Validation or write failed: ${error.message}`,\n };\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 { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setManifestsSingleton } from \"next/dist/esm/server/app-render/manifests-singleton\";\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/ide/claude/apply/route\",\n pathname: \"/api/ide/claude/apply\",\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]/src/app/api/ide/claude/apply/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 if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/ide/claude/apply/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, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\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 if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\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 isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest\n });\n }\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 authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext, silenceLog)=>routeModule.onRequestError(req, error, errorContext, silenceLog, 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} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && 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 const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, 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 isMinimalMode\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 (!isMinimalMode) {\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 (!(isMinimalMode && 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, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n 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} ${srcPage}`,\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 const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\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":[1]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},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"))},98857,e=>{"use strict";var t=e.i(38483);class r{async forwardRequest(e,r){let o,a,n;console.log("[OpenAI Adapter] Starting forwardRequest:",{modelId:e.model_id,modelName:e.name||"unnamed",providerName:e.provider.name,providerBaseUrl:e.provider.base_url,hasEncryptedApiKey:!!e.provider.api_key,encryptedApiKeyLength:e.provider.api_key?.length||0});try{if(o=(0,t.decryptApiKey)(e.provider.api_key),console.log("[OpenAI Adapter] API key decrypted successfully:",{length:o.length,prefix:o.substring(0,10)+"...",suffix:"..."+o.substring(Math.max(0,o.length-10)),isEmpty:!o||""===o.trim(),fullKey:o}),!o||""===o.trim())return console.error("[OpenAI Adapter] Decrypted API key is empty!"),{status:500,headers:{"Content-Type":"application/json"},body:{error:{message:"API key is empty after decryption",type:"decryption_error"}}};o=o.trim()}catch(t){return console.error("[OpenAI Adapter] Failed to decrypt API key:",{error:t.message,stack:t.stack,encryptedKeyLength:e.provider.api_key?.length||0,encryptedKeyPrefix:e.provider.api_key?.substring(0,20)||"none"}),{status:500,headers:{"Content-Type":"application/json"},body:{error:{message:"Failed to decrypt API key: "+t.message,type:"decryption_error"}}}}let s=e.provider.base_url||"https://api.openai.com/v1";s=s.trim().replace(/\/+$/,"");let i=r.path;i&&"/"!==i&&""!==i?i.startsWith("/v1/")?i=i.substring(4):i.startsWith("/")&&(i=i.substring(1)):i="chat/completions",s.endsWith("/v1")||(s+="/v1");let l=`${s}/${i}`;console.log("[OpenAI Adapter] Forwarding request:",{baseUrl:e.provider.base_url,normalizedBaseUrl:s,originalPath:r.path,targetPath:i,url:l,method:r.method,hasApiKey:!!o,apiKeyPrefix:o?o.substring(0,7)+"...":"none",requestBody:r.body?JSON.stringify(r.body).substring(0,200):"none"});let d={"content-type":"application/json"};for(let[e,t]of(d.authorization=`Bearer ${o}`,Object.entries(r.headers))){let r=e.toLowerCase();"host"!==r&&"connection"!==r&&"authorization"!==r&&"x-api-key"!==r&&"content-length"!==r&&"content-type"!==r&&(d[e]=t)}if(console.log("[OpenAI Adapter] Request headers:",{"content-type":d["content-type"],authorization:d.authorization?`Bearer ${o.substring(0,10)}...${o.substring(o.length-4)}`:"none","authorization-full":d.authorization,"user-agent":d["user-agent"]||d["User-Agent"]||"none",allHeaders:Object.keys(d)}),"GET"!==r.method&&"HEAD"!==r.method){let t;t=r.body?{...r.body}:{},e.model_id&&(t.model=e.model_id),console.log("[OpenAI Adapter] Request body:",a=JSON.stringify(t)),console.log("[OpenAI Adapter] Request body length:",a.length)}console.log("[OpenAI Adapter] Sending fetch request:",{url:l.replace(o,"***"),method:r.method,hasBody:!!a,bodyLength:a?.length||0});let p=await fetch(l,{method:r.method,headers:d,body:a});console.log("[OpenAI Adapter] Response received:",{status:p.status,statusText:p.statusText,headers:Object.fromEntries(p.headers.entries())});let u=await p.text();console.log("[OpenAI Adapter] Response body preview:",u.substring(0,200));try{n=JSON.parse(u)}catch{n=u,console.log("[OpenAI Adapter] Response body is not JSON, returning as string")}return{status:p.status,headers:Object.fromEntries(p.headers.entries()),body:n}}async listModels(e){let r=(0,t.decryptApiKey)(e.api_key),o=e.base_url||"https://api.openai.com/v1";(o=o.trim().replace(/\/+$/,"")).endsWith("/v1")||(o=o.endsWith("/")?o+"v1":o+"/v1");let a=`${o}/models`;console.log("[OpenAI] Fetching models:",{baseUrl:e.base_url,normalizedBaseUrl:o,url:a,apiKeyPrefix:r.substring(0,10)+"...",apiKeyLength:r.length});try{let e=await fetch(a,{headers:{Authorization:`Bearer ${r}`,"Content-Type":"application/json"}});if(console.log("[OpenAI] Response status:",e.status,e.statusText),!e.ok){let t=await e.text();throw console.error("[OpenAI] Error response body:",t),Error(`Failed to fetch models: ${e.status} ${e.statusText} - ${t.substring(0,200)}`)}let t=await e.json();return console.log("[OpenAI] Fetched models count:",t.data?.length||0),(t.data||[]).map(e=>({id:e.id,name:e.id}))}catch(t){throw console.error("[OpenAI] Error fetching models:",{error:t instanceof Error?t.message:String(t),stack:t instanceof Error?t.stack:void 0,url:a,baseUrl:e.base_url}),t}}}class o{async forwardRequest(e,r){let o,a;console.log("[Anthropic Adapter] Starting forwardRequest:",{modelId:e.model_id,modelName:e.name||"unnamed",providerName:e.provider.name,providerBaseUrl:e.provider.base_url,hasEncryptedApiKey:!!e.provider.api_key,encryptedApiKeyLength:e.provider.api_key?.length||0});try{o=(0,t.decryptApiKey)(e.provider.api_key),console.log("[Anthropic Adapter] API key decrypted successfully, length:",o.length)}catch(e){return console.error("[Anthropic Adapter] Failed to decrypt API key:",e.message),{status:500,headers:{"Content-Type":"application/json"},body:{error:{message:"Failed to decrypt API key",type:"decryption_error"}}}}let n=e.provider.base_url||"https://api.anthropic.com/v1";n=n.trim().replace(/\/+$/,"");let s=r.path;console.log("[Anthropic Adapter] Path processing START:",{inputBaseUrl:e.provider.base_url,originalRequestPath:r.path,hasPath:!!r.path,pathLength:r.path?.length,pathPrefix:r.path?.substring(0,20)}),s&&"/"!==s&&""!==s?s.startsWith("/v1/")?s=s.substring(4):s.startsWith("/")?s=s.substring(1):s.startsWith("v1/")&&(s=s.substring(3)):s="messages";let i=`${n}/${s}`;console.log("[Anthropic Adapter] Path processing result:",{targetPathAfter:s,finalUrl:i}),console.log("[Anthropic Adapter] Forwarding request:",{baseUrl:e.provider.base_url,normalizedBaseUrl:n,originalPath:r.path,targetPath:s,url:i,method:r.method,hasApiKey:!!o,apiKeyPrefix:o?o.substring(0,10)+"...":"none"});let l={"x-api-key":o,Authorization:`Bearer ${o}`,"anthropic-version":"2023-06-01","Content-Type":"application/json",...r.headers};delete l.host,delete l.connection,console.log("[Anthropic Adapter] Request headers:",{"Content-Type":l["Content-Type"],"x-api-key":l["x-api-key"]?`${o.substring(0,10)}...${o.substring(o.length-4)}`:"none",Authorization:l.Authorization?`Bearer ${o.substring(0,10)}...${o.substring(o.length-4)}`:"none","anthropic-version":l["anthropic-version"]});let d=await fetch(i,{method:r.method,headers:l,body:"GET"!==r.method&&"HEAD"!==r.method?JSON.stringify(r.body):void 0});console.log("[Anthropic Adapter] Response status:",d.status,d.statusText);let p=await d.text();console.log("[Anthropic Adapter] Response body preview:",p.substring(0,200));try{a=JSON.parse(p)}catch{a=p,console.log("[Anthropic Adapter] Response body is not JSON, returning as string")}return{status:d.status,headers:Object.fromEntries(d.headers.entries()),body:a}}async listModels(e){return[{id:"claude-3-5-sonnet-20241022",name:"Claude 3.5 Sonnet"},{id:"claude-3-opus-20240229",name:"Claude 3 Opus"},{id:"claude-3-sonnet-20240229",name:"Claude 3 Sonnet"},{id:"claude-3-haiku-20240307",name:"Claude 3 Haiku"}]}}class a{async forwardRequest(e,r){let o,a=(0,t.decryptApiKey)(e.provider.api_key),n=e.provider.base_url||"https://generativelanguage.googleapis.com/v1";n=n.trim().replace(/\/+$/,"");let s=r.path;s&&"/"!==s&&""!==s?s.startsWith("/v1/")?s=s.substring(4):s.startsWith("/")&&(s=s.substring(1)):s=`models/${e.model_id}:generateContent`,n.endsWith("/v1")||(n+="/v1");let i=`${n}/${s}?key=${a}`;console.log("[Gemini Adapter] Forwarding request:",{baseUrl:e.provider.base_url,normalizedBaseUrl:n,originalPath:r.path,targetPath:s,url:i.replace(a,"***"),method:r.method,hasApiKey:!!a});let l={"Content-Type":"application/json",...r.headers};delete l.host,delete l.connection,delete l.authorization,console.log("[Gemini Adapter] Request headers:",{"Content-Type":l["Content-Type"]});let d=await fetch(i,{method:r.method,headers:l,body:"GET"!==r.method&&"HEAD"!==r.method?JSON.stringify(r.body):void 0});console.log("[Gemini Adapter] Response status:",d.status,d.statusText);let p=await d.text();console.log("[Gemini Adapter] Response body preview:",p.substring(0,200));try{o=JSON.parse(p)}catch{o=p,console.log("[Gemini Adapter] Response body is not JSON, returning as string")}return{status:d.status,headers:Object.fromEntries(d.headers.entries()),body:o}}async listModels(e){let r=(0,t.decryptApiKey)(e.api_key),o=e.base_url||"https://generativelanguage.googleapis.com/v1";try{let e=await fetch(`${o}/models?key=${r}`,{headers:{"Content-Type":"application/json"}});if(!e.ok)throw Error(`Failed to fetch models: ${e.statusText}`);let t=await e.json();if(!t.models||!Array.isArray(t.models))return console.error("[Gemini Adapter] Invalid models response:",t),[];return t.models.filter(e=>e&&"object"==typeof e).map(e=>{let t=e.name?e.name.replace("models/",""):"",r=e.displayName||e.name||"";return console.log("[Gemini Adapter] Processing model:",{id:t,name:r}),{id:t,name:r}})}catch(e){throw console.error("Error fetching Gemini models:",e),e}}}function n(e){let t=(e||"").toLowerCase().trim();switch(t){case"openai":return new r;case"anthropic":return new o;case"gemini":return new a;default:throw console.error(`[ProviderAdapter] Unsupported protocol: "${e}", normalized: "${t}"`),Error(`Unsupported protocol: ${e}. Supported protocols: openai, anthropic, gemini`)}}e.s(["getProviderAdapter",()=>n],98857)},39380,e=>{"use strict";var t=e.i(97731),r=e.i(98857),o=e.i(38483);async function a(e,r){try{let a=function(e){let t={...e};if(t.authorization){let e=t.authorization;e.startsWith("Bearer ")?t.authorization=`Bearer ${(0,o.maskToken)(e.substring(7))}`:t.authorization=(0,o.maskToken)(e)}return t["x-api-key"]&&(t["x-api-key"]=(0,o.maskApiKey)(t["x-api-key"])),t["api-key"]&&(t["api-key"]=(0,o.maskApiKey)(t["api-key"])),t}(e.headers),n=function e(t){if(!t||"object"!=typeof t)return t;if(Array.isArray(t))return t.map(e);let r={};for(let[a,n]of Object.entries(t)){let t=a.toLowerCase();t.includes("api")&&t.includes("key")?r[a]=(0,o.maskApiKey)(String(n)):t.includes("token")||"authorization"===t?r[a]=(0,o.maskToken)(String(n)):"object"==typeof n&&null!==n?r[a]=e(n):r[a]=n}return r}(e.body);await (0,t.createRequestLog)({model_id:e.modelId,request_method:e.method,request_path:e.path,request_headers:JSON.stringify(a),request_query:JSON.stringify(e.query),request_body:JSON.stringify(n),response_status:r.status,response_body:JSON.stringify(r.body),response_time_ms:r.responseTimeMs})}catch(e){console.error("Failed to log request:",e)}}async function n(e,o,n){let s=Date.now(),i=`${Date.now()}-${Math.random().toString(36).substr(2,9)}`;console.log(`[Gateway ${i}] handleGatewayRequest called:`,{modelId:e,providerName:n||"not specified",method:o.method,path:o.path});try{let l=n,d=e;if(!n){console.log(`[Gateway ${i}] Provider not specified, attempting auto-routing by model_id:`,e),o.body?.model&&(d=o.body.model,console.log(`[Gateway ${i}] Using model_id from request body:`,d));let r=await (0,t.getModelByModelIdAny)(d);if(!r)return console.log(`[Gateway ${i}] Model not found in database:`,d),{status:404,headers:{"Content-Type":"application/json"},body:{error:{message:`Model "${d}" not found or not enabled. Please configure the model in the Gateway settings first.`,type:"model_not_found"}}};l=r.provider_name,console.log(`[Gateway ${i}] Auto-routed model "${d}" to provider:`,l)}let p=await (0,t.getAllProviders)();console.log(`[Gateway ${i}] Available providers:`,p.map(e=>({id:e.id,name:e.name})));let u=p.find(e=>e.name&&e.name.toLowerCase()===l.toLowerCase());if(!u){console.log(`[Gateway ${i}] Provider not found:`,l);let e=p.map(e=>e.name).join(", ");return{status:404,headers:{"Content-Type":"application/json"},body:{error:{message:`Provider "${l}" not found. Available providers: ${e||"none"}`,type:"provider_not_found"}}}}console.log(`[Gateway ${i}] Provider found:`,{id:u.id,name:u.name,protocol:u.protocol,base_url:u.base_url,hasApiKey:!!u.api_key});let c=u.name||"unknown",h={id:0,provider_id:u.id,name:d||"unnamed",model_id:d||"unknown",enabled:!0,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),provider:{id:u.id,name:c,protocol:u.protocol,base_url:u.base_url||"",api_key:u.api_key||""}},y=(0,r.getProviderAdapter)(u.protocol);console.log(`[Gateway ${i}] Forwarding request with:`,{provider:u.name,protocol:u.protocol,modelId:d});let g=await y.forwardRequest(h,o),m=Date.now()-s;console.log(`[Gateway ${i}] About to log request, response type:`,typeof g.body);try{await a({modelId:null,method:o.method,path:o.path,headers:o.headers,query:o.query,body:o.body},{status:g.status,headers:g.headers,body:g.body,responseTimeMs:m}),console.log(`[Gateway ${i}] Request logged successfully`)}catch(e){console.error(`[Gateway ${i}] Failed to log request:`,e.message,e.stack)}return g}catch(r){let e=Date.now()-s;console.error(`[Gateway ${i}] Error:`,{message:r.message,stack:r.stack});let t={status:500,headers:{"Content-Type":"application/json"},body:{error:{message:r.message||"Internal server error",type:"gateway_error"}}};try{await a({modelId:null,method:o.method,path:o.path,headers:o.headers,query:o.query,body:o.body},{status:t.status,headers:t.headers,body:t.body,responseTimeMs:e})}catch(e){console.error(`[Gateway ${i}] Failed to log error request:`,e.message)}return t}}e.s(["handleGatewayRequest",()=>n],39380)},45861,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),n=e.i(61916),s=e.i(74677),i=e.i(69741),l=e.i(16795),d=e.i(87718),p=e.i(95169),u=e.i(47587),c=e.i(66012),h=e.i(70101),y=e.i(26937),g=e.i(10372),m=e.i(93695);e.i(52474);var b=e.i(220),f=e.i(89171),A=e.i(71560),v=e.i(39380);async function w(e){return R(e,"POST")}async function x(e){return R(e,"GET")}async function R(e,t){try{(0,A.getDatabase)();let r=e.nextUrl.searchParams,o=r.get("model")||r.get("model_id"),a=r.get("provider"),n=null;try{if("GET"!==t&&"HEAD"!==t){let t=await e.text();t&&(n=JSON.parse(t))}}catch{}!o&&n&&(o=n.model||n.model_id);let s=n?.provider;if(!o)return f.NextResponse.json({error:{message:"Model ID not specified"}},{status:400});let i={method:t,path:"/",headers:Object.fromEntries(e.headers.entries()),query:Object.fromEntries(r.entries()),body:n},l=await (0,v.handleGatewayRequest)(o,i,a||s||void 0);return f.NextResponse.json(l.body,{status:l.status,headers:l.headers})}catch(e){return f.NextResponse.json({error:{message:e.message||"Internal server error"}},{status:500})}}e.s(["GET",()=>x,"POST",()=>w,"runtime",0,"nodejs"],29727);var _=e.i(29727);let k=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/gateway/route",pathname:"/api/gateway",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/gateway/route.ts",nextConfigOutput:"",userland:_}),{workAsyncStorage:E,workUnitAsyncStorage:O,serverHooks:q}=k;function $(){return(0,o.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:O})}async function C(e,t,o){k.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let f="/api/gateway/route";f=f.replace(/\/index$/,"")||"/";let A=await k.prepare(e,t,{srcPage:f,multiZoneDraftMode:!1});if(!A)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:v,params:w,nextConfig:x,parsedUrl:R,isDraftMode:_,prerenderManifest:E,routerServerContext:O,isOnDemandRevalidate:q,revalidateOnlyGenerated:$,resolvedPathname:C,clientReferenceManifest:T,serverActionsManifest:P}=A,I=(0,i.normalizeAppPath)(f),S=!!(E.dynamicRoutes[I]||E.routes[C]),j=async()=>((null==O?void 0:O.render404)?await O.render404(e,t,R,!1):t.end("This page could not be found"),null);if(S&&!_){let e=!!E.routes[C],t=E.dynamicRoutes[I];if(t&&!1===t.fallback&&!e){if(x.experimental.adapterPath)return await j();throw new m.NoFallbackError}}let N=null;!S||k.isDev||_||(N="/index"===(N=C)?"/":N);let G=!0===k.isDev||!S,U=S&&!G;P&&T&&(0,s.setManifestsSingleton)({page:f,clientReferenceManifest:T,serverActionsManifest:P});let K=e.method||"GET",D=(0,n.getTracer)(),F=D.getActiveScopeSpan(),H={params:w,prerenderManifest:E,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:G,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:x.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>k.onRequestError(e,t,o,a,O)},sharedContext:{buildId:v}},M=new l.NodeNextRequest(e),z=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(M,(0,d.signalFromNodeResponse)(t));try{let s=async e=>k.handle(B,H).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=D.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==p.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${K} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t)}else e.updateName(`${K} ${f}`)}),i=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var n,l;let d=async({previousCacheEntry:r})=>{try{if(!i&&q&&$&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await s(a);e.fetchMetrics=H.renderOpts.fetchMetrics;let l=H.renderOpts.pendingWaitUntil;l&&o.waitUntil&&(o.waitUntil(l),l=void 0);let d=H.renderOpts.collectedTags;if(!S)return await (0,c.sendResponse)(M,z,n,H.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(n.headers);d&&(t[g.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==H.renderOpts.collectedRevalidate&&!(H.renderOpts.collectedRevalidate>=g.INFINITE_CACHE)&&H.renderOpts.collectedRevalidate,o=void 0===H.renderOpts.collectedExpire||H.renderOpts.collectedExpire>=g.INFINITE_CACHE?void 0:H.renderOpts.collectedExpire;return{value:{kind:b.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await k.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:q})},!1,O),t}},p=await k.handleResponse({req:e,nextConfig:x,cacheKey:N,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:q,revalidateOnlyGenerated:$,responseGenerator:d,waitUntil:o.waitUntil,isMinimalMode:i});if(!S)return null;if((null==p||null==(n=p.value)?void 0:n.kind)!==b.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==p||null==(l=p.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",q?"REVALIDATED":p.isMiss?"MISS":p.isStale?"STALE":"HIT"),_&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let m=(0,h.fromNodeOutgoingHttpHeaders)(p.value.headers);return i&&S||m.delete(g.NEXT_CACHE_TAGS_HEADER),!p.cacheControl||t.getHeader("Cache-Control")||m.get("Cache-Control")||m.set("Cache-Control",(0,y.getCacheControlHeader)(p.cacheControl)),await (0,c.sendResponse)(M,z,new Response(p.value.body,{headers:m,status:p.value.status||200})),null};F?await l(F):await D.withPropagatedContext(e.headers,()=>D.trace(p.BaseServerSpan.handleRequest,{spanName:`${K} ${f}`,kind:n.SpanKind.SERVER,attributes:{"http.method":K,"http.target":e.url}},l))}catch(t){if(t instanceof m.NoFallbackError||await k.onRequestError(e,t,{routerKind:"App Router",routePath:I,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:q})},!1,O),S)throw t;return await (0,c.sendResponse)(M,z,new Response(null,{status:500})),null}}e.s(["handler",()=>C,"patchFetch",()=>$,"routeModule",()=>k,"serverHooks",()=>q,"workAsyncStorage",()=>E,"workUnitAsyncStorage",()=>O],45861)}];
|
|
1
|
+
module.exports=[93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},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"))},98857,e=>{"use strict";var t=e.i(38483);class r{async forwardRequest(e,r){let o,a,n;console.log("[OpenAI Adapter] Starting forwardRequest:",{modelId:e.model_id,modelName:e.name||"unnamed",providerName:e.provider.name,providerBaseUrl:e.provider.base_url,hasEncryptedApiKey:!!e.provider.api_key,encryptedApiKeyLength:e.provider.api_key?.length||0});try{if(o=(0,t.decryptApiKey)(e.provider.api_key),console.log("[OpenAI Adapter] API key decrypted successfully:",{length:o.length,prefix:o.substring(0,10)+"...",suffix:"..."+o.substring(Math.max(0,o.length-10)),isEmpty:!o||""===o.trim(),fullKey:o}),!o||""===o.trim())return console.error("[OpenAI Adapter] Decrypted API key is empty!"),{status:500,headers:{"Content-Type":"application/json"},body:{error:{message:"API key is empty after decryption",type:"decryption_error"}}};o=o.trim()}catch(t){return console.error("[OpenAI Adapter] Failed to decrypt API key:",{error:t.message,stack:t.stack,encryptedKeyLength:e.provider.api_key?.length||0,encryptedKeyPrefix:e.provider.api_key?.substring(0,20)||"none"}),{status:500,headers:{"Content-Type":"application/json"},body:{error:{message:"Failed to decrypt API key: "+t.message,type:"decryption_error"}}}}let s=e.provider.base_url||"https://api.openai.com/v1";s=s.trim().replace(/\/+$/,"");let i=r.path;i&&"/"!==i&&""!==i?i.startsWith("/v1/")?i=i.substring(4):i.startsWith("/")&&(i=i.substring(1)):i="chat/completions",s.endsWith("/v1")||(s+="/v1");let l=`${s}/${i}`;console.log("[OpenAI Adapter] Forwarding request:",{baseUrl:e.provider.base_url,normalizedBaseUrl:s,originalPath:r.path,targetPath:i,url:l,method:r.method,hasApiKey:!!o,apiKeyPrefix:o?o.substring(0,7)+"...":"none",requestBody:r.body?JSON.stringify(r.body).substring(0,200):"none"});let d={"content-type":"application/json"};for(let[e,t]of(d.authorization=`Bearer ${o}`,Object.entries(r.headers))){let r=e.toLowerCase();"host"!==r&&"connection"!==r&&"authorization"!==r&&"x-api-key"!==r&&"content-length"!==r&&"content-type"!==r&&(d[e]=t)}if(console.log("[OpenAI Adapter] Request headers:",{"content-type":d["content-type"],authorization:d.authorization?`Bearer ${o.substring(0,10)}...${o.substring(o.length-4)}`:"none","authorization-full":d.authorization,"user-agent":d["user-agent"]||d["User-Agent"]||"none",allHeaders:Object.keys(d)}),"GET"!==r.method&&"HEAD"!==r.method){let t;t=r.body?{...r.body}:{},e.model_id&&(t.model=e.model_id),console.log("[OpenAI Adapter] Request body:",a=JSON.stringify(t)),console.log("[OpenAI Adapter] Request body length:",a.length)}console.log("[OpenAI Adapter] Sending fetch request:",{url:l.replace(o,"***"),method:r.method,hasBody:!!a,bodyLength:a?.length||0});let p=await fetch(l,{method:r.method,headers:d,body:a});console.log("[OpenAI Adapter] Response received:",{status:p.status,statusText:p.statusText,headers:Object.fromEntries(p.headers.entries())});let u=await p.text();console.log("[OpenAI Adapter] Response body preview:",u.substring(0,200));try{n=JSON.parse(u)}catch{n=u,console.log("[OpenAI Adapter] Response body is not JSON, returning as string")}return{status:p.status,headers:Object.fromEntries(p.headers.entries()),body:n}}async listModels(e){let r=(0,t.decryptApiKey)(e.api_key),o=e.base_url||"https://api.openai.com/v1";(o=o.trim().replace(/\/+$/,"")).endsWith("/v1")||(o=o.endsWith("/")?o+"v1":o+"/v1");let a=`${o}/models`;console.log("[OpenAI] Fetching models:",{baseUrl:e.base_url,normalizedBaseUrl:o,url:a,apiKeyPrefix:r.substring(0,10)+"...",apiKeyLength:r.length});try{let e=await fetch(a,{headers:{Authorization:`Bearer ${r}`,"Content-Type":"application/json"}});if(console.log("[OpenAI] Response status:",e.status,e.statusText),!e.ok){let t=await e.text();throw console.error("[OpenAI] Error response body:",t),Error(`Failed to fetch models: ${e.status} ${e.statusText} - ${t.substring(0,200)}`)}let t=await e.json();return console.log("[OpenAI] Fetched models count:",t.data?.length||0),(t.data||[]).map(e=>({id:e.id,name:e.id}))}catch(t){throw console.error("[OpenAI] Error fetching models:",{error:t instanceof Error?t.message:String(t),stack:t instanceof Error?t.stack:void 0,url:a,baseUrl:e.base_url}),t}}}class o{async forwardRequest(e,r){let o,a;console.log("[Anthropic Adapter] Starting forwardRequest:",{modelId:e.model_id,modelName:e.name||"unnamed",providerName:e.provider.name,providerBaseUrl:e.provider.base_url,hasEncryptedApiKey:!!e.provider.api_key,encryptedApiKeyLength:e.provider.api_key?.length||0});try{o=(0,t.decryptApiKey)(e.provider.api_key),console.log("[Anthropic Adapter] API key decrypted successfully, length:",o.length)}catch(e){return console.error("[Anthropic Adapter] Failed to decrypt API key:",e.message),{status:500,headers:{"Content-Type":"application/json"},body:{error:{message:"Failed to decrypt API key",type:"decryption_error"}}}}let n=e.provider.base_url||"https://api.anthropic.com/v1";n=n.trim().replace(/\/+$/,"");let s=r.path;console.log("[Anthropic Adapter] Path processing START:",{inputBaseUrl:e.provider.base_url,originalRequestPath:r.path,hasPath:!!r.path,pathLength:r.path?.length,pathPrefix:r.path?.substring(0,20)}),s&&"/"!==s&&""!==s?s.startsWith("/v1/")?s=s.substring(4):s.startsWith("/")?s=s.substring(1):s.startsWith("v1/")&&(s=s.substring(3)):s="messages";let i=`${n}/${s}`;console.log("[Anthropic Adapter] Path processing result:",{targetPathAfter:s,finalUrl:i}),console.log("[Anthropic Adapter] Forwarding request:",{baseUrl:e.provider.base_url,normalizedBaseUrl:n,originalPath:r.path,targetPath:s,url:i,method:r.method,hasApiKey:!!o,apiKeyPrefix:o?o.substring(0,10)+"...":"none"});let l={"x-api-key":o,Authorization:`Bearer ${o}`,"anthropic-version":"2023-06-01","Content-Type":"application/json",...r.headers};delete l.host,delete l.connection,console.log("[Anthropic Adapter] Request headers:",{"Content-Type":l["Content-Type"],"x-api-key":l["x-api-key"]?`${o.substring(0,10)}...${o.substring(o.length-4)}`:"none",Authorization:l.Authorization?`Bearer ${o.substring(0,10)}...${o.substring(o.length-4)}`:"none","anthropic-version":l["anthropic-version"]});let d=await fetch(i,{method:r.method,headers:l,body:"GET"!==r.method&&"HEAD"!==r.method?JSON.stringify(r.body):void 0});console.log("[Anthropic Adapter] Response status:",d.status,d.statusText);let p=await d.text();console.log("[Anthropic Adapter] Response body preview:",p.substring(0,200));try{a=JSON.parse(p)}catch{a=p,console.log("[Anthropic Adapter] Response body is not JSON, returning as string")}return{status:d.status,headers:Object.fromEntries(d.headers.entries()),body:a}}async listModels(e){return[{id:"claude-3-5-sonnet-20241022",name:"Claude 3.5 Sonnet"},{id:"claude-3-opus-20240229",name:"Claude 3 Opus"},{id:"claude-3-sonnet-20240229",name:"Claude 3 Sonnet"},{id:"claude-3-haiku-20240307",name:"Claude 3 Haiku"}]}}class a{async forwardRequest(e,r){let o,a=(0,t.decryptApiKey)(e.provider.api_key),n=e.provider.base_url||"https://generativelanguage.googleapis.com/v1";n=n.trim().replace(/\/+$/,"");let s=r.path;s&&"/"!==s&&""!==s?s.startsWith("/v1/")?s=s.substring(4):s.startsWith("/")&&(s=s.substring(1)):s=`models/${e.model_id}:generateContent`,n.endsWith("/v1")||(n+="/v1");let i=`${n}/${s}?key=${a}`;console.log("[Gemini Adapter] Forwarding request:",{baseUrl:e.provider.base_url,normalizedBaseUrl:n,originalPath:r.path,targetPath:s,url:i.replace(a,"***"),method:r.method,hasApiKey:!!a});let l={"Content-Type":"application/json",...r.headers};delete l.host,delete l.connection,delete l.authorization,console.log("[Gemini Adapter] Request headers:",{"Content-Type":l["Content-Type"]});let d=await fetch(i,{method:r.method,headers:l,body:"GET"!==r.method&&"HEAD"!==r.method?JSON.stringify(r.body):void 0});console.log("[Gemini Adapter] Response status:",d.status,d.statusText);let p=await d.text();console.log("[Gemini Adapter] Response body preview:",p.substring(0,200));try{o=JSON.parse(p)}catch{o=p,console.log("[Gemini Adapter] Response body is not JSON, returning as string")}return{status:d.status,headers:Object.fromEntries(d.headers.entries()),body:o}}async listModels(e){let r=(0,t.decryptApiKey)(e.api_key),o=e.base_url||"https://generativelanguage.googleapis.com/v1";try{let e=await fetch(`${o}/models?key=${r}`,{headers:{"Content-Type":"application/json"}});if(!e.ok)throw Error(`Failed to fetch models: ${e.statusText}`);let t=await e.json();if(!t.models||!Array.isArray(t.models))return console.error("[Gemini Adapter] Invalid models response:",t),[];return t.models.filter(e=>e&&"object"==typeof e).map(e=>{let t=e.name?e.name.replace("models/",""):"",r=e.displayName||e.name||"";return console.log("[Gemini Adapter] Processing model:",{id:t,name:r}),{id:t,name:r}})}catch(e){throw console.error("Error fetching Gemini models:",e),e}}}function n(e){let t=(e||"").toLowerCase().trim();switch(t){case"openai":return new r;case"anthropic":return new o;case"gemini":return new a;default:throw console.error(`[ProviderAdapter] Unsupported protocol: "${e}", normalized: "${t}"`),Error(`Unsupported protocol: ${e}. Supported protocols: openai, anthropic, gemini`)}}e.s(["getProviderAdapter",()=>n],98857)},39380,e=>{"use strict";var t=e.i(97731),r=e.i(98857),o=e.i(38483);function a(e){if(void 0===e)return"";if(null===e)return"null";try{return JSON.stringify(e)}catch{try{return String(e)}catch{return"[Non-serializable]"}}}async function n(e,r){try{let n=function(e){let t={...e};if(t.authorization){let e=t.authorization;e.startsWith("Bearer ")?t.authorization=`Bearer ${(0,o.maskToken)(e.substring(7))}`:t.authorization=(0,o.maskToken)(e)}return t["x-api-key"]&&(t["x-api-key"]=(0,o.maskApiKey)(t["x-api-key"])),t["api-key"]&&(t["api-key"]=(0,o.maskApiKey)(t["api-key"])),t}(e.headers),s=function e(t){if(!t||"object"!=typeof t)return t;if(Array.isArray(t))return t.map(e);let r={};for(let[a,n]of Object.entries(t)){let t=a.toLowerCase();t.includes("api")&&t.includes("key")?r[a]=(0,o.maskApiKey)(String(n)):t.includes("token")||"authorization"===t?r[a]=(0,o.maskToken)(String(n)):"object"==typeof n&&null!==n?r[a]=e(n):r[a]=n}return r}(e.body);await (0,t.createRequestLog)({model_id:e.modelId,request_method:e.method,request_path:e.path,request_headers:a(n),request_query:a(e.query),request_body:a(s),response_status:r.status,response_body:a(r.body),response_time_ms:r.responseTimeMs})}catch(e){console.error("Failed to log request:",e)}}async function s(e,o,a){let s=Date.now(),i=`${Date.now()}-${Math.random().toString(36).substr(2,9)}`;console.log(`[Gateway ${i}] handleGatewayRequest called:`,{modelId:e,providerName:a||"not specified",method:o.method,path:o.path});try{let l=a,d=e;if(!a){console.log(`[Gateway ${i}] Provider not specified, attempting auto-routing by model_id:`,e),o.body?.model&&(d=o.body.model,console.log(`[Gateway ${i}] Using model_id from request body:`,d));let r=await (0,t.getModelByModelIdAny)(d);if(!r)return console.log(`[Gateway ${i}] Model not found in database:`,d),{status:404,headers:{"Content-Type":"application/json"},body:{error:{message:`Model "${d}" not found or not enabled. Please configure the model in the Gateway settings first.`,type:"model_not_found"}}};l=r.provider_name,console.log(`[Gateway ${i}] Auto-routed model "${d}" to provider:`,l)}let p=await (0,t.getAllProviders)();console.log(`[Gateway ${i}] Available providers:`,p.map(e=>({id:e.id,name:e.name})));let u=p.find(e=>e.name&&e.name.toLowerCase()===l.toLowerCase());if(!u){console.log(`[Gateway ${i}] Provider not found:`,l);let e=p.map(e=>e.name).join(", ");return{status:404,headers:{"Content-Type":"application/json"},body:{error:{message:`Provider "${l}" not found. Available providers: ${e||"none"}`,type:"provider_not_found"}}}}console.log(`[Gateway ${i}] Provider found:`,{id:u.id,name:u.name,protocol:u.protocol,base_url:u.base_url,hasApiKey:!!u.api_key});let c=u.name||"unknown",h={id:0,provider_id:u.id,name:d||"unnamed",model_id:d||"unknown",enabled:!0,created_at:new Date().toISOString(),updated_at:new Date().toISOString(),provider:{id:u.id,name:c,protocol:u.protocol,base_url:u.base_url||"",api_key:u.api_key||""}},y=(0,r.getProviderAdapter)(u.protocol);console.log(`[Gateway ${i}] Forwarding request with:`,{provider:u.name,protocol:u.protocol,modelId:d});let g=await y.forwardRequest(h,o),m=Date.now()-s;console.log(`[Gateway ${i}] About to log request, response type:`,typeof g.body);try{await n({modelId:null,method:o.method,path:o.path,headers:o.headers,query:o.query,body:o.body},{status:g.status,headers:g.headers,body:g.body,responseTimeMs:m}),console.log(`[Gateway ${i}] Request logged successfully`)}catch(e){console.error(`[Gateway ${i}] Failed to log request:`,e.message,e.stack)}return g}catch(r){let e=Date.now()-s;console.error(`[Gateway ${i}] Error:`,{message:r.message,stack:r.stack});let t={status:500,headers:{"Content-Type":"application/json"},body:{error:{message:r.message||"Internal server error",type:"gateway_error"}}};try{await n({modelId:null,method:o.method,path:o.path,headers:o.headers,query:o.query,body:o.body},{status:t.status,headers:t.headers,body:t.body,responseTimeMs:e})}catch(e){console.error(`[Gateway ${i}] Failed to log error request:`,e.message)}return t}}e.s(["handleGatewayRequest",()=>s],39380)},45861,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),n=e.i(61916),s=e.i(74677),i=e.i(69741),l=e.i(16795),d=e.i(87718),p=e.i(95169),u=e.i(47587),c=e.i(66012),h=e.i(70101),y=e.i(26937),g=e.i(10372),m=e.i(93695);e.i(52474);var b=e.i(220),f=e.i(89171),v=e.i(71560),A=e.i(39380);async function w(e){return R(e,"POST")}async function x(e){return R(e,"GET")}async function R(e,t){try{await (0,v.getDatabase)();let r=e.nextUrl.searchParams,o=r.get("model")||r.get("model_id"),a=r.get("provider"),n=null;try{if("GET"!==t&&"HEAD"!==t){let t=await e.text();t&&(n=JSON.parse(t))}}catch{}!o&&n&&(o=n.model||n.model_id);let s=n?.provider;if(!o)return f.NextResponse.json({error:{message:"Model ID not specified"}},{status:400});let i={method:t,path:"/",headers:Object.fromEntries(e.headers.entries()),query:Object.fromEntries(r.entries()),body:n},l=await (0,A.handleGatewayRequest)(o,i,a||s||void 0);return f.NextResponse.json(l.body,{status:l.status,headers:l.headers})}catch(e){return f.NextResponse.json({error:{message:e.message||"Internal server error"}},{status:500})}}e.s(["GET",()=>x,"POST",()=>w,"runtime",0,"nodejs"],29727);var _=e.i(29727);let k=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/gateway/route",pathname:"/api/gateway",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/gateway/route.ts",nextConfigOutput:"",userland:_}),{workAsyncStorage:E,workUnitAsyncStorage:O,serverHooks:q}=k;function $(){return(0,o.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:O})}async function C(e,t,o){k.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let f="/api/gateway/route";f=f.replace(/\/index$/,"")||"/";let v=await k.prepare(e,t,{srcPage:f,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:A,params:w,nextConfig:x,parsedUrl:R,isDraftMode:_,prerenderManifest:E,routerServerContext:O,isOnDemandRevalidate:q,revalidateOnlyGenerated:$,resolvedPathname:C,clientReferenceManifest:T,serverActionsManifest:P}=v,I=(0,i.normalizeAppPath)(f),S=!!(E.dynamicRoutes[I]||E.routes[C]),j=async()=>((null==O?void 0:O.render404)?await O.render404(e,t,R,!1):t.end("This page could not be found"),null);if(S&&!_){let e=!!E.routes[C],t=E.dynamicRoutes[I];if(t&&!1===t.fallback&&!e){if(x.experimental.adapterPath)return await j();throw new m.NoFallbackError}}let N=null;!S||k.isDev||_||(N="/index"===(N=C)?"/":N);let G=!0===k.isDev||!S,U=S&&!G;P&&T&&(0,s.setManifestsSingleton)({page:f,clientReferenceManifest:T,serverActionsManifest:P});let K=e.method||"GET",D=(0,n.getTracer)(),z=D.getActiveScopeSpan(),F={params:w,prerenderManifest:E,renderOpts:{experimental:{authInterrupts:!!x.experimental.authInterrupts},cacheComponents:!!x.cacheComponents,supportsDynamicResponse:G,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:x.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>k.onRequestError(e,t,o,a,O)},sharedContext:{buildId:A}},H=new l.NodeNextRequest(e),M=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(H,(0,d.signalFromNodeResponse)(t));try{let s=async e=>k.handle(B,F).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=D.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==p.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${K} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t)}else e.updateName(`${K} ${f}`)}),i=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var n,l;let d=async({previousCacheEntry:r})=>{try{if(!i&&q&&$&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await s(a);e.fetchMetrics=F.renderOpts.fetchMetrics;let l=F.renderOpts.pendingWaitUntil;l&&o.waitUntil&&(o.waitUntil(l),l=void 0);let d=F.renderOpts.collectedTags;if(!S)return await (0,c.sendResponse)(H,M,n,F.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(n.headers);d&&(t[g.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==F.renderOpts.collectedRevalidate&&!(F.renderOpts.collectedRevalidate>=g.INFINITE_CACHE)&&F.renderOpts.collectedRevalidate,o=void 0===F.renderOpts.collectedExpire||F.renderOpts.collectedExpire>=g.INFINITE_CACHE?void 0:F.renderOpts.collectedExpire;return{value:{kind:b.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await k.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:q})},!1,O),t}},p=await k.handleResponse({req:e,nextConfig:x,cacheKey:N,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:q,revalidateOnlyGenerated:$,responseGenerator:d,waitUntil:o.waitUntil,isMinimalMode:i});if(!S)return null;if((null==p||null==(n=p.value)?void 0:n.kind)!==b.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==p||null==(l=p.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",q?"REVALIDATED":p.isMiss?"MISS":p.isStale?"STALE":"HIT"),_&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let m=(0,h.fromNodeOutgoingHttpHeaders)(p.value.headers);return i&&S||m.delete(g.NEXT_CACHE_TAGS_HEADER),!p.cacheControl||t.getHeader("Cache-Control")||m.get("Cache-Control")||m.set("Cache-Control",(0,y.getCacheControlHeader)(p.cacheControl)),await (0,c.sendResponse)(H,M,new Response(p.value.body,{headers:m,status:p.value.status||200})),null};z?await l(z):await D.withPropagatedContext(e.headers,()=>D.trace(p.BaseServerSpan.handleRequest,{spanName:`${K} ${f}`,kind:n.SpanKind.SERVER,attributes:{"http.method":K,"http.target":e.url}},l))}catch(t){if(t instanceof m.NoFallbackError||await k.onRequestError(e,t,{routerKind:"App Router",routePath:I,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:q})},!1,O),S)throw t;return await (0,c.sendResponse)(H,M,new Response(null,{status:500})),null}}e.s(["handler",()=>C,"patchFetch",()=>$,"routeModule",()=>k,"serverHooks",()=>q,"workAsyncStorage",()=>E,"workUnitAsyncStorage",()=>O],45861)}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__6ce199d2._.js.map
|