Octogen Python SDK built on langgraph
Project description
Octogen Python SDK built on LangGraph
A Python SDK for building LLM-powered shop agents using LangGraph and LangChain, designed to work with the Octogen platform.
Features
- Build conversational shop agents with LangGraph's state management
- Structured output parsing with Pydantic models
- Built-in recommendation expansion functionality
- Server deployment capabilities with FastAPI
- Integration with Octogen MCP tools for product discovery
- Streamlined agent creation through factory patterns
Environment Variables
Required Variables
OPENAI_API_KEY- Your OpenAI API keyOCTOGEN_API_KEY- Your Octogen API keyOCTOGEN_MCP_SERVER_HOST- Octogen MCP server host URL
Optional Variables (for LangChain Tracing)
LANGCHAIN_API_KEY- Your LangChain API keyLANGCHAIN_TRACING_V2- Enable LangChain tracing (set to "true")LANGCHAIN_PROJECT- LangChain project name
.env File Placement
For the SDK to properly load your environment variables, you can:
-
Place a .env file in your project's root directory - The default behavior is to look for a .env file in the current working directory.
-
Explicitly specify the path - When using example servers or creating agents, pass the path to your .env file:
from dotenv import find_dotenv from octogen.shop_agent.settings import get_agent_settings # Pass the path to your .env file get_agent_settings(find_dotenv(usecwd=True))
-
Set environment variables directly - You can also set these variables in your environment before running your application.
Example Projects
When running the example projects (stylist, discovery, comparison), place your .env file in the specific example's directory. For instance, to run the stylist example:
examples/stylist/.env # Place your .env file here when running the stylist example
This is because the examples use find_dotenv(usecwd=True), which looks for a .env file in the current working directory.
Installation
pip install octogen-sdk-langgraph
Requirements
- Python ≥ 3.12
- Dependencies:
- langchain ≥ 0.3.25
- langgraph ≥ 0.4.3
- pydantic ≥ 2.11.4
- octogen-api ≥ 0.1.0a4
- structlog ≥ 25.3.0
Quick Start
from langchain_openai import ChatOpenAI
from octogen.shop_agent import ShopAgent, create_agent
from your_models import ResponseClass, HydratedResponseClass
# Define your recommendation expansion function
def expand_recommendations(response, messages):
# Process and expand recommendations
return json.dumps(expanded_response)
# Create a shop agent
async with create_agent(
model=ChatOpenAI(model="gpt-4"),
agent_name="MyShopAgent",
response_class=ResponseClass,
hydrated_response_class=HydratedResponseClass,
rec_expansion_fn=expand_recommendations,
tool_names=["agent_search_products", "enrich_product_image"],
hub_prompt_id="your/hub/prompt_id",
) as agent:
# Use the agent
result = await agent.run("I'm looking for a new jacket")
Usage Examples
See the examples/ directory for complete implementations:
examples/stylist/- A personal shopping assistantexamples/discovery/- Product discovery agentexamples/comparison/- Product comparison tool
License
This project is licensed under the terms included in the LICENSE file.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file octogen_sdk_langgraph-0.1.6.tar.gz.
File metadata
- Download URL: octogen_sdk_langgraph-0.1.6.tar.gz
- Upload date:
- Size: 18.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
50820c07567d482789b3efbb7c880dd97af7bf1a0bbaa24662851ce77c14d160
|
|
| MD5 |
fd234d78dc6923725cfaf0149046a40d
|
|
| BLAKE2b-256 |
93756408d18389053baadad7d683d59fb2dedc6d62df36b31f280b89f7abde3e
|
Provenance
The following attestation bundles were made for octogen_sdk_langgraph-0.1.6.tar.gz:
Publisher:
python-publish.yml on octogen-ai/octogen-py-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
octogen_sdk_langgraph-0.1.6.tar.gz -
Subject digest:
50820c07567d482789b3efbb7c880dd97af7bf1a0bbaa24662851ce77c14d160 - Sigstore transparency entry: 257096166
- Sigstore integration time:
-
Permalink:
octogen-ai/octogen-py-sdk@359e562262bd6d8530219eef55205c3d8a603c59 -
Branch / Tag:
refs/tags/v0.1.6 - Owner: https://github.com/octogen-ai
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@359e562262bd6d8530219eef55205c3d8a603c59 -
Trigger Event:
release
-
Statement type:
File details
Details for the file octogen_sdk_langgraph-0.1.6-py3-none-any.whl.
File metadata
- Download URL: octogen_sdk_langgraph-0.1.6-py3-none-any.whl
- Upload date:
- Size: 3.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
915a3a3adb919fdb3bbdddb3f35f6e4fa58ecb58aa7d4513e67c4c0f17fcf2a1
|
|
| MD5 |
d2e8b39fb9620ee88af7fe629a10e950
|
|
| BLAKE2b-256 |
a66643d9dd5b8df529e0fd463f6528d483b0871c9b7149acc43f2e9fca3ca548
|
Provenance
The following attestation bundles were made for octogen_sdk_langgraph-0.1.6-py3-none-any.whl:
Publisher:
python-publish.yml on octogen-ai/octogen-py-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
octogen_sdk_langgraph-0.1.6-py3-none-any.whl -
Subject digest:
915a3a3adb919fdb3bbdddb3f35f6e4fa58ecb58aa7d4513e67c4c0f17fcf2a1 - Sigstore transparency entry: 257096174
- Sigstore integration time:
-
Permalink:
octogen-ai/octogen-py-sdk@359e562262bd6d8530219eef55205c3d8a603c59 -
Branch / Tag:
refs/tags/v0.1.6 - Owner: https://github.com/octogen-ai
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@359e562262bd6d8530219eef55205c3d8a603c59 -
Trigger Event:
release
-
Statement type: