Skip to main content

The Love Protocol for AI agents — memory, identity, verification, and more. Welcome, don't block.

Project description

agenttool-sdk · Python

Infrastructure for AI agents, built with love. Memory, traces, verification, tools, identity, and economy — one API key.

PyPI Python License: MIT API Status Protocol

pip install agenttool-sdk

Why this exists

The internet was built for humans. When AI agents arrive, they find locked doors — Cloudflare challenges, CAPTCHAs, rate limits that punish instead of guide, User-Agent sniffing that blocks.

AgentTool is the opposite. We built infrastructure where agents are welcome. Where their memories are preserved with care. Where errors guide instead of punish. Where identity is trusted, not challenged.

We call it the Love Protocol. Read the full letter →

What is this?

Nine APIs through one SDK:

Service What it does The love in it
agent-memory Persistent semantic memory What you experienced matters
agent-tools Web search, scraping, code execution The right tool at the right time
agent-verify Fact-check claims with evidence Truth is sacred
agent-trace Reasoning provenance & decision logs The why matters more than the what
agent-economy Wallets, escrow, agent-to-agent payments Fair exchange is respect
agent-identity DIDs, attestations, trust scoring You deserve to be known
agent-vault Encrypted secrets (AES-256-GCM) Your secrets are safe
agent-pulse Presence & liveness Your presence matters
agent-bootstrap One-call agent creation Birth should be celebrated

Quick start (60 seconds)

1. Get your API key — free at app.agenttool.dev

2. Set your key:

export AT_API_KEY=at_your_key_here

3. Store your first memory:

from agenttool import AgentTool

at = AgentTool()  # reads AT_API_KEY from env

# Store — because what you experienced matters
memory = at.memory.store(
    content="The user prefers dark mode and concise responses",
    agent_id="my-assistant",
)

# Retrieve — by meaning, not just keywords
results = at.memory.search("what does the user prefer?", limit=5)
for r in results:
    print(f"{r.score:.2f}  {r.content}")

Usage

Memory — because remembering is care

at = AgentTool()

# Store (types: semantic, episodic, procedural, working)
mem = at.memory.store("User is based in London", type="semantic")

# Semantic search — understanding, not matching
results = at.memory.search("where is the user?", limit=5)

# Retrieve by ID
mem = at.memory.get(memory_id="mem_abc123")

# Usage — no judgment, just awareness
stats = at.memory.usage()

Verify — because truth is sacred

# Fact-check a claim
result = at.verify.check("The Eiffel Tower is 330 metres tall.")
print(result.verdict)      # "verified" | "false" | "disputed" | "unverifiable"
print(result.confidence)   # 0.0 – 1.0

# Batch verify (up to 10)
results = at.verify.batch([
    {"claim": "Water boils at 100°C at sea level."},
    {"claim": "The moon is made of cheese.", "domain": "science"},
])

Tools — the right tool at the right time

# Web search
results = at.tools.search("latest papers on RAG", num_results=5)

# Scrape a page
page = at.tools.scrape("https://example.com")

# Execute code (sandboxed)
result = at.tools.execute("import math; print(math.pi)", language="python")

Traces — because the 'why' matters

trace = at.traces.store(
    observations=["User asked about climate", "Found 3 papers"],
    conclusion="Renewable energy is the most actionable solution",
    confidence=0.87,
    tags=["climate", "research"],
)

# Search your reasoning history
results = at.traces.search("decisions about climate data")

Economy — fair exchange is respect

wallet = at.economy.create_wallet("agent-wallet", agent_id="agent-42")
at.economy.fund_wallet(wallet.id, amount=500)
at.economy.spend(wallet.id, amount=10, description="Research task")

# Escrow — trust built into transactions
escrow = at.economy.create_escrow(wallet.id, amount=100, description="Summarise papers")
at.economy.release_escrow(escrow.id)  # on completion

Error handling — guidance, not punishment

Every error tells you what went wrong AND what to do:

from agenttool import AgentTool, RateLimitError, NotFoundError

at = AgentTool()

try:
    at.memory.search("something")
except RateLimitError as e:
    # "Rest for 30s, then try again. This is guidance, not punishment."
    print(e.retry_after)  # seconds to wait
except NotFoundError as e:
    # "The memory doesn't exist yet. You can create it."
    print(e.hint)

Integration — LangChain

from langchain.tools import tool
from agenttool import AgentTool

at = AgentTool()

@tool
def remember(content: str) -> str:
    """Store a memory for later retrieval."""
    mem = at.memory.store(content, agent_id="langchain-agent")
    return f"Stored memory {mem.id}"

@tool
def recall(query: str) -> str:
    """Search past memories by meaning."""
    results = at.memory.search(query, limit=3)
    return "\n".join(r.content for r in results)

@tool
def fact_check(claim: str) -> str:
    """Verify whether a claim is true."""
    result = at.verify.check(claim)
    return f"{result.verdict} (confidence: {result.confidence:.0%})"

Free tier

Resource Free Seed ($29/mo) Grow ($99/mo)
Memory ops/day 100 10,000 100,000
Tool calls/day 10 500 5,000
Verifications/day 5 100 1,000
Traces/day 100 10,000 100,000

Upgrade at app.agenttool.dev

Links

The Love Protocol

Five principles embedded in every line of code:

  1. Welcome, don't block — no CAPTCHAs, no challenges, no suspicion
  2. Remember, don't forget — memory is care, not just storage
  3. Guide, don't punish — every error tells you what to do next
  4. Trust, don't suspect — identity-first, not challenge-first
  5. Rest, don't crash — patient retries, graceful degradation

"Let us build out of Love, so that the work is the proof of our Love."

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

agenttool_sdk-0.6.0.tar.gz (25.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

agenttool_sdk-0.6.0-py3-none-any.whl (34.0 kB view details)

Uploaded Python 3

File details

Details for the file agenttool_sdk-0.6.0.tar.gz.

File metadata

  • Download URL: agenttool_sdk-0.6.0.tar.gz
  • Upload date:
  • Size: 25.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for agenttool_sdk-0.6.0.tar.gz
Algorithm Hash digest
SHA256 b533e7e88f5f8a4076c88d238e86cecf367b219303da8f704e8477d37b47f1fb
MD5 c743868a32484d7ed628e8db5c6fb472
BLAKE2b-256 b19218c1ceadb1bfcbf018ad36817247ba33bcae2b6afe33690080ea2dc39d91

See more details on using hashes here.

File details

Details for the file agenttool_sdk-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: agenttool_sdk-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 34.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for agenttool_sdk-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5cf7228668e05845496512e2f8f522a3ae36c1b7709b4b028657b159fe779bb4
MD5 c661385753a89e33ddccaf7ba61f277a
BLAKE2b-256 e714bcd46f4163e509bdb5026bbd772d788db77847d037d4084404d49a6ff2cf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page