ai-agent-router 0.1.21 → 0.2.0

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.
Files changed (133) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +2 -2
  3. package/.next/fallback-build-manifest.json +2 -2
  4. package/.next/server/app/_global-error.html +2 -2
  5. package/.next/server/app/_global-error.rsc +1 -1
  6. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  7. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  8. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  9. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  10. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  11. package/.next/server/app/_not-found.html +1 -1
  12. package/.next/server/app/_not-found.rsc +1 -1
  13. package/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  14. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  15. package/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  16. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  17. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  18. package/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  19. package/.next/server/app/api/config/route.js.nft.json +1 -1
  20. package/.next/server/app/api/gateway/[...path]/route.js.nft.json +1 -1
  21. package/.next/server/app/api/gateway/models/route.js.nft.json +1 -1
  22. package/.next/server/app/api/gateway/route.js.nft.json +1 -1
  23. package/.next/server/app/api/ide/claude/apply/route.js.nft.json +1 -1
  24. package/.next/server/app/api/ide/claude/available-models/route.js.nft.json +1 -1
  25. package/.next/server/app/api/ide/claude/save/route.js.nft.json +1 -1
  26. package/.next/server/app/api/ide/claude/status/route.js.nft.json +1 -1
  27. package/.next/server/app/api/ide/claude/test/route.js.nft.json +1 -1
  28. package/.next/server/app/api/logs/route.js.nft.json +1 -1
  29. package/.next/server/app/api/models/route.js.nft.json +1 -1
  30. package/.next/server/app/api/providers/route.js.nft.json +1 -1
  31. package/.next/server/app/api/providers/test/route.js.nft.json +1 -1
  32. package/.next/server/app/api/service/force-stop/route.js.nft.json +1 -1
  33. package/.next/server/app/api/service/start/route.js.nft.json +1 -1
  34. package/.next/server/app/api/service/status/route.js.nft.json +1 -1
  35. package/.next/server/app/api/service/stop/route.js.nft.json +1 -1
  36. package/.next/server/app/ide.html +1 -1
  37. package/.next/server/app/ide.rsc +1 -1
  38. package/.next/server/app/ide.segments/_full.segment.rsc +1 -1
  39. package/.next/server/app/ide.segments/_head.segment.rsc +1 -1
  40. package/.next/server/app/ide.segments/_index.segment.rsc +1 -1
  41. package/.next/server/app/ide.segments/_tree.segment.rsc +1 -1
  42. package/.next/server/app/ide.segments/ide/__PAGE__.segment.rsc +1 -1
  43. package/.next/server/app/ide.segments/ide.segment.rsc +1 -1
  44. package/.next/server/app/index.html +1 -1
  45. package/.next/server/app/index.rsc +1 -1
  46. package/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  47. package/.next/server/app/index.segments/_full.segment.rsc +1 -1
  48. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  49. package/.next/server/app/index.segments/_index.segment.rsc +1 -1
  50. package/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  51. package/.next/server/app/logs/page_client-reference-manifest.js +1 -1
  52. package/.next/server/app/logs.html +1 -1
  53. package/.next/server/app/logs.rsc +2 -2
  54. package/.next/server/app/logs.segments/_full.segment.rsc +2 -2
  55. package/.next/server/app/logs.segments/_head.segment.rsc +1 -1
  56. package/.next/server/app/logs.segments/_index.segment.rsc +1 -1
  57. package/.next/server/app/logs.segments/_tree.segment.rsc +1 -1
  58. package/.next/server/app/logs.segments/logs/__PAGE__.segment.rsc +2 -2
  59. package/.next/server/app/logs.segments/logs.segment.rsc +1 -1
  60. package/.next/server/app/models.html +1 -1
  61. package/.next/server/app/models.rsc +1 -1
  62. package/.next/server/app/models.segments/_full.segment.rsc +1 -1
  63. package/.next/server/app/models.segments/_head.segment.rsc +1 -1
  64. package/.next/server/app/models.segments/_index.segment.rsc +1 -1
  65. package/.next/server/app/models.segments/_tree.segment.rsc +1 -1
  66. package/.next/server/app/models.segments/models/__PAGE__.segment.rsc +1 -1
  67. package/.next/server/app/models.segments/models.segment.rsc +1 -1
  68. package/.next/server/app/providers.html +1 -1
  69. package/.next/server/app/providers.rsc +1 -1
  70. package/.next/server/app/providers.segments/_full.segment.rsc +1 -1
  71. package/.next/server/app/providers.segments/_head.segment.rsc +1 -1
  72. package/.next/server/app/providers.segments/_index.segment.rsc +1 -1
  73. package/.next/server/app/providers.segments/_tree.segment.rsc +1 -1
  74. package/.next/server/app/providers.segments/providers/__PAGE__.segment.rsc +1 -1
  75. package/.next/server/app/providers.segments/providers.segment.rsc +1 -1
  76. package/.next/server/chunks/[root-of-the-server]__1480f018._.js +1 -1
  77. package/.next/server/chunks/[root-of-the-server]__1480f018._.js.map +1 -1
  78. package/.next/server/chunks/[root-of-the-server]__1909f3aa._.js +1 -1
  79. package/.next/server/chunks/[root-of-the-server]__1909f3aa._.js.map +1 -1
  80. package/.next/server/chunks/[root-of-the-server]__1d4b7fc5._.js +1 -1
  81. package/.next/server/chunks/[root-of-the-server]__1d4b7fc5._.js.map +1 -1
  82. package/.next/server/chunks/[root-of-the-server]__372ef2bf._.js +1 -1
  83. package/.next/server/chunks/[root-of-the-server]__372ef2bf._.js.map +1 -1
  84. package/.next/server/chunks/[root-of-the-server]__3aaf963c._.js +1 -1
  85. package/.next/server/chunks/[root-of-the-server]__3aaf963c._.js.map +1 -1
  86. package/.next/server/chunks/[root-of-the-server]__6ce199d2._.js +1 -1
  87. package/.next/server/chunks/[root-of-the-server]__6ce199d2._.js.map +1 -1
  88. package/.next/server/chunks/[root-of-the-server]__772134c6._.js +1 -1
  89. package/.next/server/chunks/[root-of-the-server]__772134c6._.js.map +1 -1
  90. package/.next/server/chunks/[root-of-the-server]__7b77f523._.js +1 -1
  91. package/.next/server/chunks/[root-of-the-server]__7b77f523._.js.map +1 -1
  92. package/.next/server/chunks/[root-of-the-server]__c1b4b601._.js +18 -18
  93. package/.next/server/chunks/[root-of-the-server]__c1b4b601._.js.map +1 -1
  94. package/.next/server/chunks/[root-of-the-server]__ccfc7f1d._.js +1 -1
  95. package/.next/server/chunks/[root-of-the-server]__ccfc7f1d._.js.map +1 -1
  96. package/.next/server/chunks/ssr/src_app_logs_page_tsx_7b7b7b83._.js +1 -1
  97. package/.next/server/chunks/ssr/src_app_logs_page_tsx_7b7b7b83._.js.map +1 -1
  98. package/.next/server/pages/404.html +1 -1
  99. package/.next/server/pages/500.html +2 -2
  100. package/.next/static/chunks/{81c904164fe81379.js → b6b258e8582e47c4.js} +1 -1
  101. package/README.md +100 -111
  102. package/dist/src/app/api/gateway/[...path]/route.js +1 -1
  103. package/dist/src/app/api/gateway/route.js +1 -1
  104. package/dist/src/app/api/logs/route.js +2 -2
  105. package/dist/src/app/api/models/route.js +5 -5
  106. package/dist/src/app/api/providers/route.js +4 -4
  107. package/dist/src/app/api/providers/test/route.js +1 -1
  108. package/dist/src/app/api/service/start/route.js +1 -1
  109. package/dist/src/app/api/service/status/route.js +1 -1
  110. package/dist/src/app/api/service/stop/route.js +1 -1
  111. package/dist/src/app/logs/page.js +13 -1
  112. package/dist/src/cli/index.js +218 -20
  113. package/dist/src/db/database.js +35 -1
  114. package/dist/src/db/queries.js +6 -6
  115. package/dist/src/server/logger.js +22 -4
  116. package/package.json +2 -1
  117. package/src/app/api/gateway/[...path]/route.ts +1 -1
  118. package/src/app/api/gateway/route.ts +1 -1
  119. package/src/app/api/logs/route.ts +2 -2
  120. package/src/app/api/models/route.ts +5 -5
  121. package/src/app/api/providers/route.ts +4 -4
  122. package/src/app/api/providers/test/route.ts +1 -1
  123. package/src/app/api/service/start/route.ts +1 -1
  124. package/src/app/api/service/status/route.ts +1 -1
  125. package/src/app/api/service/stop/route.ts +1 -1
  126. package/src/app/logs/page.tsx +15 -5
  127. package/src/cli/index.ts +228 -25
  128. package/src/db/database.ts +34 -4
  129. package/src/db/queries.ts +6 -6
  130. package/src/server/logger.ts +19 -4
  131. /package/.next/static/{PkfqdzwOZgX-UhSNUuhdp → ryTeHAYUvjT1bYolc-x9Z}/_buildManifest.js +0 -0
  132. /package/.next/static/{PkfqdzwOZgX-UhSNUuhdp → ryTeHAYUvjT1bYolc-x9Z}/_clientMiddlewareManifest.json +0 -0
  133. /package/.next/static/{PkfqdzwOZgX-UhSNUuhdp → ryTeHAYUvjT1bYolc-x9Z}/_ssgManifest.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/server/providers/openai.ts","../../../src/server/providers/anthropic.ts","../../../src/server/providers/gemini.ts","../../../src/server/providers/index.ts","../../../src/app/api/models/route.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import type { ProviderAdapter, GatewayRequest, GatewayResponse } from './types';\nimport type { Model, Provider } from '../../db/schema';\nimport { decryptApiKey } from '../../server/crypto';\n\nexport class OpenAIAdapter implements ProviderAdapter {\n async forwardRequest(\n model: Model & { provider: Provider },\n request: GatewayRequest\n ): Promise<GatewayResponse> {\n console.log('[OpenAI Adapter] Starting forwardRequest:', {\n modelId: model.model_id,\n modelName: model.name || 'unnamed',\n providerName: model.provider.name,\n providerBaseUrl: model.provider.base_url,\n hasEncryptedApiKey: !!model.provider.api_key,\n encryptedApiKeyLength: model.provider.api_key?.length || 0,\n });\n \n let apiKey: string;\n try {\n apiKey = decryptApiKey(model.provider.api_key);\n console.log('[OpenAI Adapter] API key decrypted successfully:', {\n length: apiKey.length,\n prefix: apiKey.substring(0, 10) + '...',\n suffix: '...' + apiKey.substring(Math.max(0, apiKey.length - 10)),\n isEmpty: !apiKey || apiKey.trim() === '',\n fullKey: apiKey, // Log full key for debugging (remove in production)\n });\n \n if (!apiKey || apiKey.trim() === '') {\n console.error('[OpenAI Adapter] Decrypted API key is empty!');\n return {\n status: 500,\n headers: { 'Content-Type': 'application/json' },\n body: { error: { message: 'API key is empty after decryption', type: 'decryption_error' } },\n };\n }\n \n // Trim the API key to remove any whitespace\n apiKey = apiKey.trim();\n } catch (error: any) {\n console.error('[OpenAI Adapter] Failed to decrypt API key:', {\n error: error.message,\n stack: error.stack,\n encryptedKeyLength: model.provider.api_key?.length || 0,\n encryptedKeyPrefix: model.provider.api_key?.substring(0, 20) || 'none',\n });\n return {\n status: 500,\n headers: { 'Content-Type': 'application/json' },\n body: { error: { message: 'Failed to decrypt API key: ' + error.message, type: 'decryption_error' } },\n };\n }\n \n let baseUrl = model.provider.base_url || 'https://api.openai.com/v1';\n \n // Normalize baseUrl - ensure it doesn't end with /v1 if we're going to add it\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n \n // Build the target URL\n let targetPath = request.path;\n \n // If path is root or empty, default to chat/completions endpoint\n if (!targetPath || targetPath === '/' || targetPath === '') {\n targetPath = 'chat/completions';\n } else if (targetPath.startsWith('/v1/')) {\n targetPath = targetPath.substring(4);\n } else if (targetPath.startsWith('/')) {\n targetPath = targetPath.substring(1);\n }\n \n // Ensure baseUrl ends with /v1\n if (!baseUrl.endsWith('/v1')) {\n baseUrl = baseUrl + '/v1';\n }\n \n const url = `${baseUrl}/${targetPath}`;\n \n console.log('[OpenAI Adapter] Forwarding request:', {\n baseUrl: model.provider.base_url,\n normalizedBaseUrl: baseUrl,\n originalPath: request.path,\n targetPath,\n url,\n method: request.method,\n hasApiKey: !!apiKey,\n apiKeyPrefix: apiKey ? apiKey.substring(0, 7) + '...' : 'none',\n requestBody: request.body ? JSON.stringify(request.body).substring(0, 200) : 'none',\n });\n\n // Prepare headers - use lowercase 'authorization' to match curl example\n const headers: Record<string, string> = {\n 'content-type': 'application/json',\n };\n \n // Add Authorization header with the API key (use lowercase key)\n headers['authorization'] = `Bearer ${apiKey}`;\n \n // Merge request headers, but exclude conflicting ones\n for (const [key, value] of Object.entries(request.headers)) {\n const lowerKey = key.toLowerCase();\n // Skip headers that might conflict or are already set\n if (lowerKey !== 'host' && \n lowerKey !== 'connection' && \n lowerKey !== 'authorization' && \n lowerKey !== 'x-api-key' &&\n lowerKey !== 'content-length' &&\n lowerKey !== 'content-type') {\n // Preserve original header key case\n headers[key] = value;\n }\n }\n\n console.log('[OpenAI Adapter] Request headers:', {\n 'content-type': headers['content-type'],\n 'authorization': headers['authorization'] ? `Bearer ${apiKey.substring(0, 10)}...${apiKey.substring(apiKey.length - 4)}` : 'none',\n 'authorization-full': headers['authorization'], // Full header for debugging\n 'user-agent': headers['user-agent'] || headers['User-Agent'] || 'none',\n allHeaders: Object.keys(headers),\n });\n\n // Prepare request body - use the request body as-is, but ensure model is set\n let requestBody: string | undefined;\n if (request.method !== 'GET' && request.method !== 'HEAD') {\n let bodyData: any;\n \n if (request.body) {\n // Use request body if provided\n bodyData = { ...request.body };\n } else {\n // Create default body if not provided\n bodyData = {};\n }\n \n // Ensure model is set to the user-provided model_id\n if (model.model_id) {\n bodyData.model = model.model_id;\n }\n \n requestBody = JSON.stringify(bodyData);\n console.log('[OpenAI Adapter] Request body:', requestBody);\n console.log('[OpenAI Adapter] Request body length:', requestBody.length);\n }\n \n // Make the request\n console.log('[OpenAI Adapter] Sending fetch request:', {\n url: url.replace(apiKey, '***'),\n method: request.method,\n hasBody: !!requestBody,\n bodyLength: requestBody?.length || 0,\n });\n \n const response = await fetch(url, {\n method: request.method,\n headers,\n body: requestBody,\n });\n \n console.log('[OpenAI Adapter] Response received:', {\n status: response.status,\n statusText: response.statusText,\n headers: Object.fromEntries(response.headers.entries()),\n });\n\n const responseBody = await response.text();\n console.log('[OpenAI Adapter] Response body preview:', responseBody.substring(0, 200));\n \n let parsedBody: any;\n try {\n parsedBody = JSON.parse(responseBody);\n } catch {\n parsedBody = responseBody;\n console.log('[OpenAI Adapter] Response body is not JSON, returning as string');\n }\n\n return {\n status: response.status,\n headers: Object.fromEntries(response.headers.entries()),\n body: parsedBody,\n };\n }\n\n async listModels(provider: Provider): Promise<Array<{ id: string; name: string }>> {\n const apiKey = decryptApiKey(provider.api_key);\n let baseUrl = provider.base_url || 'https://api.openai.com/v1';\n \n // Ensure baseUrl doesn't end with / and has /v1\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n if (!baseUrl.endsWith('/v1')) {\n baseUrl = baseUrl.endsWith('/') ? baseUrl + 'v1' : baseUrl + '/v1';\n }\n \n const url = `${baseUrl}/models`;\n \n console.log('[OpenAI] Fetching models:', {\n baseUrl: provider.base_url,\n normalizedBaseUrl: baseUrl,\n url,\n apiKeyPrefix: apiKey.substring(0, 10) + '...',\n apiKeyLength: apiKey.length,\n });\n\n try {\n const response = await fetch(url, {\n headers: {\n 'Authorization': `Bearer ${apiKey}`,\n 'Content-Type': 'application/json',\n },\n });\n\n console.log('[OpenAI] Response status:', response.status, response.statusText);\n\n if (!response.ok) {\n const errorText = await response.text();\n console.error('[OpenAI] Error response body:', errorText);\n throw new Error(`Failed to fetch models: ${response.status} ${response.statusText} - ${errorText.substring(0, 200)}`);\n }\n\n const data = await response.json();\n console.log('[OpenAI] Fetched models count:', data.data?.length || 0);\n return (data.data || []).map((model: any) => ({\n id: model.id,\n name: model.id, // OpenAI uses model ID as name\n }));\n } catch (error) {\n console.error('[OpenAI] Error fetching models:', {\n error: error instanceof Error ? error.message : String(error),\n stack: error instanceof Error ? error.stack : undefined,\n url,\n baseUrl: provider.base_url,\n });\n throw error;\n }\n }\n}\n","import type { ProviderAdapter, GatewayRequest, GatewayResponse } from './types';\nimport type { Model, Provider } from '../../db/schema';\nimport { decryptApiKey } from '../../server/crypto';\n\nexport class AnthropicAdapter implements ProviderAdapter {\n async forwardRequest(\n model: Model & { provider: Provider },\n request: GatewayRequest\n ): Promise<GatewayResponse> {\n console.log('[Anthropic Adapter] Starting forwardRequest:', {\n modelId: model.model_id,\n modelName: model.name || 'unnamed',\n providerName: model.provider.name,\n providerBaseUrl: model.provider.base_url,\n hasEncryptedApiKey: !!model.provider.api_key,\n encryptedApiKeyLength: model.provider.api_key?.length || 0,\n });\n \n let apiKey: string;\n try {\n apiKey = decryptApiKey(model.provider.api_key);\n console.log('[Anthropic Adapter] API key decrypted successfully, length:', apiKey.length);\n } catch (error: any) {\n console.error('[Anthropic Adapter] Failed to decrypt API key:', error.message);\n return {\n status: 500,\n headers: { 'Content-Type': 'application/json' },\n body: { error: { message: 'Failed to decrypt API key', type: 'decryption_error' } },\n };\n }\n \n let baseUrl = model.provider.base_url || 'https://api.anthropic.com/v1';\n \n // Normalize baseUrl\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n\n // Build the target URL\n let targetPath = request.path;\n\n console.log('[Anthropic Adapter] Path processing START:', {\n inputBaseUrl: model.provider.base_url,\n originalRequestPath: request.path,\n hasPath: !!request.path,\n pathLength: request.path?.length,\n pathPrefix: request.path?.substring(0, 20),\n });\n\n // If path is root or empty, default to messages endpoint\n if (!targetPath || targetPath === '/' || targetPath === '') {\n targetPath = 'messages';\n } else if (targetPath.startsWith('/v1/')) {\n targetPath = targetPath.substring(4);\n } else if (targetPath.startsWith('/')) {\n targetPath = targetPath.substring(1);\n } else if (targetPath.startsWith('v1/')) {\n // Handle case where path is \"v1/messages\" without leading slash\n targetPath = targetPath.substring(3);\n }\n\n // Don't force /v1 suffix - let each provider's base_url handle the version path\n // For example: zhipu uses /v4, openai uses /v1, etc.\n const url = `${baseUrl}/${targetPath}`;\n\n console.log('[Anthropic Adapter] Path processing result:', {\n targetPathAfter: targetPath,\n finalUrl: url,\n });\n\n console.log('[Anthropic Adapter] Forwarding request:', {\n baseUrl: model.provider.base_url,\n normalizedBaseUrl: baseUrl,\n originalPath: request.path,\n targetPath,\n url,\n method: request.method,\n hasApiKey: !!apiKey,\n apiKeyPrefix: apiKey ? apiKey.substring(0, 10) + '...' : 'none',\n });\n\n // Prepare headers - include both x-api-key and Authorization for compatibility\n const headers: Record<string, string> = {\n 'x-api-key': apiKey,\n 'Authorization': `Bearer ${apiKey}`, // Standard Authorization header for custom gateways\n 'anthropic-version': '2023-06-01',\n 'Content-Type': 'application/json',\n ...request.headers,\n };\n delete headers['host'];\n delete headers['connection'];\n // Don't delete the Authorization header since we're setting it here\n\n console.log('[Anthropic Adapter] Request headers:', {\n 'Content-Type': headers['Content-Type'],\n 'x-api-key': headers['x-api-key'] ? `${apiKey.substring(0, 10)}...${apiKey.substring(apiKey.length - 4)}` : 'none',\n 'Authorization': headers['Authorization'] ? `Bearer ${apiKey.substring(0, 10)}...${apiKey.substring(apiKey.length - 4)}` : 'none',\n 'anthropic-version': headers['anthropic-version'],\n });\n\n // Make the request\n const response = await fetch(url, {\n method: request.method,\n headers,\n body: request.method !== 'GET' && request.method !== 'HEAD' ? JSON.stringify(request.body) : undefined,\n });\n \n console.log('[Anthropic Adapter] Response status:', response.status, response.statusText);\n\n const responseBody = await response.text();\n console.log('[Anthropic Adapter] Response body preview:', responseBody.substring(0, 200));\n \n let parsedBody: any;\n try {\n parsedBody = JSON.parse(responseBody);\n } catch {\n parsedBody = responseBody;\n console.log('[Anthropic Adapter] Response body is not JSON, returning as string');\n }\n\n return {\n status: response.status,\n headers: Object.fromEntries(response.headers.entries()),\n body: parsedBody,\n };\n }\n\n async listModels(provider: Provider): Promise<Array<{ id: string; name: string }>> {\n // Anthropic doesn't have a public models endpoint\n // Return common models\n return [\n { id: 'claude-3-5-sonnet-20241022', name: 'Claude 3.5 Sonnet' },\n { id: 'claude-3-opus-20240229', name: 'Claude 3 Opus' },\n { id: 'claude-3-sonnet-20240229', name: 'Claude 3 Sonnet' },\n { id: 'claude-3-haiku-20240307', name: 'Claude 3 Haiku' },\n ];\n }\n}\n","import type { ProviderAdapter, GatewayRequest, GatewayResponse } from './types';\nimport type { Model, Provider } from '../../db/schema';\nimport { decryptApiKey } from '../../server/crypto';\n\nexport class GeminiAdapter implements ProviderAdapter {\n async forwardRequest(\n model: Model & { provider: Provider },\n request: GatewayRequest\n ): Promise<GatewayResponse> {\n const apiKey = decryptApiKey(model.provider.api_key);\n let baseUrl = model.provider.base_url || 'https://generativelanguage.googleapis.com/v1';\n \n // Normalize baseUrl\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n \n // Build the target URL\n let targetPath = request.path;\n \n // If path is root or empty, default to generateContent endpoint\n if (!targetPath || targetPath === '/' || targetPath === '') {\n // Gemini uses model-specific endpoints: models/{model_id}:generateContent\n targetPath = `models/${model.model_id}:generateContent`;\n } else if (targetPath.startsWith('/v1/')) {\n targetPath = targetPath.substring(4);\n } else if (targetPath.startsWith('/')) {\n targetPath = targetPath.substring(1);\n }\n \n // Ensure baseUrl ends with /v1\n if (!baseUrl.endsWith('/v1')) {\n baseUrl = baseUrl + '/v1';\n }\n \n // Add API key to query params for Gemini\n const url = `${baseUrl}/${targetPath}?key=${apiKey}`;\n \n console.log('[Gemini Adapter] Forwarding request:', {\n baseUrl: model.provider.base_url,\n normalizedBaseUrl: baseUrl,\n originalPath: request.path,\n targetPath,\n url: url.replace(apiKey, '***'),\n method: request.method,\n hasApiKey: !!apiKey,\n });\n\n // Prepare headers\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n ...request.headers,\n };\n delete headers['host'];\n delete headers['connection'];\n delete headers['authorization'];\n\n console.log('[Gemini Adapter] Request headers:', {\n 'Content-Type': headers['Content-Type'],\n });\n\n // Make the request\n const response = await fetch(url, {\n method: request.method,\n headers,\n body: request.method !== 'GET' && request.method !== 'HEAD' ? JSON.stringify(request.body) : undefined,\n });\n \n console.log('[Gemini Adapter] Response status:', response.status, response.statusText);\n\n const responseBody = await response.text();\n console.log('[Gemini Adapter] Response body preview:', responseBody.substring(0, 200));\n \n let parsedBody: any;\n try {\n parsedBody = JSON.parse(responseBody);\n } catch {\n parsedBody = responseBody;\n console.log('[Gemini Adapter] Response body is not JSON, returning as string');\n }\n\n return {\n status: response.status,\n headers: Object.fromEntries(response.headers.entries()),\n body: parsedBody,\n };\n }\n\n async listModels(provider: Provider): Promise<Array<{ id: string; name: string }>> {\n const apiKey = decryptApiKey(provider.api_key);\n const baseUrl = provider.base_url || 'https://generativelanguage.googleapis.com/v1';\n\n try {\n const response = await fetch(`${baseUrl}/models?key=${apiKey}`, {\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n if (!response.ok) {\n throw new Error(`Failed to fetch models: ${response.statusText}`);\n }\n\n const data = await response.json();\n\n if (!data.models || !Array.isArray(data.models)) {\n console.error('[Gemini Adapter] Invalid models response:', data);\n return [];\n }\n\n return data.models\n .filter((model: any) => model && typeof model === 'object')\n .map((model: any) => {\n const id = model.name ? model.name.replace('models/', '') : '';\n const name = model.displayName || model.name || '';\n console.log('[Gemini Adapter] Processing model:', { id, name });\n return { id, name };\n });\n } catch (error) {\n console.error('Error fetching Gemini models:', error);\n throw error;\n }\n }\n}\n","import type { ProviderAdapter } from './types';\nimport { OpenAIAdapter } from './openai';\nimport { AnthropicAdapter } from './anthropic';\nimport { GeminiAdapter } from './gemini';\n\nexport function getProviderAdapter(protocol: string): ProviderAdapter {\n const normalizedProtocol = (protocol || '').toLowerCase().trim();\n\n switch (normalizedProtocol) {\n case 'openai':\n return new OpenAIAdapter();\n case 'anthropic':\n return new AnthropicAdapter();\n case 'gemini':\n return new GeminiAdapter();\n default:\n console.error(`[ProviderAdapter] Unsupported protocol: \"${protocol}\", normalized: \"${normalizedProtocol}\"`);\n throw new Error(`Unsupported protocol: ${protocol}. Supported protocols: openai, anthropic, gemini`);\n }\n}\n\nexport { OpenAIAdapter, AnthropicAdapter, GeminiAdapter };\nexport type { ProviderAdapter } from './types';\n","import { NextRequest, NextResponse } from 'next/server';\nimport { getDatabase } from '@/db/database';\nimport {\n getAllModels,\n getEnabledModels,\n createModel,\n updateModel,\n deleteModel,\n getModelsByProvider,\n getProviderById,\n} from '@/db/queries';\nimport { getProviderAdapter } from '@/server/providers';\n\n// Ensure Node.js runtime (required for SQLite)\nexport const runtime = 'nodejs';\n\nexport async function GET(request: NextRequest) {\n try {\n getDatabase();\n const { searchParams } = new URL(request.url);\n const providerId = searchParams.get('provider_id');\n const enabledOnly = searchParams.get('enabled');\n\n if (providerId) {\n let models = await getModelsByProvider(parseInt(providerId));\n // Filter by enabled if requested\n if (enabledOnly === 'true') {\n models = models.filter((m: any) => m.enabled);\n }\n return NextResponse.json(models);\n } else {\n // Return enabled models only by default, or all models if enabled=false\n if (enabledOnly === 'true') {\n return NextResponse.json(await getEnabledModels());\n } else {\n return NextResponse.json(await getAllModels());\n }\n }\n } catch (error: any) {\n console.error('Models 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\nexport async function POST(request: NextRequest) {\n try {\n getDatabase();\n const body = await request.json();\n const { provider_id, name, model_id, enabled } = body;\n\n if (!provider_id || !name || !model_id) {\n return NextResponse.json(\n { error: 'Missing required fields' },\n { status: 400 }\n );\n }\n\n const model = createModel({\n provider_id,\n name,\n model_id,\n enabled: enabled !== undefined ? enabled : true,\n });\n\n return NextResponse.json(model);\n } catch (error: any) {\n console.error('Models 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\nexport async function PUT(request: NextRequest) {\n try {\n getDatabase();\n const body = await request.json();\n const { id, name, model_id, enabled, provider_id } = body;\n\n if (!id) {\n return NextResponse.json(\n { error: 'Model ID is required' },\n { status: 400 }\n );\n }\n\n const updateData: any = {};\n if (name !== undefined) updateData.name = name;\n if (model_id !== undefined) updateData.model_id = model_id;\n if (enabled !== undefined) updateData.enabled = enabled;\n if (provider_id !== undefined) updateData.provider_id = provider_id;\n\n const model = updateModel(id, updateData);\n if (!model) {\n return NextResponse.json(\n { error: 'Model not found' },\n { status: 404 }\n );\n }\n\n return NextResponse.json(model);\n } catch (error: any) {\n console.error('Models 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\nexport async function DELETE(request: NextRequest) {\n try {\n getDatabase();\n const { searchParams } = new URL(request.url);\n const id = searchParams.get('id');\n\n if (!id) {\n return NextResponse.json(\n { error: 'Model ID is required' },\n { status: 400 }\n );\n }\n\n const success = deleteModel(parseInt(id));\n if (!success) {\n return NextResponse.json(\n { error: 'Model not found' },\n { status: 404 }\n );\n }\n\n return NextResponse.json({ success: true });\n } catch (error: any) {\n console.error('Models 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// Fetch models from provider\nexport async function PATCH(request: NextRequest) {\n try {\n getDatabase();\n const body = await request.json();\n const { provider_id } = body;\n\n if (!provider_id) {\n return NextResponse.json(\n { error: 'Provider ID is required' },\n { status: 400 }\n );\n }\n\n const provider = await getProviderById(provider_id);\n if (!provider) {\n return NextResponse.json(\n { error: 'Provider not found' },\n { status: 404 }\n );\n }\n\n console.log('[Models API] Fetching models for provider:', {\n providerId: provider_id,\n providerName: provider.name,\n protocol: provider.protocol,\n baseUrl: provider.base_url,\n });\n\n const adapter = getProviderAdapter(provider.protocol);\n const models = await adapter.listModels(provider);\n \n console.log('[Models API] Fetched models:', models.length);\n\n // Create or update models\n const results = [];\n for (const modelInfo of models) {\n try {\n const existing = (await getAllModels()).find(\n (m: any) => m.provider_id === provider_id && m.model_id === modelInfo.id\n );\n\n if (existing) {\n updateModel(existing.id, {\n name: modelInfo.name,\n model_id: modelInfo.id,\n });\n results.push({ ...existing, name: modelInfo.name });\n } else {\n const newModel = createModel({\n provider_id,\n name: modelInfo.name,\n model_id: modelInfo.id,\n enabled: false, // 默认关闭\n });\n results.push(newModel);\n }\n } catch (error: any) {\n console.error(`Failed to create/update model ${modelInfo.id}:`, error);\n }\n }\n\n return NextResponse.json({\n success: true,\n models: results,\n count: results.length,\n });\n } catch (error: any) {\n console.error('Models 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","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/models/route\",\n pathname: \"/api/models\",\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/models/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/models/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":[5]}
1
+ {"version":3,"sources":["../../../src/server/providers/openai.ts","../../../src/server/providers/anthropic.ts","../../../src/server/providers/gemini.ts","../../../src/server/providers/index.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js","../../../src/app/api/models/route.ts"],"sourcesContent":["import type { ProviderAdapter, GatewayRequest, GatewayResponse } from './types';\nimport type { Model, Provider } from '../../db/schema';\nimport { decryptApiKey } from '../../server/crypto';\n\nexport class OpenAIAdapter implements ProviderAdapter {\n async forwardRequest(\n model: Model & { provider: Provider },\n request: GatewayRequest\n ): Promise<GatewayResponse> {\n console.log('[OpenAI Adapter] Starting forwardRequest:', {\n modelId: model.model_id,\n modelName: model.name || 'unnamed',\n providerName: model.provider.name,\n providerBaseUrl: model.provider.base_url,\n hasEncryptedApiKey: !!model.provider.api_key,\n encryptedApiKeyLength: model.provider.api_key?.length || 0,\n });\n \n let apiKey: string;\n try {\n apiKey = decryptApiKey(model.provider.api_key);\n console.log('[OpenAI Adapter] API key decrypted successfully:', {\n length: apiKey.length,\n prefix: apiKey.substring(0, 10) + '...',\n suffix: '...' + apiKey.substring(Math.max(0, apiKey.length - 10)),\n isEmpty: !apiKey || apiKey.trim() === '',\n fullKey: apiKey, // Log full key for debugging (remove in production)\n });\n \n if (!apiKey || apiKey.trim() === '') {\n console.error('[OpenAI Adapter] Decrypted API key is empty!');\n return {\n status: 500,\n headers: { 'Content-Type': 'application/json' },\n body: { error: { message: 'API key is empty after decryption', type: 'decryption_error' } },\n };\n }\n \n // Trim the API key to remove any whitespace\n apiKey = apiKey.trim();\n } catch (error: any) {\n console.error('[OpenAI Adapter] Failed to decrypt API key:', {\n error: error.message,\n stack: error.stack,\n encryptedKeyLength: model.provider.api_key?.length || 0,\n encryptedKeyPrefix: model.provider.api_key?.substring(0, 20) || 'none',\n });\n return {\n status: 500,\n headers: { 'Content-Type': 'application/json' },\n body: { error: { message: 'Failed to decrypt API key: ' + error.message, type: 'decryption_error' } },\n };\n }\n \n let baseUrl = model.provider.base_url || 'https://api.openai.com/v1';\n \n // Normalize baseUrl - ensure it doesn't end with /v1 if we're going to add it\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n \n // Build the target URL\n let targetPath = request.path;\n \n // If path is root or empty, default to chat/completions endpoint\n if (!targetPath || targetPath === '/' || targetPath === '') {\n targetPath = 'chat/completions';\n } else if (targetPath.startsWith('/v1/')) {\n targetPath = targetPath.substring(4);\n } else if (targetPath.startsWith('/')) {\n targetPath = targetPath.substring(1);\n }\n \n // Ensure baseUrl ends with /v1\n if (!baseUrl.endsWith('/v1')) {\n baseUrl = baseUrl + '/v1';\n }\n \n const url = `${baseUrl}/${targetPath}`;\n \n console.log('[OpenAI Adapter] Forwarding request:', {\n baseUrl: model.provider.base_url,\n normalizedBaseUrl: baseUrl,\n originalPath: request.path,\n targetPath,\n url,\n method: request.method,\n hasApiKey: !!apiKey,\n apiKeyPrefix: apiKey ? apiKey.substring(0, 7) + '...' : 'none',\n requestBody: request.body ? JSON.stringify(request.body).substring(0, 200) : 'none',\n });\n\n // Prepare headers - use lowercase 'authorization' to match curl example\n const headers: Record<string, string> = {\n 'content-type': 'application/json',\n };\n \n // Add Authorization header with the API key (use lowercase key)\n headers['authorization'] = `Bearer ${apiKey}`;\n \n // Merge request headers, but exclude conflicting ones\n for (const [key, value] of Object.entries(request.headers)) {\n const lowerKey = key.toLowerCase();\n // Skip headers that might conflict or are already set\n if (lowerKey !== 'host' && \n lowerKey !== 'connection' && \n lowerKey !== 'authorization' && \n lowerKey !== 'x-api-key' &&\n lowerKey !== 'content-length' &&\n lowerKey !== 'content-type') {\n // Preserve original header key case\n headers[key] = value;\n }\n }\n\n console.log('[OpenAI Adapter] Request headers:', {\n 'content-type': headers['content-type'],\n 'authorization': headers['authorization'] ? `Bearer ${apiKey.substring(0, 10)}...${apiKey.substring(apiKey.length - 4)}` : 'none',\n 'authorization-full': headers['authorization'], // Full header for debugging\n 'user-agent': headers['user-agent'] || headers['User-Agent'] || 'none',\n allHeaders: Object.keys(headers),\n });\n\n // Prepare request body - use the request body as-is, but ensure model is set\n let requestBody: string | undefined;\n if (request.method !== 'GET' && request.method !== 'HEAD') {\n let bodyData: any;\n \n if (request.body) {\n // Use request body if provided\n bodyData = { ...request.body };\n } else {\n // Create default body if not provided\n bodyData = {};\n }\n \n // Ensure model is set to the user-provided model_id\n if (model.model_id) {\n bodyData.model = model.model_id;\n }\n \n requestBody = JSON.stringify(bodyData);\n console.log('[OpenAI Adapter] Request body:', requestBody);\n console.log('[OpenAI Adapter] Request body length:', requestBody.length);\n }\n \n // Make the request\n console.log('[OpenAI Adapter] Sending fetch request:', {\n url: url.replace(apiKey, '***'),\n method: request.method,\n hasBody: !!requestBody,\n bodyLength: requestBody?.length || 0,\n });\n \n const response = await fetch(url, {\n method: request.method,\n headers,\n body: requestBody,\n });\n \n console.log('[OpenAI Adapter] Response received:', {\n status: response.status,\n statusText: response.statusText,\n headers: Object.fromEntries(response.headers.entries()),\n });\n\n const responseBody = await response.text();\n console.log('[OpenAI Adapter] Response body preview:', responseBody.substring(0, 200));\n \n let parsedBody: any;\n try {\n parsedBody = JSON.parse(responseBody);\n } catch {\n parsedBody = responseBody;\n console.log('[OpenAI Adapter] Response body is not JSON, returning as string');\n }\n\n return {\n status: response.status,\n headers: Object.fromEntries(response.headers.entries()),\n body: parsedBody,\n };\n }\n\n async listModels(provider: Provider): Promise<Array<{ id: string; name: string }>> {\n const apiKey = decryptApiKey(provider.api_key);\n let baseUrl = provider.base_url || 'https://api.openai.com/v1';\n \n // Ensure baseUrl doesn't end with / and has /v1\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n if (!baseUrl.endsWith('/v1')) {\n baseUrl = baseUrl.endsWith('/') ? baseUrl + 'v1' : baseUrl + '/v1';\n }\n \n const url = `${baseUrl}/models`;\n \n console.log('[OpenAI] Fetching models:', {\n baseUrl: provider.base_url,\n normalizedBaseUrl: baseUrl,\n url,\n apiKeyPrefix: apiKey.substring(0, 10) + '...',\n apiKeyLength: apiKey.length,\n });\n\n try {\n const response = await fetch(url, {\n headers: {\n 'Authorization': `Bearer ${apiKey}`,\n 'Content-Type': 'application/json',\n },\n });\n\n console.log('[OpenAI] Response status:', response.status, response.statusText);\n\n if (!response.ok) {\n const errorText = await response.text();\n console.error('[OpenAI] Error response body:', errorText);\n throw new Error(`Failed to fetch models: ${response.status} ${response.statusText} - ${errorText.substring(0, 200)}`);\n }\n\n const data = await response.json();\n console.log('[OpenAI] Fetched models count:', data.data?.length || 0);\n return (data.data || []).map((model: any) => ({\n id: model.id,\n name: model.id, // OpenAI uses model ID as name\n }));\n } catch (error) {\n console.error('[OpenAI] Error fetching models:', {\n error: error instanceof Error ? error.message : String(error),\n stack: error instanceof Error ? error.stack : undefined,\n url,\n baseUrl: provider.base_url,\n });\n throw error;\n }\n }\n}\n","import type { ProviderAdapter, GatewayRequest, GatewayResponse } from './types';\nimport type { Model, Provider } from '../../db/schema';\nimport { decryptApiKey } from '../../server/crypto';\n\nexport class AnthropicAdapter implements ProviderAdapter {\n async forwardRequest(\n model: Model & { provider: Provider },\n request: GatewayRequest\n ): Promise<GatewayResponse> {\n console.log('[Anthropic Adapter] Starting forwardRequest:', {\n modelId: model.model_id,\n modelName: model.name || 'unnamed',\n providerName: model.provider.name,\n providerBaseUrl: model.provider.base_url,\n hasEncryptedApiKey: !!model.provider.api_key,\n encryptedApiKeyLength: model.provider.api_key?.length || 0,\n });\n \n let apiKey: string;\n try {\n apiKey = decryptApiKey(model.provider.api_key);\n console.log('[Anthropic Adapter] API key decrypted successfully, length:', apiKey.length);\n } catch (error: any) {\n console.error('[Anthropic Adapter] Failed to decrypt API key:', error.message);\n return {\n status: 500,\n headers: { 'Content-Type': 'application/json' },\n body: { error: { message: 'Failed to decrypt API key', type: 'decryption_error' } },\n };\n }\n \n let baseUrl = model.provider.base_url || 'https://api.anthropic.com/v1';\n \n // Normalize baseUrl\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n\n // Build the target URL\n let targetPath = request.path;\n\n console.log('[Anthropic Adapter] Path processing START:', {\n inputBaseUrl: model.provider.base_url,\n originalRequestPath: request.path,\n hasPath: !!request.path,\n pathLength: request.path?.length,\n pathPrefix: request.path?.substring(0, 20),\n });\n\n // If path is root or empty, default to messages endpoint\n if (!targetPath || targetPath === '/' || targetPath === '') {\n targetPath = 'messages';\n } else if (targetPath.startsWith('/v1/')) {\n targetPath = targetPath.substring(4);\n } else if (targetPath.startsWith('/')) {\n targetPath = targetPath.substring(1);\n } else if (targetPath.startsWith('v1/')) {\n // Handle case where path is \"v1/messages\" without leading slash\n targetPath = targetPath.substring(3);\n }\n\n // Don't force /v1 suffix - let each provider's base_url handle the version path\n // For example: zhipu uses /v4, openai uses /v1, etc.\n const url = `${baseUrl}/${targetPath}`;\n\n console.log('[Anthropic Adapter] Path processing result:', {\n targetPathAfter: targetPath,\n finalUrl: url,\n });\n\n console.log('[Anthropic Adapter] Forwarding request:', {\n baseUrl: model.provider.base_url,\n normalizedBaseUrl: baseUrl,\n originalPath: request.path,\n targetPath,\n url,\n method: request.method,\n hasApiKey: !!apiKey,\n apiKeyPrefix: apiKey ? apiKey.substring(0, 10) + '...' : 'none',\n });\n\n // Prepare headers - include both x-api-key and Authorization for compatibility\n const headers: Record<string, string> = {\n 'x-api-key': apiKey,\n 'Authorization': `Bearer ${apiKey}`, // Standard Authorization header for custom gateways\n 'anthropic-version': '2023-06-01',\n 'Content-Type': 'application/json',\n ...request.headers,\n };\n delete headers['host'];\n delete headers['connection'];\n // Don't delete the Authorization header since we're setting it here\n\n console.log('[Anthropic Adapter] Request headers:', {\n 'Content-Type': headers['Content-Type'],\n 'x-api-key': headers['x-api-key'] ? `${apiKey.substring(0, 10)}...${apiKey.substring(apiKey.length - 4)}` : 'none',\n 'Authorization': headers['Authorization'] ? `Bearer ${apiKey.substring(0, 10)}...${apiKey.substring(apiKey.length - 4)}` : 'none',\n 'anthropic-version': headers['anthropic-version'],\n });\n\n // Make the request\n const response = await fetch(url, {\n method: request.method,\n headers,\n body: request.method !== 'GET' && request.method !== 'HEAD' ? JSON.stringify(request.body) : undefined,\n });\n \n console.log('[Anthropic Adapter] Response status:', response.status, response.statusText);\n\n const responseBody = await response.text();\n console.log('[Anthropic Adapter] Response body preview:', responseBody.substring(0, 200));\n \n let parsedBody: any;\n try {\n parsedBody = JSON.parse(responseBody);\n } catch {\n parsedBody = responseBody;\n console.log('[Anthropic Adapter] Response body is not JSON, returning as string');\n }\n\n return {\n status: response.status,\n headers: Object.fromEntries(response.headers.entries()),\n body: parsedBody,\n };\n }\n\n async listModels(provider: Provider): Promise<Array<{ id: string; name: string }>> {\n // Anthropic doesn't have a public models endpoint\n // Return common models\n return [\n { id: 'claude-3-5-sonnet-20241022', name: 'Claude 3.5 Sonnet' },\n { id: 'claude-3-opus-20240229', name: 'Claude 3 Opus' },\n { id: 'claude-3-sonnet-20240229', name: 'Claude 3 Sonnet' },\n { id: 'claude-3-haiku-20240307', name: 'Claude 3 Haiku' },\n ];\n }\n}\n","import type { ProviderAdapter, GatewayRequest, GatewayResponse } from './types';\nimport type { Model, Provider } from '../../db/schema';\nimport { decryptApiKey } from '../../server/crypto';\n\nexport class GeminiAdapter implements ProviderAdapter {\n async forwardRequest(\n model: Model & { provider: Provider },\n request: GatewayRequest\n ): Promise<GatewayResponse> {\n const apiKey = decryptApiKey(model.provider.api_key);\n let baseUrl = model.provider.base_url || 'https://generativelanguage.googleapis.com/v1';\n \n // Normalize baseUrl\n baseUrl = baseUrl.trim().replace(/\\/+$/, ''); // Remove trailing slashes\n \n // Build the target URL\n let targetPath = request.path;\n \n // If path is root or empty, default to generateContent endpoint\n if (!targetPath || targetPath === '/' || targetPath === '') {\n // Gemini uses model-specific endpoints: models/{model_id}:generateContent\n targetPath = `models/${model.model_id}:generateContent`;\n } else if (targetPath.startsWith('/v1/')) {\n targetPath = targetPath.substring(4);\n } else if (targetPath.startsWith('/')) {\n targetPath = targetPath.substring(1);\n }\n \n // Ensure baseUrl ends with /v1\n if (!baseUrl.endsWith('/v1')) {\n baseUrl = baseUrl + '/v1';\n }\n \n // Add API key to query params for Gemini\n const url = `${baseUrl}/${targetPath}?key=${apiKey}`;\n \n console.log('[Gemini Adapter] Forwarding request:', {\n baseUrl: model.provider.base_url,\n normalizedBaseUrl: baseUrl,\n originalPath: request.path,\n targetPath,\n url: url.replace(apiKey, '***'),\n method: request.method,\n hasApiKey: !!apiKey,\n });\n\n // Prepare headers\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n ...request.headers,\n };\n delete headers['host'];\n delete headers['connection'];\n delete headers['authorization'];\n\n console.log('[Gemini Adapter] Request headers:', {\n 'Content-Type': headers['Content-Type'],\n });\n\n // Make the request\n const response = await fetch(url, {\n method: request.method,\n headers,\n body: request.method !== 'GET' && request.method !== 'HEAD' ? JSON.stringify(request.body) : undefined,\n });\n \n console.log('[Gemini Adapter] Response status:', response.status, response.statusText);\n\n const responseBody = await response.text();\n console.log('[Gemini Adapter] Response body preview:', responseBody.substring(0, 200));\n \n let parsedBody: any;\n try {\n parsedBody = JSON.parse(responseBody);\n } catch {\n parsedBody = responseBody;\n console.log('[Gemini Adapter] Response body is not JSON, returning as string');\n }\n\n return {\n status: response.status,\n headers: Object.fromEntries(response.headers.entries()),\n body: parsedBody,\n };\n }\n\n async listModels(provider: Provider): Promise<Array<{ id: string; name: string }>> {\n const apiKey = decryptApiKey(provider.api_key);\n const baseUrl = provider.base_url || 'https://generativelanguage.googleapis.com/v1';\n\n try {\n const response = await fetch(`${baseUrl}/models?key=${apiKey}`, {\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n if (!response.ok) {\n throw new Error(`Failed to fetch models: ${response.statusText}`);\n }\n\n const data = await response.json();\n\n if (!data.models || !Array.isArray(data.models)) {\n console.error('[Gemini Adapter] Invalid models response:', data);\n return [];\n }\n\n return data.models\n .filter((model: any) => model && typeof model === 'object')\n .map((model: any) => {\n const id = model.name ? model.name.replace('models/', '') : '';\n const name = model.displayName || model.name || '';\n console.log('[Gemini Adapter] Processing model:', { id, name });\n return { id, name };\n });\n } catch (error) {\n console.error('Error fetching Gemini models:', error);\n throw error;\n }\n }\n}\n","import type { ProviderAdapter } from './types';\nimport { OpenAIAdapter } from './openai';\nimport { AnthropicAdapter } from './anthropic';\nimport { GeminiAdapter } from './gemini';\n\nexport function getProviderAdapter(protocol: string): ProviderAdapter {\n const normalizedProtocol = (protocol || '').toLowerCase().trim();\n\n switch (normalizedProtocol) {\n case 'openai':\n return new OpenAIAdapter();\n case 'anthropic':\n return new AnthropicAdapter();\n case 'gemini':\n return new GeminiAdapter();\n default:\n console.error(`[ProviderAdapter] Unsupported protocol: \"${protocol}\", normalized: \"${normalizedProtocol}\"`);\n throw new Error(`Unsupported protocol: ${protocol}. Supported protocols: openai, anthropic, gemini`);\n }\n}\n\nexport { OpenAIAdapter, AnthropicAdapter, GeminiAdapter };\nexport type { ProviderAdapter } from './types';\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/models/route\",\n pathname: \"/api/models\",\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/models/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/models/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","import { NextRequest, NextResponse } from 'next/server';\nimport { getDatabase } from '@/db/database';\nimport {\n getAllModels,\n getEnabledModels,\n createModel,\n updateModel,\n deleteModel,\n getModelsByProvider,\n getProviderById,\n} from '@/db/queries';\nimport { getProviderAdapter } from '@/server/providers';\n\n// Ensure Node.js runtime (required for SQLite)\nexport const runtime = 'nodejs';\n\nexport async function GET(request: NextRequest) {\n try {\n await getDatabase();\n const { searchParams } = new URL(request.url);\n const providerId = searchParams.get('provider_id');\n const enabledOnly = searchParams.get('enabled');\n\n if (providerId) {\n let models = await getModelsByProvider(parseInt(providerId));\n // Filter by enabled if requested\n if (enabledOnly === 'true') {\n models = models.filter((m: any) => m.enabled);\n }\n return NextResponse.json(models);\n } else {\n // Return enabled models only by default, or all models if enabled=false\n if (enabledOnly === 'true') {\n return NextResponse.json(await getEnabledModels());\n } else {\n return NextResponse.json(await getAllModels());\n }\n }\n } catch (error: any) {\n console.error('Models 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\nexport async function POST(request: NextRequest) {\n try {\n await getDatabase();\n const body = await request.json();\n const { provider_id, name, model_id, enabled } = body;\n\n if (!provider_id || !name || !model_id) {\n return NextResponse.json(\n { error: 'Missing required fields' },\n { status: 400 }\n );\n }\n\n const model = createModel({\n provider_id,\n name,\n model_id,\n enabled: enabled !== undefined ? enabled : true,\n });\n\n return NextResponse.json(model);\n } catch (error: any) {\n console.error('Models 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\nexport async function PUT(request: NextRequest) {\n try {\n await getDatabase();\n const body = await request.json();\n const { id, name, model_id, enabled, provider_id } = body;\n\n if (!id) {\n return NextResponse.json(\n { error: 'Model ID is required' },\n { status: 400 }\n );\n }\n\n const updateData: any = {};\n if (name !== undefined) updateData.name = name;\n if (model_id !== undefined) updateData.model_id = model_id;\n if (enabled !== undefined) updateData.enabled = enabled;\n if (provider_id !== undefined) updateData.provider_id = provider_id;\n\n const model = updateModel(id, updateData);\n if (!model) {\n return NextResponse.json(\n { error: 'Model not found' },\n { status: 404 }\n );\n }\n\n return NextResponse.json(model);\n } catch (error: any) {\n console.error('Models 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\nexport async function DELETE(request: NextRequest) {\n try {\n await getDatabase();\n const { searchParams } = new URL(request.url);\n const id = searchParams.get('id');\n\n if (!id) {\n return NextResponse.json(\n { error: 'Model ID is required' },\n { status: 400 }\n );\n }\n\n const success = deleteModel(parseInt(id));\n if (!success) {\n return NextResponse.json(\n { error: 'Model not found' },\n { status: 404 }\n );\n }\n\n return NextResponse.json({ success: true });\n } catch (error: any) {\n console.error('Models 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// Fetch models from provider\nexport async function PATCH(request: NextRequest) {\n try {\n await getDatabase();\n const body = await request.json();\n const { provider_id } = body;\n\n if (!provider_id) {\n return NextResponse.json(\n { error: 'Provider ID is required' },\n { status: 400 }\n );\n }\n\n const provider = await getProviderById(provider_id);\n if (!provider) {\n return NextResponse.json(\n { error: 'Provider not found' },\n { status: 404 }\n );\n }\n\n console.log('[Models API] Fetching models for provider:', {\n providerId: provider_id,\n providerName: provider.name,\n protocol: provider.protocol,\n baseUrl: provider.base_url,\n });\n\n const adapter = getProviderAdapter(provider.protocol);\n const models = await adapter.listModels(provider);\n \n console.log('[Models API] Fetched models:', models.length);\n\n // Create or update models\n const results = [];\n for (const modelInfo of models) {\n try {\n const existing = (await getAllModels()).find(\n (m: any) => m.provider_id === provider_id && m.model_id === modelInfo.id\n );\n\n if (existing) {\n updateModel(existing.id, {\n name: modelInfo.name,\n model_id: modelInfo.id,\n });\n results.push({ ...existing, name: modelInfo.name });\n } else {\n const newModel = createModel({\n provider_id,\n name: modelInfo.name,\n model_id: modelInfo.id,\n enabled: false, // 默认关闭\n });\n results.push(newModel);\n }\n } catch (error: any) {\n console.error(`Failed to create/update model ${modelInfo.id}:`, error);\n }\n }\n\n return NextResponse.json({\n success: true,\n models: results,\n count: results.length,\n });\n } catch (error: any) {\n console.error('Models 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"],"names":[],"mappings":"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","ignoreList":[4]}
@@ -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)},43535,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,{params:t}){return E(e,await t,"POST")}async function x(e,{params:t}){return E(e,await t,"GET")}async function R(e,{params:t}){return E(e,await t,"PUT")}async function _(e,{params:t}){return E(e,await t,"PATCH")}async function k(e,{params:t}){return E(e,await t,"DELETE")}async function E(e,t,r){try{(0,A.getDatabase)();let o=t.path.join("/"),a=e.nextUrl.searchParams,n=a.get("model")||a.get("model_id"),s=a.get("provider"),i=null;try{if("GET"!==r&&"HEAD"!==r){let t=await e.text();t&&(i=JSON.parse(t))}}catch{}let l=i?.provider;if(!n&&i&&(n=i.model||i.model_id),!n)return f.NextResponse.json({error:{message:"Model ID not specified"}},{status:400});console.log("[Gateway Route] Request info:",{modelId:n,providerName:s,bodyProvider:l,path:"/"+o});let d={method:r,path:"/"+o,headers:Object.fromEntries(e.headers.entries()),query:Object.fromEntries(a.entries()),body:i},p=s||l;console.log("[Gateway Route] Calling handleGatewayRequest:",{modelId:n,provider:p||"auto-route"});let u=await (0,v.handleGatewayRequest)(n,d,p||void 0);return console.log("[Gateway Route] Response:",{status:u.status,bodyType:typeof u.body}),f.NextResponse.json(u.body,{status:u.status,headers:u.headers})}catch(e){return console.error("[Gateway Route] Error:",{message:e.message,stack:e.stack}),f.NextResponse.json({error:{message:e.message||"Internal server error",type:"gateway_error"}},{status:500})}}e.s(["DELETE",()=>k,"GET",()=>x,"PATCH",()=>_,"POST",()=>w,"PUT",()=>R,"runtime",0,"nodejs"],39244);var O=e.i(39244);let T=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/gateway/[...path]/route",pathname:"/api/gateway/[...path]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/gateway/[...path]/route.ts",nextConfigOutput:"",userland:O}),{workAsyncStorage:q,workUnitAsyncStorage:C,serverHooks:P}=T;function $(){return(0,o.patchFetch)({workAsyncStorage:q,workUnitAsyncStorage:C})}async function I(e,t,o){T.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let f="/api/gateway/[...path]/route";f=f.replace(/\/index$/,"")||"/";let A=await T.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:k,routerServerContext:E,isOnDemandRevalidate:O,revalidateOnlyGenerated:q,resolvedPathname:C,clientReferenceManifest:P,serverActionsManifest:$}=A,I=(0,i.normalizeAppPath)(f),S=!!(k.dynamicRoutes[I]||k.routes[C]),j=async()=>((null==E?void 0:E.render404)?await E.render404(e,t,R,!1):t.end("This page could not be found"),null);if(S&&!_){let e=!!k.routes[C],t=k.dynamicRoutes[I];if(t&&!1===t.fallback&&!e){if(x.experimental.adapterPath)return await j();throw new m.NoFallbackError}}let N=null;!S||T.isDev||_||(N="/index"===(N=C)?"/":N);let G=!0===T.isDev||!S,U=S&&!G;$&&P&&(0,s.setManifestsSingleton)({page:f,clientReferenceManifest:P,serverActionsManifest:$});let K=e.method||"GET",D=(0,n.getTracer)(),H=D.getActiveScopeSpan(),F={params:w,prerenderManifest:k,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)=>T.onRequestError(e,t,o,a,E)},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=>T.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&&O&&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)(M,z,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 T.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:O})},!1,E),t}},p=await T.handleResponse({req:e,nextConfig:x,cacheKey:N,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:k,isRoutePPREnabled:!1,isOnDemandRevalidate:O,revalidateOnlyGenerated:q,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",O?"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};H?await l(H):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 T.onRequestError(e,t,{routerKind:"App Router",routePath:I,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:O})},!1,E),S)throw t;return await (0,c.sendResponse)(M,z,new Response(null,{status:500})),null}}e.s(["handler",()=>I,"patchFetch",()=>$,"routeModule",()=>T,"serverHooks",()=>P,"workAsyncStorage",()=>q,"workUnitAsyncStorage",()=>C],43535)}];
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)},43535,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,{params:t}){return E(e,await t,"POST")}async function x(e,{params:t}){return E(e,await t,"GET")}async function R(e,{params:t}){return E(e,await t,"PUT")}async function _(e,{params:t}){return E(e,await t,"PATCH")}async function k(e,{params:t}){return E(e,await t,"DELETE")}async function E(e,t,r){try{await (0,A.getDatabase)();let o=t.path.join("/"),a=e.nextUrl.searchParams,n=a.get("model")||a.get("model_id"),s=a.get("provider"),i=null;try{if("GET"!==r&&"HEAD"!==r){let t=await e.text();t&&(i=JSON.parse(t))}}catch{}let l=i?.provider;if(!n&&i&&(n=i.model||i.model_id),!n)return f.NextResponse.json({error:{message:"Model ID not specified"}},{status:400});console.log("[Gateway Route] Request info:",{modelId:n,providerName:s,bodyProvider:l,path:"/"+o});let d={method:r,path:"/"+o,headers:Object.fromEntries(e.headers.entries()),query:Object.fromEntries(a.entries()),body:i},p=s||l;console.log("[Gateway Route] Calling handleGatewayRequest:",{modelId:n,provider:p||"auto-route"});let u=await (0,v.handleGatewayRequest)(n,d,p||void 0);return console.log("[Gateway Route] Response:",{status:u.status,bodyType:typeof u.body}),f.NextResponse.json(u.body,{status:u.status,headers:u.headers})}catch(e){return console.error("[Gateway Route] Error:",{message:e.message,stack:e.stack}),f.NextResponse.json({error:{message:e.message||"Internal server error",type:"gateway_error"}},{status:500})}}e.s(["DELETE",()=>k,"GET",()=>x,"PATCH",()=>_,"POST",()=>w,"PUT",()=>R,"runtime",0,"nodejs"],39244);var T=e.i(39244);let O=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/gateway/[...path]/route",pathname:"/api/gateway/[...path]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/gateway/[...path]/route.ts",nextConfigOutput:"",userland:T}),{workAsyncStorage:q,workUnitAsyncStorage:C,serverHooks:P}=O;function $(){return(0,o.patchFetch)({workAsyncStorage:q,workUnitAsyncStorage:C})}async function I(e,t,o){O.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let f="/api/gateway/[...path]/route";f=f.replace(/\/index$/,"")||"/";let A=await O.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:k,routerServerContext:E,isOnDemandRevalidate:T,revalidateOnlyGenerated:q,resolvedPathname:C,clientReferenceManifest:P,serverActionsManifest:$}=A,I=(0,i.normalizeAppPath)(f),S=!!(k.dynamicRoutes[I]||k.routes[C]),j=async()=>((null==E?void 0:E.render404)?await E.render404(e,t,R,!1):t.end("This page could not be found"),null);if(S&&!_){let e=!!k.routes[C],t=k.dynamicRoutes[I];if(t&&!1===t.fallback&&!e){if(x.experimental.adapterPath)return await j();throw new m.NoFallbackError}}let N=null;!S||O.isDev||_||(N="/index"===(N=C)?"/":N);let G=!0===O.isDev||!S,U=S&&!G;$&&P&&(0,s.setManifestsSingleton)({page:f,clientReferenceManifest:P,serverActionsManifest:$});let K=e.method||"GET",D=(0,n.getTracer)(),H=D.getActiveScopeSpan(),z={params:w,prerenderManifest:k,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)=>O.onRequestError(e,t,o,a,E)},sharedContext:{buildId:v}},F=new l.NodeNextRequest(e),M=new l.NodeNextResponse(t),B=d.NextRequestAdapter.fromNodeNextRequest(F,(0,d.signalFromNodeResponse)(t));try{let s=async e=>O.handle(B,z).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&&T&&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=z.renderOpts.fetchMetrics;let l=z.renderOpts.pendingWaitUntil;l&&o.waitUntil&&(o.waitUntil(l),l=void 0);let d=z.renderOpts.collectedTags;if(!S)return await (0,c.sendResponse)(F,M,n,z.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!==z.renderOpts.collectedRevalidate&&!(z.renderOpts.collectedRevalidate>=g.INFINITE_CACHE)&&z.renderOpts.collectedRevalidate,o=void 0===z.renderOpts.collectedExpire||z.renderOpts.collectedExpire>=g.INFINITE_CACHE?void 0:z.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 O.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:T})},!1,E),t}},p=await O.handleResponse({req:e,nextConfig:x,cacheKey:N,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:k,isRoutePPREnabled:!1,isOnDemandRevalidate:T,revalidateOnlyGenerated:q,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",T?"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)(F,M,new Response(p.value.body,{headers:m,status:p.value.status||200})),null};H?await l(H):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 O.onRequestError(e,t,{routerKind:"App Router",routePath:I,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:T})},!1,E),S)throw t;return await (0,c.sendResponse)(F,M,new Response(null,{status:500})),null}}e.s(["handler",()=>I,"patchFetch",()=>$,"routeModule",()=>O,"serverHooks",()=>P,"workAsyncStorage",()=>q,"workUnitAsyncStorage",()=>C],43535)}];
2
2
 
3
3
  //# sourceMappingURL=%5Broot-of-the-server%5D__3aaf963c._.js.map