2024-08-01 22:03:32 +02:00
|
|
|
const { TEXTGEN_TYPES, OPENROUTER_HEADERS, FEATHERLESS_HEADERS } = require('./constants');
|
2023-12-10 01:35:49 +01:00
|
|
|
const { SECRET_KEYS, readSecret } = require('./endpoints/secrets');
|
|
|
|
const { getConfigValue } = require('./util');
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the Mancer API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getMancerHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.MANCER);
|
2023-12-10 01:35:49 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'X-API-KEY': apiKey,
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the TogetherAI API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getTogetherAIHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.TOGETHERAI);
|
2023-12-17 22:38:03 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the InfermaticAI API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getInfermaticAIHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.INFERMATICAI);
|
2024-01-24 13:59:27 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the DreamGen API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getDreamGenHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.DREAMGEN);
|
2024-03-07 10:55:08 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the OpenRouter API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getOpenRouterHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.OPENROUTER);
|
2024-02-25 21:47:07 +01:00
|
|
|
const baseHeaders = { ...OPENROUTER_HEADERS };
|
|
|
|
|
|
|
|
return apiKey ? Object.assign(baseHeaders, { 'Authorization': `Bearer ${apiKey}` }) : baseHeaders;
|
|
|
|
}
|
|
|
|
|
2024-05-03 00:40:40 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the vLLM API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getVllmHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.VLLM);
|
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the Aphrodite API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getAphroditeHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.APHRODITE);
|
2023-12-10 01:35:49 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'X-API-KEY': apiKey,
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the Tabby API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getTabbyHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.TABBY);
|
2023-12-10 01:35:49 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'x-api-key': apiKey,
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the LlamaCPP API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getLlamaCppHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.LLAMACPP);
|
2024-03-30 23:27:12 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the Ooba API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getOobaHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.OOBA);
|
2024-02-07 05:00:16 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-04-07 00:47:07 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the KoboldCpp API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getKoboldCppHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.KOBOLDCPP);
|
2024-03-13 23:34:09 +01:00
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2024-06-28 18:09:12 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the Featherless API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
2024-06-28 14:20:15 +02:00
|
|
|
function getFeatherlessHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.FEATHERLESS);
|
2024-08-01 22:03:32 +02:00
|
|
|
const baseHeaders = { ...FEATHERLESS_HEADERS };
|
2024-06-28 14:20:15 +02:00
|
|
|
|
2024-08-01 22:03:32 +02:00
|
|
|
return apiKey ? Object.assign(baseHeaders, { 'Authorization': `Bearer ${apiKey}` }) : baseHeaders;
|
2024-06-28 14:20:15 +02:00
|
|
|
}
|
|
|
|
|
2024-06-28 17:17:27 +02:00
|
|
|
/**
|
|
|
|
* Gets the headers for the HuggingFace API.
|
|
|
|
* @param {import('./users').UserDirectoryList} directories
|
|
|
|
* @returns {object} Headers for the request
|
|
|
|
*/
|
|
|
|
function getHuggingFaceHeaders(directories) {
|
|
|
|
const apiKey = readSecret(directories, SECRET_KEYS.HUGGINGFACE);
|
|
|
|
|
|
|
|
return apiKey ? ({
|
|
|
|
'Authorization': `Bearer ${apiKey}`,
|
|
|
|
}) : {};
|
|
|
|
}
|
|
|
|
|
2023-12-10 01:35:49 +01:00
|
|
|
function getOverrideHeaders(urlHost) {
|
|
|
|
const requestOverrides = getConfigValue('requestOverrides', []);
|
|
|
|
const overrideHeaders = requestOverrides?.find((e) => e.hosts?.includes(urlHost))?.headers;
|
|
|
|
if (overrideHeaders && urlHost) {
|
|
|
|
return overrideHeaders;
|
|
|
|
} else {
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets additional headers for the request.
|
2024-04-07 00:47:07 +02:00
|
|
|
* @param {import('express').Request} request Original request body
|
2023-12-10 01:35:49 +01:00
|
|
|
* @param {object} args New request arguments
|
|
|
|
* @param {string|null} server API server for new request
|
|
|
|
*/
|
|
|
|
function setAdditionalHeaders(request, args, server) {
|
2024-05-28 21:54:50 +02:00
|
|
|
setAdditionalHeadersByType(args.headers, request.body.api_type, server, request.user.directories);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param {object} requestHeaders Request headers
|
|
|
|
* @param {string} type API type
|
|
|
|
* @param {string|null} server API server for new request
|
|
|
|
* @param {import('./users').UserDirectoryList} directories User directories
|
|
|
|
*/
|
|
|
|
function setAdditionalHeadersByType(requestHeaders, type, server, directories) {
|
2024-03-30 23:27:12 +01:00
|
|
|
const headerGetters = {
|
|
|
|
[TEXTGEN_TYPES.MANCER]: getMancerHeaders,
|
2024-05-03 00:40:40 +02:00
|
|
|
[TEXTGEN_TYPES.VLLM]: getVllmHeaders,
|
2024-03-30 23:27:12 +01:00
|
|
|
[TEXTGEN_TYPES.APHRODITE]: getAphroditeHeaders,
|
|
|
|
[TEXTGEN_TYPES.TABBY]: getTabbyHeaders,
|
|
|
|
[TEXTGEN_TYPES.TOGETHERAI]: getTogetherAIHeaders,
|
|
|
|
[TEXTGEN_TYPES.OOBA]: getOobaHeaders,
|
|
|
|
[TEXTGEN_TYPES.INFERMATICAI]: getInfermaticAIHeaders,
|
|
|
|
[TEXTGEN_TYPES.DREAMGEN]: getDreamGenHeaders,
|
|
|
|
[TEXTGEN_TYPES.OPENROUTER]: getOpenRouterHeaders,
|
|
|
|
[TEXTGEN_TYPES.KOBOLDCPP]: getKoboldCppHeaders,
|
|
|
|
[TEXTGEN_TYPES.LLAMACPP]: getLlamaCppHeaders,
|
2024-06-28 14:20:15 +02:00
|
|
|
[TEXTGEN_TYPES.FEATHERLESS]: getFeatherlessHeaders,
|
2024-06-28 17:17:27 +02:00
|
|
|
[TEXTGEN_TYPES.HUGGINGFACE]: getHuggingFaceHeaders,
|
2024-03-30 23:27:12 +01:00
|
|
|
};
|
|
|
|
|
2024-05-28 21:54:50 +02:00
|
|
|
const getHeaders = headerGetters[type];
|
|
|
|
const headers = getHeaders ? getHeaders(directories) : {};
|
2023-12-10 01:35:49 +01:00
|
|
|
|
2024-03-13 23:48:08 +01:00
|
|
|
if (typeof server === 'string' && server.length > 0) {
|
|
|
|
try {
|
|
|
|
const url = new URL(server);
|
2024-05-28 21:54:50 +02:00
|
|
|
const overrideHeaders = getOverrideHeaders(url.host);
|
2024-03-13 23:48:08 +01:00
|
|
|
|
|
|
|
if (overrideHeaders && Object.keys(overrideHeaders).length > 0) {
|
|
|
|
Object.assign(headers, overrideHeaders);
|
|
|
|
}
|
|
|
|
} catch {
|
|
|
|
// Do nothing
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-05-28 21:54:50 +02:00
|
|
|
Object.assign(requestHeaders, headers);
|
2023-12-10 01:35:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
getOverrideHeaders,
|
|
|
|
setAdditionalHeaders,
|
2024-05-28 21:54:50 +02:00
|
|
|
setAdditionalHeadersByType,
|
2023-12-10 01:35:49 +01:00
|
|
|
};
|