mirror of
https://github.com/ParisNeo/lollms-webui.git
synced 2025-01-18 18:56:32 +00:00
204 lines
8.0 KiB
Python
204 lines
8.0 KiB
Python
"""
|
|
project: lollms_webui
|
|
file: lollms_webui_infos.py
|
|
author: ParisNeo
|
|
description:
|
|
This module contains a set of FastAPI routes that provide information about the Lord of Large Language and Multimodal Systems (LoLLMs) Web UI
|
|
application. These routes allow users to retrieve details such as the current version number, a list of available databases, and options for
|
|
updating or restarting the software.
|
|
|
|
"""
|
|
|
|
from fastapi import APIRouter, Request
|
|
from pydantic import BaseModel, Field
|
|
import pkg_resources
|
|
from lollms_webui import LOLLMSWebUI
|
|
from ascii_colors import ASCIIColors
|
|
from lollms.utilities import load_config, run_async, show_yes_no_dialog
|
|
from lollms.security import sanitize_path, forbid_remote_access, check_access
|
|
from pathlib import Path
|
|
from typing import List
|
|
import sys
|
|
import socketio
|
|
import time
|
|
# ----------------------- Defining router and main class ------------------------------
|
|
|
|
# Create an instance of the LoLLMSWebUI class
|
|
lollmsElfServer:LOLLMSWebUI = LOLLMSWebUI.get_instance()
|
|
router = APIRouter()
|
|
|
|
class LastViewedVideoUrlRequest(BaseModel):
|
|
client_id: str = Field(...)
|
|
last_viewed_video_url: str = Field(..., description="Last viewed model")
|
|
|
|
|
|
@router.get("/get_versionID")
|
|
async def get_lollms_version():
|
|
"""Get the version of the LoLLMs Web UI application."""
|
|
# Return the version string
|
|
return {"id":9}
|
|
|
|
@router.get("/get_changeLog")
|
|
async def get_lollms_version():
|
|
"""Get the changelog."""
|
|
# Return the version string
|
|
with open("CHANGELOG.md","r",encoding="utf8") as f:
|
|
infos = f.read()
|
|
return infos
|
|
|
|
|
|
@router.get("/get_news")
|
|
async def get_lollms_version():
|
|
"""Get the changelog."""
|
|
base_path = Path(__file__).parent
|
|
infos = base_path/"news"/"current.html"
|
|
return infos.read_text(encoding="utf8")
|
|
from pathlib import Path
|
|
import json
|
|
|
|
@router.get("/get_last_video_url")
|
|
async def get_last_video_url():
|
|
"""Get the URL and type of the last video."""
|
|
base_path = Path(__file__).parent
|
|
info_file = base_path / "news" / "latest_video.json"
|
|
|
|
try:
|
|
with open(info_file, 'r', encoding='utf-8') as file:
|
|
video_info = json.load(file)
|
|
|
|
return {
|
|
"url": video_info["url"],
|
|
"type": video_info["type"]
|
|
}
|
|
except FileNotFoundError:
|
|
return {"error": "Video information not found"}
|
|
except json.JSONDecodeError:
|
|
return {"error": "Invalid JSON format in the video information file"}
|
|
except KeyError as e:
|
|
return {"error": f"Missing key in JSON: {str(e)}"}
|
|
|
|
|
|
@router.get("/get_last_viewed_video_url")
|
|
async def get_last_video_url():
|
|
"""Get the URL of the last video."""
|
|
# This is a static URL for demonstration purposes
|
|
return lollmsElfServer.config.last_viewed_video
|
|
|
|
|
|
@router.post("/set_last_viewed_video_url")
|
|
async def set_last_video_url(req:LastViewedVideoUrlRequest):
|
|
"""Get the URL of the last video."""
|
|
# This is a static URL for demonstration purposes
|
|
check_access(lollmsElfServer,req.client_id)
|
|
lollmsElfServer.config.last_viewed_video = req.last_viewed_video_url
|
|
lollmsElfServer.config.save_config()
|
|
|
|
@router.get("/get_themes")
|
|
async def get_themes():
|
|
"""Get the list of available themes."""
|
|
base_path = Path(__file__).parent.parent
|
|
themes_path = base_path / "web" / "dist" / "themes"
|
|
|
|
# Get all .css files in the themes directory
|
|
theme_files = list(themes_path.glob('*.css'))
|
|
|
|
# Remove the .css extension from each file name
|
|
themes = [theme_file.stem for theme_file in theme_files]
|
|
|
|
return themes
|
|
|
|
@router.get("/get_lollms_webui_version")
|
|
async def get_lollms_webui_version():
|
|
"""Get the version of the LoLLMs Web UI application."""
|
|
# Return the version string
|
|
return lollmsElfServer.version
|
|
|
|
class Identification(BaseModel):
|
|
client_id:str
|
|
|
|
@router.post("/restart_program")
|
|
async def restart_program(data:Identification):
|
|
check_access(lollmsElfServer, data.client_id)
|
|
"""Restart the program."""
|
|
forbid_remote_access(lollmsElfServer)
|
|
if lollmsElfServer.config.headless_server_mode:
|
|
return {"status":False,"error":"Restarting app is blocked when in headless mode for obvious security reasons!"}
|
|
|
|
if lollmsElfServer.config.host!="localhost" and lollmsElfServer.config.host!="127.0.0.1":
|
|
return {"status":False,"error":"Restarting app is blocked when the server is exposed outside for very obvious reasons!"}
|
|
|
|
if lollmsElfServer.config.turn_on_setting_update_validation:
|
|
if not show_yes_no_dialog("Validation","Reboot requested from client\nDo you validate rebooting the app?"):
|
|
return {"status":False,"error":"User refused the execution!"}
|
|
|
|
lollmsElfServer.ShowBlockingMessage("Restarting program.\nPlease stand by...")
|
|
# Stop the socketIO server
|
|
run_async(lollmsElfServer.sio.shutdown)
|
|
# Sleep for 1 second before rebooting
|
|
time.sleep(1)
|
|
lollmsElfServer.HideBlockingMessage()
|
|
# Reboot the program
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info(" ╔══════════════════════════════════════════════════╗")
|
|
ASCIIColors.info(" ║ Restarting backend ║")
|
|
ASCIIColors.info(" ╚══════════════════════════════════════════════════╝")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
lollmsElfServer.run_restart_script(lollmsElfServer.args)
|
|
|
|
@router.post("/update_software")
|
|
async def update_software(data:Identification):
|
|
check_access(lollmsElfServer, data.client_id)
|
|
"""Update the software."""
|
|
forbid_remote_access(lollmsElfServer)
|
|
if lollmsElfServer.config.headless_server_mode:
|
|
return {"status":False,"error":"Updating app is blocked when in headless mode for obvious security reasons!"}
|
|
|
|
if lollmsElfServer.config.host!="localhost" and lollmsElfServer.config.host!="127.0.0.1":
|
|
return {"status":False,"error":"Updating app is blocked when the server is exposed outside for very obvious reasons!"}
|
|
|
|
if lollmsElfServer.config.turn_on_setting_update_validation:
|
|
if not show_yes_no_dialog("Validation","App upgrade requested from client\nDo you validate rebooting the app?"):
|
|
return {"status":False,"error":"User refused the execution!"}
|
|
|
|
# Display an informative message
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("╔══════════════════════════════════════════════════╗")
|
|
ASCIIColors.info("║ Updating backend ║")
|
|
ASCIIColors.info("╚══════════════════════════════════════════════════╝")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
ASCIIColors.info("")
|
|
# Stop the socketIO server
|
|
await lollmsElfServer.sio.shutdown()
|
|
# Sleep for 1 second before rebooting
|
|
time.sleep(1)
|
|
|
|
# Run the update script using the provided arguments
|
|
lollmsElfServer.run_update_script(lollmsElfServer.args)
|
|
# Exit the program after successful update
|
|
sys.exit()
|
|
|
|
|
|
@router.get("/check_update")
|
|
def check_update():
|
|
"""Checks if an update is available"""
|
|
forbid_remote_access(lollmsElfServer)
|
|
if lollmsElfServer.config.headless_server_mode:
|
|
return {"status":False,"error":"Checking updates is blocked when in headless mode for obvious security reasons!"}
|
|
|
|
if lollmsElfServer.config.host!="localhost" and lollmsElfServer.config.host!="127.0.0.1":
|
|
return {"status":False,"error":"Checking updates is blocked when the server is exposed outside for very obvious reasons!"}
|
|
|
|
if lollmsElfServer.config.auto_update:
|
|
res = lollmsElfServer.check_update_()
|
|
return {'update_availability':res}
|
|
else:
|
|
return {'update_availability':False}
|
|
|