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
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { NextRequest, NextResponse } from 'next/server';
|
|
2
|
+
import { existsSync, readFileSync, statSync } from 'fs';
|
|
3
|
+
import { join } from 'path';
|
|
4
|
+
import { homedir } from 'os';
|
|
5
|
+
import { getDatabase } from '@/db/database';
|
|
6
|
+
import { getConfig } from '@/db/queries';
|
|
7
|
+
|
|
8
|
+
// OpenCode 配置文件路径(XDG)
|
|
9
|
+
const OPENCODE_DIR =
|
|
10
|
+
process.platform === 'win32'
|
|
11
|
+
? join(process.env.APPDATA || homedir(), 'opencode')
|
|
12
|
+
: join(homedir(), '.config', 'opencode');
|
|
13
|
+
const OPENCODE_FILE = join(OPENCODE_DIR, 'opencode.json');
|
|
14
|
+
const BACKUP_FILE = join(OPENCODE_DIR, 'opencode.json.aar.bak');
|
|
15
|
+
const AAR_DIR = join(homedir(), '.aar');
|
|
16
|
+
const TEMP_OPENCODE_FILE = join(AAR_DIR, 'opencode.tmp.json');
|
|
17
|
+
|
|
18
|
+
type OpenCodeStatus = {
|
|
19
|
+
applied: boolean;
|
|
20
|
+
defaultModel?: string;
|
|
21
|
+
gatewayAddress?: string;
|
|
22
|
+
apiKey?: string;
|
|
23
|
+
lastUpdated?: string | null;
|
|
24
|
+
backupExists: boolean;
|
|
25
|
+
matchCurrentGateway?: boolean;
|
|
26
|
+
routerProvider?: string;
|
|
27
|
+
tempDefaultModel?: string;
|
|
28
|
+
providerName?: string;
|
|
29
|
+
modelsCount?: number;
|
|
30
|
+
/** 当前磁盘上 opencode.json 的完整内容,用于「生效中」展示;还原后即显示还原后的内容 */
|
|
31
|
+
config?: Record<string, unknown> | null;
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
function maskApiKey(apiKey: string): string {
|
|
35
|
+
if (!apiKey || apiKey === 'your-gateway-api-key') return apiKey;
|
|
36
|
+
if (apiKey.length <= 8) return apiKey.slice(0, 2) + '***' + apiKey.slice(-2);
|
|
37
|
+
return apiKey.slice(0, 4) + '****' + apiKey.slice(-4);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export async function GET(request: NextRequest) {
|
|
41
|
+
try {
|
|
42
|
+
const fileExists = existsSync(OPENCODE_FILE);
|
|
43
|
+
const backupExists = existsSync(BACKUP_FILE);
|
|
44
|
+
|
|
45
|
+
await getDatabase();
|
|
46
|
+
const gatewayApiKeyConfig = await getConfig('api_key');
|
|
47
|
+
const portConfig = await getConfig('port');
|
|
48
|
+
const gatewayApiKey = gatewayApiKeyConfig?.value || 'your-gateway-api-key';
|
|
49
|
+
const gatewayAddress = `http://localhost:${portConfig?.value || '1357'}/v1`;
|
|
50
|
+
|
|
51
|
+
if (!fileExists) {
|
|
52
|
+
let tempDefaultModel: string | undefined;
|
|
53
|
+
if (existsSync(TEMP_OPENCODE_FILE)) {
|
|
54
|
+
try {
|
|
55
|
+
const temp = JSON.parse(readFileSync(TEMP_OPENCODE_FILE, 'utf-8'));
|
|
56
|
+
tempDefaultModel = temp.defaultModel;
|
|
57
|
+
} catch {}
|
|
58
|
+
}
|
|
59
|
+
return NextResponse.json({
|
|
60
|
+
applied: false,
|
|
61
|
+
defaultModel: undefined,
|
|
62
|
+
gatewayAddress,
|
|
63
|
+
apiKey: maskApiKey(gatewayApiKey),
|
|
64
|
+
backupExists: false,
|
|
65
|
+
lastUpdated: undefined,
|
|
66
|
+
matchCurrentGateway: false,
|
|
67
|
+
routerProvider: undefined,
|
|
68
|
+
tempDefaultModel,
|
|
69
|
+
} as OpenCodeStatus);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const content = readFileSync(OPENCODE_FILE, 'utf-8');
|
|
73
|
+
let config: any;
|
|
74
|
+
try {
|
|
75
|
+
config = JSON.parse(content);
|
|
76
|
+
} catch {
|
|
77
|
+
return NextResponse.json({ error: 'Invalid opencode.json format' }, { status: 500 });
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
const providerMap = config.provider && typeof config.provider === 'object' ? config.provider : {};
|
|
81
|
+
const aarProvider = providerMap['aar-gateway'];
|
|
82
|
+
const provider = aarProvider;
|
|
83
|
+
const appliedBaseUrl = provider?.options?.baseURL;
|
|
84
|
+
const appliedApiKey = provider?.options?.apiKey;
|
|
85
|
+
const matchCurrentGateway = appliedBaseUrl === gatewayAddress && appliedApiKey === gatewayApiKey;
|
|
86
|
+
const defaultModel =
|
|
87
|
+
typeof config.model === 'string' && config.model.startsWith('aar-gateway/')
|
|
88
|
+
? config.model.slice('aar-gateway/'.length)
|
|
89
|
+
: config.default_model;
|
|
90
|
+
const modelsCount = provider?.models ? Object.keys(provider.models).length : 0;
|
|
91
|
+
|
|
92
|
+
let tempDefaultModel: string | undefined;
|
|
93
|
+
if (!matchCurrentGateway && existsSync(TEMP_OPENCODE_FILE)) {
|
|
94
|
+
try {
|
|
95
|
+
const temp = JSON.parse(readFileSync(TEMP_OPENCODE_FILE, 'utf-8'));
|
|
96
|
+
tempDefaultModel = temp.defaultModel;
|
|
97
|
+
} catch {}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
let lastUpdated: string | null = null;
|
|
101
|
+
try {
|
|
102
|
+
lastUpdated = new Date(statSync(OPENCODE_FILE).mtime).toISOString();
|
|
103
|
+
} catch {}
|
|
104
|
+
|
|
105
|
+
const status: OpenCodeStatus = {
|
|
106
|
+
applied: true,
|
|
107
|
+
defaultModel,
|
|
108
|
+
gatewayAddress: appliedBaseUrl,
|
|
109
|
+
apiKey: maskApiKey(appliedApiKey || gatewayApiKey),
|
|
110
|
+
backupExists,
|
|
111
|
+
lastUpdated,
|
|
112
|
+
matchCurrentGateway,
|
|
113
|
+
routerProvider: aarProvider ? 'aar' : undefined,
|
|
114
|
+
tempDefaultModel,
|
|
115
|
+
providerName: provider?.name,
|
|
116
|
+
modelsCount,
|
|
117
|
+
config,
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
return NextResponse.json(status);
|
|
121
|
+
} catch (error: any) {
|
|
122
|
+
console.error('OpenCode Status API error:', error);
|
|
123
|
+
return NextResponse.json(
|
|
124
|
+
{ error: error.message || 'Internal server error', stack: process.env.NODE_ENV === 'development' ? error.stack : undefined },
|
|
125
|
+
{ status: 500 }
|
|
126
|
+
);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { NextRequest, NextResponse } from 'next/server';
|
|
2
|
+
import { existsSync, readFileSync } from 'fs';
|
|
3
|
+
import { join } from 'path';
|
|
4
|
+
import { homedir } from 'os';
|
|
5
|
+
import { spawn } from 'child_process';
|
|
6
|
+
|
|
7
|
+
const OPENCODE_FILE =
|
|
8
|
+
process.platform === 'win32'
|
|
9
|
+
? join(process.env.APPDATA || homedir(), 'opencode', 'opencode.json')
|
|
10
|
+
: join(homedir(), '.config', 'opencode', 'opencode.json');
|
|
11
|
+
|
|
12
|
+
const TEST_PROMPT = '严格只输出这个 JSON,不要多任何字:{"test":"ok"}';
|
|
13
|
+
const EXPECTED_JSON = '{"test":"ok"}';
|
|
14
|
+
const RUN_TIMEOUT_MS = 90_000;
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* 在子进程中执行 opencode run,不阻塞主进程;若输出中出现 {"test":"ok"} 则判定通过
|
|
18
|
+
*/
|
|
19
|
+
function runOpencodeTest(model: string): Promise<{ success: boolean; stdout: string; stderr: string; error?: string; latency: number }> {
|
|
20
|
+
return new Promise((resolve) => {
|
|
21
|
+
const start = Date.now();
|
|
22
|
+
let settled = false;
|
|
23
|
+
let timeoutId: ReturnType<typeof setTimeout>;
|
|
24
|
+
const done = (success: boolean, error?: string) => {
|
|
25
|
+
if (settled) return;
|
|
26
|
+
settled = true;
|
|
27
|
+
clearTimeout(timeoutId);
|
|
28
|
+
resolve({
|
|
29
|
+
success,
|
|
30
|
+
stdout,
|
|
31
|
+
stderr,
|
|
32
|
+
error,
|
|
33
|
+
latency: Date.now() - start,
|
|
34
|
+
});
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
const args = ['run', TEST_PROMPT, '--model', model];
|
|
38
|
+
const child = spawn('opencode', args, {
|
|
39
|
+
shell: process.platform === 'win32',
|
|
40
|
+
stdio: ['ignore', 'pipe', 'pipe'],
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
let stdout = '';
|
|
44
|
+
let stderr = '';
|
|
45
|
+
|
|
46
|
+
child.stdout?.on('data', (chunk: Buffer) => {
|
|
47
|
+
stdout += chunk.toString('utf-8');
|
|
48
|
+
});
|
|
49
|
+
child.stderr?.on('data', (chunk: Buffer) => {
|
|
50
|
+
stderr += chunk.toString('utf-8');
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
child.on('error', (err) => {
|
|
54
|
+
done(false, err.message || 'Failed to spawn opencode');
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
child.on('close', (code, signal) => {
|
|
58
|
+
if (settled) return;
|
|
59
|
+
const combined = stdout + stderr;
|
|
60
|
+
const hasExpected = combined.includes(EXPECTED_JSON);
|
|
61
|
+
if (hasExpected) {
|
|
62
|
+
done(true);
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
if (code !== 0 && code !== null) {
|
|
66
|
+
done(false, `opencode exited with code ${code}${signal ? ` signal ${signal}` : ''}`);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
done(false, 'Output did not contain expected JSON');
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
timeoutId = setTimeout(() => {
|
|
73
|
+
try {
|
|
74
|
+
child.kill('SIGTERM');
|
|
75
|
+
} catch {
|
|
76
|
+
try {
|
|
77
|
+
child.kill('SIGKILL');
|
|
78
|
+
} catch {}
|
|
79
|
+
}
|
|
80
|
+
done(false, 'Request timed out');
|
|
81
|
+
}, RUN_TIMEOUT_MS);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* 测试 OpenCode 配置:用子进程执行 opencode run,检查输出是否包含 {"test":"ok"}
|
|
87
|
+
*/
|
|
88
|
+
export async function GET(request: NextRequest) {
|
|
89
|
+
try {
|
|
90
|
+
if (!existsSync(OPENCODE_FILE)) {
|
|
91
|
+
return NextResponse.json({
|
|
92
|
+
success: false,
|
|
93
|
+
error: 'Configuration file not found',
|
|
94
|
+
suggestion: 'Please apply configuration first',
|
|
95
|
+
gatewayRunning: false,
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
const content = readFileSync(OPENCODE_FILE, 'utf-8');
|
|
100
|
+
let config: any;
|
|
101
|
+
try {
|
|
102
|
+
config = JSON.parse(content);
|
|
103
|
+
} catch {
|
|
104
|
+
return NextResponse.json({
|
|
105
|
+
success: false,
|
|
106
|
+
error: 'Invalid configuration format',
|
|
107
|
+
gatewayRunning: false,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
const model = config.model;
|
|
112
|
+
if (!model || typeof model !== 'string') {
|
|
113
|
+
return NextResponse.json({
|
|
114
|
+
success: false,
|
|
115
|
+
error: 'No model set in config (config.model)',
|
|
116
|
+
suggestion: 'Apply configuration with a default model',
|
|
117
|
+
gatewayRunning: false,
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
const result = await runOpencodeTest(model);
|
|
122
|
+
|
|
123
|
+
return NextResponse.json({
|
|
124
|
+
success: result.success,
|
|
125
|
+
gatewayRunning: undefined,
|
|
126
|
+
opencodeTest: {
|
|
127
|
+
success: result.success,
|
|
128
|
+
message: result.success ? 'opencode run 输出符合预期' : (result.error || 'Output did not contain expected JSON'),
|
|
129
|
+
error: result.error || '',
|
|
130
|
+
latency: result.latency,
|
|
131
|
+
stdout: result.stdout.slice(-2000),
|
|
132
|
+
stderr: result.stderr.slice(-1000),
|
|
133
|
+
},
|
|
134
|
+
configSummary: {
|
|
135
|
+
model,
|
|
136
|
+
},
|
|
137
|
+
});
|
|
138
|
+
} catch (error: any) {
|
|
139
|
+
console.error('OpenCode Test API error:', error);
|
|
140
|
+
return NextResponse.json(
|
|
141
|
+
{ error: error.message || 'Internal server error', gatewayRunning: false },
|
|
142
|
+
{ status: 500 }
|
|
143
|
+
);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
@@ -34,7 +34,7 @@ function cleanLogData(log: any) {
|
|
|
34
34
|
|
|
35
35
|
export async function GET(request: NextRequest) {
|
|
36
36
|
try {
|
|
37
|
-
getDatabase();
|
|
37
|
+
await getDatabase();
|
|
38
38
|
const { searchParams } = new URL(request.url);
|
|
39
39
|
const id = searchParams.get('id');
|
|
40
40
|
const limit = parseInt(searchParams.get('limit') || '100');
|
|
@@ -79,7 +79,7 @@ export async function GET(request: NextRequest) {
|
|
|
79
79
|
|
|
80
80
|
export async function DELETE(request: NextRequest) {
|
|
81
81
|
try {
|
|
82
|
-
getDatabase();
|
|
82
|
+
await getDatabase();
|
|
83
83
|
const { searchParams } = new URL(request.url);
|
|
84
84
|
const ids = searchParams.get('ids');
|
|
85
85
|
const clearAll = searchParams.get('clear_all') === 'true';
|
|
@@ -16,7 +16,7 @@ export const runtime = 'nodejs';
|
|
|
16
16
|
|
|
17
17
|
export async function GET(request: NextRequest) {
|
|
18
18
|
try {
|
|
19
|
-
getDatabase();
|
|
19
|
+
await getDatabase();
|
|
20
20
|
const { searchParams } = new URL(request.url);
|
|
21
21
|
const providerId = searchParams.get('provider_id');
|
|
22
22
|
const enabledOnly = searchParams.get('enabled');
|
|
@@ -47,7 +47,7 @@ export async function GET(request: NextRequest) {
|
|
|
47
47
|
|
|
48
48
|
export async function POST(request: NextRequest) {
|
|
49
49
|
try {
|
|
50
|
-
getDatabase();
|
|
50
|
+
await getDatabase();
|
|
51
51
|
const body = await request.json();
|
|
52
52
|
const { provider_id, name, model_id, enabled } = body;
|
|
53
53
|
|
|
@@ -77,7 +77,7 @@ export async function POST(request: NextRequest) {
|
|
|
77
77
|
|
|
78
78
|
export async function PUT(request: NextRequest) {
|
|
79
79
|
try {
|
|
80
|
-
getDatabase();
|
|
80
|
+
await getDatabase();
|
|
81
81
|
const body = await request.json();
|
|
82
82
|
const { id, name, model_id, enabled, provider_id } = body;
|
|
83
83
|
|
|
@@ -114,7 +114,7 @@ export async function PUT(request: NextRequest) {
|
|
|
114
114
|
|
|
115
115
|
export async function DELETE(request: NextRequest) {
|
|
116
116
|
try {
|
|
117
|
-
getDatabase();
|
|
117
|
+
await getDatabase();
|
|
118
118
|
const { searchParams } = new URL(request.url);
|
|
119
119
|
const id = searchParams.get('id');
|
|
120
120
|
|
|
@@ -146,7 +146,7 @@ export async function DELETE(request: NextRequest) {
|
|
|
146
146
|
// Fetch models from provider
|
|
147
147
|
export async function PATCH(request: NextRequest) {
|
|
148
148
|
try {
|
|
149
|
-
getDatabase();
|
|
149
|
+
await getDatabase();
|
|
150
150
|
const body = await request.json();
|
|
151
151
|
const { provider_id } = body;
|
|
152
152
|
|
|
@@ -8,7 +8,7 @@ export const runtime = 'nodejs';
|
|
|
8
8
|
|
|
9
9
|
export async function GET(request: NextRequest) {
|
|
10
10
|
try {
|
|
11
|
-
getDatabase();
|
|
11
|
+
await getDatabase();
|
|
12
12
|
const { searchParams } = new URL(request.url);
|
|
13
13
|
const id = searchParams.get('id');
|
|
14
14
|
const includeKey = searchParams.get('includeKey') === 'true';
|
|
@@ -48,7 +48,7 @@ export async function GET(request: NextRequest) {
|
|
|
48
48
|
|
|
49
49
|
export async function POST(request: NextRequest) {
|
|
50
50
|
try {
|
|
51
|
-
getDatabase();
|
|
51
|
+
await getDatabase();
|
|
52
52
|
const body = await request.json();
|
|
53
53
|
const { name, protocol, base_url, api_key } = body;
|
|
54
54
|
|
|
@@ -82,7 +82,7 @@ export async function POST(request: NextRequest) {
|
|
|
82
82
|
|
|
83
83
|
export async function PUT(request: NextRequest) {
|
|
84
84
|
try {
|
|
85
|
-
getDatabase();
|
|
85
|
+
await getDatabase();
|
|
86
86
|
const body = await request.json();
|
|
87
87
|
const { id, name, protocol, base_url, api_key } = body;
|
|
88
88
|
|
|
@@ -132,7 +132,7 @@ export async function PUT(request: NextRequest) {
|
|
|
132
132
|
|
|
133
133
|
export async function DELETE(request: NextRequest) {
|
|
134
134
|
try {
|
|
135
|
-
getDatabase();
|
|
135
|
+
await getDatabase();
|
|
136
136
|
const { searchParams } = new URL(request.url);
|
|
137
137
|
const id = searchParams.get('id');
|
|
138
138
|
|
|
@@ -10,7 +10,7 @@ export const runtime = 'nodejs';
|
|
|
10
10
|
export async function POST(request: NextRequest) {
|
|
11
11
|
try {
|
|
12
12
|
// Initialize database
|
|
13
|
-
getDatabase();
|
|
13
|
+
await getDatabase();
|
|
14
14
|
|
|
15
15
|
const body = await request.json().catch(() => ({}));
|
|
16
16
|
const port = body.port ? parseInt(body.port, 10) : null;
|
package/src/app/globals.css
CHANGED
|
@@ -69,3 +69,20 @@ button:disabled {
|
|
|
69
69
|
::-webkit-scrollbar-thumb:hover {
|
|
70
70
|
background: #94a3b8;
|
|
71
71
|
}
|
|
72
|
+
|
|
73
|
+
/* OpenCode 配置预览:去掉选中高亮与焦点白圈,避免与深色背景冲突 */
|
|
74
|
+
.opencode-preview-textarea::selection {
|
|
75
|
+
background: transparent !important;
|
|
76
|
+
color: inherit !important;
|
|
77
|
+
}
|
|
78
|
+
.opencode-preview-textarea::-moz-selection {
|
|
79
|
+
background: transparent !important;
|
|
80
|
+
color: inherit !important;
|
|
81
|
+
}
|
|
82
|
+
/* 去掉焦点时的白圈/高亮(覆盖全局 input/textarea:focus 的 ring) */
|
|
83
|
+
.opencode-preview-textarea:focus {
|
|
84
|
+
outline: none !important;
|
|
85
|
+
box-shadow: none !important;
|
|
86
|
+
--tw-ring-shadow: none !important;
|
|
87
|
+
--tw-ring-offset-shadow: none !important;
|
|
88
|
+
}
|