Skip to main content

LinkAuth credential broker adapter for the Model Context Standard.

Project description

mcs-auth-linkauth

Authentication for agents that can't open a browser. LinkAuth credential broker adapter for the Model Context Standard (MCS).

CLI tools, Telegram bots, background workers, Docker containers -- your agent shows a URL and a code, the user authenticates on any device, and the agent picks up the credentials automatically. No localhost callback. No web server. No browser on the agent's machine.

Think of it as the Device Flow experience, but for any credential type -- OAuth tokens, API keys, passwords, or custom secrets.

Installation

pip install mcs-auth-linkauth

Quick start

from mcs.auth.linkauth import LinkAuthProvider

provider = LinkAuthProvider(
    broker_url="https://auth.example.com",
    template="google_mail",
    display_name="Gmail Access",
)

try:
    token = provider.get_token("gmail")
except AuthChallenge as e:
    # Show this to the user via LLM, Telegram, CLI, ...
    print(f"Open {e.url} and enter code {e.code}")

How it works

Agent                     LinkAuth Broker              User
  |                            |                        |
  |-- create session --------->|                        |
  |   (public_key, template)   |                        |
  |<-- url + code ------------|                        |
  |                            |                        |
  |-- raise AuthChallenge ---->|                        |
  |   "Open URL, enter ABCD"  |                        |
  |                            |<-- user opens URL -----|
  |                            |    enters code         |
  |                            |    provides credentials|
  |                            |    (encrypted w/ pubkey)|
  |                            |                        |
  |-- poll ------------------->|                        |
  |<-- encrypted credentials --|                        |
  |-- decrypt (private key) -->|                        |
  |                            |                        |
  | token ready!               |                        |

Zero-knowledge: For form-based credentials (API keys, passwords), the broker encrypts with the agent's public key in the browser. The broker never sees the plaintext. For OAuth flows, the broker briefly handles tokens server-side before encrypting -- a documented trade-off.

Use with Auth0 Token Vault

The killer combo -- LinkAuth's device-flow UX with Auth0's multi-provider Token Vault:

from mcs.auth.auth0 import Auth0Provider
from mcs.auth.linkauth import LinkAuthAdapter

provider = Auth0Provider(
    domain="my-tenant.auth0.com",
    client_id="...",
    client_secret="...",
    _auth=LinkAuthAdapter(
        broker_url="https://auth.example.com",
        oauth_provider="auth0",
        oauth_scopes=["openid", "email", "offline_access"],
        oauth_extra_params={"audience": "...", "connection": "google-oauth2"},
        display_name="Gmail Access",
    ),
)

# Agent shows URL + code, user authenticates, Token Vault does the rest
token = provider.get_token("gmail")

Supported credential types

Template What the user sees
api_key Single password field
basic_auth Username + password form
openai, anthropic Branded API key form
google_mail, github, ... OAuth consent flow
Custom Define your own fields or OAuth provider

Links

License

Apache-2.0

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

mcs_auth_linkauth-0.1.0.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

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

mcs_auth_linkauth-0.1.0-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file mcs_auth_linkauth-0.1.0.tar.gz.

File metadata

  • Download URL: mcs_auth_linkauth-0.1.0.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.5

File hashes

Hashes for mcs_auth_linkauth-0.1.0.tar.gz
Algorithm Hash digest
SHA256 0ed98b37f4ad1be8ac432fbc29b6c910debce27e7c1fa251ecf0928a2d713dd7
MD5 b90ad1b52f1925bdbd2ddc552ba10d05
BLAKE2b-256 cdd732b7c4a815cc7e29c3f6c7f6ba4585e6fcc7cf0c31f444d882e44f46da1c

See more details on using hashes here.

File details

Details for the file mcs_auth_linkauth-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mcs_auth_linkauth-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e475e9983fe815fc23e526045c7b8ef291b690accf77e5cba5742bbb73037518
MD5 48ddab31a7c74849ba40a1b8d50d3cf7
BLAKE2b-256 56962bb47e3998d35136ca967718de9c9c40e4fe04ab5546519f262ac80f9355

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