Merge branch 'staging' into timed-wi
This commit is contained in:
commit
4b4ee7409b
|
@ -377,6 +377,12 @@ jQuery(async function () {
|
||||||
}
|
}
|
||||||
function switchMultimodalBlocks() {
|
function switchMultimodalBlocks() {
|
||||||
const isMultimodal = extension_settings.caption.source === 'multimodal';
|
const isMultimodal = extension_settings.caption.source === 'multimodal';
|
||||||
|
$('#caption_ollama_pull').on('click', (e) => {
|
||||||
|
const presetModel = extension_settings.caption.multimodal_model !== 'ollama_current' ? extension_settings.caption.multimodal_model : '';
|
||||||
|
e.preventDefault();
|
||||||
|
$('#ollama_download_model').trigger('click');
|
||||||
|
$('#dialogue_popup_input').val(presetModel);
|
||||||
|
});
|
||||||
$('#caption_multimodal_block').toggle(isMultimodal);
|
$('#caption_multimodal_block').toggle(isMultimodal);
|
||||||
$('#caption_prompt_block').toggle(isMultimodal);
|
$('#caption_prompt_block').toggle(isMultimodal);
|
||||||
$('#caption_multimodal_api').val(extension_settings.caption.multimodal_api);
|
$('#caption_multimodal_api').val(extension_settings.caption.multimodal_api);
|
||||||
|
|
|
@ -58,14 +58,20 @@
|
||||||
<option data-type="openrouter" value="google/gemini-flash-1.5">google/gemini-flash-1.5</option>
|
<option data-type="openrouter" value="google/gemini-flash-1.5">google/gemini-flash-1.5</option>
|
||||||
<option data-type="openrouter" value="liuhaotian/llava-yi-34b">liuhaotian/llava-yi-34b</option>
|
<option data-type="openrouter" value="liuhaotian/llava-yi-34b">liuhaotian/llava-yi-34b</option>
|
||||||
<option data-type="ollama" value="ollama_current" data-i18n="currently_selected">[Currently selected]</option>
|
<option data-type="ollama" value="ollama_current" data-i18n="currently_selected">[Currently selected]</option>
|
||||||
<option data-type="ollama" value="bakllava:latest">bakllava:latest</option>
|
<option data-type="ollama" value="bakllava">bakllava</option>
|
||||||
<option data-type="ollama" value="llava:latest">llava:latest</option>
|
<option data-type="ollama" value="llava">llava</option>
|
||||||
|
<option data-type="ollama" value="llava-llama3">llava-llama3</option>
|
||||||
|
<option data-type="ollama" value="llava-phi3">llava-phi3</option>
|
||||||
|
<option data-type="ollama" value="moondream">moondream</option>
|
||||||
<option data-type="llamacpp" value="llamacpp_current" data-i18n="currently_loaded">[Currently loaded]</option>
|
<option data-type="llamacpp" value="llamacpp_current" data-i18n="currently_loaded">[Currently loaded]</option>
|
||||||
<option data-type="ooba" value="ooba_current" data-i18n="currently_loaded">[Currently loaded]</option>
|
<option data-type="ooba" value="ooba_current" data-i18n="currently_loaded">[Currently loaded]</option>
|
||||||
<option data-type="koboldcpp" value="koboldcpp_current" data-i18n="currently_loaded">[Currently loaded]</option>
|
<option data-type="koboldcpp" value="koboldcpp_current" data-i18n="currently_loaded">[Currently loaded]</option>
|
||||||
<option data-type="custom" value="custom_current" data-i18n="currently_selected">[Currently selected]</option>
|
<option data-type="custom" value="custom_current" data-i18n="currently_selected">[Currently selected]</option>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
<div data-type="ollama">
|
||||||
|
The model must be downloaded first! Do it with the <code>ollama pull</code> command or <a href="#" id="caption_ollama_pull">click here</a>.
|
||||||
|
</div>
|
||||||
<label data-type="openai,anthropic,google" class="checkbox_label flexBasis100p" for="caption_allow_reverse_proxy" title="Allow using reverse proxy if defined and valid.">
|
<label data-type="openai,anthropic,google" class="checkbox_label flexBasis100p" for="caption_allow_reverse_proxy" title="Allow using reverse proxy if defined and valid.">
|
||||||
<input id="caption_allow_reverse_proxy" type="checkbox" class="checkbox">
|
<input id="caption_allow_reverse_proxy" type="checkbox" class="checkbox">
|
||||||
<span data-i18n="Allow reverse proxy">Allow reverse proxy</span>
|
<span data-i18n="Allow reverse proxy">Allow reverse proxy</span>
|
||||||
|
|
|
@ -148,7 +148,7 @@ export class SettingsUi {
|
||||||
this.onQrSetChange();
|
this.onQrSetChange();
|
||||||
}
|
}
|
||||||
onQrSetChange() {
|
onQrSetChange() {
|
||||||
this.currentQrSet = QuickReplySet.get(this.currentSet.value);
|
this.currentQrSet = QuickReplySet.get(this.currentSet.value) ?? new QuickReplySet();
|
||||||
this.disableSend.checked = this.currentQrSet.disableSend;
|
this.disableSend.checked = this.currentQrSet.disableSend;
|
||||||
this.placeBeforeInput.checked = this.currentQrSet.placeBeforeInput;
|
this.placeBeforeInput.checked = this.currentQrSet.placeBeforeInput;
|
||||||
this.injectInput.checked = this.currentQrSet.injectInput;
|
this.injectInput.checked = this.currentQrSet.injectInput;
|
||||||
|
|
|
@ -20,7 +20,7 @@ import {
|
||||||
renderExtensionTemplateAsync,
|
renderExtensionTemplateAsync,
|
||||||
doExtrasFetch, getApiUrl,
|
doExtrasFetch, getApiUrl,
|
||||||
} from '../../extensions.js';
|
} from '../../extensions.js';
|
||||||
import { collapseNewlines } from '../../power-user.js';
|
import { collapseNewlines, registerDebugFunction } from '../../power-user.js';
|
||||||
import { SECRET_KEYS, secret_state, writeSecret } from '../../secrets.js';
|
import { SECRET_KEYS, secret_state, writeSecret } from '../../secrets.js';
|
||||||
import { getDataBankAttachments, getDataBankAttachmentsForSource, getFileAttachment } from '../../chats.js';
|
import { getDataBankAttachments, getDataBankAttachmentsForSource, getFileAttachment } from '../../chats.js';
|
||||||
import { debounce, getStringHash as calculateHash, waitUntilCondition, onlyUnique, splitRecursive, trimToStartSentence, trimToEndSentence } from '../../utils.js';
|
import { debounce, getStringHash as calculateHash, waitUntilCondition, onlyUnique, splitRecursive, trimToStartSentence, trimToEndSentence } from '../../utils.js';
|
||||||
|
@ -989,6 +989,28 @@ async function purgeVectorIndex(collectionId) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Purges all vector indexes.
|
||||||
|
*/
|
||||||
|
async function purgeAllVectorIndexes() {
|
||||||
|
try {
|
||||||
|
const response = await fetch('/api/vector/purge-all', {
|
||||||
|
method: 'POST',
|
||||||
|
headers: getRequestHeaders(),
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!response.ok) {
|
||||||
|
throw new Error('Failed to purge all vector indexes');
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Vectors: Purged all vector indexes');
|
||||||
|
toastr.success('All vector indexes purged', 'Purge successful');
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Vectors: Failed to purge all', error);
|
||||||
|
toastr.error('Failed to purge all vector indexes', 'Purge failed');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function toggleSettings() {
|
function toggleSettings() {
|
||||||
$('#vectors_files_settings').toggle(!!settings.enabled_files);
|
$('#vectors_files_settings').toggle(!!settings.enabled_files);
|
||||||
$('#vectors_chats_settings').toggle(!!settings.enabled_chats);
|
$('#vectors_chats_settings').toggle(!!settings.enabled_chats);
|
||||||
|
@ -1502,6 +1524,13 @@ jQuery(async () => {
|
||||||
saveSettingsDebounced();
|
saveSettingsDebounced();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$('#vectors_ollama_pull').on('click', (e) => {
|
||||||
|
const presetModel = extension_settings.vectors.ollama_model || '';
|
||||||
|
e.preventDefault();
|
||||||
|
$('#ollama_download_model').trigger('click');
|
||||||
|
$('#dialogue_popup_input').val(presetModel);
|
||||||
|
});
|
||||||
|
|
||||||
const validSecret = !!secret_state[SECRET_KEYS.NOMICAI];
|
const validSecret = !!secret_state[SECRET_KEYS.NOMICAI];
|
||||||
const placeholder = validSecret ? '✔️ Key saved' : '❌ Missing key';
|
const placeholder = validSecret ? '✔️ Key saved' : '❌ Missing key';
|
||||||
$('#api_key_nomicai').attr('placeholder', placeholder);
|
$('#api_key_nomicai').attr('placeholder', placeholder);
|
||||||
|
@ -1571,4 +1600,11 @@ jQuery(async () => {
|
||||||
],
|
],
|
||||||
returns: ARGUMENT_TYPE.LIST,
|
returns: ARGUMENT_TYPE.LIST,
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
registerDebugFunction('purge-everything', 'Purge all vector indices', 'Obliterate all stored vectors for all sources. No mercy.', async () => {
|
||||||
|
if (!confirm('Are you sure?')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
await purgeAllVectorIndexes();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -32,8 +32,11 @@
|
||||||
<input id="vectors_ollama_keep" type="checkbox" />
|
<input id="vectors_ollama_keep" type="checkbox" />
|
||||||
<span data-i18n="Keep model in memory">Keep model in memory</span>
|
<span data-i18n="Keep model in memory">Keep model in memory</span>
|
||||||
</label>
|
</label>
|
||||||
<i data-i18n="Hint: Download models and set the URL in the API connection settings.">
|
<div>
|
||||||
Hint: Download models and set the URL in the API connection settings.
|
The model must be downloaded first! Do it with the <code>ollama pull</code> command or <a href="#" id="vectors_ollama_pull">click here</a>.
|
||||||
|
</div>
|
||||||
|
<i data-i18n="Hint: Set the URL in the API connection settings.">
|
||||||
|
Hint: Set the URL in the API connection settings.
|
||||||
</i>
|
</i>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-container flexFlowColumn" id="llamacpp_vectorsModel">
|
<div class="flex-container flexFlowColumn" id="llamacpp_vectorsModel">
|
||||||
|
|
|
@ -140,7 +140,10 @@ class PresetManager {
|
||||||
* @param {string} value Preset option value
|
* @param {string} value Preset option value
|
||||||
*/
|
*/
|
||||||
selectPreset(value) {
|
selectPreset(value) {
|
||||||
$(this.select).find(`option[value=${value}]`).prop('selected', true);
|
const option = $(this.select).filter(function() {
|
||||||
|
return $(this).val() === value;
|
||||||
|
});
|
||||||
|
option.prop('selected', true);
|
||||||
$(this.select).val(value).trigger('change');
|
$(this.select).val(value).trigger('change');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,9 +21,11 @@
|
||||||
<li><tt>{{char_version}}</tt> – <span data-i18n="help_macros_17">the Character's version number</span></li>
|
<li><tt>{{char_version}}</tt> – <span data-i18n="help_macros_17">the Character's version number</span></li>
|
||||||
<li><tt>{{group}}</tt> – <span data-i18n="help_macros_18">a comma-separated list of group member names or the character name in solo chats. Alias: {{charIfNotGroup}}</span></li>
|
<li><tt>{{group}}</tt> – <span data-i18n="help_macros_18">a comma-separated list of group member names or the character name in solo chats. Alias: {{charIfNotGroup}}</span></li>
|
||||||
<li><tt>{{model}}</tt> – <span data-i18n="help_macros_19">a text generation model name for the currently selected API. </span><b data-i18n="Can be inaccurate!">Can be inaccurate!</b></li>
|
<li><tt>{{model}}</tt> – <span data-i18n="help_macros_19">a text generation model name for the currently selected API. </span><b data-i18n="Can be inaccurate!">Can be inaccurate!</b></li>
|
||||||
<li><tt>{{lastMessage}}</tt> - <span data-i18n="help_macros_20">the text of the latest chat message.</span></li>
|
<li><tt>{{lastMessage}}</tt> – <span data-i18n="help_macros_20">the text of the latest chat message.</span></li>
|
||||||
|
<li><tt>{{lastUserMessage}}</tt> – <span data-i18n="help_macros_lastUser">the text of the latest user chat message.</span></li>
|
||||||
|
<li><tt>{{lastCharMessage}}</tt> – <span data-i18n="help_macros_lastChar">the text of the latest character chat message.</span></li>
|
||||||
<li><tt>{{lastMessageId}}</tt> – <span data-i18n="help_macros_21">index # of the latest chat message. Useful for slash command batching.</span></li>
|
<li><tt>{{lastMessageId}}</tt> – <span data-i18n="help_macros_21">index # of the latest chat message. Useful for slash command batching.</span></li>
|
||||||
<li><tt>{{firstIncludedMessageId}}</tt> - <span data-i18n="help_macros_22">the ID of the first message included in the context. Requires generation to be ran at least once in the current session.</span></li>
|
<li><tt>{{firstIncludedMessageId}}</tt> – <span data-i18n="help_macros_22">the ID of the first message included in the context. Requires generation to be ran at least once in the current session.</span></li>
|
||||||
<li><tt>{{currentSwipeId}}</tt> – <span data-i18n="help_macros_23">the 1-based ID of the current swipe in the last chat message. Empty string if the last message is user or prompt-hidden.</span></li>
|
<li><tt>{{currentSwipeId}}</tt> – <span data-i18n="help_macros_23">the 1-based ID of the current swipe in the last chat message. Empty string if the last message is user or prompt-hidden.</span></li>
|
||||||
<li><tt>{{lastSwipeId}}</tt> – <span data-i18n="help_macros_24">the number of swipes in the last chat message. Empty string if the last message is user or prompt-hidden.</span></li>
|
<li><tt>{{lastSwipeId}}</tt> – <span data-i18n="help_macros_24">the number of swipes in the last chat message. Empty string if the last message is user or prompt-hidden.</span></li>
|
||||||
<li><tt>{{// (note)}}</tt> – <span data-i18n="help_macros_25">you can leave a note here, and the macro will be replaced with blank content. Not visible for the AI.</span></li>
|
<li><tt>{{// (note)}}</tt> – <span data-i18n="help_macros_25">you can leave a note here, and the macro will be replaced with blank content. Not visible for the AI.</span></li>
|
||||||
|
|
|
@ -191,7 +191,7 @@ router.post('/delete', jsonParser, async (request, response) => {
|
||||||
return response.status(400).send('Bad Request: extensionName is required in the request body.');
|
return response.status(400).send('Bad Request: extensionName is required in the request body.');
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sanatize the extension name to prevent directory traversal
|
// Sanitize the extension name to prevent directory traversal
|
||||||
const extensionName = sanitize(request.body.extensionName);
|
const extensionName = sanitize(request.body.extensionName);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -201,7 +201,7 @@ router.post('/delete', jsonParser, async (request, response) => {
|
||||||
return response.status(404).send(`Directory does not exist at ${extensionPath}`);
|
return response.status(404).send(`Directory does not exist at ${extensionPath}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
await fs.promises.rmdir(extensionPath, { recursive: true });
|
await fs.promises.rm(extensionPath, { recursive: true });
|
||||||
console.log(`Extension has been deleted at ${extensionPath}`);
|
console.log(`Extension has been deleted at ${extensionPath}`);
|
||||||
|
|
||||||
return response.send(`Extension has been deleted at ${extensionPath}`);
|
return response.send(`Extension has been deleted at ${extensionPath}`);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
const vectra = require('vectra');
|
const vectra = require('vectra');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
const fs = require('fs');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
const sanitize = require('sanitize-filename');
|
const sanitize = require('sanitize-filename');
|
||||||
const { jsonParser } = require('../express-common');
|
const { jsonParser } = require('../express-common');
|
||||||
|
@ -440,6 +441,24 @@ router.post('/delete', jsonParser, async (req, res) => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
router.post('/purge-all', jsonParser, async (req, res) => {
|
||||||
|
try {
|
||||||
|
for (const source of SOURCES) {
|
||||||
|
const sourcePath = path.join(req.user.directories.vectors, sanitize(source));
|
||||||
|
if (!fs.existsSync(sourcePath)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
await fs.promises.rm(sourcePath, { recursive: true });
|
||||||
|
console.log(`Deleted vector source store at ${sourcePath}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
return res.sendStatus(200);
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
return res.sendStatus(500);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
router.post('/purge', jsonParser, async (req, res) => {
|
router.post('/purge', jsonParser, async (req, res) => {
|
||||||
try {
|
try {
|
||||||
if (!req.body.collectionId) {
|
if (!req.body.collectionId) {
|
||||||
|
|
Loading…
Reference in New Issue