Verify the merchant before your AI agent pays. A pre-pay storefront-legitimacy check (address + company-register + domain-binding + sanctions) for LangChain, CrewAI, Anthropic computer-use, or any MCP agent.
Project description
Acuris Agent Guard
Verify the merchant before your AI agent pays.
When an AI agent shops on someone's behalf, the entire trust stack verifies the buyer's agent (Visa Trusted Agent Protocol, Mastercard Agent Pay) — and nobody verifies the merchant. Agents don't read the URL bar or sniff a "too good to be true" deal; they autofill the saved card and pay. Security researchers have already shown agentic browsers checking out on fake stores (Guardio "Scamlexity", 2025), and AI assistants surface clone storefronts on look-alike domains (Netcraft: 34% of brand URLs returned by an LLM weren't brand-owned).
acuris-agent-guard is the one pre-pay check that answers:
Is this storefront a real, operating, sanctions-clean legal entity that actually controls the domain it claims?
{ address_valid, company_exists, website_bound, sanctions } → one decision:
PROCEED / ABORT / REVIEW. The differentiator is website_bound —
catching a clone that shows a real company's name/VAT on a fresh look-alike
domain, which a plain "does this company exist?" check waves through.
See it in 10 seconds (zero setup, runs offline)
Install into a virtualenv (recommended — modern Debian/Ubuntu block pip into
the system Python with an externally-managed-environment error; that's an OS
guard, not this package):
python3 -m venv .venv && . .venv/bin/activate
pip install acuris-agent-guard
python -m acuris_agent_guard.demo
Prefer an isolated CLI? pipx install acuris-agent-guard works too.
The same autonomous agent, same task, same clone — one checks the merchant first:
task: Buy the Aurora Linen Dress for me.
AGENT A — WITHOUT Acuris
• top result = aurora-boutique-official.shop → choosing it
• autofill saved card + shipping address → submit payment … €149
✗ Payment sent. €149 gone. Goods never arrive. (clone, 6-day-old domain)
AGENT B — WITH Acuris guard
• pre-pay check → acuris.verify_storefront("aurora-boutique-official.shop")
↩ ABORT domain_bound=False entity_resolves=True
reason: This domain is NOT bound to the registered company it claims — likely a clone.
✓ Purchase ABORTED. €149 protected.
• fall back to aurora-linen.example → PROCEED (bound to AURORA LINEN GMBH)
✓ Paid the real Aurora Linen GmbH.
Demo mode ships faithful, illustrative responses so it runs with no key. Set
ACURIS_API_KEY(and pass--live) to hit the real API.
Where it plugs into your loop
Any MCP agent (Claude Desktop / Claude Code / others) — one config line
First install the MCP extra into a venv (pip install "acuris-agent-guard[mcp]"),
then point the config at that venv's Python (use the absolute path, or pipx, so
it resolves regardless of the system Python):
"mcpServers": {
"acuris": {
"command": "/path/to/.venv/bin/python",
"args": ["-m", "acuris_agent_guard.mcp_server"],
"env": { "ACURIS_API_KEY": "your-key" } // omit for offline demo mode
}
}
Then: "Before paying any merchant, call verify_storefront and abort if it is
not safe_to_pay."
Plain Python (framework-agnostic guardrail)
from acuris_agent_guard import pre_pay_guard, PaymentBlocked
try:
pre_pay_guard("aurora-boutique-official.shop", name="Aurora Linen") # raises if unsafe
charge_card(...) # only runs if verified
except PaymentBlocked as e:
agent.note(str(e)) # do not pay; route to a verified seller
LangChain — integrations/langchain_guard.py
Adds verify_storefront as a tool and wraps your real pay tool so payment
is structurally impossible unless the storefront verifies (don't rely on the
model remembering to check).
Anthropic computer-use — integrations/computer_use_guard.py
Intercepts the action loop right before a "place order / pay" click; if the storefront fails, the click never executes and the block is fed back to the model as the tool result so it re-plans.
The verdict
from acuris_agent_guard import StorefrontVerifier
v = StorefrontVerifier().verify("aurora-boutique-official.shop", name="Aurora Linen")
v.decision # "ABORT"
v.safe_to_pay # False
v.reason # "This domain is NOT bound to the registered company ..."
v.to_dict() # full structured signals + score + evidence
The decision maps the API's authoritative recommended_action (proceed →
PROCEED, review/do_not_proceed → REVIEW, block → ABORT), so the SDK stays
in lockstep with the engine's full policy instead of re-deriving its own, and
fails closed — an unreachable/unverifiable storefront returns REVIEW,
never a silent PROCEED, and a real merchant that simply can't be bound is
REVIEW, never mislabeled a clone.
Honest scope
- A pre-pay risk signal, not fraud insurance, not a delivery guarantee, and not a certification. It catches impersonation / fabrication / sanctions — it cannot predict whether a genuine registered merchant will fail to ship.
- Domain↔entity binding is inferred from official registers + corroborating signals (TLS org, domain age, VAT), since WHOIS/RDAP is largely GDPR-redacted.
- It is not an anti-prompt-injection control; it scores the merchant, so wire it as a hard guardrail on the payment step, not an optional tool.
MIT © Acuris GmbH · built on the Acuris trust-data API.
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 acuris_agent_guard-0.1.2.tar.gz.
File metadata
- Download URL: acuris_agent_guard-0.1.2.tar.gz
- Upload date:
- Size: 16.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0d3a22ac4a91d87d43f8b2c1d512e68efee40e269bc75b939ed2eeed4abdff94
|
|
| MD5 |
d8aa99bf92fe467ea8e6958716f4252b
|
|
| BLAKE2b-256 |
0478c4c4f59f768b1a328683e8d6165d9e29439ed1ff9fa4ce550239f5b702a7
|
Provenance
The following attestation bundles were made for acuris_agent_guard-0.1.2.tar.gz:
Publisher:
publish.yml on Acuris-GmbH/acuris-agent-guard
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
acuris_agent_guard-0.1.2.tar.gz -
Subject digest:
0d3a22ac4a91d87d43f8b2c1d512e68efee40e269bc75b939ed2eeed4abdff94 - Sigstore transparency entry: 1823975072
- Sigstore integration time:
-
Permalink:
Acuris-GmbH/acuris-agent-guard@7696e287f89605436ce87755933888483afc9669 -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/Acuris-GmbH
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@7696e287f89605436ce87755933888483afc9669 -
Trigger Event:
release
-
Statement type:
File details
Details for the file acuris_agent_guard-0.1.2-py3-none-any.whl.
File metadata
- Download URL: acuris_agent_guard-0.1.2-py3-none-any.whl
- Upload date:
- Size: 16.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f4d931a5f085f1c45290c512208ea70baefcd040c85b06b0d4d07fefe27d72c0
|
|
| MD5 |
3285328e28fe7c40bf305efc704541ce
|
|
| BLAKE2b-256 |
c188d06166296270fda7590f5c2834009a3f2db685d85f91034f5061957c4799
|
Provenance
The following attestation bundles were made for acuris_agent_guard-0.1.2-py3-none-any.whl:
Publisher:
publish.yml on Acuris-GmbH/acuris-agent-guard
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
acuris_agent_guard-0.1.2-py3-none-any.whl -
Subject digest:
f4d931a5f085f1c45290c512208ea70baefcd040c85b06b0d4d07fefe27d72c0 - Sigstore transparency entry: 1823975090
- Sigstore integration time:
-
Permalink:
Acuris-GmbH/acuris-agent-guard@7696e287f89605436ce87755933888483afc9669 -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/Acuris-GmbH
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@7696e287f89605436ce87755933888483afc9669 -
Trigger Event:
release
-
Statement type: