mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2025-06-05 21:59:27 +02:00
Merge branch 'main' into dev
This commit is contained in:
Binary file not shown.
Before Width: | Height: | Size: 2.9 KiB |
Binary file not shown.
Before Width: | Height: | Size: 396 KiB After Width: | Height: | Size: 396 KiB |
Binary file not shown.
Before Width: | Height: | Size: 420 KiB After Width: | Height: | Size: 420 KiB |
File diff suppressed because it is too large
Load Diff
@@ -10,7 +10,7 @@ let extensions = [];
|
|||||||
<h3>Extensions</h3>
|
<h3>Extensions</h3>
|
||||||
<input id="extensions_url" type="text" class="text_pole" />
|
<input id="extensions_url" type="text" class="text_pole" />
|
||||||
<div class="extensions_url_block">
|
<div class="extensions_url_block">
|
||||||
<input id="extensions_connect" type="submit" value="Connect" />
|
<input id="extensions_connect" class="menu_button" type="submit" value="Connect" />
|
||||||
<span class="expander"></span>
|
<span class="expander"></span>
|
||||||
<input id="extensions_autoconnect" type="checkbox"/><h4>Auto-connect</h4>
|
<input id="extensions_autoconnect" type="checkbox"/><h4>Auto-connect</h4>
|
||||||
</div>
|
</div>
|
||||||
@@ -214,8 +214,9 @@ let extensions = [];
|
|||||||
}
|
}
|
||||||
|
|
||||||
$(document).ready(async function () {
|
$(document).ready(async function () {
|
||||||
|
debugger;
|
||||||
const url = localStorage.getItem(extensions_urlKey) ?? defaultUrl;
|
const url = localStorage.getItem(extensions_urlKey) ?? defaultUrl;
|
||||||
const autoConnect = Boolean(localStorage.getItem(extensions_autoConnectKey)) ?? false;
|
const autoConnect = localStorage.getItem(extensions_autoConnectKey) == 'true';
|
||||||
$('#rm_api_block').append(settings_html);
|
$('#rm_api_block').append(settings_html);
|
||||||
$('head').append(settings_style);
|
$('head').append(settings_style);
|
||||||
$("#extensions_url").val(url);
|
$("#extensions_url").val(url);
|
||||||
|
826
public/style.css
826
public/style.css
File diff suppressed because it is too large
Load Diff
103
server.js
103
server.js
@@ -58,16 +58,20 @@ var api_key_novel;
|
|||||||
//New chats made with characters will use this new formatting.
|
//New chats made with characters will use this new formatting.
|
||||||
//Useable variable is (( humanizedISO8601Datetime ))
|
//Useable variable is (( humanizedISO8601Datetime ))
|
||||||
|
|
||||||
var baseDate = new Date(Date.now());
|
|
||||||
var humanYear = baseDate.getFullYear();
|
|
||||||
var humanMonth = (baseDate.getMonth()+1);
|
|
||||||
var humanDate = baseDate.getDate();
|
|
||||||
var humanHour = (baseDate.getHours() < 10? '0' : '') + baseDate.getHours();
|
|
||||||
var humanMinute = (baseDate.getMinutes() < 10? '0' : '') + baseDate.getMinutes();
|
|
||||||
var humanSecond = (baseDate.getSeconds() < 10? '0' : '') + baseDate.getSeconds();
|
|
||||||
var humanMillisecond = (baseDate.getMilliseconds() < 10? '0' : '') + baseDate.getMilliseconds();
|
|
||||||
|
|
||||||
var humanizedISO8601DateTime = (humanYear+"-"+humanMonth+"-"+humanDate+" @"+humanHour+"h "+humanMinute+"m "+humanSecond+"s "+humanMillisecond+"ms");
|
|
||||||
|
function humanizedISO8601DateTime() {
|
||||||
|
let baseDate = new Date(Date.now());
|
||||||
|
let humanYear = baseDate.getFullYear();
|
||||||
|
let humanMonth = (baseDate.getMonth()+1);
|
||||||
|
let humanDate = baseDate.getDate();
|
||||||
|
let humanHour = (baseDate.getHours() < 10? '0' : '') + baseDate.getHours();
|
||||||
|
let humanMinute = (baseDate.getMinutes() < 10? '0' : '') + baseDate.getMinutes();
|
||||||
|
let humanSecond = (baseDate.getSeconds() < 10? '0' : '') + baseDate.getSeconds();
|
||||||
|
let humanMillisecond = (baseDate.getMilliseconds() < 10? '0' : '') + baseDate.getMilliseconds();
|
||||||
|
let HumanizedDateTime = (humanYear+"-"+humanMonth+"-"+humanDate+" @"+humanHour+"h "+humanMinute+"m "+humanSecond+"s "+humanMillisecond+"ms");
|
||||||
|
return HumanizedDateTime;
|
||||||
|
};
|
||||||
|
|
||||||
var is_colab = false;
|
var is_colab = false;
|
||||||
var charactersPath = 'public/characters/';
|
var charactersPath = 'public/characters/';
|
||||||
@@ -288,7 +292,7 @@ app.post("/generate", jsonParser, function(request, response_generate = response
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
app.post("/savechat", jsonParser, function(request, response){
|
app.post("/savechat", jsonParser, function(request, response){
|
||||||
//console.log('/savechat/ entered');
|
//console.log(humanizedISO8601DateTime()+':/savechat/ entered');
|
||||||
//console.log(request.data);
|
//console.log(request.data);
|
||||||
//console.log(request.body.bg);
|
//console.log(request.body.bg);
|
||||||
//const data = request.body;
|
//const data = request.body;
|
||||||
@@ -296,8 +300,10 @@ app.post("/savechat", jsonParser, function(request, response){
|
|||||||
//console.log(request.body.chat);
|
//console.log(request.body.chat);
|
||||||
//var bg = "body {background-image: linear-gradient(rgba(19,21,44,0.75), rgba(19,21,44,0.75)), url(../backgrounds/"+request.body.bg+");}";
|
//var bg = "body {background-image: linear-gradient(rgba(19,21,44,0.75), rgba(19,21,44,0.75)), url(../backgrounds/"+request.body.bg+");}";
|
||||||
var dir_name = String(request.body.avatar_url).replace('.png','');
|
var dir_name = String(request.body.avatar_url).replace('.png','');
|
||||||
|
//console.log(humanizedISO8601DateTime()+':/savechat sees '+dir_name+' as the character name (derived from avatar PNG filename)');
|
||||||
let chat_data = request.body.chat;
|
let chat_data = request.body.chat;
|
||||||
let jsonlData = chat_data.map(JSON.stringify).join('\n');
|
let jsonlData = chat_data.map(JSON.stringify).join('\n');
|
||||||
|
//console.log(humanizedISO8601DateTime()+':/savechat saving a chat named '+request.body.file_name+'.jsonl');
|
||||||
fs.writeFile(chatsPath+dir_name+"/"+request.body.file_name+'.jsonl', jsonlData, 'utf8', function(err) {
|
fs.writeFile(chatsPath+dir_name+"/"+request.body.file_name+'.jsonl', jsonlData, 'utf8', function(err) {
|
||||||
if(err) {
|
if(err) {
|
||||||
response.send(err);
|
response.send(err);
|
||||||
@@ -317,7 +323,7 @@ app.post("/getchat", jsonParser, function(request, response){
|
|||||||
//console.log(request);
|
//console.log(request);
|
||||||
//console.log(request.body.chat);
|
//console.log(request.body.chat);
|
||||||
//var bg = "body {background-image: linear-gradient(rgba(19,21,44,0.75), rgba(19,21,44,0.75)), url(../backgrounds/"+request.body.bg+");}";
|
//var bg = "body {background-image: linear-gradient(rgba(19,21,44,0.75), rgba(19,21,44,0.75)), url(../backgrounds/"+request.body.bg+");}";
|
||||||
//console.log('/getchat entered');
|
//console.log(humanizedISO8601DateTime()+':/getchat entered');
|
||||||
var dir_name = String(request.body.avatar_url).replace('.png','');
|
var dir_name = String(request.body.avatar_url).replace('.png','');
|
||||||
|
|
||||||
fs.stat(chatsPath+dir_name, function(err, stat) {
|
fs.stat(chatsPath+dir_name, function(err, stat) {
|
||||||
@@ -334,7 +340,7 @@ app.post("/getchat", jsonParser, function(request, response){
|
|||||||
fs.stat(chatsPath+dir_name+"/"+request.body.file_name+".jsonl", function(err, stat) {
|
fs.stat(chatsPath+dir_name+"/"+request.body.file_name+".jsonl", function(err, stat) {
|
||||||
|
|
||||||
if (err === null) { //if no error (the file exists), read the file
|
if (err === null) { //if no error (the file exists), read the file
|
||||||
|
//console.log(humanizedISO8601DateTime()+':/getchat tries to access: '+chatsPath+dir_name+'/'+request.body.file_name+'.jsonl');
|
||||||
if(stat !== undefined){
|
if(stat !== undefined){
|
||||||
fs.readFile(chatsPath+dir_name+"/"+request.body.file_name+".jsonl", 'utf8', (err, data) => {
|
fs.readFile(chatsPath+dir_name+"/"+request.body.file_name+".jsonl", 'utf8', (err, data) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
@@ -362,11 +368,8 @@ app.post("/getchat", jsonParser, function(request, response){
|
|||||||
console.error(err);
|
console.error(err);
|
||||||
response.send({});
|
response.send({});
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
@@ -466,27 +469,29 @@ function checkServer(){
|
|||||||
|
|
||||||
//***************** Main functions
|
//***************** Main functions
|
||||||
function charaFormatData(data){
|
function charaFormatData(data){
|
||||||
var char = {"name": data.ch_name, "description": data.description, "personality": data.personality, "first_mes": data.first_mes, "avatar": 'none', "chat": Date.now(), "mes_example": data.mes_example, "scenario": data.scenario, "create_date": Date.now(), "talkativeness": data.talkativeness};
|
var char = {"name": data.ch_name, "description": data.description, "personality": data.personality, "first_mes": data.first_mes, "avatar": 'none', "chat": data.ch_name+' - '+humanizedISO8601DateTime(), "mes_example": data.mes_example, "scenario": data.scenario, "create_date": humanizedISO8601DateTime, "talkativeness": data.talkativeness};
|
||||||
return char;
|
return char;
|
||||||
}
|
}
|
||||||
app.post("/createcharacter", urlencodedParser, function(request, response){
|
app.post("/createcharacter", urlencodedParser, function(request, response){
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//var sameNameChar = fs.existsSync(charactersPath+request.body.ch_name+'.png');
|
||||||
|
//if (sameNameChar == true) return response.sendStatus(500);
|
||||||
if(!request.body) return response.sendStatus(400);
|
if(!request.body) return response.sendStatus(400);
|
||||||
|
console.log('/createcharacter -- looking for -- '+(charactersPath+request.body.ch_name+'.png'));
|
||||||
|
console.log('Does this file already exists? '+fs.existsSync(charactersPath+request.body.ch_name+'.png'));
|
||||||
if (!fs.existsSync(charactersPath+request.body.ch_name+'.png')){
|
if (!fs.existsSync(charactersPath+request.body.ch_name+'.png')){
|
||||||
if(!fs.existsSync(chatsPath+request.body.ch_name) )fs.mkdirSync(chatsPath+request.body.ch_name);
|
if(!fs.existsSync(chatsPath+request.body.ch_name) )fs.mkdirSync(chatsPath+request.body.ch_name);
|
||||||
|
|
||||||
let filedata = request.file;
|
let filedata = request.file;
|
||||||
//console.log(filedata.mimetype);
|
//console.log(filedata.mimetype);
|
||||||
var fileType = ".png";
|
var fileType = ".png";
|
||||||
var img_file = "ai";
|
var img_file = "ai";
|
||||||
var img_path = "public/img/";
|
var img_path = "public/img/";
|
||||||
|
|
||||||
var char = charaFormatData(request.body);//{"name": request.body.ch_name, "description": request.body.description, "personality": request.body.personality, "first_mes": request.body.first_mes, "avatar": 'none', "chat": Date.now(), "last_mes": '', "mes_example": ''};
|
var char = charaFormatData(request.body);//{"name": request.body.ch_name, "description": request.body.description, "personality": request.body.personality, "first_mes": request.body.first_mes, "avatar": 'none', "chat": Date.now(), "last_mes": '', "mes_example": ''};
|
||||||
char = JSON.stringify(char);
|
char = JSON.stringify(char);
|
||||||
if(!filedata){
|
if(!filedata){
|
||||||
|
|
||||||
charaWrite('./public/img/fluffy.png', char, request.body.ch_name, response);
|
charaWrite('./public/img/fluffy.png', char, request.body.ch_name, response);
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
|
|
||||||
img_path = "./uploads/";
|
img_path = "./uploads/";
|
||||||
@@ -500,7 +505,9 @@ app.post("/createcharacter", urlencodedParser, function(request, response){
|
|||||||
//console.log("The file was saved.");
|
//console.log("The file was saved.");
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
|
console.error("Error: Cannot save file. A character with that name already exists.");
|
||||||
response.send("Error: A character with that name already exists.");
|
response.send("Error: A character with that name already exists.");
|
||||||
|
//response.send({error: true});
|
||||||
}
|
}
|
||||||
//console.log(request.body);
|
//console.log(request.body);
|
||||||
//response.send(request.body.ch_name);
|
//response.send(request.body.ch_name);
|
||||||
@@ -1020,12 +1027,14 @@ app.post("/getallchatsofcharacter", jsonParser, function(request, response){
|
|||||||
var char_dir = (request.body.avatar_url).replace('.png','')
|
var char_dir = (request.body.avatar_url).replace('.png','')
|
||||||
fs.readdir(chatsPath+char_dir, (err, files) => {
|
fs.readdir(chatsPath+char_dir, (err, files) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
|
console.log('found error in history loading');
|
||||||
console.error(err);
|
console.error(err);
|
||||||
response.send({error: true});
|
response.send({error: true});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// filter for JSON files
|
// filter for JSON files
|
||||||
|
console.log('looking for JSONL files');
|
||||||
const jsonFiles = files.filter(file => path.extname(file) === '.jsonl');
|
const jsonFiles = files.filter(file => path.extname(file) === '.jsonl');
|
||||||
|
|
||||||
// sort the files by name
|
// sort the files by name
|
||||||
@@ -1033,10 +1042,10 @@ app.post("/getallchatsofcharacter", jsonParser, function(request, response){
|
|||||||
// print the sorted file names
|
// print the sorted file names
|
||||||
var chatData = {};
|
var chatData = {};
|
||||||
let ii = jsonFiles.length; //this is the number of files belonging to the character
|
let ii = jsonFiles.length; //this is the number of files belonging to the character
|
||||||
|
if (ii !== 0) {
|
||||||
|
//console.log('found '+ii+' chat logs to load');
|
||||||
for(let i = jsonFiles.length-1; i >= 0; i--){
|
for(let i = jsonFiles.length-1; i >= 0; i--){
|
||||||
const file = jsonFiles[i];
|
const file = jsonFiles[i];
|
||||||
|
|
||||||
const fileStream = fs.createReadStream(chatsPath+char_dir+'/'+file);
|
const fileStream = fs.createReadStream(chatsPath+char_dir+'/'+file);
|
||||||
const rl = readline.createInterface({
|
const rl = readline.createInterface({
|
||||||
input: fileStream,
|
input: fileStream,
|
||||||
@@ -1056,18 +1065,23 @@ app.post("/getallchatsofcharacter", jsonParser, function(request, response){
|
|||||||
chatData[i]['mes'] = jsonData['mes'];
|
chatData[i]['mes'] = jsonData['mes'];
|
||||||
ii--;
|
ii--;
|
||||||
if(ii === 0){
|
if(ii === 0){
|
||||||
|
console.log('ii count went to zero, responding with chatData');
|
||||||
response.send(chatData);
|
response.send(chatData);
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
|
console.log('just returning from getallchatsofcharacter');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
console.log('successfully closing getallchatsofcharacter');
|
||||||
rl.close();
|
rl.close();
|
||||||
});
|
});
|
||||||
}
|
};
|
||||||
});
|
}else{
|
||||||
|
//console.log('Found No Chats. Exiting Load Routine.');
|
||||||
});
|
response.send({error: true});
|
||||||
|
};
|
||||||
|
})});
|
||||||
function getPngName(file){
|
function getPngName(file){
|
||||||
let i = 1;
|
let i = 1;
|
||||||
let base_name = file;
|
let base_name = file;
|
||||||
@@ -1078,6 +1092,7 @@ function getPngName(file){
|
|||||||
return file;
|
return file;
|
||||||
}
|
}
|
||||||
app.post("/importcharacter", urlencodedParser, async function(request, response){
|
app.post("/importcharacter", urlencodedParser, async function(request, response){
|
||||||
|
|
||||||
if(!request.body) return response.sendStatus(400);
|
if(!request.body) return response.sendStatus(400);
|
||||||
|
|
||||||
let png_name = '';
|
let png_name = '';
|
||||||
@@ -1094,24 +1109,20 @@ app.post("/importcharacter", urlencodedParser, async function(request, response)
|
|||||||
}
|
}
|
||||||
const jsonData = JSON.parse(data);
|
const jsonData = JSON.parse(data);
|
||||||
|
|
||||||
try {
|
|
||||||
if(jsonData.name !== undefined){
|
if(jsonData.name !== undefined){
|
||||||
png_name = getPngName(jsonData.name);
|
png_name = getPngName(jsonData.name);
|
||||||
let char = {"name": jsonData.name, "description": jsonData.description ?? '', "personality": jsonData.personality ?? '', "first_mes": jsonData.first_mes ?? '', "avatar": 'none', "chat": Date.now(), "mes_example": jsonData.mes_example ?? '', "scenario": jsonData.scenario ?? '', "create_date": Date.now(), "talkativeness": jsonData.talkativeness ?? 0.5};
|
let char = {"name": jsonData.name, "description": jsonData.description ?? '', "personality": jsonData.personality ?? '', "first_mes": jsonData.first_mes ?? '', "avatar": 'none', "chat": humanizedISO8601DateTime(), "mes_example": jsonData.mes_example ?? '', "scenario": jsonData.scenario ?? '', "create_date": humanizedISO8601DateTime, "talkativeness": jsonData.talkativeness ?? 0.5};
|
||||||
char = JSON.stringify(char);
|
char = JSON.stringify(char);
|
||||||
await charaWrite('./public/img/fluffy.png', char, png_name, response, {file_name: png_name});
|
charaWrite('./public/img/fluffy.png', char, png_name, response, {file_name: png_name});
|
||||||
}else if(jsonData.char_name !== undefined){//json Pygmalion notepad
|
}else if(jsonData.char_name !== undefined){//json Pygmalion notepad
|
||||||
png_name = getPngName(jsonData.char_name);
|
png_name = getPngName(jsonData.char_name);
|
||||||
let char = {"name": jsonData.char_name, "description": jsonData.char_persona ?? '', "personality": '', "first_mes": jsonData.char_greeting ?? '', "avatar": 'none', "chat": Date.now(), "mes_example": jsonData.example_dialogue ?? '', "scenario": jsonData.world_scenario ?? '', "create_date": Date.now(), "talkativeness": jsonData.talkativeness ?? 0.5};
|
let char = {"name": jsonData.char_name, "description": jsonData.char_persona ?? '', "personality": '', "first_mes": jsonData.char_greeting ?? '', "avatar": 'none', "chat": humanizedISO8601DateTime(), "mes_example": jsonData.example_dialogue ?? '', "scenario": jsonData.world_scenario ?? '', "create_date": humanizedISO8601DateTime, "talkativeness": jsonData.talkativeness ?? 0.5};
|
||||||
char = JSON.stringify(char);
|
char = JSON.stringify(char);
|
||||||
await charaWrite('./public/img/fluffy.png', char, png_name, response, {file_name: png_name});
|
charaWrite('./public/img/fluffy.png', char, png_name, response, {file_name: png_name});
|
||||||
}else{
|
}else{
|
||||||
console.log('Incorrect character format .json');
|
console.log('Incorrect character format .json');
|
||||||
response.send({error:true});
|
response.send({error:true});
|
||||||
}
|
}
|
||||||
} catch {
|
|
||||||
response.send({ error: true });
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}else{
|
}else{
|
||||||
try{
|
try{
|
||||||
@@ -1121,7 +1132,7 @@ app.post("/importcharacter", urlencodedParser, async function(request, response)
|
|||||||
png_name = getPngName(jsonData.name);
|
png_name = getPngName(jsonData.name);
|
||||||
|
|
||||||
if(jsonData.name !== undefined){
|
if(jsonData.name !== undefined){
|
||||||
let char = {"name": jsonData.name, "description": jsonData.description ?? '', "personality": jsonData.personality ?? '', "first_mes": jsonData.first_mes ?? '', "avatar": 'none', "chat": Date.now(), "mes_example": jsonData.mes_example ?? '', "scenario": jsonData.scenario ?? '', "create_date": Date.now(), "talkativeness": jsonData.talkativeness ?? 0.5};
|
let char = {"name": jsonData.name, "description": jsonData.description ?? '', "personality": jsonData.personality ?? '', "first_mes": jsonData.first_mes ?? '', "avatar": 'none', "chat": humanizedISO8601DateTime(), "mes_example": jsonData.mes_example ?? '', "scenario": jsonData.scenario ?? '', "create_date": humanizedISO8601DateTime, "talkativeness": jsonData.talkativeness ?? 0.5};
|
||||||
char = JSON.stringify(char);
|
char = JSON.stringify(char);
|
||||||
await charaWrite('./uploads/'+filedata.filename, char, png_name, response, {file_name: png_name});
|
await charaWrite('./uploads/'+filedata.filename, char, png_name, response, {file_name: png_name});
|
||||||
/*
|
/*
|
||||||
@@ -1153,6 +1164,7 @@ app.post("/importcharacter", urlencodedParser, async function(request, response)
|
|||||||
});
|
});
|
||||||
|
|
||||||
app.post("/importchat", urlencodedParser, function(request, response){
|
app.post("/importchat", urlencodedParser, function(request, response){
|
||||||
|
//console.log(humanizedISO8601DateTime()+':/importchat begun');
|
||||||
if(!request.body) return response.sendStatus(400);
|
if(!request.body) return response.sendStatus(400);
|
||||||
|
|
||||||
var format = request.body.file_type;
|
var format = request.body.file_type;
|
||||||
@@ -1176,11 +1188,12 @@ app.post("/importchat", urlencodedParser, function(request, response){
|
|||||||
const jsonData = JSON.parse(data);
|
const jsonData = JSON.parse(data);
|
||||||
var new_chat = [];
|
var new_chat = [];
|
||||||
if(jsonData.histories !== undefined){
|
if(jsonData.histories !== undefined){
|
||||||
|
//console.log('/importchat confirms JSON histories are defined');
|
||||||
let i = 0;
|
let i = 0;
|
||||||
new_chat[i] = {};
|
new_chat[i] = {};
|
||||||
new_chat[0]['user_name'] = 'You';
|
new_chat[0]['user_name'] = 'You';
|
||||||
new_chat[0]['character_name'] = ch_name;
|
new_chat[0]['character_name'] = ch_name;
|
||||||
new_chat[0]['create_date'] = Date.now() //Date.now();
|
new_chat[0]['create_date'] = humanizedISO8601DateTime() //Date.now();
|
||||||
i++;
|
i++;
|
||||||
jsonData.histories.histories[0].msgs.forEach(function(item) {
|
jsonData.histories.histories[0].msgs.forEach(function(item) {
|
||||||
new_chat[i] = {};
|
new_chat[i] = {};
|
||||||
@@ -1191,12 +1204,13 @@ app.post("/importchat", urlencodedParser, function(request, response){
|
|||||||
}
|
}
|
||||||
new_chat[i]['is_user'] = item.src.is_human;
|
new_chat[i]['is_user'] = item.src.is_human;
|
||||||
new_chat[i]['is_name'] = true;
|
new_chat[i]['is_name'] = true;
|
||||||
new_chat[i]['send_date'] = Date.now() //Date.now();
|
new_chat[i]['send_date'] = humanizedISO8601DateTime() //Date.now();
|
||||||
new_chat[i]['mes'] = item.text;
|
new_chat[i]['mes'] = item.text;
|
||||||
i++;
|
i++;
|
||||||
});
|
});
|
||||||
const chatJsonlData = new_chat.map(JSON.stringify).join('\n');
|
const chatJsonlData = new_chat.map(JSON.stringify).join('\n');
|
||||||
fs.writeFile(chatsPath+avatar_url+'/'+ch_name+' - '+humanizedISO8601DateTime+' imported.jsonl', chatJsonlData, 'utf8', function(err) { //added ch_name and replaced Date.now() with humanizedISO8601DateTime
|
//console.log('/importchat saving a file: '+ch_name+' - '+humanizedISO8601DateTime()+' imported.jsonl');
|
||||||
|
fs.writeFile(chatsPath+avatar_url+'/'+ch_name+' - '+humanizedISO8601DateTime()+' imported.jsonl', chatJsonlData, 'utf8', function(err) { //added ch_name and replaced Date.now() with humanizedISO8601DateTime
|
||||||
|
|
||||||
if(err) {
|
if(err) {
|
||||||
response.send(err);
|
response.send(err);
|
||||||
@@ -1216,6 +1230,7 @@ app.post("/importchat", urlencodedParser, function(request, response){
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
if(format === 'jsonl'){
|
if(format === 'jsonl'){
|
||||||
|
//console.log(humanizedISO8601DateTime()+':imported chat format is JSONL');
|
||||||
const fileStream = fs.createReadStream('./uploads/'+filedata.filename);
|
const fileStream = fs.createReadStream('./uploads/'+filedata.filename);
|
||||||
const rl = readline.createInterface({
|
const rl = readline.createInterface({
|
||||||
input: fileStream,
|
input: fileStream,
|
||||||
@@ -1226,7 +1241,8 @@ app.post("/importchat", urlencodedParser, function(request, response){
|
|||||||
let jsonData = JSON.parse(line);
|
let jsonData = JSON.parse(line);
|
||||||
|
|
||||||
if(jsonData.user_name !== undefined){
|
if(jsonData.user_name !== undefined){
|
||||||
fs.copyFile('./uploads/'+filedata.filename, chatsPath+avatar_url+'/'+ch_name+' - '+humanizedISO8601DateTime+'.jsonl', (err) => { //added character name and replaced Date.now() with humanizedISO8601DateTime
|
//console.log(humanizedISO8601DateTime()+':/importchat copying chat as '+ch_name+' - '+humanizedISO8601DateTime()+'.jsonl');
|
||||||
|
fs.copyFile('./uploads/'+filedata.filename, chatsPath+avatar_url+'/'+ch_name+' - '+humanizedISO8601DateTime()+'.jsonl', (err) => { //added character name and replaced Date.now() with humanizedISO8601DateTime
|
||||||
if(err) {
|
if(err) {
|
||||||
response.send({error:true});
|
response.send({error:true});
|
||||||
return console.log(err);
|
return console.log(err);
|
||||||
@@ -1524,7 +1540,7 @@ function convertStage2(){
|
|||||||
//console.log(directoriesB[key]);
|
//console.log(directoriesB[key]);
|
||||||
|
|
||||||
var char = JSON.parse(charactersB[key]);
|
var char = JSON.parse(charactersB[key]);
|
||||||
char.create_date = Date.now();
|
char.create_date = humanizedISO8601DateTime();
|
||||||
charactersB[key] = JSON.stringify(char);
|
charactersB[key] = JSON.stringify(char);
|
||||||
var avatar = 'public/img/fluffy.png';
|
var avatar = 'public/img/fluffy.png';
|
||||||
if(char.avatar !== 'none'){
|
if(char.avatar !== 'none'){
|
||||||
@@ -1554,7 +1570,7 @@ function convertStage2(){
|
|||||||
}
|
}
|
||||||
let i = 0;
|
let i = 0;
|
||||||
let ii = 0;
|
let ii = 0;
|
||||||
new_chat_data[i] = {user_name:'You', character_name:char.name, create_date: Date.now()};
|
new_chat_data[i] = {user_name:'You', character_name:char.name, create_date: humanizedISO8601DateTime()};
|
||||||
i++;
|
i++;
|
||||||
ii++;
|
ii++;
|
||||||
chat_data.forEach(function(mes) {
|
chat_data.forEach(function(mes) {
|
||||||
@@ -1570,14 +1586,14 @@ function convertStage2(){
|
|||||||
new_chat_data[ii]['name'] = char.name;
|
new_chat_data[ii]['name'] = char.name;
|
||||||
new_chat_data[ii]['is_user'] = false;
|
new_chat_data[ii]['is_user'] = false;
|
||||||
new_chat_data[ii]['is_name'] = is_name;
|
new_chat_data[ii]['is_name'] = is_name;
|
||||||
new_chat_data[ii]['send_date'] = Date.now(); //Date.now();
|
new_chat_data[ii]['send_date'] = humanizedISO8601DateTime(); //Date.now();
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
mes = mes.replace(this_chat_user_name+':','');
|
mes = mes.replace(this_chat_user_name+':','');
|
||||||
new_chat_data[ii]['name'] = 'You';
|
new_chat_data[ii]['name'] = 'You';
|
||||||
new_chat_data[ii]['is_user'] = true;
|
new_chat_data[ii]['is_user'] = true;
|
||||||
new_chat_data[ii]['is_name'] = true;
|
new_chat_data[ii]['is_name'] = true;
|
||||||
new_chat_data[ii]['send_date'] = Date.now() //Date.now();
|
new_chat_data[ii]['send_date'] = humanizedISO8601DateTime(); //Date.now();
|
||||||
|
|
||||||
}
|
}
|
||||||
new_chat_data[ii]['mes'] = mes.trim();
|
new_chat_data[ii]['mes'] = mes.trim();
|
||||||
@@ -1589,6 +1605,7 @@ function convertStage2(){
|
|||||||
});
|
});
|
||||||
const jsonlData = new_chat_data.map(JSON.stringify).join('\n');
|
const jsonlData = new_chat_data.map(JSON.stringify).join('\n');
|
||||||
// Write the contents to the destination folder
|
// Write the contents to the destination folder
|
||||||
|
//console.log('convertstage2 writing a file: '+chatsPath+char.name+'/' + file+'l');
|
||||||
fs.writeFileSync(chatsPath+char.name+'/' + file+'l', jsonlData);
|
fs.writeFileSync(chatsPath+char.name+'/' + file+'l', jsonlData);
|
||||||
});
|
});
|
||||||
//fs.rmSync('public/characters/'+directoriesB[key],{ recursive: true });
|
//fs.rmSync('public/characters/'+directoriesB[key],{ recursive: true });
|
||||||
|
Reference in New Issue
Block a user