Update api.js

This commit is contained in:
2025-10-30 18:20:58 +08:00
committed by GitHub
parent 63da4f6aab
commit f1ac0cbbff

View File

@@ -379,30 +379,81 @@ async function fetchSillyTavernPresetModels() {
export function getApiSettings() { export function getApiSettings() {
const settings = extension_settings[extensionName] || {};
const apiProvider = document.getElementById('amily2_api_provider')?.value || 'openai';
let model;
if (apiProvider === 'sillytavern_preset') {
const context = getContext();
const profileId = document.getElementById('amily2_preset_selector')?.value;
const profile = context.extensionSettings?.connectionManager?.profiles?.find(p => p.id === profileId);
model = profile?.openai_model || 'Preset Model';
} else {
model = document.getElementById('amily2_model')?.value;
}
return { return {
apiProvider: $("#amily2_api_provider").val() || 'openai', apiProvider: apiProvider,
apiUrl: $("#amily2_api_url").val().trim(), apiUrl: document.getElementById('amily2_api_url')?.value.trim() || '',
apiKey: $("#amily2_api_key").val().trim(), apiKey: document.getElementById('amily2_api_key')?.value.trim() || '',
model: $("#amily2_model").val(), model: model,
maxTokens: extension_settings[extensionName]?.maxTokens || 4000, maxTokens: settings.maxTokens || 4000,
temperature: extension_settings[extensionName]?.temperature || 0.7, temperature: settings.temperature || 0.7,
tavernProfile: extension_settings[extensionName]?.tavernProfile || '' tavernProfile: document.getElementById('amily2_preset_selector')?.value || ''
}; };
} }
export async function testApiConnection() { export async function testApiConnection() {
console.log('[Amily2号-外交部] 开始API连接测试'); console.log('[Amily2号-外交部] 开始API连接测试');
const $button = $("#amily2_test_api_connection");
const apiProvider = $("#amily2_api_provider").val() || 'openai'; if (!$button.length) return;
const models = await fetchModels();
const originalHtml = $button.html();
if (models.length > 0) { $button.prop("disabled", true).html('<i class="fas fa-spinner fa-spin"></i> 测试中');
toastr.success(`${apiProvider} 提供商连接正常,找到 ${models.length} 个模型`, 'API连接正常');
return true; try {
} else { const apiSettings = getApiSettings();
toastr.error('无法获取模型列表,请检查配置', 'API连接失败');
if (apiSettings.apiProvider === 'sillytavern_preset') {
if (!apiSettings.tavernProfile) {
throw new Error("请先在下方选择一个SillyTavern预设");
}
} else {
if (!apiSettings.apiUrl || !apiSettings.apiKey || !apiSettings.model) {
throw new Error("API配置不完整请检查URL、Key和模型选择");
}
}
toastr.info('正在发送测试消息"你好!"...', 'API连接测试');
const userName = getContext()?.name1 || '用户';
const systemPrompt = `接下来用户会使用测试按钮测试api连接是否正常请回复ta连接是正常的称呼用户为${userName}大人”并复述群号1060183271告知ta本扩展开发者“诗与酒.”正静待ta的入驻。`;
const testMessages = [
{ role: 'system', content: systemPrompt },
{ role: 'user', content: '你好!' }
];
const response = await callAI(testMessages, {
maxTokens: 8192,
temperature: 0.5
});
if (response && response.trim()) {
console.log('[Amily2号-外交部] 测试消息响应:', response);
toastr.success(`连接测试成功AI回复: "${response}"`, 'API连接测试成功');
return true;
} else {
throw new Error('API未返回有效响应请检查您的代理、API URL和密钥是否正确。这通常发生在网络问题或认证失败时。');
}
} catch (error) {
console.error('[Amily2号-使节团] API连接测试失败:', error);
toastr.error(`连接测试失败: ${error.message}`, 'API连接测试失败');
return false; return false;
} finally {
$button.prop("disabled", false).html(originalHtml);
} }
} }
@@ -531,28 +582,30 @@ async function callOpenAICompatible(messages, options) {
} }
async function callOpenAITest(messages, options) { async function callOpenAITest(messages, options) {
const body = {
chat_completion_source: 'openai',
messages: messages,
model: options.model,
reverse_proxy: options.apiUrl,
proxy_password: options.apiKey,
stream: false,
max_tokens: options.maxTokens || 30000,
temperature: options.temperature || 1,
top_p: options.top_p || 1,
custom_prompt_post_processing: 'strict',
enable_web_search: false,
frequency_penalty: 0,
group_names: [],
include_reasoning: false,
presence_penalty: 0.12,
reasoning_effort: 'medium',
request_images: false,
};
const response = await fetch('/api/backends/chat-completions/generate', { const response = await fetch('/api/backends/chat-completions/generate', {
method: 'POST', method: 'POST',
headers: { ...getRequestHeaders(), 'Content-Type': 'application/json' }, headers: { ...getRequestHeaders(), 'Content-Type': 'application/json' },
body: JSON.stringify({ body: JSON.stringify(body)
chat_completion_source: 'openai',
custom_prompt_post_processing: 'strict',
enable_web_search: false,
frequency_penalty: 0,
group_names: [],
include_reasoning: false,
max_tokens: options.maxTokens || 100000,
messages: messages,
model: options.model,
presence_penalty: 0.12,
proxy_password: options.apiKey,
reasoning_effort: 'medium',
request_images: false,
reverse_proxy: options.apiUrl,
stream: false,
temperature: options.temperature || 1,
top_p: options.top_p || 1
})
}); });
if (!response.ok) { if (!response.ok) {
@@ -561,6 +614,15 @@ async function callOpenAITest(messages, options) {
} }
const responseData = await response.json(); const responseData = await response.json();
if (!responseData || !responseData.choices || responseData.choices.length === 0) {
console.error('[Amily2号-OpenAI兼容(测试)] API返回了空的choices数组或错误:', responseData);
if (responseData.error) {
throw new Error(`API返回错误: ${responseData.error.message || JSON.stringify(responseData.error)}`);
}
return null;
}
return responseData?.choices?.[0]?.message?.content; return responseData?.choices?.[0]?.message?.content;
} }