diff --git a/.github/workflows/docker-build.yml b/.github/workflows/docker-build.yml index f480d3214..b5424b367 100644 --- a/.github/workflows/docker-build.yml +++ b/.github/workflows/docker-build.yml @@ -80,7 +80,10 @@ jobs: langflowai/langflow-frontend:1.0-alpha restart-space: + name: Restart HuggingFace Spaces + if: ${{ inputs.release_type == 'main' }} runs-on: ubuntu-latest + needs: docker_build strategy: matrix: python-version: diff --git a/docker/build_and_push.Dockerfile b/docker/build_and_push.Dockerfile index bd177e9bc..29f9294a6 100644 --- a/docker/build_and_push.Dockerfile +++ b/docker/build_and_push.Dockerfile @@ -1,6 +1,14 @@ # syntax=docker/dockerfile:1 # Keep this syntax directive! It's used to enable Docker BuildKit +FROM node:20-bookworm-slim as builder-node +WORKDIR /app +COPY src/frontend/package.json src/frontend/package-lock.json ./ +RUN npm install +COPY src/frontend/ ./ +RUN npm run build + + ################################ # BUILDER-BASE # Used to build deps + create our virtual environment @@ -48,10 +56,10 @@ COPY pyproject.toml poetry.lock README.md ./ COPY src/ ./src COPY scripts/ ./scripts RUN python -m pip install requests --user && cd ./scripts && python update_dependencies.py +COPY --from=builder-node /app/build ./src/backend/base/langflow/frontend RUN $POETRY_HOME/bin/poetry lock --no-update \ - && $POETRY_HOME/bin/poetry install --no-interaction --no-ansi -E deploy \ && $POETRY_HOME/bin/poetry build -f wheel \ - && $POETRY_HOME/bin/poetry run pip install dist/*.whl + && $POETRY_HOME/bin/poetry run pip install dist/*.whl --force-reinstall ################################ # RUNTIME diff --git a/poetry.lock b/poetry.lock index c2cf1b2d5..4bf30b352 100644 --- a/poetry.lock +++ b/poetry.lock @@ -698,13 +698,13 @@ graph = ["gremlinpython (==3.4.6)"] [[package]] name = "cassio" -version = "0.1.7" +version = "0.1.8" description = "A framework-agnostic Python library to seamlessly integrate Apache Cassandra(R) with ML/LLM/genAI workloads." optional = false python-versions = "<4.0,>=3.8" files = [ - {file = "cassio-0.1.7-py3-none-any.whl", hash = "sha256:08d1028a20d09bd207de0e17eaf7ae821b3c8e4788555e2d337aa440e0846d87"}, - {file = "cassio-0.1.7.tar.gz", hash = "sha256:44f705dff8a9a1c48527db2c9e968686358c960fa21ba940d9e66de00639ad78"}, + {file = "cassio-0.1.8-py3-none-any.whl", hash = "sha256:c09e7c884ba7227ff5277c86f3b0f31c523672ea407f56d093c7227e69c54d94"}, + {file = "cassio-0.1.8.tar.gz", hash = "sha256:4e09929506cb3dd6fad217e89846d0a1a59069afd24b82c72526ef6f2e9271af"}, ] [package.dependencies] @@ -4327,7 +4327,7 @@ types-requests = ">=2.31.0.2,<3.0.0.0" [[package]] name = "langflow-base" -version = "0.0.58" +version = "0.0.59" description = "A Python package with a built-in web application" optional = false python-versions = ">=3.10,<3.13" @@ -5588,13 +5588,13 @@ sympy = "*" [[package]] name = "openai" -version = "1.31.2" +version = "1.32.0" description = "The official Python library for the openai API" optional = false python-versions = ">=3.7.1" files = [ - {file = "openai-1.31.2-py3-none-any.whl", hash = "sha256:203cf21294f347c3d7b591e0ccbe18389d6f8967d4237214b926ea76b1e1781c"}, - {file = "openai-1.31.2.tar.gz", hash = "sha256:966ab3165b926cb5ec091d2434c90613e2ea8b73ffad984f7fec34bde971725a"}, + {file = "openai-1.32.0-py3-none-any.whl", hash = "sha256:953d57669f309002044fd2f678aba9f07a43256d74b3b00cd04afb5b185568ea"}, + {file = "openai-1.32.0.tar.gz", hash = "sha256:a6df15a7ab9344b1bc2bc8d83639f68b7a7e2453c0f5e50c1666547eee86f0bd"}, ] [package.dependencies] diff --git a/pyproject.toml b/pyproject.toml index 07d4f55a6..7e29d83c8 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "langflow" -version = "1.0.0a47" +version = "1.0.0a48" description = "A Python package with a built-in web application" authors = ["Langflow "] maintainers = [ diff --git a/src/backend/base/langflow/components/vectorstores/__init__.py b/src/backend/base/langflow/components/vectorstores/__init__.py index d38b0a735..e69de29bb 100644 --- a/src/backend/base/langflow/components/vectorstores/__init__.py +++ b/src/backend/base/langflow/components/vectorstores/__init__.py @@ -1,28 +0,0 @@ -from .AstraDB import AstraDBVectorStoreComponent -from .Chroma import ChromaComponent -from .FAISS import FAISSComponent -from .MongoDBAtlasVector import MongoDBAtlasComponent -from .Pinecone import PineconeComponent -from .Qdrant import QdrantComponent -from .Redis import RedisComponent -from .SupabaseVectorStore import SupabaseComponent -from .Vectara import VectaraComponent -from .Weaviate import WeaviateVectorStoreComponent -from .pgvector import PGVectorComponent -from .Couchbase import CouchbaseComponent - -__all__ = [ - "AstraDBVectorStoreComponent", - "ChromaComponent", - "CouchbaseComponent", - "FAISSComponent", - "MongoDBAtlasComponent", - "PineconeComponent", - "QdrantComponent", - "RedisComponent", - "SupabaseComponent", - "VectaraComponent", - "WeaviateVectorStoreComponent", - "base", - "PGVectorComponent", -] diff --git a/src/backend/base/langflow/custom/code_parser/code_parser.py b/src/backend/base/langflow/custom/code_parser/code_parser.py index 17fe12896..705e779f4 100644 --- a/src/backend/base/langflow/custom/code_parser/code_parser.py +++ b/src/backend/base/langflow/custom/code_parser/code_parser.py @@ -297,7 +297,7 @@ class CodeParser: bases = self.execute_and_inspect_classes(self.code) except Exception as e: # If the code cannot be executed, return an empty list - logger.exception(e) + logger.debug(e) bases = [] raise e return bases diff --git a/src/backend/base/langflow/custom/directory_reader/directory_reader.py b/src/backend/base/langflow/custom/directory_reader/directory_reader.py index b9f55f21f..52a310314 100644 --- a/src/backend/base/langflow/custom/directory_reader/directory_reader.py +++ b/src/backend/base/langflow/custom/directory_reader/directory_reader.py @@ -78,7 +78,8 @@ class DirectoryReader: component_tuple = (*build_component(component), component) components.append(component_tuple) except Exception as e: - logger.error(f"Error while loading component { component['name']}: {e}") + logger.debug(f"Error while loading component { component['name']}") + logger.debug(e) continue items.append({"name": menu["name"], "path": menu["path"], "components": components}) filtered = [menu for menu in items if menu["components"]] @@ -266,8 +267,7 @@ class DirectoryReader: if validation_result: try: output_types = self.get_output_types_from_code(result_content) - except Exception as exc: - logger.exception(f"Error while getting output types from code: {str(exc)}") + except Exception: output_types = [component_name_camelcase] else: output_types = [component_name_camelcase] diff --git a/src/backend/base/pyproject.toml b/src/backend/base/pyproject.toml index 39319be9a..f2df7364f 100644 --- a/src/backend/base/pyproject.toml +++ b/src/backend/base/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "langflow-base" -version = "0.0.58" +version = "0.0.59" description = "A Python package with a built-in web application" authors = ["Langflow "] maintainers = [