Skip to main content

Turbo Agent 授权管理库,支持基于平台授权方法与秘钥的登录、刷新与请求鉴权

Project description

turbo-agent-auth

Turbo Agent 授权管理库。提供基于 turbo-agent-core 中定义的 PlatformAuthMethodSecret 数据模型,执行多步登录流程、凭据刷新、请求鉴权注入等能力。

定位

  • 纯库,不包含数据库、HTTP 服务等基础设施依赖
  • 不做凭据持久化——只负责授权流程的执行与 HTTP 请求的鉴权注入
  • 存储由上层模块(cloud / store)负责

核心能力

  1. 登录流程执行 (AuthFlowExecutor):基于 AuthMethod.loginFlow 定义的多步模板,渲染占位符、发送请求、解析响应、提取凭据
  2. 同步/异步授权客户端 (AuthClient / AsyncAuthClient):封装 Platform + AuthMethod + Secret,提供 login() / refresh() / request() 等方法
  3. 请求鉴权注入 (BaseAuthClient.prepare_http()):根据 authFieldPlacements 将 Token/Cookie/APIKey 注入到 HTTP 请求的 Header/Query/Cookie/Body 中
  4. 默认授权模板 (get_default_schemas()):内置 JWT、OAuth1/2、APIKey、Cookies、SMTP、POP3 的默认字段与流程模板
  5. SMTP/POP3 邮件支持 (AuthClient.smtp_send() / AuthClient.pop3_fetch())

安装

uv add turbo-agent-auth

快速使用

from turbo_agent_core.schema.external import Platform, AuthMethod, Secret
from turbo_agent_auth import AuthClient, AsyncAuthClient

# 构造平台、授权方式、秘钥实例(通常从 store 读取)
platform = Platform(...)
auth_method = AuthMethod(...)
secret = Secret(...)

# 同步客户端
client = AuthClient(platform, auth_method, secret)
client.login()  # 执行登录流程,更新 secret.credential
resp = client.get("/api/some-endpoint")  # 自动注入鉴权信息

# 异步客户端
async_client = AsyncAuthClient(platform, auth_method, secret)
await async_client.login()
resp = await async_client.get("/api/some-endpoint")

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

turbo_agent_auth-0.1.11rc1.tar.gz (21.6 kB view details)

Uploaded Source

Built Distribution

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

turbo_agent_auth-0.1.11rc1-py3-none-any.whl (22.7 kB view details)

Uploaded Python 3

File details

Details for the file turbo_agent_auth-0.1.11rc1.tar.gz.

File metadata

  • Download URL: turbo_agent_auth-0.1.11rc1.tar.gz
  • Upload date:
  • Size: 21.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for turbo_agent_auth-0.1.11rc1.tar.gz
Algorithm Hash digest
SHA256 5ca1601a114baa4823d08109ac6761b65ce18318b22211fc0db337ec7f5ab599
MD5 917f2f511baa32d0d2e2dab71226b544
BLAKE2b-256 f8712c6aa0a5397e5cfb7080774e4faa9f7587ab3ad70d44685f3d8d36d61662

See more details on using hashes here.

File details

Details for the file turbo_agent_auth-0.1.11rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for turbo_agent_auth-0.1.11rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 6527c23f9e82b475f9aabc4e3fccb037767292b36fa936a491a2cc1ef8952112
MD5 a7b76a8898e1a04886688933d05c2826
BLAKE2b-256 2b1f53e2f4a16db6f5381cb9043e7863c7a9ff1ece7bc1b1e7808a4bb5207876

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