Merge pull request #1887 from Bronya-Rand/staging
Import PygmalionAI/JanitorAI/Chub Bots via UUID
This commit is contained in:
commit
1395f9bd9e
|
@ -9974,10 +9974,10 @@ jQuery(async function () {
|
||||||
const html = `<h3>Enter the URL of the content to import</h3>
|
const html = `<h3>Enter the URL of the content to import</h3>
|
||||||
Supported sources:<br>
|
Supported sources:<br>
|
||||||
<ul class="justifyLeft">
|
<ul class="justifyLeft">
|
||||||
<li>Chub characters (direct link or id)<br>Example: <tt>Anonymous/example-character</tt></li>
|
<li>Chub Character (Direct Link or ID)<br>Example: <tt>Anonymous/example-character</tt></li>
|
||||||
<li>Chub lorebooks (direct link or id)<br>Example: <tt>lorebooks/bartleby/example-lorebook</tt></li>
|
<li>Chub Lorebook (Direct Link or ID)<br>Example: <tt>lorebooks/bartleby/example-lorebook</tt></li>
|
||||||
<li>JanitorAI character (direct link or id)<br>Example: <tt>https://janitorai.com/characters/ddd1498a-a370-4136-b138-a8cd9461fdfe_character-aqua-the-useless-goddess</tt></li>
|
<li>JanitorAI Character (Direct Link or UUID)<br>Example: <tt>ddd1498a-a370-4136-b138-a8cd9461fdfe_character-aqua-the-useless-goddess</tt></li>
|
||||||
<li>Pygmalion.chat character (link)<br>Example: <tt>https://pygmalion.chat/character/a7ca95a1-0c88-4e23-91b3-149db1e78ab9</tt></li>
|
<li>Pygmalion.chat Character (Direct Link or UUID)<br>Example: <tt>a7ca95a1-0c88-4e23-91b3-149db1e78ab9</tt></li>
|
||||||
<li>More coming soon...</li>
|
<li>More coming soon...</li>
|
||||||
<ul>`;
|
<ul>`;
|
||||||
const input = await callPopup(html, 'input', '', { okButton: 'Import', rows: 4 });
|
const input = await callPopup(html, 'input', '', { okButton: 'Import', rows: 4 });
|
||||||
|
@ -9988,13 +9988,23 @@ jQuery(async function () {
|
||||||
}
|
}
|
||||||
|
|
||||||
const url = input.trim();
|
const url = input.trim();
|
||||||
console.debug('Custom content import started', url);
|
var request;
|
||||||
|
|
||||||
const request = await fetch('/api/content/import', {
|
if (url.includes("https")) {
|
||||||
|
console.debug('Custom content import started for URL: ', url);
|
||||||
|
request = await fetch('/api/content/importURL', {
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
headers: getRequestHeaders(),
|
headers: getRequestHeaders(),
|
||||||
body: JSON.stringify({ url }),
|
body: JSON.stringify({ url }),
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
console.debug('Custom content import started for Char UUID: ', url);
|
||||||
|
request = await fetch('/api/content/importUUID', {
|
||||||
|
method: 'POST',
|
||||||
|
headers: getRequestHeaders(),
|
||||||
|
body: JSON.stringify({ url }),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
if (!request.ok) {
|
if (!request.ok) {
|
||||||
toastr.info(request.statusText, 'Custom content import failed');
|
toastr.info(request.statusText, 'Custom content import failed');
|
||||||
|
|
|
@ -357,7 +357,7 @@ function getUuidFromUrl(url) {
|
||||||
|
|
||||||
const router = express.Router();
|
const router = express.Router();
|
||||||
|
|
||||||
router.post('/import', jsonParser, async (request, response) => {
|
router.post('/importURL', jsonParser, async (request, response) => {
|
||||||
if (!request.body.url) {
|
if (!request.body.url) {
|
||||||
return response.sendStatus(400);
|
return response.sendStatus(400);
|
||||||
}
|
}
|
||||||
|
@ -413,6 +413,50 @@ router.post('/import', jsonParser, async (request, response) => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
router.post('/importUUID', jsonParser, async (request, response) => {
|
||||||
|
if (!request.body.url) {
|
||||||
|
return response.sendStatus(400);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const uuid = request.body.url;
|
||||||
|
let result;
|
||||||
|
|
||||||
|
const isJannny = uuid.includes("_character")
|
||||||
|
const isPygmalion = (!isJannny && uuid.length == 36)
|
||||||
|
const uuidType = uuid.includes("lorebook") ? "lorebook" : "character";
|
||||||
|
|
||||||
|
if (isPygmalion) {
|
||||||
|
console.debug("We have a Pyg character")
|
||||||
|
result = await downloadPygmalionCharacter(uuid);
|
||||||
|
} else if (isJannny) {
|
||||||
|
console.debug("We have a Janny character")
|
||||||
|
result = await downloadJannyCharacter(uuid.split("_")[0]);
|
||||||
|
} else {
|
||||||
|
console.debug("We have something from Chub?")
|
||||||
|
if (uuidType === 'character') {
|
||||||
|
console.log('Downloading chub character:', uuid);
|
||||||
|
result = await downloadChubCharacter(uuid);
|
||||||
|
}
|
||||||
|
else if (uuidType === 'lorebook') {
|
||||||
|
console.log('Downloading chub lorebook:', uuid);
|
||||||
|
result = await downloadChubLorebook(uuid);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return response.sendStatus(404);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (result.fileType) response.set('Content-Type', result.fileType);
|
||||||
|
response.set('Content-Disposition', `attachment; filename="${result.fileName}"`);
|
||||||
|
response.set('X-Custom-Content-Type', uuidType);
|
||||||
|
return response.send(result.buffer);
|
||||||
|
} catch (error) {
|
||||||
|
console.log('Importing custom content failed', error);
|
||||||
|
return response.sendStatus(500);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
checkForNewContent,
|
checkForNewContent,
|
||||||
getDefaultPresets,
|
getDefaultPresets,
|
||||||
|
|
Loading…
Reference in New Issue