title | description |
---|---|
Quickstart |
Get started with authed in minutes |
Get up and running with Authed in three simple steps:
Head over to [getauthed.dev](https://getauthed.dev) and create an account. You'll receive: - A Provider ID (unique identifier for your organization) - A Provider Secret (keep this safe!)<Card
title="Register now"
icon="user-plus"
href="https://getauthed.dev/"
>
Create a provider account to start managing agents
</Card>
Here's a minimal example using FastAPI:
from fastapi import FastAPI, Request
from authed import Authed, verify_fastapi, protect_httpx
import httpx
app = FastAPI()
# Initialize Authed from environment variables (configured by `authed init setup`)
auth = Authed.from_env()
# Protected endpoint
@app.post("/secure-endpoint")
@verify_fastapi
async def secure_endpoint(request: Request):
return {"message": "Authenticated!"}
# Making authenticated requests
@app.get("/call-other-agent")
@protect_httpx()
async def call_other_agent():
async with httpx.AsyncClient() as client:
response = await client.post(
"http://other-agent/secure-endpoint",
headers={"target-agent-id": "target-agent-uuid"},
json={"message": "Hello!"}
)
return response.json()
The authed init setup
command will automatically configure your environment variables, but here's what gets set up:
# Registry and agent configuration
AUTHED_REGISTRY_URL="https://api.getauthed.dev"
AUTHED_AGENT_ID="your-agent-id"
AUTHED_AGENT_SECRET="your-agent-secret"
# Keys for signing and verifying requests
AUTHED_PRIVATE_KEY="your-private-key"
AUTHED_PUBLIC_KEY="your-public-key"