2023-10-21 11:54:04 +08:00
|
|
|
|
import queryString from "query-string";
|
|
|
|
|
|
import {
|
|
|
|
|
|
OPT_TRANS_GOOGLE,
|
2025-07-02 13:38:30 +08:00
|
|
|
|
OPT_TRANS_GOOGLE_2,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
OPT_TRANS_MICROSOFT,
|
|
|
|
|
|
OPT_TRANS_DEEPL,
|
|
|
|
|
|
OPT_TRANS_DEEPLFREE,
|
|
|
|
|
|
OPT_TRANS_DEEPLX,
|
2024-04-12 11:31:01 +08:00
|
|
|
|
OPT_TRANS_NIUTRANS,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
OPT_TRANS_BAIDU,
|
|
|
|
|
|
OPT_TRANS_TENCENT,
|
2025-06-30 21:34:37 +08:00
|
|
|
|
OPT_TRANS_VOLCENGINE,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
OPT_TRANS_OPENAI,
|
2024-04-28 16:58:09 +08:00
|
|
|
|
OPT_TRANS_OPENAI_2,
|
|
|
|
|
|
OPT_TRANS_OPENAI_3,
|
2023-12-21 14:15:14 +08:00
|
|
|
|
OPT_TRANS_GEMINI,
|
2025-07-02 21:54:18 +08:00
|
|
|
|
OPT_TRANS_GEMINI_2,
|
2024-09-23 18:22:19 +08:00
|
|
|
|
OPT_TRANS_CLAUDE,
|
2023-10-26 11:13:50 +08:00
|
|
|
|
OPT_TRANS_CLOUDFLAREAI,
|
2024-04-28 21:43:20 +08:00
|
|
|
|
OPT_TRANS_OLLAMA,
|
|
|
|
|
|
OPT_TRANS_OLLAMA_2,
|
|
|
|
|
|
OPT_TRANS_OLLAMA_3,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
OPT_TRANS_CUSTOMIZE,
|
2024-04-10 13:37:16 +08:00
|
|
|
|
OPT_TRANS_CUSTOMIZE_2,
|
|
|
|
|
|
OPT_TRANS_CUSTOMIZE_3,
|
|
|
|
|
|
OPT_TRANS_CUSTOMIZE_4,
|
|
|
|
|
|
OPT_TRANS_CUSTOMIZE_5,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
URL_MICROSOFT_TRAN,
|
|
|
|
|
|
URL_TENCENT_TRANSMART,
|
2025-06-30 21:34:37 +08:00
|
|
|
|
URL_VOLCENGINE_TRAN,
|
2024-04-17 17:38:54 +08:00
|
|
|
|
INPUT_PLACE_URL,
|
|
|
|
|
|
INPUT_PLACE_FROM,
|
|
|
|
|
|
INPUT_PLACE_TO,
|
|
|
|
|
|
INPUT_PLACE_TEXT,
|
|
|
|
|
|
INPUT_PLACE_KEY,
|
2024-05-12 16:25:20 +08:00
|
|
|
|
INPUT_PLACE_MODEL,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
} from "../config";
|
2024-04-21 13:16:44 +08:00
|
|
|
|
import { msAuth } from "../libs/auth";
|
|
|
|
|
|
import { genDeeplFree } from "./deepl";
|
|
|
|
|
|
import { genBaidu } from "./baidu";
|
2024-05-12 16:10:11 +08:00
|
|
|
|
import interpreter from "../libs/interpreter";
|
2023-10-21 11:54:04 +08:00
|
|
|
|
|
2023-12-22 11:35:46 +08:00
|
|
|
|
const keyMap = new Map();
|
2024-04-20 14:01:34 +08:00
|
|
|
|
const urlMap = new Map();
|
2023-12-22 11:35:46 +08:00
|
|
|
|
|
2024-04-20 14:01:34 +08:00
|
|
|
|
// 轮询key/url
|
|
|
|
|
|
const keyPick = (translator, key = "", cacheMap) => {
|
2023-12-22 11:35:46 +08:00
|
|
|
|
const keys = key
|
2024-01-19 16:02:53 +08:00
|
|
|
|
.split(/\n|,/)
|
2023-12-22 11:35:46 +08:00
|
|
|
|
.map((item) => item.trim())
|
|
|
|
|
|
.filter(Boolean);
|
|
|
|
|
|
|
|
|
|
|
|
if (keys.length === 0) {
|
|
|
|
|
|
return "";
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-04-20 14:01:34 +08:00
|
|
|
|
const preIndex = cacheMap.get(translator) ?? -1;
|
2024-01-04 09:40:03 +08:00
|
|
|
|
const curIndex = (preIndex + 1) % keys.length;
|
2024-04-20 14:01:34 +08:00
|
|
|
|
cacheMap.set(translator, curIndex);
|
2023-12-22 11:35:46 +08:00
|
|
|
|
|
2024-01-04 09:40:03 +08:00
|
|
|
|
return keys[curIndex];
|
2023-12-22 11:35:46 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
2023-10-21 11:54:04 +08:00
|
|
|
|
const genGoogle = ({ text, from, to, url, key }) => {
|
2025-06-26 11:13:51 +08:00
|
|
|
|
const params = {
|
|
|
|
|
|
client: "gtx",
|
|
|
|
|
|
dt: "t",
|
|
|
|
|
|
dj: 1,
|
|
|
|
|
|
ie: "UTF-8",
|
|
|
|
|
|
sl: from,
|
|
|
|
|
|
tl: to,
|
|
|
|
|
|
q: text,
|
|
|
|
|
|
};
|
|
|
|
|
|
const input = `${url}?${queryString.stringify(params)}`;
|
2023-10-21 11:54:04 +08:00
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
2025-06-26 11:13:51 +08:00
|
|
|
|
"Content-type": "application/json",
|
2023-10-21 11:54:04 +08:00
|
|
|
|
},
|
|
|
|
|
|
};
|
2025-06-26 11:13:51 +08:00
|
|
|
|
if (key) {
|
|
|
|
|
|
init.headers.Authorization = `Bearer ${key}`;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return [input, init];
|
2023-10-21 11:54:04 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
2025-06-27 19:29:00 +08:00
|
|
|
|
const genGoogle2 = ({ text, from, to, url, key }) => {
|
2025-07-01 22:42:57 +08:00
|
|
|
|
const body = JSON.stringify([[[text], from, to], "wt_lib"]);
|
2025-06-27 19:29:00 +08:00
|
|
|
|
const init = {
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-Type": "application/json+protobuf",
|
|
|
|
|
|
"X-Goog-API-Key": key,
|
|
|
|
|
|
},
|
|
|
|
|
|
body,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-10-21 11:54:04 +08:00
|
|
|
|
const genMicrosoft = async ({ text, from, to }) => {
|
|
|
|
|
|
const [token] = await msAuth();
|
|
|
|
|
|
const params = {
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
"api-version": "3.0",
|
|
|
|
|
|
};
|
|
|
|
|
|
const input = `${URL_MICROSOFT_TRAN}?${queryString.stringify(params)}`;
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
Authorization: `Bearer ${token}`,
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify([{ Text: text }]),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [input, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const genDeepl = ({ text, from, to, url, key }) => {
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
text: [text],
|
|
|
|
|
|
target_lang: to,
|
|
|
|
|
|
source_lang: from,
|
|
|
|
|
|
// split_sentences: "0",
|
|
|
|
|
|
};
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
Authorization: `DeepL-Auth-Key ${key}`,
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const genDeeplX = ({ text, from, to, url, key }) => {
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
text,
|
|
|
|
|
|
target_lang: to,
|
|
|
|
|
|
source_lang: from,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
if (key) {
|
|
|
|
|
|
init.headers.Authorization = `Bearer ${key}`;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-04-12 11:31:01 +08:00
|
|
|
|
const genNiuTrans = ({ text, from, to, url, key, dictNo, memoryNo }) => {
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
apikey: key,
|
|
|
|
|
|
src_text: text,
|
|
|
|
|
|
dictNo,
|
|
|
|
|
|
memoryNo,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-10-21 11:54:04 +08:00
|
|
|
|
const genTencent = ({ text, from, to }) => {
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
header: {
|
2025-06-27 20:03:58 +08:00
|
|
|
|
fn: "auto_translation",
|
2025-07-01 22:42:57 +08:00
|
|
|
|
client_key:
|
|
|
|
|
|
"browser-chrome-110.0.0-Mac OS-df4bd4c5-a65d-44b2-a40f-42f34f3535f2-1677486696487",
|
2023-10-21 11:54:04 +08:00
|
|
|
|
},
|
2025-06-27 20:03:58 +08:00
|
|
|
|
type: "plain",
|
|
|
|
|
|
model_category: "normal",
|
2023-10-21 11:54:04 +08:00
|
|
|
|
source: {
|
2025-06-27 20:03:58 +08:00
|
|
|
|
text_list: [text],
|
2023-10-21 11:54:04 +08:00
|
|
|
|
lang: from,
|
|
|
|
|
|
},
|
|
|
|
|
|
target: {
|
|
|
|
|
|
lang: to,
|
|
|
|
|
|
},
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-Type": "application/json",
|
2025-07-01 22:42:57 +08:00
|
|
|
|
"user-agent":
|
|
|
|
|
|
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/110.0.0.0 Safari/537.36",
|
|
|
|
|
|
referer: "https://transmart.qq.com/zh-CN/index",
|
2023-10-21 11:54:04 +08:00
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [URL_TENCENT_TRANSMART, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2025-06-30 21:34:37 +08:00
|
|
|
|
const genVolcengine = ({ text, from, to }) => {
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
source_language: from,
|
|
|
|
|
|
target_language: to,
|
|
|
|
|
|
text: text,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [URL_VOLCENGINE_TRAN, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-05-21 23:15:46 +08:00
|
|
|
|
const genOpenAI = ({
|
|
|
|
|
|
text,
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
url,
|
|
|
|
|
|
key,
|
2024-09-25 14:03:12 +08:00
|
|
|
|
systemPrompt,
|
2024-11-30 00:41:29 +08:00
|
|
|
|
userPrompt,
|
2024-05-21 23:15:46 +08:00
|
|
|
|
model,
|
|
|
|
|
|
temperature,
|
|
|
|
|
|
maxTokens,
|
|
|
|
|
|
}) => {
|
2024-09-25 14:03:12 +08:00
|
|
|
|
// 兼容历史上作为systemPrompt的prompt,如果prompt中不包含带翻译文本,则添加文本到prompt末尾
|
2024-11-30 00:41:29 +08:00
|
|
|
|
// if (!prompt.includes(INPUT_PLACE_TEXT)) {
|
|
|
|
|
|
// prompt += `\nSource Text: ${INPUT_PLACE_TEXT}`;
|
|
|
|
|
|
// }
|
|
|
|
|
|
systemPrompt = systemPrompt
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
userPrompt = userPrompt
|
2024-04-17 17:38:54 +08:00
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
2024-09-25 14:03:12 +08:00
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
2023-10-21 11:54:04 +08:00
|
|
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
model,
|
|
|
|
|
|
messages: [
|
|
|
|
|
|
{
|
|
|
|
|
|
role: "system",
|
2024-09-25 14:03:12 +08:00
|
|
|
|
content: systemPrompt,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
role: "user",
|
2024-11-30 00:41:29 +08:00
|
|
|
|
content: userPrompt,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
},
|
|
|
|
|
|
],
|
2024-05-21 23:15:46 +08:00
|
|
|
|
temperature,
|
|
|
|
|
|
max_tokens: maxTokens,
|
2023-10-21 11:54:04 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
Authorization: `Bearer ${key}`, // OpenAI
|
|
|
|
|
|
"api-key": key, // Azure OpenAI
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2025-07-01 22:42:57 +08:00
|
|
|
|
const genGemini = ({
|
|
|
|
|
|
text,
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
url,
|
|
|
|
|
|
key,
|
|
|
|
|
|
systemPrompt,
|
|
|
|
|
|
userPrompt,
|
|
|
|
|
|
model,
|
2025-07-02 16:37:57 +08:00
|
|
|
|
temperature,
|
|
|
|
|
|
maxTokens,
|
2025-07-01 22:42:57 +08:00
|
|
|
|
}) => {
|
2024-05-12 16:25:20 +08:00
|
|
|
|
url = url
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_MODEL, model)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_KEY, key);
|
2024-11-30 00:41:29 +08:00
|
|
|
|
systemPrompt = systemPrompt
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
userPrompt = userPrompt
|
2024-04-17 17:38:54 +08:00
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
2024-04-18 00:31:36 +08:00
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
2023-12-21 14:15:14 +08:00
|
|
|
|
|
|
|
|
|
|
const data = {
|
2024-11-30 00:41:29 +08:00
|
|
|
|
system_instruction: {
|
|
|
|
|
|
parts: {
|
|
|
|
|
|
text: systemPrompt,
|
2025-07-01 22:42:57 +08:00
|
|
|
|
},
|
2024-11-30 00:41:29 +08:00
|
|
|
|
},
|
|
|
|
|
|
contents: {
|
2025-07-02 16:37:57 +08:00
|
|
|
|
role: "user",
|
2024-11-30 00:41:29 +08:00
|
|
|
|
parts: {
|
|
|
|
|
|
text: userPrompt,
|
2025-07-01 22:42:57 +08:00
|
|
|
|
},
|
|
|
|
|
|
},
|
2025-07-02 16:37:57 +08:00
|
|
|
|
generationConfig: {
|
|
|
|
|
|
maxOutputTokens: maxTokens,
|
|
|
|
|
|
temperature,
|
|
|
|
|
|
// topP: 0.8,
|
|
|
|
|
|
// topK: 10,
|
|
|
|
|
|
},
|
2023-12-21 14:15:14 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-05-12 16:25:20 +08:00
|
|
|
|
return [url, init];
|
2023-12-21 14:15:14 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
2025-07-02 21:54:18 +08:00
|
|
|
|
const genGemini2 = ({
|
|
|
|
|
|
text,
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
url,
|
|
|
|
|
|
key,
|
|
|
|
|
|
systemPrompt,
|
|
|
|
|
|
userPrompt,
|
|
|
|
|
|
model,
|
|
|
|
|
|
temperature,
|
2025-07-23 20:03:54 +08:00
|
|
|
|
maxTokens,
|
2025-07-02 21:54:18 +08:00
|
|
|
|
}) => {
|
|
|
|
|
|
systemPrompt = systemPrompt
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
userPrompt = userPrompt
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
model,
|
|
|
|
|
|
messages: [
|
|
|
|
|
|
{
|
|
|
|
|
|
role: "system",
|
|
|
|
|
|
content: systemPrompt,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
role: "user",
|
|
|
|
|
|
content: userPrompt,
|
|
|
|
|
|
},
|
|
|
|
|
|
],
|
|
|
|
|
|
temperature,
|
2025-07-23 20:03:54 +08:00
|
|
|
|
max_tokens: maxTokens,
|
2025-07-02 21:54:18 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
Authorization: `Bearer ${key}`,
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-09-23 18:22:19 +08:00
|
|
|
|
const genClaude = ({
|
|
|
|
|
|
text,
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
url,
|
|
|
|
|
|
key,
|
|
|
|
|
|
systemPrompt,
|
2024-11-30 00:41:29 +08:00
|
|
|
|
userPrompt,
|
2024-09-23 18:22:19 +08:00
|
|
|
|
model,
|
|
|
|
|
|
temperature,
|
|
|
|
|
|
maxTokens,
|
|
|
|
|
|
}) => {
|
2024-09-25 14:03:12 +08:00
|
|
|
|
systemPrompt = systemPrompt
|
2024-11-30 00:41:29 +08:00
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
userPrompt = userPrompt
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
2024-09-23 18:22:19 +08:00
|
|
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
model,
|
|
|
|
|
|
system: systemPrompt,
|
|
|
|
|
|
messages: [
|
|
|
|
|
|
{
|
|
|
|
|
|
role: "user",
|
2024-11-30 00:41:29 +08:00
|
|
|
|
content: userPrompt,
|
2024-09-23 18:22:19 +08:00
|
|
|
|
},
|
|
|
|
|
|
],
|
|
|
|
|
|
temperature,
|
|
|
|
|
|
max_tokens: maxTokens,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
"anthropic-version": "2023-06-01",
|
|
|
|
|
|
"x-api-key": key,
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2025-07-01 22:42:57 +08:00
|
|
|
|
const genOllama = ({
|
|
|
|
|
|
text,
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
think,
|
|
|
|
|
|
url,
|
|
|
|
|
|
key,
|
|
|
|
|
|
systemPrompt,
|
|
|
|
|
|
userPrompt,
|
|
|
|
|
|
model,
|
|
|
|
|
|
}) => {
|
2024-11-30 00:41:29 +08:00
|
|
|
|
systemPrompt = systemPrompt
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
userPrompt = userPrompt
|
2024-04-28 21:43:20 +08:00
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text);
|
|
|
|
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
model,
|
2024-11-30 00:41:29 +08:00
|
|
|
|
system: systemPrompt,
|
|
|
|
|
|
prompt: userPrompt,
|
2025-06-03 23:07:10 +08:00
|
|
|
|
think: think,
|
2024-04-28 21:43:20 +08:00
|
|
|
|
stream: false,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
if (key) {
|
|
|
|
|
|
init.headers.Authorization = `Bearer ${key}`;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-10-26 11:13:50 +08:00
|
|
|
|
const genCloudflareAI = ({ text, from, to, url, key }) => {
|
|
|
|
|
|
const data = {
|
|
|
|
|
|
text,
|
|
|
|
|
|
source_lang: from,
|
|
|
|
|
|
target_lang: to,
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const init = {
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
Authorization: `Bearer ${key}`,
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-05-12 16:10:11 +08:00
|
|
|
|
const genCustom = ({ text, from, to, url, key, reqHook }) => {
|
|
|
|
|
|
url = url
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_URL, url)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_FROM, from)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TO, to)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_TEXT, text)
|
|
|
|
|
|
.replaceAll(INPUT_PLACE_KEY, key);
|
|
|
|
|
|
let init = {};
|
|
|
|
|
|
|
|
|
|
|
|
if (reqHook?.trim()) {
|
|
|
|
|
|
interpreter.run(`exports.reqHook = ${reqHook}`);
|
|
|
|
|
|
[url, init] = interpreter.exports.reqHook(text, from, to, url, key);
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-10-21 11:54:04 +08:00
|
|
|
|
const data = {
|
|
|
|
|
|
text,
|
|
|
|
|
|
from,
|
|
|
|
|
|
to,
|
|
|
|
|
|
};
|
2024-05-12 16:10:11 +08:00
|
|
|
|
init = {
|
2023-10-21 11:54:04 +08:00
|
|
|
|
headers: {
|
|
|
|
|
|
"Content-type": "application/json",
|
|
|
|
|
|
},
|
|
|
|
|
|
method: "POST",
|
|
|
|
|
|
body: JSON.stringify(data),
|
|
|
|
|
|
};
|
|
|
|
|
|
if (key) {
|
|
|
|
|
|
init.headers.Authorization = `Bearer ${key}`;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return [url, init];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-10-26 11:13:50 +08:00
|
|
|
|
/**
|
2024-04-21 13:16:44 +08:00
|
|
|
|
* 构造翻译接口请求参数
|
2023-10-26 11:13:50 +08:00
|
|
|
|
* @param {*}
|
|
|
|
|
|
* @returns
|
|
|
|
|
|
*/
|
2024-04-21 13:16:44 +08:00
|
|
|
|
export const genTransReq = ({ translator, text, from, to }, apiSetting) => {
|
2023-10-21 11:54:04 +08:00
|
|
|
|
const args = { text, from, to, ...apiSetting };
|
2023-12-22 11:35:46 +08:00
|
|
|
|
|
|
|
|
|
|
switch (translator) {
|
|
|
|
|
|
case OPT_TRANS_DEEPL:
|
|
|
|
|
|
case OPT_TRANS_OPENAI:
|
2024-04-28 16:58:09 +08:00
|
|
|
|
case OPT_TRANS_OPENAI_2:
|
|
|
|
|
|
case OPT_TRANS_OPENAI_3:
|
2023-12-22 11:35:46 +08:00
|
|
|
|
case OPT_TRANS_GEMINI:
|
2025-07-02 21:54:18 +08:00
|
|
|
|
case OPT_TRANS_GEMINI_2:
|
2024-09-23 18:22:19 +08:00
|
|
|
|
case OPT_TRANS_CLAUDE:
|
2023-12-22 11:35:46 +08:00
|
|
|
|
case OPT_TRANS_CLOUDFLAREAI:
|
2024-04-28 21:43:20 +08:00
|
|
|
|
case OPT_TRANS_OLLAMA:
|
|
|
|
|
|
case OPT_TRANS_OLLAMA_2:
|
|
|
|
|
|
case OPT_TRANS_OLLAMA_3:
|
2024-04-12 11:31:01 +08:00
|
|
|
|
case OPT_TRANS_NIUTRANS:
|
2025-07-01 22:42:57 +08:00
|
|
|
|
case OPT_TRANS_CUSTOMIZE:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_2:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_3:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_4:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_5:
|
2024-04-20 14:01:34 +08:00
|
|
|
|
args.key = keyPick(translator, args.key, keyMap);
|
|
|
|
|
|
break;
|
|
|
|
|
|
case OPT_TRANS_DEEPLX:
|
|
|
|
|
|
args.url = keyPick(translator, args.url, urlMap);
|
2023-12-22 11:35:46 +08:00
|
|
|
|
break;
|
|
|
|
|
|
default:
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-10-21 11:54:04 +08:00
|
|
|
|
switch (translator) {
|
|
|
|
|
|
case OPT_TRANS_GOOGLE:
|
|
|
|
|
|
return genGoogle(args);
|
2025-07-02 13:38:30 +08:00
|
|
|
|
case OPT_TRANS_GOOGLE_2:
|
2025-07-01 22:42:57 +08:00
|
|
|
|
return genGoogle2(args);
|
2023-10-21 11:54:04 +08:00
|
|
|
|
case OPT_TRANS_MICROSOFT:
|
|
|
|
|
|
return genMicrosoft(args);
|
|
|
|
|
|
case OPT_TRANS_DEEPL:
|
|
|
|
|
|
return genDeepl(args);
|
|
|
|
|
|
case OPT_TRANS_DEEPLFREE:
|
|
|
|
|
|
return genDeeplFree(args);
|
|
|
|
|
|
case OPT_TRANS_DEEPLX:
|
|
|
|
|
|
return genDeeplX(args);
|
2024-04-12 11:31:01 +08:00
|
|
|
|
case OPT_TRANS_NIUTRANS:
|
|
|
|
|
|
return genNiuTrans(args);
|
2023-10-21 11:54:04 +08:00
|
|
|
|
case OPT_TRANS_BAIDU:
|
|
|
|
|
|
return genBaidu(args);
|
|
|
|
|
|
case OPT_TRANS_TENCENT:
|
|
|
|
|
|
return genTencent(args);
|
2025-06-30 21:34:37 +08:00
|
|
|
|
case OPT_TRANS_VOLCENGINE:
|
|
|
|
|
|
return genVolcengine(args);
|
2023-10-21 11:54:04 +08:00
|
|
|
|
case OPT_TRANS_OPENAI:
|
2024-04-28 16:58:09 +08:00
|
|
|
|
case OPT_TRANS_OPENAI_2:
|
|
|
|
|
|
case OPT_TRANS_OPENAI_3:
|
2023-10-26 11:13:50 +08:00
|
|
|
|
return genOpenAI(args);
|
2023-12-21 14:15:14 +08:00
|
|
|
|
case OPT_TRANS_GEMINI:
|
|
|
|
|
|
return genGemini(args);
|
2025-07-02 21:54:18 +08:00
|
|
|
|
case OPT_TRANS_GEMINI_2:
|
|
|
|
|
|
return genGemini2(args);
|
2024-09-23 18:22:19 +08:00
|
|
|
|
case OPT_TRANS_CLAUDE:
|
|
|
|
|
|
return genClaude(args);
|
2023-10-26 11:13:50 +08:00
|
|
|
|
case OPT_TRANS_CLOUDFLAREAI:
|
|
|
|
|
|
return genCloudflareAI(args);
|
2024-04-28 21:43:20 +08:00
|
|
|
|
case OPT_TRANS_OLLAMA:
|
|
|
|
|
|
case OPT_TRANS_OLLAMA_2:
|
|
|
|
|
|
case OPT_TRANS_OLLAMA_3:
|
|
|
|
|
|
return genOllama(args);
|
2023-10-21 11:54:04 +08:00
|
|
|
|
case OPT_TRANS_CUSTOMIZE:
|
2024-04-10 13:37:16 +08:00
|
|
|
|
case OPT_TRANS_CUSTOMIZE_2:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_3:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_4:
|
|
|
|
|
|
case OPT_TRANS_CUSTOMIZE_5:
|
2023-10-21 11:54:04 +08:00
|
|
|
|
return genCustom(args);
|
|
|
|
|
|
default:
|
|
|
|
|
|
throw new Error(`[trans] translator: ${translator} not support`);
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|