Library-first authentication and authorization SDK for AI agents
Project description
agentauthlayer
Unified SDK and local control plane package for Agent Auth.
agentauthlayer helps you:
- start a local Agent Auth backend and UI with one command
- authenticate once and reuse local credentials
- register agents from code
- sync tool and capability definitions
- evaluate permissions against the control plane
- apply permission checks inside runtime functions
This package now ships as a unified developer install containing:
- the reusable Python SDK layer
- the local control plane backend runtime
- the packaged admin UI assets
Install
pip install agentauthlayer
Quickstart
1. Start the local control plane
For a local developer setup, start Agent Auth with one command:
agentauth up
This starts the packaged local control plane on http://127.0.0.1:8002 by default.
If you want a different port:
agentauth up --port 8014
2. First-time developer setup
For a fresh deployment:
- Open the UI in your browser.
- Create the first super admin password.
- Create your first project.
- Then log in from the CLI.
Open the UI with:
agentauth ui --base-url http://127.0.0.1:8002
Then log in once:
agentauth login --base-url http://127.0.0.1:8002
This stores local credentials so your code can connect without manually pasting a token every time.
Useful follow-up commands:
agentauth whoami
agentauth logout
agentauth ui
If the deployment has not been initialized yet, agentauth login will tell you to finish setup in the UI first.
3. Define tools and agents in code
from agent_auth import register_tool, register_agent, require_permission
@register_tool(action="math.compute", description="Run approved math jobs")
@require_permission("math.compute", resource="math/basic")
def add(a: int, b: int, agent_id: str | None = None, role: str | None = None, context: dict | None = None):
return a + b
register_agent(
agent_id="math-agent",
name="Math Agent",
owner="you@company.com",
role="research_agent",
project_id="ai-platform",
scopes=[],
)
4. Sync everything with one command
agentauth sync --module your_module_name
This imports the module, discovers registered tools and agents, syncs capability definitions, and creates agents through the control plane.
SDK client usage
from agent_auth import AuthAPIClient
client = AuthAPIClient()
agent = client.create_agent(
agent_id="research-bot-01",
name="Research Bot 01",
owner="vaibhav@company.com",
role="research_agent",
scopes=[],
project_id="ai-platform",
)
print(agent)
Environment variables
If you prefer non-interactive configuration, the SDK also supports environment variables:
export AGENT_AUTH_URL=http://127.0.0.1:8002
export AGENT_AUTH_TOKEN=YOUR_ADMIN_OR_SERVICE_TOKEN
AGENT_AUTH_TOKEN is typically a bearer token, often represented as a long JWT string.
Recommended usage:
- use
agentauth loginfor local human developer workflows - use
AGENT_AUTH_TOKENfor CI, automation, or service-driven execution
If an env token expires, requests will fail until you replace it or log in again.
Avoid committing tokens into source control or long-lived shared .env files.
Resolution order used by AuthAPIClient():
- explicit constructor arguments
- environment variables
- stored local credentials from
agentauth login
Common tasks
Sync tools manually
client.sync_tools([
{"action": "tool.search_web", "description": "Search the web"},
{"action": "docs.read", "description": "Read protected docs"},
])
Evaluate access
decision = client.evaluate(
principal_id="research-bot-01",
action="tool.search_web",
resource="web/*",
role="research_agent",
)
print(decision)
Fetch or delete an agent
agent = client.get_agent("research-bot-01")
print(agent)
result = client.delete_agent("research-bot-01")
print(result)
CLI equivalent:
agentauth delete-agent research-bot-01
Public package scope
This package provides:
- the Python SDK (
agent_auth) - local control plane startup via
agentauth up - packaged backend runtime (
auth_app) - packaged admin UI assets
- CLI helpers for login, sync, and agent cleanup
- registry-based tool and agent sync
- permission evaluation helpers
Suitable use cases
- Python agent runtimes
- tool-based workflows
- service-to-control-plane integrations
- local development with stored credentials
- CI or automation using environment variables
Requirements
- Python 3.10+
- access to a running Agent Auth control plane
Notes
The package naming model is:
- install name:
agentauthlayer - CLI:
agentauth - Python import namespace:
agent_auth
The import path remains:
from agent_auth import ...
while the published package name is:
pip install agentauthlayer
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 agentauthlayer-0.1.7.tar.gz.
File metadata
- Download URL: agentauthlayer-0.1.7.tar.gz
- Upload date:
- Size: 1.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6a7c43b904a5a95664b56ca400dc65f044c55f178a700077a3a819d3826addce
|
|
| MD5 |
ca75dd9a0b966ec7744a4215b2bf3d94
|
|
| BLAKE2b-256 |
cef6b652ea069b3e67367009829f7d2552e049214c84b3009785f5a4aee23d6d
|
File details
Details for the file agentauthlayer-0.1.7-py3-none-any.whl.
File metadata
- Download URL: agentauthlayer-0.1.7-py3-none-any.whl
- Upload date:
- Size: 263.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
888a310d8ea0ab8c0b96fa90d11e517e06c4795d2e8e99022411ba57a0d04009
|
|
| MD5 |
1a4387d6a9b1bc57e8b4a99f3493bd10
|
|
| BLAKE2b-256 |
8916f0cd83d5a65da0bb2cff20e2146a9281bf49ce4c161f3455dc7fad298ca1
|