โ† Back to Security & Passwords
Security & Passwords by @g9pedro

pdauth

Dynamic OAuth for AI agents via Pipedream

0
Source Code

pdauth โ€” Dynamic OAuth for AI Agents

Use pdauth to give yourself (the agent) access to 2500+ APIs via OAuth. The flow:

  1. Agent needs access to an app (Spotify, Slack, Notion, etc.)
  2. Generate an OAuth link with pdauth connect <app>
  3. Share link with user โ†’ they click and authorize
  4. Agent can now call tools via pdauth call <app.tool>

Quick Reference

# Configure (one-time setup)
pdauth config

# Search for apps
pdauth apps --search spotify

# Generate OAuth link
pdauth connect spotify --user USER_ID

# Check what's connected
pdauth status --user USER_ID

# List available tools
pdauth tools spotify --user USER_ID

# Call a tool
pdauth call spotify.get_my_playlists --user USER_ID
pdauth call slack.send_message channel=general text="Hello!"

The OAuth Flow (How to Request Access)

When you need access to an app the user hasn't authorized:

1. Run: pdauth connect <app> --user <user_id>
2. Get the OAuth link from output
3. Send link to user: "To do this, I need access to <App>. Click here to authorize: <link>"
4. User clicks, authorizes via Pipedream
5. Confirm with: pdauth status --user <user_id>
6. Now you can call tools!

User ID Strategy

Use a consistent identifier per user:

  • Telegram: telegram:5439689035
  • Email: pedro@example.com
  • Custom: pedro-mainframe

The same user ID across sessions maintains their connected accounts.

Calling Tools

# Format: pdauth call <app>.<tool_name> [key=value ...]

# Simple args
pdauth call slack.send_message channel=general text="Hello"

# JSON args for complex data
pdauth call notion.create_page --args '{"title": "My Page", "content": "..."}'

# Get JSON output for parsing
pdauth call spotify.get_my_playlists --json

Checking Status

# See what user has connected
pdauth status --user pedro

# See all users
pdauth status --all

# JSON for scripting
pdauth status --user pedro --json

Popular Apps

Browse all at https://mcp.pipedream.com

App Slug Example Tools
Slack slack send_message, list_channels
Spotify spotify get_my_playlists, add_to_playlist
Notion notion create_page, query_database
Google Sheets google_sheets get_values, update_values
Gmail gmail send_email, list_messages
GitHub github create_issue, list_repos
Linear linear create_issue, list_issues
Airtable airtable list_records, create_record

Error Handling

"App not connected" โ†’ Generate link with pdauth connect and ask user to authorize

"Tool not found" โ†’ List available tools with pdauth tools <app>

"Invalid credentials" โ†’ Run pdauth config to set up Pipedream credentials

Tips

  1. Always check status first before attempting tool calls
  2. Use consistent user IDs so connections persist across sessions
  3. JSON output (--json) is best for parsing results programmatically
  4. Link expiry โ€” OAuth links expire after 4 hours, generate fresh ones as needed

Example Workflow

User: "Add 'Bohemian Rhapsody' to my Spotify playlist"

Agent:
1. pdauth status --user telegram:5439689035 --json
   โ†’ No Spotify connection

2. pdauth connect spotify --user telegram:5439689035
   โ†’ Gets OAuth link

3. Send to user: "I need Spotify access. Click here: <link>"

4. User authorizes

5. pdauth status --user telegram:5439689035
   โ†’ Spotify โœ“ connected

6. pdauth call spotify.search_tracks query="Bohemian Rhapsody" --json
   โ†’ Get track ID

7. pdauth call spotify.add_to_playlist playlist_id=... track_id=...
   โ†’ Done!

8. Reply: "Added Bohemian Rhapsody to your playlist! ๐ŸŽต"