Merge remote-tracking branch 'origin/python_custom_node_component' into form_io

This commit is contained in:
Gabriel Luiz Freitas Almeida 2023-06-27 18:05:14 -03:00
commit bc4edde8d7
3 changed files with 53 additions and 8 deletions

View file

@ -11,7 +11,10 @@ from langflow.api.v1.schemas import (
UploadFileResponse,
)
from langflow.interface.types import build_langchain_types_dict
from langflow.interface.types import (
build_langchain_types_dict,
build_langchain_template_custom_component,
)
from langflow.database.base import get_session
from sqlmodel import Session
@ -81,3 +84,45 @@ def get_version():
from langflow import __version__
return {"version": __version__}
# @router.post("/custom_component", response_model=CustomComponentResponse, status_code=200)
@router.post("/custom_component", status_code=200)
def custom_component(
code: CustomComponentCode,
session: Session = Depends(get_session),
):
code_test = """
from langflow.interface.chains.base import ChainCreator
from langflow.interface.tools.base import ToolCreator
class MyPythonClass():
def __init__(self, title: str, author: str, year_published: int):
self.title = title
self.author = author
self.year_published = year_published
def get_details(self):
return f"Title: {self.title}, Author: {self.author}, Year Published: {self.year_published}"
def update_year_published(self, new_year: int):
self.year_published = new_year
print(f"The year of publication has been updated to {new_year}.")
def build(self, name: str, id: int, other: str) -> ChainCreator:
return ChainCreator()
"""
extractor = ClassCodeExtractor(code_test)
data = extractor.extract_class_info()
is_valid_class_template(data)
(
function_args,
function_return_type,
) = extractor.get_entrypoint_function_args_and_return_type()
return build_langchain_template_custom_component(
code_test, function_args, function_return_type
)

View file

@ -336,9 +336,10 @@ export async function uploadFile(
formData.append("file", file);
return await axios.post(`/api/v1/upload/${id}`, formData);
}
export async function UpdateTemplate(
type: string,
nodeClass: APIClassType
export async function postCustomComponent(
code: string,
apiClass: APIClassType
): Promise<AxiosResponse<APIClassType>> {
return await axios.get(`/dynamic_node`);
return await axios.post(`/api/v1/custom_component`, { code });
}

View file

@ -7,7 +7,7 @@ import "ace-builds/src-noconflict/theme-twilight";
import "ace-builds/src-noconflict/ext-language_tools";
// import "ace-builds/webpack-resolver";
import { darkContext } from "../../contexts/darkContext";
import { UpdateTemplate, postValidateCode } from "../../controllers/API";
import { postCustomComponent, postValidateCode } from "../../controllers/API";
import { alertContext } from "../../contexts/alertContext";
import {
Dialog,
@ -89,10 +89,9 @@ export default function CodeAreaModal({
title: "There is something wrong with this code, please review it",
});
});
UpdateTemplate("code", nodeClass).then((apiReturn) => {
postCustomComponent(code, nodeClass).then((apiReturn) => {
const data = apiReturn.data;
if (data) {
console.log(data);
setNodeClass(data);
setModalOpen(false);
}