api/python/telnyx-oauth-python/SKILL.md
Implement OAuth 2.0 authentication flows for Telnyx API access. This skill provides Python SDK examples.
npx skillsauth add team-telnyx/telnyx-toolkit telnyx-oauth-pythonInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
pip install telnyx
import os
from telnyx import Telnyx
client = Telnyx(
api_key=os.environ.get("TELNYX_API_KEY"), # This is the default and can be omitted
)
All examples below assume client is already initialized as shown above.
OAuth 2.0 Authorization Server Metadata (RFC 8414)
GET /.well-known/oauth-authorization-server
response = client.well_known.retrieve_authorization_server_metadata()
print(response.authorization_endpoint)
OAuth 2.0 Protected Resource Metadata for resource discovery
GET /.well-known/oauth-protected-resource
response = client.well_known.retrieve_protected_resource_metadata()
print(response.authorization_servers)
OAuth 2.0 authorization endpoint for the authorization code flow
GET /oauth/authorize
client.oauth.retrieve_authorize(
client_id="client_id",
redirect_uri="https://example.com",
response_type="code",
)
Retrieve a paginated list of OAuth clients for the authenticated user
GET /oauth/clients
page = client.oauth_clients.list()
page = page.data[0]
print(page.client_id)
Create a new OAuth client
POST /oauth/clients — Required: name, allowed_scopes, client_type, allowed_grant_types
oauth_client = client.oauth_clients.create(
allowed_grant_types=["client_credentials"],
allowed_scopes=["admin"],
client_type="public",
name="My OAuth client",
)
print(oauth_client.data)
Retrieve a single OAuth client by ID
GET /oauth/clients/{id}
oauth_client = client.oauth_clients.retrieve(
"182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(oauth_client.data)
Update an existing OAuth client
PUT /oauth/clients/{id}
oauth_client = client.oauth_clients.update(
id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(oauth_client.data)
Delete an OAuth client
DELETE /oauth/clients/{id}
client.oauth_clients.delete(
"182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
Retrieve details about an OAuth consent token
GET /oauth/consent/{consent_token}
oauth = client.oauth.retrieve(
"consent_token",
)
print(oauth.data)
Retrieve a paginated list of OAuth grants for the authenticated user
GET /oauth/grants
page = client.oauth_grants.list()
page = page.data[0]
print(page.id)
Retrieve a single OAuth grant by ID
GET /oauth/grants/{id}
oauth_grant = client.oauth_grants.retrieve(
"182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(oauth_grant.data)
Revoke an OAuth grant
DELETE /oauth/grants/{id}
oauth_grant = client.oauth_grants.delete(
"182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(oauth_grant.data)
Introspect an OAuth access token to check its validity and metadata
POST /oauth/introspect — Required: token
response = client.oauth.introspect(
token="token",
)
print(response.client_id)
Retrieve the JSON Web Key Set for token verification
GET /oauth/jwks
response = client.oauth.retrieve_jwks()
print(response.keys)
Register a new OAuth client dynamically (RFC 7591)
POST /oauth/register
response = client.oauth.register()
print(response.client_id)
Exchange authorization code, client credentials, or refresh token for access token
POST /oauth/token — Required: grant_type
response = client.oauth.token(
grant_type="client_credentials",
)
print(response.access_token)
tools
Build cross-platform VoIP calling apps with React Native using Telnyx Voice SDK. High-level reactive API with automatic lifecycle management, CallKit/ConnectionService integration, and push notifications. Use for mobile VoIP apps with minimal setup.
tools
Build browser-based VoIP calling apps using Telnyx WebRTC JavaScript SDK. Covers authentication, voice calls, events, debugging, call quality metrics, and AI Agent integration. Use for web-based real-time communication.
tools
Build VoIP calling apps on iOS using Telnyx WebRTC SDK. Covers authentication, making/receiving calls, CallKit integration, PushKit/APNS push notifications, call quality metrics, and AI Agent integration. Use when implementing real-time voice communication on iOS.
tools
Build cross-platform VoIP calling apps with Flutter using Telnyx WebRTC SDK. Covers authentication, making/receiving calls, push notifications (FCM + APNS), call quality metrics, and AI Agent integration. Works on Android, iOS, and Web.