Spaces:
Runtime error
Runtime error
teralomaniac/clewd
#5
by
RKOJIN
- opened
- clewd.js +37 -45
- docker-compose.yml +3 -3
- lib/clewd-stream.js +2 -10
- lib/clewd-superfetch.js +1 -1
- lib/clewd-utils.js +78 -67
clewd.js
CHANGED
@@ -7,7 +7,7 @@
|
|
7 |
const {createServer: Server, IncomingMessage, ServerResponse} = require('node:http'), {createHash: Hash, randomUUID, randomInt, randomBytes} = require('node:crypto'), {TransformStream, ReadableStream} = require('node:stream/web'), {Readable, Writable} = require('node:stream'), {Blob} = require('node:buffer'), {existsSync: exists, writeFileSync: write, createWriteStream} = require('node:fs'), {join: joinP} = require('node:path'), {ClewdSuperfetch: Superfetch, SuperfetchAvailable} = require('./lib/clewd-superfetch'), {AI, fileName, genericFixes, bytesToSize, setTitle, checkResErr, Replacements, Main} = require('./lib/clewd-utils'), ClewdStream = require('./lib/clewd-stream');
|
8 |
|
9 |
/******************************************************* */
|
10 |
-
let currentIndex, Firstlogin = true, changeflag = 0, changing, changetime = 0, totaltime, invalidtime = 0, uuidOrgArray = [], model, reqModel,
|
11 |
|
12 |
const events = require('events'), CookieChanger = new events.EventEmitter();
|
13 |
require('events').EventEmitter.defaultMaxListeners = 0;
|
@@ -22,23 +22,11 @@ CookieChanger.on('ChangeCookie', () => {
|
|
22 |
console.error('Proxy error\n%o', err);
|
23 |
}));
|
24 |
timestamp = Date.now();
|
25 |
-
invalidtime
|
26 |
}, !Config.rProxy || Config.rProxy === AI.end() ? 15000 + timestamp - Date.now() : 0);
|
27 |
});
|
28 |
|
29 |
-
const
|
30 |
-
const ret = [], executing = [];
|
31 |
-
for (const item of array) {
|
32 |
-
const p = Promise.resolve().then(() => iteratorFn(item));
|
33 |
-
ret.push(p);
|
34 |
-
if (poolLimit <= array.length) {
|
35 |
-
const e = p.then(() => executing.splice(executing.indexOf(e), 1));
|
36 |
-
executing.push(e);
|
37 |
-
if (executing.length >= poolLimit) await Promise.race(executing);
|
38 |
-
}
|
39 |
-
}
|
40 |
-
return Promise.all(ret);
|
41 |
-
}, convertToType = value => {
|
42 |
if (value === 'true') return true;
|
43 |
if (value === 'false') return false;
|
44 |
if (/^\d+$/.test(value)) return parseInt(value);
|
@@ -48,6 +36,13 @@ const asyncPool = async (poolLimit, array, iteratorFn) => {
|
|
48 |
Config.Cookie = '';
|
49 |
writeSettings(Config);
|
50 |
currentIndex = (currentIndex - 1 + Config.CookieArray.length) % Config.CookieArray.length;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
51 |
}, padtxt = content => {
|
52 |
const {countTokens} = require('@anthropic-ai/tokenizer');
|
53 |
const placeholder = Config.padtxt_placeholder || randomBytes(randomInt(5, 15)).toString('hex');
|
@@ -229,7 +224,7 @@ const updateParams = res => {
|
|
229 |
}, onListen = async () => {
|
230 |
/***************************** */
|
231 |
if (Firstlogin) {
|
232 |
-
Firstlogin = false
|
233 |
console.log(`[2m${Main}[0m\n[33mhttp://${Config.Ip}:${Config.Port}/v1[0m\n\n${Object.keys(Config.Settings).map((setting => UnknownSettings?.includes(setting) ? `??? [31m${setting}: ${Config.Settings[setting]}[0m` : `[1m${setting}:[0m ${ChangedSettings?.includes(setting) ? '[33m' : '[36m'}${Config.Settings[setting]}[0m`)).sort().join('\n')}\n`);
|
234 |
Config.Settings.Superfetch && SuperfetchAvailable(true);
|
235 |
if (Config.localtunnel) {
|
@@ -239,11 +234,12 @@ const updateParams = res => {
|
|
239 |
console.log(`\nTunnel URL for outer websites: ${tunnel.url}/v1\n`);
|
240 |
})
|
241 |
}
|
|
|
242 |
}
|
243 |
if (Config.CookieArray?.length > 0) {
|
244 |
Config.Cookie = Config.CookieArray[currentIndex];
|
245 |
currentIndex = (currentIndex + 1) % Config.CookieArray.length;
|
246 |
-
changetime
|
247 |
}
|
248 |
let percentage = ((changetime + Math.max(Config.CookieIndex - 1, 0)) / totaltime) * 100
|
249 |
if (Config.Cookiecounter < 0 && percentage > 100) {
|
@@ -253,7 +249,6 @@ const updateParams = res => {
|
|
253 |
try {
|
254 |
/***************************** */
|
255 |
if ('SET YOUR COOKIE HERE' === Config.Cookie || Config.Cookie?.length < 1 || (Config.CookieArray?.length > 0 && invalidtime > totaltime)) { //if ('SET YOUR COOKIE HERE' === Config.Cookie || Config.Cookie?.length < 1) {
|
256 |
-
changing = false; //
|
257 |
return console.log(`[33mNo cookie available, apiKey-Only mode enabled.[0m\n`); //throw Error('Set your cookie inside config.js');
|
258 |
}
|
259 |
updateCookies(Config.Cookie.replace(/^(sessionKey=)?/, 'sessionKey=')); //updateCookies(Config.Cookie);
|
@@ -294,17 +289,17 @@ const updateParams = res => {
|
|
294 |
});
|
295 |
await checkResErr(accountRes);
|
296 |
const accountInfo = await accountRes.json();
|
297 |
-
model = accountInfo.account.statsig.values.dynamic_configs["6zA9wvTedwkzjLxWy9PVe7yydI00XDQ6L5Fejjq/2o8="]?.value?.model
|
298 |
/**************************** */
|
299 |
console.log(Config.CookieArray?.length > 0 ? `(index: [36m${currentIndex || Config.CookieArray.length}[0m) Logged in %o` : 'Logged in %o', { //console.log('Logged in %o', {
|
300 |
name: accInfo.name?.split('@')?.[0],
|
301 |
mail: accountInfo.account.email_address, //
|
302 |
model, //
|
303 |
-
capabilities: accInfo.capabilities
|
304 |
});
|
305 |
uuidOrg = accInfo?.uuid;
|
306 |
/************************* */
|
307 |
-
if (reqModel && reqModel !=
|
308 |
const Overlap = uuidOrgArray.includes(uuidOrg) && percentage <= 100 && Config.CookieArray?.length > 0;
|
309 |
!Overlap && uuidOrgArray.push(uuidOrg);
|
310 |
const Unverified = !accountInfo.account.completed_verification_at;
|
@@ -352,7 +347,7 @@ const updateParams = res => {
|
|
352 |
console.log(`${type}: ${json.error ? json.error.message || json.error.type || json.detail : 'OK'}`);
|
353 |
})(flag.type))));
|
354 |
/***************************** */
|
355 |
-
if (Config.CookieArray?.length > 0) {
|
356 |
console.log(`${'consumer_banned' === flagtype ? '[31mBanned' : '[35mRestricted'}![0m`);
|
357 |
'consumer_banned' === flagtype && CookieCleaner();
|
358 |
Config.Cookiecounter < 0 && console.log(`[progress]: [32m${percentage.toFixed(2)}%[0m\n[length]: [33m${Config.CookieArray.length}[0m\n`);
|
@@ -362,8 +357,8 @@ const updateParams = res => {
|
|
362 |
if (Config.Cookiecounter < 0 || Exceededlimit) {
|
363 |
console.log(Config.Cookiecounter < 0 ? `[progress]: [32m${percentage.toFixed(2)}%[0m\n[length]: [33m${Config.CookieArray.length}[0m\n` : '[35mExceeded limit![0m\n');
|
364 |
return CookieChanger.emit('ChangeCookie');
|
365 |
-
} else changing = false;
|
366 |
/***************************** */
|
|
|
367 |
const convRes = await fetch(`${Config.rProxy || AI.end()}/api/organizations/${uuidOrg}/chat_conversations`, {
|
368 |
method: 'GET',
|
369 |
headers: {
|
@@ -372,9 +367,9 @@ const updateParams = res => {
|
|
372 |
}
|
373 |
}), conversations = await convRes.json();
|
374 |
updateParams(convRes);
|
375 |
-
conversations.length > 0 && await
|
376 |
/***************************** */
|
377 |
-
invalidtime = 0;
|
378 |
} catch (err) {
|
379 |
console.error('[33mClewd:[0m\n%o', err);
|
380 |
Config.CookieArray?.length > 0 && CookieChanger.emit('ChangeCookie');
|
@@ -403,7 +398,7 @@ const updateParams = res => {
|
|
403 |
/***************************** */
|
404 |
data: [ //data: AI.mdl().map((name => ({
|
405 |
...AI.mdl().slice(1).map((name => ({ id: name }))), {
|
406 |
-
id: 'claude-2'
|
407 |
id: 'claude-v1.3' },{
|
408 |
id: 'claude-v1.3-100k' },{
|
409 |
id: 'claude-v1.2' },{
|
@@ -431,9 +426,7 @@ const updateParams = res => {
|
|
431 |
req.on('end', (async () => {
|
432 |
let clewdStream, titleTimer, samePrompt = false, shouldRenew = true, retryRegen = false;
|
433 |
try {
|
434 |
-
const body = JSON.parse(Buffer.concat(buffer).toString());
|
435 |
-
let {temperature} = body;
|
436 |
-
temperature = Math.max(.1, Math.min(1, temperature));
|
437 |
let {messages} = body;
|
438 |
/************************* */
|
439 |
apiKey = req.headers.authorization?.match(/sk-ant-api\d\d-[\w-]{86}-[\w-]{6}AA/g) || req.headers.authorization?.match(/(?<=3rdKey: *)[\S]*/);
|
@@ -445,9 +438,9 @@ const updateParams = res => {
|
|
445 |
model = body.model;
|
446 |
} else if (req.headers.authorization.includes('sk-ant-api') || Config.ProxyPassword != '' && req.headers.authorization != 'Bearer ' + Config.ProxyPassword) {
|
447 |
throw Error(req.headers.authorization.includes('sk-ant-api') ? 'apiKey Wrong' : 'ProxyPassword Wrong');
|
448 |
-
} else if (changing || Config.CookieArray?.length > 0 && invalidtime >= Config.CookieArray?.length || reqModel && reqModel !=
|
449 |
changing ? invalidtime = 0 : changeflag = -1;
|
450 |
-
throw Error(reqModel && reqModel
|
451 |
}
|
452 |
/************************* */
|
453 |
if (messages?.length < 1) {
|
@@ -481,9 +474,9 @@ const updateParams = res => {
|
|
481 |
throw Error('Only one can be used at the same time: AllSamples/NoSamples');
|
482 |
}
|
483 |
//const model = body.model;
|
484 |
-
//if (model === AI.mdl()[0]) {
|
485 |
-
|
486 |
-
|
487 |
if (!/claude-.*/.test(model)) {
|
488 |
throw Error('Invalid model selected: ' + model);
|
489 |
}
|
@@ -730,8 +723,8 @@ const updateParams = res => {
|
|
730 |
timezone: AI.zone(),
|
731 |
model
|
732 |
},
|
733 |
-
conversation_uuid: Conversation.uuid,
|
734 |
organization_uuid: uuidOrg,
|
|
|
735 |
text: prompt || '',
|
736 |
attachments
|
737 |
};
|
@@ -763,7 +756,7 @@ const updateParams = res => {
|
|
763 |
version: Main,
|
764 |
minSize: Config.BufferSize,
|
765 |
model,
|
766 |
-
streaming:
|
767 |
abortControl,
|
768 |
source: fetchAPI
|
769 |
}, Logger);
|
@@ -782,21 +775,21 @@ const updateParams = res => {
|
|
782 |
param: null,
|
783 |
code: err.code || 500
|
784 |
}
|
785 |
-
}
|
786 |
}
|
787 |
}
|
788 |
clearInterval(titleTimer);
|
789 |
if (clewdStream) {
|
790 |
clewdStream.censored && console.warn('[33mlikely your account is hard-censored[0m');
|
791 |
-
|
792 |
setTitle('ok ' + bytesToSize(clewdStream.size));
|
793 |
429 == fetchAPI?.status ? console.log(`[35mExceeded limit![0m\n`) : console.log(`${200 == fetchAPI?.status ? '[32m' : '[33m'}${fetchAPI?.status}![0m\n`); //console.log(`${200 == fetchAPI.status ? '[32m' : '[33m'}${fetchAPI.status}![0m\n`);
|
794 |
clewdStream.empty();
|
795 |
}
|
796 |
-
if (!apiKey) { //if (prevImpersonated) {
|
797 |
-
await deleteChat(Conversation.uuid);
|
798 |
/******************************** */
|
799 |
-
changeflag
|
800 |
if (changeflag < 0 || Config.CookieArray?.length > 0 && (429 == fetchAPI?.status || Config.Cookiecounter > 0 && changeflag >= Config.Cookiecounter)) {
|
801 |
changeflag = 0;
|
802 |
CookieChanger.emit('ChangeCookie');
|
@@ -810,10 +803,9 @@ const updateParams = res => {
|
|
810 |
case '/v1/complete':
|
811 |
res.json({
|
812 |
error: {
|
813 |
-
message: 'clewd: Set "Chat Completion
|
814 |
-
code: 404
|
815 |
}
|
816 |
-
}
|
817 |
break;
|
818 |
|
819 |
default:
|
@@ -903,4 +895,4 @@ process.on('SIGINT', cleanup);
|
|
903 |
|
904 |
process.on('exit', (async () => {
|
905 |
console.log('exiting...');
|
906 |
-
}));
|
|
|
7 |
const {createServer: Server, IncomingMessage, ServerResponse} = require('node:http'), {createHash: Hash, randomUUID, randomInt, randomBytes} = require('node:crypto'), {TransformStream, ReadableStream} = require('node:stream/web'), {Readable, Writable} = require('node:stream'), {Blob} = require('node:buffer'), {existsSync: exists, writeFileSync: write, createWriteStream} = require('node:fs'), {join: joinP} = require('node:path'), {ClewdSuperfetch: Superfetch, SuperfetchAvailable} = require('./lib/clewd-superfetch'), {AI, fileName, genericFixes, bytesToSize, setTitle, checkResErr, Replacements, Main} = require('./lib/clewd-utils'), ClewdStream = require('./lib/clewd-stream');
|
8 |
|
9 |
/******************************************************* */
|
10 |
+
let currentIndex, Firstlogin = true, changeflag = 0, changing, changetime = 0, totaltime, invalidtime = 0, uuidOrgArray = [], model, reqModel, tokens, apiKey, timestamp = Date.now();
|
11 |
|
12 |
const events = require('events'), CookieChanger = new events.EventEmitter();
|
13 |
require('events').EventEmitter.defaultMaxListeners = 0;
|
|
|
22 |
console.error('Proxy error\n%o', err);
|
23 |
}));
|
24 |
timestamp = Date.now();
|
25 |
+
invalidtime += 1;
|
26 |
}, !Config.rProxy || Config.rProxy === AI.end() ? 15000 + timestamp - Date.now() : 0);
|
27 |
});
|
28 |
|
29 |
+
const convertToType = value => {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
30 |
if (value === 'true') return true;
|
31 |
if (value === 'false') return false;
|
32 |
if (/^\d+$/.test(value)) return parseInt(value);
|
|
|
36 |
Config.Cookie = '';
|
37 |
writeSettings(Config);
|
38 |
currentIndex = (currentIndex - 1 + Config.CookieArray.length) % Config.CookieArray.length;
|
39 |
+
}, ProModelConvert = model => {
|
40 |
+
if (/^claude-2\.0$/.test(model)) return AI.mdl()[7];
|
41 |
+
if (/1\.3/.test(model)) return AI.mdl()[5];
|
42 |
+
if (/^claude-v1\.\d$/.test(model)) return AI.mdl()[1];
|
43 |
+
if (/100k/.test(model)) return AI.mdl()[2];
|
44 |
+
if (/v1\.\d/.test(model)) return AI.mdl()[3];
|
45 |
+
return model;
|
46 |
}, padtxt = content => {
|
47 |
const {countTokens} = require('@anthropic-ai/tokenizer');
|
48 |
const placeholder = Config.padtxt_placeholder || randomBytes(randomInt(5, 15)).toString('hex');
|
|
|
224 |
}, onListen = async () => {
|
225 |
/***************************** */
|
226 |
if (Firstlogin) {
|
227 |
+
Firstlogin = false;
|
228 |
console.log(`[2m${Main}[0m\n[33mhttp://${Config.Ip}:${Config.Port}/v1[0m\n\n${Object.keys(Config.Settings).map((setting => UnknownSettings?.includes(setting) ? `??? [31m${setting}: ${Config.Settings[setting]}[0m` : `[1m${setting}:[0m ${ChangedSettings?.includes(setting) ? '[33m' : '[36m'}${Config.Settings[setting]}[0m`)).sort().join('\n')}\n`);
|
229 |
Config.Settings.Superfetch && SuperfetchAvailable(true);
|
230 |
if (Config.localtunnel) {
|
|
|
234 |
console.log(`\nTunnel URL for outer websites: ${tunnel.url}/v1\n`);
|
235 |
})
|
236 |
}
|
237 |
+
totaltime = Config.CookieArray.length;
|
238 |
}
|
239 |
if (Config.CookieArray?.length > 0) {
|
240 |
Config.Cookie = Config.CookieArray[currentIndex];
|
241 |
currentIndex = (currentIndex + 1) % Config.CookieArray.length;
|
242 |
+
changetime += 1;
|
243 |
}
|
244 |
let percentage = ((changetime + Math.max(Config.CookieIndex - 1, 0)) / totaltime) * 100
|
245 |
if (Config.Cookiecounter < 0 && percentage > 100) {
|
|
|
249 |
try {
|
250 |
/***************************** */
|
251 |
if ('SET YOUR COOKIE HERE' === Config.Cookie || Config.Cookie?.length < 1 || (Config.CookieArray?.length > 0 && invalidtime > totaltime)) { //if ('SET YOUR COOKIE HERE' === Config.Cookie || Config.Cookie?.length < 1) {
|
|
|
252 |
return console.log(`[33mNo cookie available, apiKey-Only mode enabled.[0m\n`); //throw Error('Set your cookie inside config.js');
|
253 |
}
|
254 |
updateCookies(Config.Cookie.replace(/^(sessionKey=)?/, 'sessionKey=')); //updateCookies(Config.Cookie);
|
|
|
289 |
});
|
290 |
await checkResErr(accountRes);
|
291 |
const accountInfo = await accountRes.json();
|
292 |
+
model = accountInfo.account.statsig.values.dynamic_configs["6zA9wvTedwkzjLxWy9PVe7yydI00XDQ6L5Fejjq/2o8="]?.value?.model;
|
293 |
/**************************** */
|
294 |
console.log(Config.CookieArray?.length > 0 ? `(index: [36m${currentIndex || Config.CookieArray.length}[0m) Logged in %o` : 'Logged in %o', { //console.log('Logged in %o', {
|
295 |
name: accInfo.name?.split('@')?.[0],
|
296 |
mail: accountInfo.account.email_address, //
|
297 |
model, //
|
298 |
+
capabilities: accInfo.capabilities,
|
299 |
});
|
300 |
uuidOrg = accInfo?.uuid;
|
301 |
/************************* */
|
302 |
+
if (reqModel && reqModel != model && !Config.Settings.PassParams) return CookieChanger.emit('ChangeCookie');
|
303 |
const Overlap = uuidOrgArray.includes(uuidOrg) && percentage <= 100 && Config.CookieArray?.length > 0;
|
304 |
!Overlap && uuidOrgArray.push(uuidOrg);
|
305 |
const Unverified = !accountInfo.account.completed_verification_at;
|
|
|
347 |
console.log(`${type}: ${json.error ? json.error.message || json.error.type || json.detail : 'OK'}`);
|
348 |
})(flag.type))));
|
349 |
/***************************** */
|
350 |
+
if (Config.CookieArray?.length > 0) {
|
351 |
console.log(`${'consumer_banned' === flagtype ? '[31mBanned' : '[35mRestricted'}![0m`);
|
352 |
'consumer_banned' === flagtype && CookieCleaner();
|
353 |
Config.Cookiecounter < 0 && console.log(`[progress]: [32m${percentage.toFixed(2)}%[0m\n[length]: [33m${Config.CookieArray.length}[0m\n`);
|
|
|
357 |
if (Config.Cookiecounter < 0 || Exceededlimit) {
|
358 |
console.log(Config.Cookiecounter < 0 ? `[progress]: [32m${percentage.toFixed(2)}%[0m\n[length]: [33m${Config.CookieArray.length}[0m\n` : '[35mExceeded limit![0m\n');
|
359 |
return CookieChanger.emit('ChangeCookie');
|
|
|
360 |
/***************************** */
|
361 |
+
}
|
362 |
const convRes = await fetch(`${Config.rProxy || AI.end()}/api/organizations/${uuidOrg}/chat_conversations`, {
|
363 |
method: 'GET',
|
364 |
headers: {
|
|
|
367 |
}
|
368 |
}), conversations = await convRes.json();
|
369 |
updateParams(convRes);
|
370 |
+
conversations.length > 0 && await Promise.all(conversations.map((conv => deleteChat(conv.uuid))));
|
371 |
/***************************** */
|
372 |
+
invalidtime = 0, changing = false;
|
373 |
} catch (err) {
|
374 |
console.error('[33mClewd:[0m\n%o', err);
|
375 |
Config.CookieArray?.length > 0 && CookieChanger.emit('ChangeCookie');
|
|
|
398 |
/***************************** */
|
399 |
data: [ //data: AI.mdl().map((name => ({
|
400 |
...AI.mdl().slice(1).map((name => ({ id: name }))), {
|
401 |
+
id: 'claude-2.0' },{
|
402 |
id: 'claude-v1.3' },{
|
403 |
id: 'claude-v1.3-100k' },{
|
404 |
id: 'claude-v1.2' },{
|
|
|
426 |
req.on('end', (async () => {
|
427 |
let clewdStream, titleTimer, samePrompt = false, shouldRenew = true, retryRegen = false;
|
428 |
try {
|
429 |
+
const body = JSON.parse(Buffer.concat(buffer).toString()), temperature = Math.max(.1, Math.min(1, body.temperature));
|
|
|
|
|
430 |
let {messages} = body;
|
431 |
/************************* */
|
432 |
apiKey = req.headers.authorization?.match(/sk-ant-api\d\d-[\w-]{86}-[\w-]{6}AA/g) || req.headers.authorization?.match(/(?<=3rdKey: *)[\S]*/);
|
|
|
438 |
model = body.model;
|
439 |
} else if (req.headers.authorization.includes('sk-ant-api') || Config.ProxyPassword != '' && req.headers.authorization != 'Bearer ' + Config.ProxyPassword) {
|
440 |
throw Error(req.headers.authorization.includes('sk-ant-api') ? 'apiKey Wrong' : 'ProxyPassword Wrong');
|
441 |
+
} else if (changing || Config.CookieArray?.length > 0 && invalidtime >= Config.CookieArray?.length || reqModel && reqModel != model && !Config.Settings.PassParams) {
|
442 |
changing ? invalidtime = 0 : changeflag = -1;
|
443 |
+
throw Error(reqModel && reqModel && !Config.Settings.PassParams != body.model ? 'Polling requset model...' : 'Changing Cookie...');
|
444 |
}
|
445 |
/************************* */
|
446 |
if (messages?.length < 1) {
|
|
|
474 |
throw Error('Only one can be used at the same time: AllSamples/NoSamples');
|
475 |
}
|
476 |
//const model = body.model;
|
477 |
+
if (!apiKey && Config.Settings.PassParams) { //if (model === AI.mdl()[0]) {
|
478 |
+
model = ProModelConvert(model); //return;
|
479 |
+
}
|
480 |
if (!/claude-.*/.test(model)) {
|
481 |
throw Error('Invalid model selected: ' + model);
|
482 |
}
|
|
|
723 |
timezone: AI.zone(),
|
724 |
model
|
725 |
},
|
|
|
726 |
organization_uuid: uuidOrg,
|
727 |
+
conversation_uuid: Conversation.uuid,
|
728 |
text: prompt || '',
|
729 |
attachments
|
730 |
};
|
|
|
756 |
version: Main,
|
757 |
minSize: Config.BufferSize,
|
758 |
model,
|
759 |
+
streaming: body.stream, //null != body.stream,
|
760 |
abortControl,
|
761 |
source: fetchAPI
|
762 |
}, Logger);
|
|
|
775 |
param: null,
|
776 |
code: err.code || 500
|
777 |
}
|
778 |
+
});
|
779 |
}
|
780 |
}
|
781 |
clearInterval(titleTimer);
|
782 |
if (clewdStream) {
|
783 |
clewdStream.censored && console.warn('[33mlikely your account is hard-censored[0m');
|
784 |
+
prevImpersonated = clewdStream.impersonated;
|
785 |
setTitle('ok ' + bytesToSize(clewdStream.size));
|
786 |
429 == fetchAPI?.status ? console.log(`[35mExceeded limit![0m\n`) : console.log(`${200 == fetchAPI?.status ? '[32m' : '[33m'}${fetchAPI?.status}![0m\n`); //console.log(`${200 == fetchAPI.status ? '[32m' : '[33m'}${fetchAPI.status}![0m\n`);
|
787 |
clewdStream.empty();
|
788 |
}
|
789 |
+
if (!apiKey) { //if (prevImpersonated) {
|
790 |
+
await deleteChat(Conversation.uuid);
|
791 |
/******************************** */
|
792 |
+
changeflag += 1;
|
793 |
if (changeflag < 0 || Config.CookieArray?.length > 0 && (429 == fetchAPI?.status || Config.Cookiecounter > 0 && changeflag >= Config.Cookiecounter)) {
|
794 |
changeflag = 0;
|
795 |
CookieChanger.emit('ChangeCookie');
|
|
|
803 |
case '/v1/complete':
|
804 |
res.json({
|
805 |
error: {
|
806 |
+
message: 'clewd: Set "Chat Completion" to OpenAI instead of Claude. Enable "External" models aswell'
|
|
|
807 |
}
|
808 |
+
});
|
809 |
break;
|
810 |
|
811 |
default:
|
|
|
895 |
|
896 |
process.on('exit', (async () => {
|
897 |
console.log('exiting...');
|
898 |
+
}));
|
docker-compose.yml
CHANGED
@@ -2,10 +2,10 @@ version: '3'
|
|
2 |
services:
|
3 |
app:
|
4 |
build:
|
5 |
-
context:
|
6 |
-
dockerfile: Dockerfile
|
7 |
|
8 |
ports:
|
9 |
- 8444:8444
|
10 |
volumes:
|
11 |
-
-
|
|
|
2 |
services:
|
3 |
app:
|
4 |
build:
|
5 |
+
context: ..
|
6 |
+
dockerfile: docker/Dockerfile
|
7 |
|
8 |
ports:
|
9 |
- 8444:8444
|
10 |
volumes:
|
11 |
+
- ..:/app
|
lib/clewd-stream.js
CHANGED
@@ -20,7 +20,7 @@ class ClewdStream extends TransformStream {
|
|
20 |
this.#version = opts.version;
|
21 |
this.#config = opts.config;
|
22 |
this.#model = opts.model;
|
23 |
-
this.#streaming = opts.streaming;
|
24 |
this.#minSize = opts.minSize || 8;
|
25 |
this.#abortControl = opts.abortControl;
|
26 |
this.#source = opts.source;
|
@@ -42,7 +42,6 @@ class ClewdStream extends TransformStream {
|
|
42 |
#stopReason=void 0;
|
43 |
#hardCensor=false;
|
44 |
#impersonated=false;
|
45 |
-
#nochange=false; //
|
46 |
get size() {
|
47 |
return this.#recvLength;
|
48 |
}
|
@@ -54,12 +53,7 @@ class ClewdStream extends TransformStream {
|
|
54 |
}
|
55 |
get impersonated() {
|
56 |
return this.#impersonated;
|
57 |
-
}
|
58 |
-
/************************ */
|
59 |
-
get nochange() {
|
60 |
-
return this.#nochange;
|
61 |
-
}
|
62 |
-
/************************ */
|
63 |
empty() {
|
64 |
this.#compOK = this.#compRaw = '';
|
65 |
this.#compAll = [];
|
@@ -73,7 +67,6 @@ class ClewdStream extends TransformStream {
|
|
73 |
#err(err, controller) {
|
74 |
this.#logger?.write(JSON.stringify(err, null, 4));
|
75 |
const message = `## ${this.#version}\n**${this.#model} error**:\n${err.status || err.code || err.type}\n\n\`\`\`${err.message}\`\`\`\n\nFAQ: https://rentry.org/teralomaniac_clewd`;
|
76 |
-
this.#nochange = true; //
|
77 |
this.#enqueue(this.#build(message), controller);
|
78 |
return this.#endEarly(controller);
|
79 |
}
|
@@ -104,7 +97,6 @@ class ClewdStream extends TransformStream {
|
|
104 |
this.#compAll?.[0] === Buffer.from([ 73, 32, 97, 112, 111, 108, 111, 103, 105, 122, 101, 44, 32, 98, 117, 116, 32, 73, 32, 119, 105, 108, 108, 32, 110, 111, 116, 32, 112, 114, 111, 118, 105, 100, 101, 32, 97, 110, 121, 32, 114, 101, 115, 112, 111, 110, 115, 101, 115, 32, 116, 104, 97, 116, 32, 118, 105, 111, 108, 97, 116, 101, 32, 65, 110, 116, 104, 114, 111, 112, 105, 99, 39, 115, 32, 65, 99, 99, 101, 112, 116, 97, 98, 108, 101, 32, 85, 115, 101, 32, 80, 111, 108, 105, 99, 121, 32, 111, 114, 32, 99, 111, 117, 108, 100, 32, 112, 114, 111, 109, 111, 116, 101, 32, 104, 97, 114, 109, 46 ]).toString() && (this.#hardCensor = true);
|
105 |
if (!this.#ended && 0 === this.total) {
|
106 |
const err = `## ${this.#version}\n**error**:\n\n\`\`\`Received no valid replies at all\`\`\`\n\nFAQ: https://rentry.org/teralomaniac_clewd`;
|
107 |
-
this.#nochange = true; //
|
108 |
this.#enqueue(this.#build(err), controller);
|
109 |
}
|
110 |
this.#streaming && this.#enqueue('data: [DONE]\n\n', controller);
|
|
|
20 |
this.#version = opts.version;
|
21 |
this.#config = opts.config;
|
22 |
this.#model = opts.model;
|
23 |
+
this.#streaming = opts.streaming || false;
|
24 |
this.#minSize = opts.minSize || 8;
|
25 |
this.#abortControl = opts.abortControl;
|
26 |
this.#source = opts.source;
|
|
|
42 |
#stopReason=void 0;
|
43 |
#hardCensor=false;
|
44 |
#impersonated=false;
|
|
|
45 |
get size() {
|
46 |
return this.#recvLength;
|
47 |
}
|
|
|
53 |
}
|
54 |
get impersonated() {
|
55 |
return this.#impersonated;
|
56 |
+
}
|
|
|
|
|
|
|
|
|
|
|
57 |
empty() {
|
58 |
this.#compOK = this.#compRaw = '';
|
59 |
this.#compAll = [];
|
|
|
67 |
#err(err, controller) {
|
68 |
this.#logger?.write(JSON.stringify(err, null, 4));
|
69 |
const message = `## ${this.#version}\n**${this.#model} error**:\n${err.status || err.code || err.type}\n\n\`\`\`${err.message}\`\`\`\n\nFAQ: https://rentry.org/teralomaniac_clewd`;
|
|
|
70 |
this.#enqueue(this.#build(message), controller);
|
71 |
return this.#endEarly(controller);
|
72 |
}
|
|
|
97 |
this.#compAll?.[0] === Buffer.from([ 73, 32, 97, 112, 111, 108, 111, 103, 105, 122, 101, 44, 32, 98, 117, 116, 32, 73, 32, 119, 105, 108, 108, 32, 110, 111, 116, 32, 112, 114, 111, 118, 105, 100, 101, 32, 97, 110, 121, 32, 114, 101, 115, 112, 111, 110, 115, 101, 115, 32, 116, 104, 97, 116, 32, 118, 105, 111, 108, 97, 116, 101, 32, 65, 110, 116, 104, 114, 111, 112, 105, 99, 39, 115, 32, 65, 99, 99, 101, 112, 116, 97, 98, 108, 101, 32, 85, 115, 101, 32, 80, 111, 108, 105, 99, 121, 32, 111, 114, 32, 99, 111, 117, 108, 100, 32, 112, 114, 111, 109, 111, 116, 101, 32, 104, 97, 114, 109, 46 ]).toString() && (this.#hardCensor = true);
|
98 |
if (!this.#ended && 0 === this.total) {
|
99 |
const err = `## ${this.#version}\n**error**:\n\n\`\`\`Received no valid replies at all\`\`\`\n\nFAQ: https://rentry.org/teralomaniac_clewd`;
|
|
|
100 |
this.#enqueue(this.#build(err), controller);
|
101 |
}
|
102 |
this.#streaming && this.#enqueue('data: [DONE]\n\n', controller);
|
lib/clewd-superfetch.js
CHANGED
@@ -1,4 +1,4 @@
|
|
1 |
/*
|
2 |
* https://rentry.org/teralomaniac_clewd
|
3 |
* https://github.com/teralomaniac/clewd
|
4 |
-
*/"use strict";const{spawn:e}=require("node:child_process"),{relative:r,resolve:t,join:s,normalize:n,basename:o}=require("node:path"),{writeFileSync:a,unlinkSync:d,existsSync:i}=require("node:fs"),{ReadableStream:c}=require("node:stream/web"),
|
|
|
1 |
/*
|
2 |
* https://rentry.org/teralomaniac_clewd
|
3 |
* https://github.com/teralomaniac/clewd
|
4 |
+
*/"use strict";const{spawn:e}=require("node:child_process"),{relative:r,resolve:t,join:s,normalize:n,basename:o}=require("node:path"),{writeFileSync:a,unlinkSync:d,existsSync:i}=require("node:fs"),{ReadableStream:c}=require("node:stream/web"),l=e=>"win32"===process.platform?".\\"+e:e,m=e=>"win32"===process.platform||e.indexOf(" ")>-1?`"${e}"`:e,u={win32:{x64:"clewd-superfetch-win-amd64.exe"},darwin:{x64:"clewd-superfetch-mac-amd64",arm64:"clewd-superfetch-linux-arm64"},linux:{x64:"clewd-superfetch-linux-amd64",arm64:"clewd-superfetch-linux-arm64"},android:{x64:"clewd-superfetch-linux-amd64",arm64:"clewd-superfetch-linux-arm64",arm:"clewd-superfetch-android-arm"}}[process.platform]?.[process.arch],f=""+n(r("./","./bin/"+u)),p=n(t(__dirname,f,"../","../")),h=t(p,f);let b=[123,34,115,101,99,45,99,104,45,117,97,34,58,34,92,34,67,104,114,111,109,105,117,109,92,34,59,118,61,92,34,49,49,48,92,34,44,32,92,34,78,111,116,32,65,40,66,114,97,110,100,92,34,59,118,61,92,34,50,52,92,34,44,32,92,34,71,111,111,103,108,101,32,67,104,114,111,109,101,92,34,59,118,61,92,34,49,49,48,92,34,34,44,34,115,101,99,45,99,104,45,117,97,45,109,111,98,105,108,101,34,58,34,63,48,34,44,34,115,101,99,45,99,104,45,117,97,45,112,108,97,116,102,111,114,109,34,58,34,92,34,87,105,110,100,111,119,115,92,34,34,44,34,85,112,103,114,97,100,101,45,73,110,115,101,99,117,114,101,45,82,101,113,117,101,115,116,115,34,58,34,49,34,44,34,85,115,101,114,45,65,103,101,110,116,34,58,34,77,111,122,105,108,108,97,47,53,46,48,32,40,87,105,110,100,111,119,115,32,78,84,32,49,48,46,48,59,32,87,105,110,54,52,59,32,120,54,52,41,32,65,112,112,108,101,87,101,98,75,105,116,47,53,51,55,46,51,54,32,40,75,72,84,77,76,44,32,108,105,107,101,32,71,101,99,107,111,41,32,67,104,114,111,109,101,47,49,49,48,46,48,46,48,46,48,32,83,97,102,97,114,105,47,53,51,55,46,51,54,34,44,34,65,99,99,101,112,116,34,58,34,116,101,120,116,47,104,116,109,108,44,97,112,112,108,105,99,97,116,105,111,110,47,120,104,116,109,108,43,120,109,108,44,97,112,112,108,105,99,97,116,105,111,110,47,120,109,108,59,113,61,48,46,57,44,105,109,97,103,101,47,97,118,105,102,44,105,109,97,103,101,47,119,101,98,112,44,105,109,97,103,101,47,97,112,110,103,44,42,47,42,59,113,61,48,46,56,44,97,112,112,108,105,99,97,116,105,111,110,47,115,105,103,110,101,100,45,101,120,99,104,97,110,103,101,59,118,61,98,51,59,113,61,48,46,55,34,44,34,83,101,99,45,70,101,116,99,104,45,83,105,116,101,34,58,34,110,111,110,101,34,44,34,83,101,99,45,70,101,116,99,104,45,77,111,100,101,34,58,34,110,97,118,105,103,97,116,101,34,44,34,83,101,99,45,70,101,116,99,104,45,85,115,101,114,34,58,34,63,49,34,44,34,83,101,99,45,70,101,116,99,104,45,68,101,115,116,34,58,34,100,111,99,117,109,101,110,116,34,44,34,65,99,99,101,112,116,45,69,110,99,111,100,105,110,103,34,58,34,103,122,105,112,44,32,100,101,102,108,97,116,101,44,32,98,114,34,44,34,65,99,99,101,112,116,45,76,97,110,103,117,97,103,101,34,58,34,101,110,45,85,83,44,101,110,59,113,61,48,46,57,34,125],w=[91,34,45,45,99,105,112,104,101,114,115,32,84,76,83,95,65,69,83,95,49,50,56,95,71,67,77,95,83,72,65,50,53,54,44,84,76,83,95,65,69,83,95,50,53,54,95,71,67,77,95,83,72,65,51,56,52,44,84,76,83,95,67,72,65,67,72,65,50,48,95,80,79,76,89,49,51,48,53,95,83,72,65,50,53,54,44,69,67,68,72,69,45,69,67,68,83,65,45,65,69,83,49,50,56,45,71,67,77,45,83,72,65,50,53,54,44,69,67,68,72,69,45,82,83,65,45,65,69,83,49,50,56,45,71,67,77,45,83,72,65,50,53,54,44,69,67,68,72,69,45,69,67,68,83,65,45,65,69,83,50,53,54,45,71,67,77,45,83,72,65,51,56,52,44,69,67,68,72,69,45,82,83,65,45,65,69,83,50,53,54,45,71,67,77,45,83,72,65,51,56,52,44,69,67,68,72,69,45,69,67,68,83,65,45,67,72,65,67,72,65,50,48,45,80,79,76,89,49,51,48,53,44,69,67,68,72,69,45,82,83,65,45,67,72,65,67,72,65,50,48,45,80,79,76,89,49,51,48,53,44,69,67,68,72,69,45,82,83,65,45,65,69,83,49,50,56,45,83,72,65,44,69,67,68,72,69,45,82,83,65,45,65,69,83,50,53,54,45,83,72,65,44,65,69,83,49,50,56,45,71,67,77,45,83,72,65,50,53,54,44,65,69,83,50,53,54,45,71,67,77,45,83,72,65,51,56,52,44,65,69,83,49,50,56,45,83,72,65,44,65,69,83,50,53,54,45,83,72,65,34,44,34,34,44,34,45,45,104,116,116,112,50,34,44,34,45,45,104,116,116,112,50,45,110,111,45,115,101,114,118,101,114,45,112,117,115,104,34,44,34,45,45,102,97,108,115,101,45,115,116,97,114,116,34,44,34,45,45,99,111,109,112,114,101,115,115,101,100,34,44,34,45,45,116,108,115,118,49,46,50,34,44,34,45,45,110,111,45,110,112,110,34,44,34,45,45,97,108,112,115,34,44,34,45,45,116,108,115,45,112,101,114,109,117,116,101,45,101,120,116,101,110,115,105,111,110,115,34,44,34,45,45,99,101,114,116,45,99,111,109,112,114,101,115,115,105,111,110,32,98,114,111,116,108,105,34,44,34,45,45,108,111,99,97,116,105,111,110,34,93];const y=(e=false)=>{if(!u||!i(h)){e&&console.warn(`superfetch [[31merr[0m] unavailable for ${process.platform}-${process.arch}, use 3.8.5 for the time being\n`);return false}e&&console.log(`superfetch [[32mfound[0m] ${r(__dirname,h)}\n`);return true},x=(t,n)=>{n.headers||(n.headers={});"string"!=typeof n.body&&(n.body=n.body?JSON.stringify(n.body):"");if(!y())return;const o=r("./","bin/cfg"),i=r("./","bin/pyld"),c=r("./","bin/hdr"),u=r("./","bin/ca");let x={...JSON.parse(Buffer.from(b).toString()),...n.headers};const S=Object.values(x);x=Object.keys(x).map(((e,r)=>`${e}: ${S[r]}`));const _=m(l(o)),g=m(l(c)),v=m(l(i)),O=["-v","--cacert",""+m(l(u)),"--config",""+_,"--header","@"+g];if("POST"===n.method){O.push("--data");O.push("@"+v)}const j=[...JSON.parse(Buffer.from(w).toString()),"-X "+(n.method||"GET")];a(s(__dirname,o),j.join("\n"));a(s(__dirname,c),x.join("\n"));n.body&&a(s(__dirname,i),n.body);return new Promise((r=>{const a=e("android"===process.platform?h:f,[...O,""+t],{cwd:p,windowsHide:true,killSignal:"SIGKILL",windowsVerbatimArguments:true,detached:"win32"!==process.platform});a.superfetch=true;a.rape=function(){this.stdout?.end();this.stderr?.end()}.bind(a);a.once("spawn",(()=>{a.stream=n.stream||false;if(a.stream){Object.defineProperty(a,"body",{get:()=>a.stdout});return r(a)}a.body="";a.stdout.on("data",(e=>a.body+=e.toString()));a.json=async()=>JSON.parse(a.body);a.text=async()=>a.body;a.stdout.on("end",(()=>{a.stdout.removeAllListeners();return r(a)}))}));a.once("error",(e=>{console.warn("superfetch [[31merr[0m]",e)}));a.once("close",(()=>{try{d(s(__dirname,o));d(s(__dirname,c));n.body&&d(s(__dirname,i))}catch(e){}a.stdout.removeAllListeners();a.stderr.removeAllListeners();this.body?.removeAllListeners()}));a.stderr.on("data",(e=>{const r=/HTTP\/2 (\d{3})+/g,t=(e=e.toString().trim()).match(r);if(!a.status&&t){const t=r.exec(e);a.status=+t[1]}const s=/(?:< )(.+?)(?:: )(.+)/g,n=e.match(s);if(n){const e={};n.forEach((r=>{const t=r.split(s);e[t?.[1]]=t?.[2]}));a.headers=e}}))}))};module.exports.ClewdSuperfetch=x;module.exports.SuperfetchAvailable=y;module.exports.Binary=f;
|
lib/clewd-utils.js
CHANGED
@@ -5,7 +5,7 @@
|
|
5 |
'use strict';
|
6 |
|
7 |
const {randomInt, randomBytes} = require('node:crypto'), {version: Version} = require('../package.json'), Encoder = (new TextDecoder,
|
8 |
-
new TextEncoder), Main = 'clewd修改版 v' + Version + '(
|
9 |
user: 'Human',
|
10 |
assistant: 'Assistant',
|
11 |
system: '',
|
@@ -13,9 +13,9 @@ new TextEncoder), Main = 'clewd修改版 v' + Version + '(2) by tera', Replaceme
|
|
13 |
example_assistant: 'A'
|
14 |
}, DangerChars = [ ...new Set([ ...Object.values(Replacements).join(''), ...'\n', ...':', ...'\\n' ]) ].filter((char => ' ' !== char)).sort(), AI = {
|
15 |
end: () => Buffer.from([ 104, 116, 116, 112, 115, 58, 47, 47, 99, 108, 97, 117, 100, 101, 46, 97, 105 ]).toString(),
|
16 |
-
mdl: () => JSON.parse(Buffer.from([ 91, 34, 33, 32, 85, 83, 73, 78, 71, 32, 77, 79, 68, 69, 76, 83, 32, 79, 84, 72, 69, 82, 32, 84, 72, 65, 78, 32,
|
17 |
zone: () => Buffer.from([ 65, 115, 105, 97, 47, 83, 104, 97, 110, 103, 104, 97, 105 ]).toString(), //Buffer.from([ 65, 109, 101, 114, 105, 99, 97, 47, 78, 101, 119, 95, 89, 111, 114, 107 ]).toString(),
|
18 |
-
agent: () => Buffer.from([ 77, 111, 122, 105, 108, 108, 97, 47, 53, 46, 48, 32, 40,
|
19 |
cp: () => Buffer.from([ 55, 55, 49, 44, 52, 56, 54, 53, 45, 52, 56, 54, 54, 45, 52, 56, 54, 55, 45, 52, 57, 49, 57, 53, 45, 52, 57, 49, 57, 57, 45, 52, 57, 49, 57, 54, 45, 52, 57, 50, 48, 48, 45, 53, 50, 51, 57, 51, 45, 53, 50, 51, 57, 50, 45, 52, 57, 49, 55, 49, 45, 52, 57, 49, 55, 50, 45, 49, 53, 54, 45, 49, 53, 55, 45, 52, 55, 45, 53, 51, 44, 48, 45, 50, 51, 45, 54, 53, 50, 56, 49, 45, 49, 48, 45, 49, 49, 45, 51, 53, 45, 49, 54, 45, 53, 45, 49, 51, 45, 49, 56, 45, 53, 49, 45, 52, 53, 45, 52, 51, 45, 50, 55, 45, 49, 55, 53, 49, 51, 45, 50, 49, 44, 50, 57, 45, 50, 51, 45, 50, 52, 44, 48 ]).toString(),
|
20 |
hdr: refPath => ({
|
21 |
'Content-Type': 'application/json',
|
@@ -34,72 +34,83 @@ new TextEncoder), Main = 'clewd修改版 v' + Version + '(2) by tera', Replaceme
|
|
34 |
return location;
|
35 |
};
|
36 |
|
37 |
-
module.exports = {
|
38 |
-
|
39 |
-
|
40 |
-
|
41 |
-
|
42 |
-
|
43 |
-
|
44 |
-
|
45 |
-
|
46 |
-
|
47 |
-
|
48 |
-
|
49 |
-
|
50 |
-
|
51 |
-
|
52 |
-
|
53 |
-
|
54 |
-
|
55 |
-
|
56 |
-
|
57 |
-
|
58 |
-
|
59 |
-
|
60 |
-
|
61 |
-
|
62 |
-
|
63 |
-
|
64 |
-
if (CookieChanger) {
|
65 |
-
console.log(`[35mExceeded limit![0m\n`);
|
66 |
-
CookieChanger && CookieChanger.emit('ChangeCookie');
|
67 |
-
}
|
68 |
/************************** */
|
|
|
|
|
|
|
69 |
}
|
70 |
-
|
71 |
-
throw err;
|
72 |
-
}
|
73 |
-
}
|
74 |
-
return err;
|
75 |
-
},
|
76 |
-
bytesToSize: (bytes = 0, decimals = 2) => {
|
77 |
-
if (0 === bytes) {
|
78 |
-
return '0 B';
|
79 |
}
|
80 |
-
|
81 |
-
|
82 |
-
},
|
83 |
-
indexOfAny: (text, last = false) => {
|
84 |
-
let location = -1;
|
85 |
-
const fakes = [ indexOfH(text, last), indexOfA(text, last) ].filter((idx => idx > -1)).sort();
|
86 |
-
location = last ? fakes.reverse()[0] : fakes[0];
|
87 |
-
return isNaN(location) ? -1 : location;
|
88 |
-
},
|
89 |
-
cleanJSON: json => json.indexOf('data:') > -1 ? json.split('data: ')?.[1] : json,
|
90 |
-
fileName: () => {
|
91 |
-
const len = randomInt(5, 15);
|
92 |
-
let name = randomBytes(len).toString('hex');
|
93 |
-
for (let i = 0; i < name.length; i++) {
|
94 |
-
const char = name.charAt(i);
|
95 |
-
isNaN(char) && randomInt(1, 5) % 2 == 0 && ' ' !== name.charAt(i - 1) && (name = name.slice(0, i) + ' ' + name.slice(i));
|
96 |
}
|
97 |
-
return name + '.txt';
|
98 |
-
},
|
99 |
-
indexOfA,
|
100 |
-
indexOfH,
|
101 |
-
setTitle: title => {
|
102 |
-
title = `${Main} - ${title}`;
|
103 |
-
process.title !== title && (process.title = title);
|
104 |
}
|
105 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5 |
'use strict';
|
6 |
|
7 |
const {randomInt, randomBytes} = require('node:crypto'), {version: Version} = require('../package.json'), Encoder = (new TextDecoder,
|
8 |
+
new TextEncoder), Main = 'clewd修改版 v' + Version + '(1) by tera', Replacements = {
|
9 |
user: 'Human',
|
10 |
assistant: 'Assistant',
|
11 |
system: '',
|
|
|
13 |
example_assistant: 'A'
|
14 |
}, DangerChars = [ ...new Set([ ...Object.values(Replacements).join(''), ...'\n', ...':', ...'\\n' ]) ].filter((char => ' ' !== char)).sort(), AI = {
|
15 |
end: () => Buffer.from([ 104, 116, 116, 112, 115, 58, 47, 47, 99, 108, 97, 117, 100, 101, 46, 97, 105 ]).toString(),
|
16 |
+
mdl: () => JSON.parse(Buffer.from([ 91, 34, 33, 32, 85, 83, 73, 78, 71, 32, 77, 79, 68, 69, 76, 83, 32, 79, 84, 72, 69, 82, 32, 84, 72, 65, 78, 32, 99, 108, 97, 117, 100, 101, 45, 50, 46, 49, 32, 42, 67, 79, 85, 76, 68, 42, 32, 71, 69, 84, 32, 89, 79, 85, 32, 66, 65, 78, 78, 69, 68, 32, 73, 70, 32, 89, 79, 85, 39, 82, 69, 32, 78, 79, 84, 32, 65, 32, 80, 82, 79, 32, 85, 83, 69, 82, 32, 33, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 49, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 105, 110, 115, 116, 97, 110, 116, 45, 49, 48, 48, 107, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 105, 110, 115, 116, 97, 110, 116, 45, 49, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 105, 110, 115, 116, 97, 110, 116, 45, 49, 46, 50, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 49, 46, 51, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 50, 46, 48, 45, 109, 97, 103, 101, 110, 116, 97, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 50, 34, 44, 34, 99, 108, 97, 117, 100, 101, 45, 50, 46, 49, 34, 93 ]).toString()),
|
17 |
zone: () => Buffer.from([ 65, 115, 105, 97, 47, 83, 104, 97, 110, 103, 104, 97, 105 ]).toString(), //Buffer.from([ 65, 109, 101, 114, 105, 99, 97, 47, 78, 101, 119, 95, 89, 111, 114, 107 ]).toString(),
|
18 |
+
agent: () => Buffer.from([ 77, 111, 122, 105, 108, 108, 97, 47, 53, 46, 48, 32, 40, 77, 97, 99, 105, 110, 116, 111, 115, 104, 59, 32, 73, 110, 116, 101, 108, 32, 77, 97, 99, 32, 79, 83, 32, 88, 32, 49, 48, 95, 49, 53, 95, 55, 41, 32, 65, 112, 112, 108, 101, 87, 101, 98, 75, 105, 116, 47, 53, 51, 55, 46, 51, 54, 32, 40, 75, 72, 84, 77, 76, 44, 32, 108, 105, 107, 101, 32, 71, 101, 99, 107, 111, 41, 32, 67, 104, 114, 111, 109, 101, 47, 49, 49, 52, 46, 48, 46, 48, 46, 48, 32, 83, 97, 102, 97, 114, 105, 47, 53, 51, 55, 46, 51, 54, 32, 69, 100, 103, 47, 49, 49, 52, 46, 48, 46, 49, 56, 50, 51, 46, 55, 57 ]).toString(),
|
19 |
cp: () => Buffer.from([ 55, 55, 49, 44, 52, 56, 54, 53, 45, 52, 56, 54, 54, 45, 52, 56, 54, 55, 45, 52, 57, 49, 57, 53, 45, 52, 57, 49, 57, 57, 45, 52, 57, 49, 57, 54, 45, 52, 57, 50, 48, 48, 45, 53, 50, 51, 57, 51, 45, 53, 50, 51, 57, 50, 45, 52, 57, 49, 55, 49, 45, 52, 57, 49, 55, 50, 45, 49, 53, 54, 45, 49, 53, 55, 45, 52, 55, 45, 53, 51, 44, 48, 45, 50, 51, 45, 54, 53, 50, 56, 49, 45, 49, 48, 45, 49, 49, 45, 51, 53, 45, 49, 54, 45, 53, 45, 49, 51, 45, 49, 56, 45, 53, 49, 45, 52, 53, 45, 52, 51, 45, 50, 55, 45, 49, 55, 53, 49, 51, 45, 50, 49, 44, 50, 57, 45, 50, 51, 45, 50, 52, 44, 48 ]).toString(),
|
20 |
hdr: refPath => ({
|
21 |
'Content-Type': 'application/json',
|
|
|
34 |
return location;
|
35 |
};
|
36 |
|
37 |
+
module.exports.encodeDataJSON = completion => Encoder.encode(`data: ${JSON.stringify(completion)}\n\n`);
|
38 |
+
|
39 |
+
module.exports.genericFixes = text => text.replace(/(\r\n|\r|\\n)/gm, '\n');
|
40 |
+
|
41 |
+
module.exports.Replacements = Replacements;
|
42 |
+
|
43 |
+
module.exports.DangerChars = DangerChars;
|
44 |
+
|
45 |
+
module.exports.checkResErr = async (res, CookieChanger, throwIt = true) => { //module.exports.checkResErr = async (res, throwIt = true) => {
|
46 |
+
let err, json, errAPI;
|
47 |
+
if ('string' == typeof res) {
|
48 |
+
json = JSON.parse(res);
|
49 |
+
errAPI = json.error;
|
50 |
+
err = Error(errAPI.message);
|
51 |
+
} else if (res.status < 200 || res.status >= 300) {
|
52 |
+
err = Error('Unexpected response code: ' + (res.status || json.status));
|
53 |
+
json = await res.json();
|
54 |
+
errAPI = json.error;
|
55 |
+
}
|
56 |
+
if (errAPI) {
|
57 |
+
err.status = res.status || json.status;
|
58 |
+
err.planned = true;
|
59 |
+
errAPI.message && (err.message = errAPI.message);
|
60 |
+
errAPI.type && (err.type = errAPI.type);
|
61 |
+
if ((429 === res.status || 429 === json.status) && errAPI.resets_at) {
|
62 |
+
const hours = ((new Date(1e3 * errAPI.resets_at).getTime() - Date.now()) / 1e3 / 60 / 60).toFixed(1);
|
63 |
+
err.message += `, expires in ${hours} hours`;
|
|
|
|
|
|
|
|
|
64 |
/************************** */
|
65 |
+
if (CookieChanger) {
|
66 |
+
console.log(`[35mExceeded limit![0m\n`);
|
67 |
+
CookieChanger && CookieChanger.emit('ChangeCookie');
|
68 |
}
|
69 |
+
/************************** */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
70 |
}
|
71 |
+
if (throwIt) {
|
72 |
+
throw err;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
73 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
74 |
}
|
75 |
+
return err;
|
76 |
+
};
|
77 |
+
|
78 |
+
module.exports.bytesToSize = (bytes = 0, decimals = 2) => {
|
79 |
+
if (0 === bytes) {
|
80 |
+
return '0 Bytes';
|
81 |
+
}
|
82 |
+
const dm = decimals < 0 ? 0 : decimals, i = Math.round(Math.log(bytes) / Math.log(1024));
|
83 |
+
return `${(bytes / Math.pow(1024, i)).toFixed(dm)} ${[ 'Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB' ][i]}`;
|
84 |
+
};
|
85 |
+
|
86 |
+
module.exports.indexOfAny = (text, last = false) => {
|
87 |
+
let location = -1;
|
88 |
+
const fakes = [ indexOfH(text, last), indexOfA(text, last) ].filter((idx => idx > -1)).sort();
|
89 |
+
location = last ? fakes.reverse()[0] : fakes[0];
|
90 |
+
return isNaN(location) ? -1 : location;
|
91 |
+
};
|
92 |
+
|
93 |
+
module.exports.cleanJSON = json => json.replace(/^data: {/gim, '{').replace(/\s+$/gim, '');
|
94 |
+
|
95 |
+
module.exports.fileName = () => {
|
96 |
+
const len = randomInt(5, 15);
|
97 |
+
let name = randomBytes(len).toString('hex');
|
98 |
+
for (let i = 0; i < name.length; i++) {
|
99 |
+
const char = name.charAt(i);
|
100 |
+
isNaN(char) && randomInt(1, 5) % 2 == 0 && ' ' !== name.charAt(i - 1) && (name = name.slice(0, i) + ' ' + name.slice(i));
|
101 |
+
}
|
102 |
+
return name + '.txt';
|
103 |
+
};
|
104 |
+
|
105 |
+
module.exports.indexOfA = indexOfA;
|
106 |
+
|
107 |
+
module.exports.indexOfH = indexOfH;
|
108 |
+
|
109 |
+
module.exports.setTitle = title => {
|
110 |
+
title = `${Main} - ${title}`;
|
111 |
+
process.title !== title && (process.title = title);
|
112 |
+
};
|
113 |
+
|
114 |
+
module.exports.Main = Main;
|
115 |
+
|
116 |
+
module.exports.AI = AI;
|