fix: use x-api-key header for minimax

This commit is contained in:
renato97
2025-12-01 03:33:49 +00:00
parent c21734220c
commit 7c7f6e7ae6

View File

@@ -116,59 +116,86 @@ function extractJson(text) {
return null;
}
function anthConfig() {
const base =
(process.env.ANTHROPIC_BASE_URL || '').trim() ||
(process.env.ANTHROPIC_FALLBACK_BASE_URL || '').trim();
const token =
function anthConfigs() {
const configs = [];
const primaryBase = (process.env.ANTHROPIC_BASE_URL || '').trim();
const primaryToken =
(process.env.ANTHROPIC_AUTH_TOKEN || '').trim() ||
(process.env.ANTHROPIC_FALLBACK_TOKEN || '').trim();
if (!base || !token) {
return null;
(process.env.ANTHROPIC_API_KEY || '').trim();
if (primaryBase && primaryToken) {
configs.push({
endpoint: `${primaryBase.replace(/\/$/, '')}/v1/messages`,
token: primaryToken,
model: process.env.ANTHROPIC_MODEL || 'claude-3-5-sonnet-20241022'
});
}
return {
endpoint: `${base.replace(/\/$/, '')}/v1/messages`,
token
};
const fallbackBase = (process.env.ANTHROPIC_FALLBACK_BASE_URL || '').trim();
const fallbackToken = (process.env.ANTHROPIC_FALLBACK_TOKEN || '').trim();
if (fallbackBase && fallbackToken) {
const sameAsPrimary =
fallbackBase === primaryBase && fallbackToken === primaryToken;
if (!sameAsPrimary) {
configs.push({
endpoint: `${fallbackBase.replace(/\/$/, '')}/v1/messages`,
token: fallbackToken,
model:
process.env.ANTHROPIC_FALLBACK_MODEL ||
process.env.ANTHROPIC_MODEL ||
'claude-3-5-sonnet-20241022'
});
}
}
return configs;
}
async function callAnthropic(systemText, userText, maxTokens = 800) {
const cfg = anthConfig();
if (!cfg) {
const configs = anthConfigs();
if (!configs.length) {
return null;
}
const payload = {
model: process.env.ANTHROPIC_MODEL || 'claude-3-5-sonnet-20241022',
max_tokens: maxTokens,
temperature: 0.3,
system: systemText,
messages: [
{
role: 'user',
content: [{ type: 'text', text: userText }]
let lastError = null;
for (const cfg of configs) {
const payload = {
model: cfg.model || process.env.ANTHROPIC_MODEL || 'claude-3-5-sonnet-20241022',
max_tokens: maxTokens,
temperature: 0.3,
system: systemText,
messages: [
{
role: 'user',
content: [{ type: 'text', text: userText }]
}
]
};
try {
const res = await fetch(cfg.endpoint, {
method: 'POST',
headers: {
'content-type': 'application/json',
'x-api-key': cfg.token,
'anthropic-version': '2023-06-01'
},
body: JSON.stringify(payload),
timeout: Number(process.env.API_TIMEOUT_MS) || 60000
});
if (!res.ok) {
throw new Error(await res.text());
}
]
};
try {
const res = await fetch(cfg.endpoint, {
method: 'POST',
headers: {
'content-type': 'application/json',
'x-api-key': cfg.token,
'anthropic-version': '2023-06-01'
},
body: JSON.stringify(payload),
timeout: Number(process.env.API_TIMEOUT_MS) || 60000
});
if (!res.ok) {
throw new Error(await res.text());
const data = await res.json();
return data?.content?.[0]?.text || '';
} catch (err) {
lastError = err;
console.warn(
`[alsGenerator] Anthropic error (${cfg.endpoint}):`,
err.message
);
continue;
}
const data = await res.json();
return data?.content?.[0]?.text || '';
} catch (err) {
console.warn('[alsGenerator] Anthropic error:', err.message);
return null;
}
if (lastError) {
console.warn('[alsGenerator] All Anthropic endpoints failed.');
}
return null;
}
async function planWithAI(prompt, library, sources) {