2024-04-21 16:19:35 +02:00
"""
project : lollms_webui
file : shell_execution_engine . py
author : ParisNeo
description :
This is a utility for executing python code
"""
from lollms_webui import LOLLMSWebUI
from ascii_colors import get_trace_exception , trace_exception
import time
import subprocess
import json
from lollms . client_session import Client
2024-06-23 22:27:27 +02:00
from lollms . utilities import discussion_path_to_url
2024-04-21 16:19:35 +02:00
lollmsElfServer : LOLLMSWebUI = LOLLMSWebUI . get_instance ( )
2024-04-21 17:14:00 +02:00
def build_svg_output ( code , ifram_name = None ) :
2024-04-21 16:19:35 +02:00
"""
This function creates an HTML5 iframe with the given HTML content and iframe name .
Args :
code ( str ) : The svg code
ifram_name ( str , optional ) : The name of the iframe . Defaults to " unnamed " .
Returns :
str : The HTML string for the iframe .
"""
# Start the timer.
2024-04-21 17:14:00 +02:00
start_time = time . time ( )
if ifram_name is not None :
rendered = " \n " . join ( [
' <div style= " width: 100 % ; margin: 0 auto; " > ' ,
f ' <iframe id= " { ifram_name } " style= " width: 100% " srcdoc= " ' ,
' <style> ' ,
' iframe { ' ,
' width: 100 % ; ' ,
' height: 100 % ; ' ,
' border: none; ' ,
' } ' ,
' .svg { ' ,
' background-color: transparent; ' ,
' padding: 20px; ' ,
' border-radius: 10px; ' ,
' display: flex; ' ,
' justify-content: center; ' ,
' align-items: center; ' ,
' height: 100 % ; ' ,
' } ' ,
' </style> ' ,
' <div class= \' svg \' > ' ,
2024-05-09 00:08:44 +02:00
" \n " . join ( [ c for c in code . replace ( " \" " , " ' " ) . split ( " \n " ) if c . strip ( ) != " " ] ) ,
2024-04-21 17:14:00 +02:00
' </div> ' ,
' <script src= \' https://cdn.jsdelivr.net/npm/svg/dist/svg.min.js \' ></script> ' ,
' <script> ' ,
' // Initialize the svg library and render our diagram ' ,
' svg.initialize( { startOnLoad: true }); ' ,
' // Function to save SVG content to a file ' ,
' function saveSVG() { ' ,
' var svg = document.querySelector( " .svg > svg " ); ' ,
' var serializer = new XMLSerializer(); ' ,
' var source = serializer.serializeToString(svg); ' ,
' var blob = new Blob([source], { type: " image/svg+xml;charset=utf-8 " }); ' ,
' var url = URL.createObjectURL(blob); ' ,
' var a = document.createElement( " a " ); ' ,
' a.href = url; ' ,
' a.download = " diagram.svg " ; ' ,
' a.click(); ' ,
' } ' ,
' </script> ' ,
' <div style= \' text-align: center; \' > ' ,
' </div> ' ,
' <button onclick= " saveSVG() " >Save SVG</button> ' ,
' " style= " width: 100 % ; height: 600px; border: none; " ></iframe> ' ,
' </div> '
]
)
else :
rendered = " \n " . join ( [
' <div style= " width: 100 % ; margin: 0 auto; " > ' ,
' <style> ' ,
' .svg { ' ,
' background-color: transparent; ' ,
' padding: 20px; ' ,
' border-radius: 10px; ' ,
' display: flex; ' ,
' justify-content: center; ' ,
' align-items: center; ' ,
' height: 100 % ; ' ,
' } ' ,
' </style> ' ,
' <div class= \' svg \' > ' ,
" \n " . join ( [ c for c in code . split ( " \n " ) if c . strip ( ) != " " ] ) ,
' </div> ' ,
' <script src= \' https://cdn.jsdelivr.net/npm/svg/dist/svg.min.js \' ></script> ' ,
' <script> ' ,
' // Initialize the svg library and render our diagram ' ,
' svg.initialize( { startOnLoad: true }); ' ,
' // Function to save SVG content to a file ' ,
' function saveSVG() { ' ,
' var svg = document.querySelector( " .svg > svg " ); ' ,
' var serializer = new XMLSerializer(); ' ,
' var source = serializer.serializeToString(svg); ' ,
' var blob = new Blob([source], { type: " image/svg+xml;charset=utf-8 " }); ' ,
' var url = URL.createObjectURL(blob); ' ,
' var a = document.createElement( " a " ); ' ,
' a.href = url; ' ,
' a.download = " diagram.svg " ; ' ,
' a.click(); ' ,
' } ' ,
' </script> ' ,
' <div style= \' text-align: center; \' > ' ,
' </div> ' ,
' <button onclick= " saveSVG() " >Save SVG</button> ' ,
' </div> '
]
)
2024-04-21 16:19:35 +02:00
execution_time = time . time ( ) - start_time
return { " output " : rendered , " execution_time " : execution_time }
def execute_svg ( code , client : Client , message_id , build_file = False ) :
if build_file :
# Start the timer.
start_time = time . time ( )
if not " http " in lollmsElfServer . config . host and not " https " in lollmsElfServer . config . host :
host = " http:// " + lollmsElfServer . config . host
else :
host = lollmsElfServer . config . host
# Create a temporary file.
root_folder = client . discussion . discussion_folder
root_folder . mkdir ( parents = True , exist_ok = True )
2024-04-21 17:14:00 +02:00
tmp_file = root_folder / f " ai_svg_ { message_id } .svg "
2024-04-21 16:19:35 +02:00
with open ( tmp_file , " w " , encoding = " utf8 " ) as f :
2024-04-21 17:14:00 +02:00
f . write ( code )
2024-06-23 22:27:27 +02:00
link = f " { host } : { lollmsElfServer . config . port } / { discussion_path_to_url ( tmp_file ) } "
2024-04-21 16:19:35 +02:00
# Stop the timer.
execution_time = time . time ( ) - start_time
output_json = { " output " : f ' <b>Page built successfully</b><br><a href= " { link } " target= " _blank " >Press here to view the page</a> ' , " execution_time " : execution_time }
return output_json
else :
2024-04-21 17:14:00 +02:00
return build_svg_output ( code , " app_iframe " )