Langflow overview
This page explores the fundamental building blocks of Langflow, beginning with the question, "What is a flow?"
What is a flow?
A flow is an application. It receives input, processes it, and produces output.
Flows are created in the workspace with components dragged from the components sidebar.
A flow can be as simple as the basic prompting flow, which creates an OpenAI chatbot with four components.
- Each component in a flow is a node that performs a specific task, like an AI model or a data source.
- Each component has a Configuration menu. Click the Code pane to see a component's underlying Python code.
- Components are connected with edges to form flows.
If you're familiar with ReactFlow, a flow is a node-based application, a component is a node, and the connections between components are edges.
When a flow is run, Langflow builds a Directed Acyclic Graph (DAG) graph object from the nodes (components) and edges (connections between components), with the nodes sorted to determine the order of execution. The graph build calls the individual components' def_build
functions to validate and prepare the nodes. This graph is then processed in dependency order. Each node is built and executed sequentially, with results from each built node being passed to nodes that are dependent on the previous node's results.
Flows are stored on local disk at these default locations:
- Linux or WSL on Windows:
home/<username>/.cache/langflow/
- MacOS:
/Users/<username>/Library/Caches/langflow/
The flow storage location can be customized with the LANGFLOW_CONFIG_DIR environment variable.
Find your way around
If you're new to Langflow, it's OK to feel a bit lost at first. We’ll take you on a tour, so you can orient yourself and start creating applications quickly.
Langflow has four distinct regions: the workspace is the main area where you build your flows. The components sidebar is on the left, and lists the available components. The playground and API pane are available in the upper right corner.
Workspace
The workspace is where you create AI applications by connecting and running components in flows.
The workspace controls allow you to adjust your view and lock your flows in place.
- Add Notes to flows with the Add Note button, similar to commenting in code.
- To access the Settings menu, click ⚙️ Settings.
This menu contains configuration for Global Variables, Langflow API, Shortcuts, and Messages.
Components
A component is a single building block within a flow and consists of inputs, outputs, and parameters that define its functionality.
To add a component to your flow, drag it from the sidebar onto the workspace.
To connect components, drag a line from the output handle (⚪) of one component to the input handle of another.
For more information, see Components overview.
Playground
The Playground executes the current flow in the workspace.
Chat with your flow, view inputs and outputs, and modify your AI's memories to tune your responses in real time.
Either the Chat Input or Chat Output component can be opened in the Playground and tested in real time.
For more information, see the Playground.
API pane
The API pane provides code templates to integrate your flows into external applications.
For more information, see the API pane.
View logs
The Logs pane provides a detailed record of all component executions within a workspace.
To access the Logs pane, click your Flow Name, and then select Logs.
Projects and folders
The My Projects page displays all the flows and components you've created in the Langflow workspace.
My Projects is the default folder where all new projects and components are initially stored.
Projects, folders, and flows are exchanged as JSON objects.
-
To create a new folder, click 📁 New Folder.
-
To rename a folder, double-click the folder name.
-
To download a folder, click 📥 Download.
-
To upload a folder, click 📤 Upload. The default maximum file upload size is 100 MB.
-
To move a flow or component, drag and drop it into the desired folder.
Options menu
The dropdown menu labeled with the project name offers several management and customization options for the current flow in the Langflow workspace.
- New: Create a new flow from scratch.
- Settings: Adjust settings specific to the current flow, such as its name, description, and endpoint name.
- Logs: View logs for the current project, including execution history, errors, and other runtime events.
- Import: Import a flow or component from a JSON file into the workspace.
- Export: Export the current flow as a JSON file.
- Undo (⌘Z): Revert the last action taken in the project.
- Redo (⌘Y): Reapply a previously undone action.
- Refresh All: Refresh all components and delete cache.
Settings
Click Settings to access Global variables, Langflow API, Shortcuts, and Messages.