mirror of
https://github.com/KoboldAI/KoboldAI-Client.git
synced 2025-04-02 20:51:37 +02:00
Merge pull request #149 from ebolam/Web-UI
--remote jailed to model directory and delete of models from UI
This commit is contained in:
commit
9add3b0761
18
aiserver.py
18
aiserver.py
@ -355,6 +355,7 @@ from flask import Flask, render_template, Response, request, copy_current_reques
|
|||||||
from flask_socketio import SocketIO, emit
|
from flask_socketio import SocketIO, emit
|
||||||
app = Flask(__name__, root_path=os.getcwd())
|
app = Flask(__name__, root_path=os.getcwd())
|
||||||
app.config['SECRET KEY'] = 'secret!'
|
app.config['SECRET KEY'] = 'secret!'
|
||||||
|
app.config['TEMPLATES_AUTO_RELOAD'] = True
|
||||||
socketio = SocketIO(app, async_method="eventlet")
|
socketio = SocketIO(app, async_method="eventlet")
|
||||||
print("{0}OK!{1}".format(colors.GREEN, colors.END))
|
print("{0}OK!{1}".format(colors.GREEN, colors.END))
|
||||||
|
|
||||||
@ -365,6 +366,8 @@ def sendModelSelection(menu="mainmenu", folder="./models"):
|
|||||||
#If we send one of the manual load options, send back the list of model directories, otherwise send the menu
|
#If we send one of the manual load options, send back the list of model directories, otherwise send the menu
|
||||||
if menu in ('NeoCustom', 'GPT2Custom'):
|
if menu in ('NeoCustom', 'GPT2Custom'):
|
||||||
(paths, breadcrumbs) = get_folder_path_info(folder)
|
(paths, breadcrumbs) = get_folder_path_info(folder)
|
||||||
|
if args.remote:
|
||||||
|
breadcrumbs = []
|
||||||
menu_list = [[folder, menu, "", False] for folder in paths]
|
menu_list = [[folder, menu, "", False] for folder in paths]
|
||||||
menu_list.append(["Return to Main Menu", "mainmenu", "", True])
|
menu_list.append(["Return to Main Menu", "mainmenu", "", True])
|
||||||
emit('from_server', {'cmd': 'show_model_menu', 'data': menu_list, 'menu': menu, 'breadcrumbs': breadcrumbs}, broadcast=True)
|
emit('from_server', {'cmd': 'show_model_menu', 'data': menu_list, 'menu': menu, 'breadcrumbs': breadcrumbs}, broadcast=True)
|
||||||
@ -2046,6 +2049,9 @@ def load_model(use_gpu=True, gpu_layers=None, initial_load=False, online_model="
|
|||||||
@app.route('/')
|
@app.route('/')
|
||||||
@app.route('/index')
|
@app.route('/index')
|
||||||
def index():
|
def index():
|
||||||
|
if 'new_ui' in request.args:
|
||||||
|
return render_template('index_new.html', hide_ai_menu=args.noaimenu)
|
||||||
|
else:
|
||||||
return render_template('index.html', hide_ai_menu=args.noaimenu)
|
return render_template('index.html', hide_ai_menu=args.noaimenu)
|
||||||
@app.route('/favicon.ico')
|
@app.route('/favicon.ico')
|
||||||
def favicon():
|
def favicon():
|
||||||
@ -3134,7 +3140,17 @@ def get_message(msg):
|
|||||||
get_model_info(msg['data'], directory=msg['path'])
|
get_model_info(msg['data'], directory=msg['path'])
|
||||||
else:
|
else:
|
||||||
get_model_info(vars.model)
|
get_model_info(vars.model)
|
||||||
|
elif(msg['cmd'] == 'delete_model'):
|
||||||
|
if "{}/models".format(os.getcwd()) in msg['data'] or "{}\\models".format(os.getcwd()) in msg['data']:
|
||||||
|
if check_if_dir_is_model(msg['data']):
|
||||||
|
print("It's a model, now we really will kill it")
|
||||||
|
import shutil
|
||||||
|
shutil.rmtree(msg['data'])
|
||||||
|
sendModelSelection(menu=msg['menu'])
|
||||||
|
else:
|
||||||
|
print("Not a model, don't delete")
|
||||||
|
else:
|
||||||
|
print("Ah ah ah, you didn't say the magic word: The selected directory is not in the KoboldAI Models directory, not doing anything.")
|
||||||
elif(msg['cmd'] == 'OAI_Key_Update'):
|
elif(msg['cmd'] == 'OAI_Key_Update'):
|
||||||
get_oai_models(msg['key'])
|
get_oai_models(msg['key'])
|
||||||
elif(msg['cmd'] == 'loadselect'):
|
elif(msg['cmd'] == 'loadselect'):
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
[pytest]
|
[pytest]
|
||||||
addopts = --ignore=miniconda3 --html=unit_test_report.html --self-contained-html -v
|
addopts = --ignore=miniconda3 --ignore=runtime --html=unit_test_report.html --self-contained-html -v
|
@ -1031,6 +1031,14 @@ function buildLoadModelList(ar, menu, breadcrumbs) {
|
|||||||
$("#loadmodellistbreadcrumbs").append("<hr size='1'>")
|
$("#loadmodellistbreadcrumbs").append("<hr size='1'>")
|
||||||
}
|
}
|
||||||
for(i=0; i<ar.length; i++) {
|
for(i=0; i<ar.length; i++) {
|
||||||
|
if (Array.isArray(ar[i][0])) {
|
||||||
|
full_path = ar[i][0][0];
|
||||||
|
folder = ar[i][0][1];
|
||||||
|
} else {
|
||||||
|
full_path = "";
|
||||||
|
folder = ar[i][0];
|
||||||
|
}
|
||||||
|
|
||||||
var html
|
var html
|
||||||
html = "<div class=\"flex\">\
|
html = "<div class=\"flex\">\
|
||||||
<div class=\"loadlistpadding\"></div>"
|
<div class=\"loadlistpadding\"></div>"
|
||||||
@ -1041,13 +1049,14 @@ function buildLoadModelList(ar, menu, breadcrumbs) {
|
|||||||
//this is a model
|
//this is a model
|
||||||
html = html + "<div class=\"loadlistpadding\"></div>"
|
html = html + "<div class=\"loadlistpadding\"></div>"
|
||||||
}
|
}
|
||||||
if (Array.isArray(ar[i][0])) {
|
|
||||||
full_path = ar[i][0][0];
|
//now let's do the delete icon if applicable
|
||||||
folder = ar[i][0][1];
|
if (['NeoCustom', 'GPT2Custom'].includes(menu) && !ar[i][3]) {
|
||||||
|
html = html + "<span class=\"loadlisticon loadmodellisticon-folder oi oi-x allowed\" aria-hidden=\"true\" onclick='if(confirm(\"This will delete the selected folder with all contents. Are you sure?\")) { socket.send({\"cmd\": \"delete_model\", \"data\": \""+full_path.replaceAll("\\", "\\\\")+"\", \"menu\": \""+menu+"\"});}'></span>"
|
||||||
} else {
|
} else {
|
||||||
full_path = "";
|
html = html + "<div class=\"loadlistpadding\"></div>"
|
||||||
folder = ar[i][0];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
html = html + "<div class=\"loadlistpadding\"></div>\
|
html = html + "<div class=\"loadlistpadding\"></div>\
|
||||||
<div class=\"loadlistitem\" id=\"loadmodel"+i+"\" name=\""+ar[i][1]+"\" pretty_name=\""+full_path+"\">\
|
<div class=\"loadlistitem\" id=\"loadmodel"+i+"\" name=\""+ar[i][1]+"\" pretty_name=\""+full_path+"\">\
|
||||||
<div>"+folder+"</div>\
|
<div>"+folder+"</div>\
|
||||||
|
@ -1495,3 +1495,54 @@ body.connected .popupfooter, .popupfooter.always-available {
|
|||||||
.model_layers:focus {
|
.model_layers:focus {
|
||||||
color: #cdf;
|
color: #cdf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.menu_icon {
|
||||||
|
position: fixed;
|
||||||
|
top:10px;
|
||||||
|
left: 5px;
|
||||||
|
z-index:100;
|
||||||
|
display: inline-block;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.SideMenu {
|
||||||
|
height: 100%;
|
||||||
|
width: 0;
|
||||||
|
position: fixed;
|
||||||
|
z-index: 1;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
background-color: #111;
|
||||||
|
overflow-x: hidden;
|
||||||
|
transition: 0.5s;
|
||||||
|
padding-top: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.SideMenu.open {
|
||||||
|
width: 450px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-width: 768px) {
|
||||||
|
.SideMenu.open {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.menubar1, .menubar2, .menubar3 {
|
||||||
|
width: 21px;
|
||||||
|
height: 3px;
|
||||||
|
background-color: #999;
|
||||||
|
margin: 3px 0;
|
||||||
|
transition: 0.4s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.change .menubar1 {
|
||||||
|
transform: translate(0px, 6px) rotate(-45deg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.change .menubar2 {opacity: 0;}
|
||||||
|
|
||||||
|
.change .menubar3 {
|
||||||
|
transform: translate(0px, -6px) rotate(45deg);
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user