AgentSIM Python SDK — autonomous OTP relay for AI agents
Project description
agentsim-sdk
Autonomous OTP relay for AI agents. AgentSIM provisions real carrier-routed phone numbers, receives inbound SMS, and delivers parsed OTP codes back to your agent — no human relay needed.
Install
uv add agentsim-sdk
Or with pip:
pip install agentsim-sdk
Quickstart
import agentsim
async with agentsim.provision(agent_id="checkout-bot", country="US") as num:
await enter_phone_number(num.number) # "+14155552671"
otp = await num.wait_for_otp(timeout=60)
await enter_otp(otp.otp_code) # "391847"
# number auto-released
Auth
Set AGENTSIM_API_KEY in your environment, or call agentsim.configure() at startup:
agentsim.configure(api_key="asm_live_xxx")
Get your API key at console.agentsim.dev.
API
agentsim.provision(*, agent_id, country="US", service_url=None, ttl_seconds=3600, webhook_url=None)
Returns an async context manager. Provisions a number on enter, auto-releases on exit (even if the body raises).
async with agentsim.provision(agent_id="stripe-setup", country="US") as num:
print(num.number) # E.164 phone number
print(num.session_id)
otp = await num.wait_for_otp(timeout=30)
print(otp.otp_code)
num.wait_for_otp(timeout=60, auto_reroute=False, max_reroutes=2, on_reregistration_needed=None)
Long-polls until an OTP arrives or timeout seconds elapse.
Returns: OtpResult(otp_code, from_number, received_at)
Raises: OtpTimeoutError if no OTP arrives within timeout seconds.
Set auto_reroute=True to automatically provision a replacement number in another country if no OTP arrives. on_reregistration_needed is an async callback (new_number: str, country: str) -> None called when re-registration on the target service is required.
agentsim.provision_sync(...) / num.wait_for_otp_sync(timeout=60)
Synchronous variants for non-async codebases:
with agentsim.provision_sync(agent_id="x") as num:
otp = num.wait_for_otp_sync(timeout=60)
Error Reference
| Exception | When |
|---|---|
AuthenticationError |
Missing or invalid API key |
PoolExhaustedError |
No numbers available in requested country |
OtpTimeoutError |
No OTP arrived within timeout seconds |
RateLimitError |
Too many requests — back off and retry |
SessionNotFoundError |
Session expired or already released |
CountryNotAllowedError |
Country not available on current plan |
Supported Countries
US
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 agentsim_sdk-0.14.0.tar.gz.
File metadata
- Download URL: agentsim_sdk-0.14.0.tar.gz
- Upload date:
- Size: 22.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f4c3604cbd23d8cfa47ca9f6d2125f5ce898720e0e9cc0520e7b4fc1d7f94660
|
|
| MD5 |
ba58e1562ea5da95775c201ddb597e9c
|
|
| BLAKE2b-256 |
455fae099b920a8941961d1ba32941ab703cf143d6bbb9a17025992006d14949
|
Provenance
The following attestation bundles were made for agentsim_sdk-0.14.0.tar.gz:
Publisher:
publish-pypi.yml on agentsimdev/agentsim
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agentsim_sdk-0.14.0.tar.gz -
Subject digest:
f4c3604cbd23d8cfa47ca9f6d2125f5ce898720e0e9cc0520e7b4fc1d7f94660 - Sigstore transparency entry: 1239444985
- Sigstore integration time:
-
Permalink:
agentsimdev/agentsim@c32a8c3d9168f7c12e1bf078577b6141a1cbe919 -
Branch / Tag:
refs/tags/v0.14.0 - Owner: https://github.com/agentsimdev
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@c32a8c3d9168f7c12e1bf078577b6141a1cbe919 -
Trigger Event:
release
-
Statement type:
File details
Details for the file agentsim_sdk-0.14.0-py3-none-any.whl.
File metadata
- Download URL: agentsim_sdk-0.14.0-py3-none-any.whl
- Upload date:
- Size: 8.0 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 |
ef3ff5819b4cf259197406212b71bfe08578d828ecf6cd4eb83daac080086758
|
|
| MD5 |
8c505b088e2844255750be59e61029bb
|
|
| BLAKE2b-256 |
c75d8f79cada5b2946284ebec71c9f10e6a6d9b400dc4e629f5308d4d8a8c3bc
|
Provenance
The following attestation bundles were made for agentsim_sdk-0.14.0-py3-none-any.whl:
Publisher:
publish-pypi.yml on agentsimdev/agentsim
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agentsim_sdk-0.14.0-py3-none-any.whl -
Subject digest:
ef3ff5819b4cf259197406212b71bfe08578d828ecf6cd4eb83daac080086758 - Sigstore transparency entry: 1239444987
- Sigstore integration time:
-
Permalink:
agentsimdev/agentsim@c32a8c3d9168f7c12e1bf078577b6141a1cbe919 -
Branch / Tag:
refs/tags/v0.14.0 - Owner: https://github.com/agentsimdev
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@c32a8c3d9168f7c12e1bf078577b6141a1cbe919 -
Trigger Event:
release
-
Statement type: