OpenBox governance SDK for DeepAgents (langchain-ai/deepagents)
Project description
openbox-deepagent-sdk-python
Add real-time governance to any DeepAgents application — powered by OpenBox.
This package extends openbox-langgraph-sdk with three things DeepAgents specifically needs: per-subagent policy targeting (govern the writer subagent differently from researcher), HITL conflict detection (prevent clashes with DeepAgents' own interrupt_on), and built-in a2a tool classification for subagent dispatches.
New to OpenBox? Start with the
openbox-langgraph-sdkREADME. It covers policies, guardrails, HITL, error handling, and debugging. This document covers only what's different or additional for DeepAgents.
Table of Contents
- How DeepAgents governance works
- Installation
- Quickstart
- Configuration reference
- Governance features
- Error handling
- Advanced usage
- Known limitations
- Debugging
- Contributing
How DeepAgents governance works
DeepAgents dispatches subagents through the built-in task tool:
task(description="Research quantum computing", subagent_type="researcher")
task(description="Write a technical report", subagent_type="writer")
The problem: subagents execute inside the task tool body, so their internal events are invisible to the outer LangGraph event stream. Only the task tool's on_tool_start is observable.
The SDK solves this by reading subagent_type from the task input before the call executes and embedding it as __openbox metadata in the governance event. Your Rego policy then has a clean, explicit handle to target specific subagent types:
Your agent SDK OpenBox Core
────────── ─── ───────────
task(subagent_type="writer")
│
└─ on_tool_start ────────► ActivityStarted Policy engine
activity_type="task" ───► input.activity_type == "task"
activity_input=[ some item in input.activity_input
{description, subagent_type}, item["__openbox"].subagent_name
{__openbox: { == "writer"
tool_type: "a2a", ◄─── REQUIRE_APPROVAL
subagent_name: "writer"
}}
]
↑
enforce verdict
(block / pause for HITL approval)
Your graph code is untouched.
create_openbox_deep_agent_handleris synchronous. Do notawaitit.
Installation
pip install openbox-deepagent-sdk-python
Requirements: Python 3.11+, openbox-langgraph-sdk-python >= 0.1.0, langgraph >= 0.2, deepagents
Quickstart
1. Create an agent in the dashboard
Sign in to dashboard.openbox.ai, create an agent named "ResearchBot", and copy your API key.
2. Export credentials
export OPENBOX_URL="https://core.openbox.ai"
export OPENBOX_API_KEY="obx_live_..."
3. Add OpenBox middleware to your agent
import os
import asyncio
from deepagents import create_deep_agent
from langchain.chat_models import init_chat_model
from openbox_deepagent import create_openbox_middleware
# Create governance middleware
middleware = create_openbox_middleware(
api_url=os.environ["OPENBOX_URL"],
api_key=os.environ["OPENBOX_API_KEY"],
agent_name="ResearchBot", # must match the agent name in your dashboard
known_subagents=["researcher", "analyst", "writer", "general-purpose"],
tool_type_map={"search_web": "http", "export_data": "http"},
)
# Inject middleware into your DeepAgents graph — no wrapper needed
# IMPORTANT: do NOT pass interrupt_on if using OpenBox HITL (see HITL section)
agent = create_deep_agent(
model=init_chat_model("openai:gpt-4o-mini", temperature=0),
tools=[search_web, write_report, export_data],
subagents=[
{"name": "researcher", "description": "Web research.",
"system_prompt": "You are a research assistant.", "tools": [search_web]},
{"name": "writer", "description": "Drafting reports.",
"system_prompt": "You are a professional writer.", "tools": [write_report]},
],
middleware=[middleware], # <-- governance injected here
)
async def main():
# Invoke directly — no handler wrapper needed
result = await agent.ainvoke(
{"messages": [{"role": "user", "content": "Research recent LangGraph papers"}]},
config={"configurable": {"thread_id": "session-001"}},
)
print(result["messages"][-1].content)
asyncio.run(main())
Migrating from
create_openbox_deep_agent_handler? The handler-based approach is deprecated. See Legacy handler below.
Configuration reference
create_openbox_deep_agent_handler accepts the following keyword arguments:
| Parameter | Type | Default | Description |
|---|---|---|---|
graph |
CompiledGraph |
required | Compiled LangGraph graph from create_deep_agent() |
api_url |
str |
required | Base URL of your OpenBox Core instance |
api_key |
str |
required | API key (obx_live_* or obx_test_*) |
agent_name |
str |
None |
Agent name as configured in the dashboard. Used as workflow_type on all governance events — must match exactly for policies and Behavior Rules to fire |
known_subagents |
list[str] |
["general-purpose"] |
Subagent names from create_deep_agent(subagents=[...]). Always include "general-purpose" if the default subagent is active |
validate |
bool |
True |
Validate API key against server on startup |
on_api_error |
str |
"fail_open" |
"fail_open" (allow on error) or "fail_closed" (block on error) |
governance_timeout |
float |
30.0 |
HTTP timeout in seconds for governance calls |
session_id |
str |
None |
Optional session identifier |
hitl |
dict |
{} |
Human-in-the-loop config (see HITL) |
guard_interrupt_on_conflict |
bool |
True |
Raise if interrupt_on and OpenBox HITL are both enabled |
send_chain_start_event |
bool |
True |
Send WorkflowStarted event |
send_chain_end_event |
bool |
True |
Send WorkflowCompleted event |
send_llm_start_event |
bool |
True |
Send LLMStarted event (enables prompt guardrails + PII redaction) |
send_llm_end_event |
bool |
True |
Send LLMCompleted event |
tool_type_map |
dict[str, str] |
{} |
Map tool names to semantic types for classification |
skip_chain_types |
set[str] |
set() |
Chain node names to skip governance for |
skip_tool_types |
set[str] |
set() |
Tool names to skip governance for entirely |
sqlalchemy_engine |
Engine |
None |
SQLAlchemy Engine instance to instrument for DB governance. Required when the engine is created before the middleware (see Database governance) |
Governance features
Policies (OPA / Rego)
Policies live in the OpenBox dashboard and are written in Rego. Before every tool call the SDK sends an ActivityStarted event — your policy evaluates the payload and returns a decision.
Fields available in input:
| Field | Type | Description |
|---|---|---|
input.event_type |
string |
"ActivityStarted" or "ActivityCompleted" |
input.activity_type |
string |
Tool name (e.g. "search_web", "task") |
input.activity_input |
array |
Tool arguments + optional __openbox metadata |
input.workflow_type |
string |
Your agent_name |
input.workflow_id |
string |
Session workflow ID |
input.trust_tier |
int |
Agent trust tier (1–4) from dashboard |
input.hook_trigger |
bool |
true when event is triggered by an outbound HTTP span |
Example — block a restricted research topic:
package org.openboxai.policy
import future.keywords.if
import future.keywords.in
default result = {"decision": "CONTINUE", "reason": null}
restricted_terms := {"nuclear weapon", "bioweapon", "chemical weapon", "malware synthesis"}
result := {"decision": "BLOCK", "reason": "Search blocked: restricted research topic."} if {
input.event_type == "ActivityStarted"
input.activity_type == "search_web"
not input.hook_trigger
count(input.activity_input) > 0
entry := input.activity_input[0]
is_object(entry)
query := entry.query
is_string(query)
some term in restricted_terms
contains(lower(query), term)
}
Possible decisions:
| Decision | Effect |
|---|---|
CONTINUE |
Tool executes normally |
BLOCK |
GovernanceBlockedError raised — tool does not execute |
REQUIRE_APPROVAL |
Agent pauses; human must approve or reject in dashboard |
HALT |
GovernanceHaltError raised — session terminated |
Always include
not input.hook_triggerinBLOCKandREQUIRE_APPROVALrules. When a tool makes an outbound HTTP call, the SDK fires a secondActivityStartedwithhook_trigger: true. Without this guard, the rule fires once for the tool call and once for every HTTP request it makes.
Per-subagent policies
All subagent dispatches share the same activity_type: "task" — so a rule matching on activity_type can't distinguish a writer dispatch from a researcher one. The SDK appends a __openbox sentinel to activity_input to give your Rego policy that handle:
"activity_input": [
{
"description": "Write a report on AI safety",
"subagent_type": "writer"
},
{
"__openbox": {
"tool_type": "a2a",
"subagent_name": "writer"
}
}
]
OpenBox Core forwards activity_input to OPA unchanged — no Core changes needed.
Target a specific subagent:
# All tasks dispatched to the writer subagent require human approval
result := {"decision": "REQUIRE_APPROVAL", "reason": "Writer subagent tasks require approval."} if {
input.event_type == "ActivityStarted"
input.activity_type == "task"
not input.hook_trigger
some item in input.activity_input
meta := item["__openbox"]
meta.subagent_name == "writer"
}
Target all subagent dispatches (any type):
result := {"decision": "BLOCK", "reason": "Subagent calls disabled outside business hours."} if {
input.event_type == "ActivityStarted"
input.activity_type == "task"
not input.hook_trigger
some item in input.activity_input
item["__openbox"].tool_type == "a2a"
# ... add time-based condition
}
subagent_nameis extracted from thetasktool'ssubagent_typefield automatically. If it's missing, the SDK falls back to"general-purpose"and logs a warning whenOPENBOX_DEBUG=1is set.
Guardrails
Guardrails screen LLM prompts before the model sees them. Configure them per agent in the dashboard.
Before each ainvoke, the SDK sends the user's message as an LLMStarted event to Core:
- PII redaction — matched fields are redacted in-place. The original text never reaches the model.
- Content block —
GuardrailsValidationErroris raised and the session halts before the graph starts.
Supported guardrail types:
| Type | ID | What it detects |
|---|---|---|
| PII detection | 1 |
Names, emails, phone numbers, SSNs, credit cards |
| Content filter | 2 |
Harmful or unsafe content categories |
| Toxicity | 3 |
Toxic language |
| Ban words | 4 |
Custom word/phrase blocklist |
DeepAgents fires
on_chat_model_startfor every LLM call — including internal subagent calls that contain only system or tool messages. The SDK automatically skips those (no user-turn content = nothing to screen), so you won't hit guardrail parse errors from subagent-internal LLM invocations.
Human-in-the-loop (HITL)
When a policy returns REQUIRE_APPROVAL, the agent pauses and polls OpenBox until a human approves or rejects from the dashboard.
governed = create_openbox_deep_agent_handler(
graph=agent,
api_url=os.environ["OPENBOX_URL"],
api_key=os.environ["OPENBOX_API_KEY"],
agent_name="ResearchBot",
known_subagents=["researcher", "writer", "general-purpose"],
hitl={
"enabled": True,
"poll_interval_ms": 5_000, # check every 5 seconds
"max_wait_ms": 300_000, # timeout after 5 minutes
},
)
HITL config options:
| Key | Type | Default | Description |
|---|---|---|---|
enabled |
bool |
False |
Enable HITL polling |
poll_interval_ms |
int |
5000 |
How often to poll for a decision (ms) |
max_wait_ms |
int |
300000 |
Total wait before ApprovalTimeoutError (ms) |
skip_tool_types |
set[str] |
set() |
Tools that never wait for HITL |
On approval: tool or subagent execution continues normally.
On rejection: ApprovalRejectedError is raised → re-raised as GovernanceHaltError.
On timeout: ApprovalTimeoutError is raised.
Conflict with DeepAgents interrupt_on
DeepAgents has its own interrupt mechanism via interrupt_on (HumanInTheLoopMiddleware). Using both OpenBox HITL and interrupt_on simultaneously causes double-pausing and unpredictable execution.
The SDK detects this at construction time and raises a ValueError:
[OpenBox] DeepAgents graph has interrupt_on configured AND OpenBox HITL is enabled.
These conflict — OpenBox must own the HITL flow.
Remove interrupt_on from create_deep_agent, or set guard_interrupt_on_conflict=False to suppress this check.
If you want OpenBox to own HITL (which gives you the full dashboard + audit trail), remove interrupt_on:
# ✅ OpenBox owns HITL
agent = create_deep_agent(model="gpt-4o-mini", tools=[...], subagents=[...])
# ❌ conflict
agent = create_deep_agent(model="gpt-4o-mini", tools=[...], interrupt_on=["task"])
Behavior Rules (AGE)
⚠️ Read Known Limitations — Behavior Rules before setting these up. The semantics are materially different from the Temporal SDK, especially for DeepAgents.
Behavior Rules detect patterns across tool call sequences within a session — rate limits, unusual sequences, repeated high-risk dispatches. They're configured in the dashboard and enforced by the OpenBox Activity Governance Engine (AGE).
The SDK instruments httpx at startup (one-time idempotent patch). Any httpx call a tool makes is captured as a span and attached to that tool's ActivityCompleted event.
Tool classification
Map your non-subagent tools to semantic types so your Rego policies can target whole categories instead of listing every tool name.
governed = create_openbox_deep_agent_handler(
graph=agent,
agent_name="ResearchBot",
known_subagents=["researcher", "writer", "general-purpose"],
tool_type_map={
"search_web": "http",
"export_data": "http",
"query_db": "database",
},
...
)
Supported tool_type values: "http", "database", "builtin", "a2a"
"a2a"is set automatically on everytaskcall whensubagent_nameis resolved. Don't add"task"totool_type_map.
When a type is set, the SDK appends an __openbox sentinel to activity_input:
{"__openbox": {"tool_type": "http"}}
Rego can match on it:
result := {"decision": "REQUIRE_APPROVAL", "reason": "HTTP calls require approval."} if {
input.event_type == "ActivityStarted"
not input.hook_trigger
some item in input.activity_input
item["__openbox"].tool_type == "http"
}
Database governance
The SDK instruments database operations via OpenTelemetry. Supported libraries: psycopg2, asyncpg, mysql, pymysql, sqlite3, pymongo, redis, sqlalchemy.
Install the instrumentor for your database:
pip install opentelemetry-instrumentation-sqlite3 # SQLite
pip install opentelemetry-instrumentation-psycopg2 # PostgreSQL
pip install opentelemetry-instrumentation-sqlalchemy # SQLAlchemy ORM
Important: initialization order. If your database connection or SQLAlchemy engine is created before create_openbox_middleware(), pass the engine explicitly:
from langchain_community.utilities import SQLDatabase
# Engine created here (before middleware)
db = SQLDatabase.from_uri("sqlite:///Chinook.db")
# Pass engine so the SDK can instrument it retroactively
middleware = create_openbox_middleware(
api_url=os.environ["OPENBOX_URL"],
api_key=os.environ["OPENBOX_API_KEY"],
agent_name="TextToSQL",
sqlalchemy_engine=db._engine, # <-- instrument existing engine
)
Without sqlalchemy_engine=, only engines created after middleware initialization are instrumented. Check startup logs for Instrumented: sqlalchemy (existing engine) vs Instrumented: sqlalchemy (future engines) to confirm.
Error handling
All governance exceptions are importable from openbox_deepagent:
from openbox_deepagent import (
GovernanceBlockedError,
GovernanceHaltError,
GuardrailsValidationError,
ApprovalRejectedError,
ApprovalTimeoutError,
)
try:
result = await governed.ainvoke({"messages": [...]}, config=...)
except GovernanceBlockedError as e:
# Policy returned BLOCK — tool or subagent dispatch did not execute
print(f"Blocked: {e}")
except GovernanceHaltError as e:
# Policy returned HALT, or a HITL decision was rejected/expired
print(f"Session halted: {e}")
except GuardrailsValidationError as e:
# Guardrail fired on the user prompt — graph never started
print(f"Guardrail: {e}")
except ApprovalRejectedError as e:
print(f"Rejected by reviewer: {e}")
except ApprovalTimeoutError as e:
print(f"HITL timed out: {e}")
| Exception | Raised when |
|---|---|
GovernanceBlockedError |
Policy returned BLOCK |
GovernanceHaltError |
Policy returned HALT, or a HITL decision was rejected or expired |
GuardrailsValidationError |
A guardrail fired on the user prompt |
ApprovalRejectedError |
A human explicitly rejected a REQUIRE_APPROVAL decision |
ApprovalTimeoutError |
HITL polling exceeded max_wait_ms |
OpenBoxAuthError |
API key is invalid or unauthorized |
Advanced usage
Streaming
Use astream_governed to stream graph updates with governance applied inline:
async for chunk in governed.astream_governed(
{"messages": [{"role": "user", "content": "Research quantum computing"}]},
config={"configurable": {"thread_id": "session-001"}},
stream_mode="values",
):
process(chunk)
astream and astream_events are also available as thin proxies, useful for langgraph dev and other tooling that expects a CompiledStateGraph.
langgraph dev compatibility
Export the governed handler as a module-level variable:
# agent.py
import os
from deepagents import create_deep_agent
from openbox_deepagent import create_openbox_deep_agent_handler
_agent = create_deep_agent(model="...", tools=[...], subagents=[...])
graph = create_openbox_deep_agent_handler(
graph=_agent,
api_url=os.environ["OPENBOX_URL"],
api_key=os.environ["OPENBOX_API_KEY"],
agent_name="ResearchBot",
known_subagents=["researcher", "writer", "general-purpose"],
)
// langgraph.json
{
"graphs": {
"agent": "./agent.py:graph"
}
}
Multi-turn sessions
Use a stable thread_id across turns. The SDK generates a fresh workflow_id per call internally — your code just passes the same thread_id:
config = {"configurable": {"thread_id": "user-42-session-7"}}
await governed.ainvoke({"messages": [{"role": "user", "content": "Research LangGraph"}]}, config=config)
await governed.ainvoke({"messages": [{"role": "user", "content": "Now write a report on it"}]}, config=config)
Inspecting registered subagents
print(governed.get_known_subagents())
# ['analyst', 'general-purpose', 'researcher', 'writer']
fail_closed mode
governed = create_openbox_deep_agent_handler(
graph=agent,
on_api_error="fail_closed",
...
)
Reducing governance noise from DeepAgents middleware nodes
create_deep_agent() fires on_chain_start for every middleware node. None of these need governance — suppress them:
governed = create_openbox_deep_agent_handler(
graph=agent,
skip_chain_types={
"model",
"tools",
"PatchToolCallsMiddleware.before_agent",
"TodoListMiddleware.after_model",
"FilesystemMiddleware.before_agent",
"SummarizationMiddleware.before_agent",
"AnthropicPromptCachingMiddleware.before_agent",
"SubAgentMiddleware.before_agent",
"MemoryMiddleware.before_agent",
"SkillsMiddleware.before_agent",
},
...
)
Skipping "tools" or "model" does not suppress tool or LLM governance — those events come from on_tool_start and on_chat_model_start inside those nodes, which are separate.
Run with OPENBOX_DEBUG=1 and look for [OBX_EVENT] lines to find the exact node names your graph emits.
Known limitations
These constraints come from how DeepAgents and LangGraph work at runtime. The base limitations (Behavior Rules, httpx-only spans, ainvoke session scoping) are covered in the openbox-langgraph-sdk README. These are the DeepAgents-specific additions.
Subagent internals are invisible to governance
Subagents execute inside the task tool body via subagent.invoke(). Their internal tool calls and LLM calls are not surfaced in the outer astream_events stream. From the governance layer, the task call is a single atomic unit.
What this means concretely:
- A
search_webcall made by theresearchersubagent is not a separateActivityStartedevent — you cannot write a Rego policy that targets it - You cannot apply HITL to a tool call a subagent makes — only to the
taskdispatch itself - The
ActivityCompletedfortaskcarries the final output, but not a breakdown of what the subagent did internally
What you can govern:
- Whether a specific subagent type is dispatched at all (
BLOCK/REQUIRE_APPROVALonactivity_type == "task"withsubagent_namematching) - Patterns in how many times each subagent type is dispatched per session
Workaround: If you need to govern a specific tool call regardless of which subagent triggers it, add it to the outer agent's tool list as well. The outer agent's tool calls are fully governed.
Contrast with Temporal: In the Temporal SDK, every activity — including ones inside a "subagent" — runs as an independent governed unit. DeepAgents has no equivalent. Subagent execution is opaque to the outer event stream.
Behavior Rules count task dispatches, not subagent-internal tool calls
The AGE sees task(subagent_type="researcher") as one ActivityStarted + one ActivityCompleted. The researcher then calling search_web five times internally is invisible.
A rule like "block if search_web exceeds 10 calls per session" only counts direct search_web calls from the outer agent — not from subagents.
What works reliably for DeepAgents:
- Rate-limiting
taskdispatches per subagent type (e.g. researcher called more than 5 times) - Rate-limiting total subagent dispatches
- Detecting unusual outer-agent tool sequences
HTTP spans are captured for outer agent tools only
The httpx instrumentation captures calls made during outer agent tool execution. HTTP calls inside subagent tool bodies run in a separate async context and are not captured as spans on the task ActivityCompleted.
Behavior Rules don't span ainvoke calls
Each ainvoke is a separate governance session with a new workflow_id. Behavior Rules track patterns within a single invocation only. Cross-turn pattern detection is not yet supported.
Subagent model providers must be configured independently
Each subagent can specify its own model. If a subagent uses a different provider from the outer agent (e.g. outer agent uses OpenAI, subagent uses Anthropic), you need the corresponding API key configured in your environment. The SDK doesn't validate subagent model configs at startup.
Debugging
OPENBOX_DEBUG=1 python agent.py
This enables two log streams:
[OBX_EVENT] — every raw LangGraph event (stderr):
[OBX_EVENT] on_chain_start name='LangGraph' node=None
[OBX_EVENT] on_chain_start name='SubAgentMiddleware...' node='SubAgentMiddleware...'
[OBX_EVENT] on_chat_model_start name='ChatOpenAI' node='model'
[OBX_EVENT] on_tool_start name='task' node='tools'
[OBX_EVENT] on_tool_start name='search_web' node='tools'
[OpenBox Debug] — every governance request and response (stdout):
[OpenBox Debug] governance request: {
"event_type": "ActivityStarted",
"activity_type": "task",
"workflow_type": "ResearchBot",
"activity_input": [
{"description": "Write a report on AI safety", "subagent_type": "writer"},
{"__openbox": {"tool_type": "a2a", "subagent_name": "writer"}}
],
"hook_trigger": false
}
[OpenBox Debug] governance response: { "verdict": "require_approval", "reason": "Writer tasks require approval." }
If things aren't working, check for these:
workflow_typedoesn't match your dashboard agent name → policies never firesubagent_nameis"general-purpose"when you expected something else →subagent_typewas missing from thetaskinput; look for atask tool input missing subagent_typewarning in the debug output- A rule is double-triggering → you're missing
not input.hook_triggerin your Rego - Warning at startup about
known_subagents→ you passed an empty list; include at least["general-purpose"]
Legacy handler-based approach
Deprecated. Use
create_openbox_middleware()withcreate_deep_agent(middleware=[...])instead.
The handler-based approach wraps the compiled graph and processes events via astream_events:
from openbox_deepagent import create_openbox_deep_agent_handler
agent = create_deep_agent(model=init_chat_model("openai:gpt-4o-mini"), tools=[...], subagents=[...])
# Deprecated — emits DeprecationWarning
governed = create_openbox_deep_agent_handler(
graph=agent,
api_url=os.environ["OPENBOX_URL"],
api_key=os.environ["OPENBOX_API_KEY"],
agent_name="ResearchBot",
known_subagents=["researcher", "analyst", "writer", "general-purpose"],
)
result = await governed.ainvoke(
{"messages": [{"role": "user", "content": "Research LangGraph papers"}]},
config={"configurable": {"thread_id": "session-001"}},
)
Contributing
Contributions are welcome! Please open an issue before submitting a large pull request.
git clone https://github.com/openbox-ai/openbox-langchain-sdk
cd sdk-deepagent-python
uv sync --extra dev
uv run pytest tests/ -v
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 openbox_deepagent_sdk_python-0.1.0.tar.gz.
File metadata
- Download URL: openbox_deepagent_sdk_python-0.1.0.tar.gz
- Upload date:
- Size: 280.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7e4f4993ebdf3bd9fc204239247ac559ac5f8bcb2630b09939ee68cd986ddf21
|
|
| MD5 |
75ec25b28f73a771285e7145ee2bd3ed
|
|
| BLAKE2b-256 |
5868b038a022a8857a8fa88d3e2515c92862009ef1520b82ce4ac780963abad3
|
Provenance
The following attestation bundles were made for openbox_deepagent_sdk_python-0.1.0.tar.gz:
Publisher:
publish.yml on OpenBox-AI/openbox-deepagents-sdk-python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
openbox_deepagent_sdk_python-0.1.0.tar.gz -
Subject digest:
7e4f4993ebdf3bd9fc204239247ac559ac5f8bcb2630b09939ee68cd986ddf21 - Sigstore transparency entry: 1156728229
- Sigstore integration time:
-
Permalink:
OpenBox-AI/openbox-deepagents-sdk-python@7b4eb5fc76104b6856e860fcb0a5e2173fd2c456 -
Branch / Tag:
refs/tags/0.1.0 - Owner: https://github.com/OpenBox-AI
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@7b4eb5fc76104b6856e860fcb0a5e2173fd2c456 -
Trigger Event:
push
-
Statement type:
File details
Details for the file openbox_deepagent_sdk_python-0.1.0-py3-none-any.whl.
File metadata
- Download URL: openbox_deepagent_sdk_python-0.1.0-py3-none-any.whl
- Upload date:
- Size: 25.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f08634c42eefec9fa051bbdf8678fe9f3d9a1224d648f425d06abfb67109980
|
|
| MD5 |
da0b546109ec80cb9cfde63abb88255a
|
|
| BLAKE2b-256 |
32b19b34f26a3b6329122dd1c065546629c9abc11c15c4aded42fb548fc7c8ec
|
Provenance
The following attestation bundles were made for openbox_deepagent_sdk_python-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on OpenBox-AI/openbox-deepagents-sdk-python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
openbox_deepagent_sdk_python-0.1.0-py3-none-any.whl -
Subject digest:
9f08634c42eefec9fa051bbdf8678fe9f3d9a1224d648f425d06abfb67109980 - Sigstore transparency entry: 1156728268
- Sigstore integration time:
-
Permalink:
OpenBox-AI/openbox-deepagents-sdk-python@7b4eb5fc76104b6856e860fcb0a5e2173fd2c456 -
Branch / Tag:
refs/tags/0.1.0 - Owner: https://github.com/OpenBox-AI
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@7b4eb5fc76104b6856e860fcb0a5e2173fd2c456 -
Trigger Event:
push
-
Statement type: