hyperpocket 0.3.4__py3-none-any.whl → 0.3.6__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- hyperpocket/auth/activeloop/README.md +8 -0
- hyperpocket/auth/activeloop/__init__.py +0 -0
- hyperpocket/auth/activeloop/context.py +15 -0
- hyperpocket/auth/activeloop/token_context.py +11 -0
- hyperpocket/auth/activeloop/token_handler.py +92 -0
- hyperpocket/auth/activeloop/token_schema.py +9 -0
- hyperpocket/auth/adobe/README.md +8 -0
- hyperpocket/auth/adobe/__init__.py +0 -0
- hyperpocket/auth/adobe/context.py +15 -0
- hyperpocket/auth/adobe/token_context.py +11 -0
- hyperpocket/auth/adobe/token_handler.py +89 -0
- hyperpocket/auth/adobe/token_schema.py +11 -0
- hyperpocket/auth/affinity/README.md +18 -0
- hyperpocket/auth/affinity/__init__.py +0 -0
- hyperpocket/auth/affinity/context.py +15 -0
- hyperpocket/auth/affinity/token_context.py +11 -0
- hyperpocket/auth/affinity/token_handler.py +92 -0
- hyperpocket/auth/affinity/token_schema.py +11 -0
- hyperpocket/auth/agentql/README.md +8 -0
- hyperpocket/auth/agentql/__init__.py +0 -0
- hyperpocket/auth/agentql/context.py +15 -0
- hyperpocket/auth/agentql/token_context.py +11 -0
- hyperpocket/auth/agentql/token_handler.py +92 -0
- hyperpocket/auth/agentql/token_schema.py +9 -0
- hyperpocket/auth/ahrefs/README.md +8 -0
- hyperpocket/auth/ahrefs/__init__.py +0 -0
- hyperpocket/auth/ahrefs/context.py +15 -0
- hyperpocket/auth/ahrefs/token_context.py +11 -0
- hyperpocket/auth/ahrefs/token_handler.py +89 -0
- hyperpocket/auth/ahrefs/token_schema.py +11 -0
- hyperpocket/auth/airtable/README.md +8 -0
- hyperpocket/auth/airtable/__init__.py +0 -0
- hyperpocket/auth/airtable/context.py +15 -0
- hyperpocket/auth/airtable/token_context.py +11 -0
- hyperpocket/auth/airtable/token_handler.py +92 -0
- hyperpocket/auth/airtable/token_schema.py +11 -0
- hyperpocket/auth/alchemy/README.md +8 -0
- hyperpocket/auth/alchemy/__init__.py +0 -0
- hyperpocket/auth/alchemy/context.py +15 -0
- hyperpocket/auth/alchemy/token_context.py +11 -0
- hyperpocket/auth/alchemy/token_handler.py +92 -0
- hyperpocket/auth/alchemy/token_schema.py +11 -0
- hyperpocket/auth/altoviz/README.md +8 -0
- hyperpocket/auth/altoviz/__init__.py +0 -0
- hyperpocket/auth/altoviz/context.py +15 -0
- hyperpocket/auth/altoviz/token_context.py +11 -0
- hyperpocket/auth/altoviz/token_handler.py +92 -0
- hyperpocket/auth/altoviz/token_schema.py +11 -0
- hyperpocket/auth/asana/README.md +13 -0
- hyperpocket/auth/asana/__init__.py +0 -0
- hyperpocket/auth/asana/context.py +15 -0
- hyperpocket/auth/asana/oauth2_context.py +36 -0
- hyperpocket/auth/asana/oauth2_handler.py +158 -0
- hyperpocket/auth/asana/oauth2_schema.py +18 -0
- hyperpocket/auth/bamboohr/README.md +9 -0
- hyperpocket/auth/bamboohr/__init__.py +0 -0
- hyperpocket/auth/bamboohr/context.py +15 -0
- hyperpocket/auth/bamboohr/token_context.py +11 -0
- hyperpocket/auth/bamboohr/token_handler.py +92 -0
- hyperpocket/auth/bamboohr/token_schema.py +11 -0
- hyperpocket/auth/bitbucket/README.md +13 -0
- hyperpocket/auth/bitbucket/__init__.py +0 -0
- hyperpocket/auth/bitbucket/context.py +15 -0
- hyperpocket/auth/bitbucket/oauth2_context.py +33 -0
- hyperpocket/auth/bitbucket/oauth2_handler.py +146 -0
- hyperpocket/auth/bitbucket/oauth2_schema.py +18 -0
- hyperpocket/auth/bitwarden/README.md +9 -0
- hyperpocket/auth/bitwarden/__init__.py +0 -0
- hyperpocket/auth/bitwarden/context.py +15 -0
- hyperpocket/auth/bitwarden/token_context.py +11 -0
- hyperpocket/auth/bitwarden/token_handler.py +92 -0
- hyperpocket/auth/bitwarden/token_schema.py +11 -0
- hyperpocket/auth/brevo/README.md +9 -0
- hyperpocket/auth/brevo/__init__.py +0 -0
- hyperpocket/auth/brevo/context.py +15 -0
- hyperpocket/auth/brevo/token_context.py +11 -0
- hyperpocket/auth/brevo/token_handler.py +89 -0
- hyperpocket/auth/brevo/token_schema.py +11 -0
- hyperpocket/auth/brex/README.md +9 -0
- hyperpocket/auth/brex/__init__.py +0 -0
- hyperpocket/auth/brex/context.py +15 -0
- hyperpocket/auth/brex/token_context.py +11 -0
- hyperpocket/auth/brex/token_handler.py +87 -0
- hyperpocket/auth/brex/token_schema.py +11 -0
- hyperpocket/auth/cal/README.md +9 -0
- hyperpocket/auth/cal/__init__.py +0 -0
- hyperpocket/auth/cal/context.py +15 -0
- hyperpocket/auth/cal/token_context.py +11 -0
- hyperpocket/auth/cal/token_handler.py +85 -0
- hyperpocket/auth/cal/token_schema.py +11 -0
- hyperpocket/auth/calendly/README.md +13 -0
- hyperpocket/auth/canvas/README.md +9 -0
- hyperpocket/auth/canvas/__init__.py +0 -0
- hyperpocket/auth/canvas/context.py +15 -0
- hyperpocket/auth/canvas/token_context.py +11 -0
- hyperpocket/auth/canvas/token_handler.py +89 -0
- hyperpocket/auth/canvas/token_schema.py +11 -0
- hyperpocket/auth/clickup/README.md +9 -0
- hyperpocket/auth/clickup/__init__.py +0 -0
- hyperpocket/auth/clickup/context.py +15 -0
- hyperpocket/auth/clickup/token_context.py +11 -0
- hyperpocket/auth/clickup/token_handler.py +92 -0
- hyperpocket/auth/clickup/token_schema.py +11 -0
- hyperpocket/auth/cloudflare/README.md +9 -0
- hyperpocket/auth/cloudflare/__init__.py +0 -0
- hyperpocket/auth/cloudflare/context.py +15 -0
- hyperpocket/auth/cloudflare/token_context.py +11 -0
- hyperpocket/auth/cloudflare/token_handler.py +92 -0
- hyperpocket/auth/cloudflare/token_schema.py +11 -0
- hyperpocket/auth/dailybot/README.md +9 -0
- hyperpocket/auth/dailybot/__init__.py +0 -0
- hyperpocket/auth/dailybot/context.py +15 -0
- hyperpocket/auth/dailybot/token_context.py +11 -0
- hyperpocket/auth/dailybot/token_handler.py +92 -0
- hyperpocket/auth/dailybot/token_schema.py +11 -0
- hyperpocket/auth/datadog/README.md +9 -0
- hyperpocket/auth/datadog/__init__.py +0 -0
- hyperpocket/auth/datadog/context.py +15 -0
- hyperpocket/auth/datadog/token_context.py +11 -0
- hyperpocket/auth/datadog/token_handler.py +92 -0
- hyperpocket/auth/datadog/token_schema.py +11 -0
- hyperpocket/auth/discord/README.md +14 -0
- hyperpocket/auth/discord/__init__.py +0 -0
- hyperpocket/auth/discord/context.py +15 -0
- hyperpocket/auth/discord/oauth2_context.py +35 -0
- hyperpocket/auth/discord/oauth2_handler.py +133 -0
- hyperpocket/auth/discord/oauth2_schema.py +18 -0
- hyperpocket/auth/discord/token_context.py +11 -0
- hyperpocket/auth/discord/token_handler.py +92 -0
- hyperpocket/auth/discord/token_schema.py +11 -0
- hyperpocket/auth/discordbot/README.md +14 -0
- hyperpocket/auth/discordbot/__init__.py +0 -0
- hyperpocket/auth/discordbot/context.py +15 -0
- hyperpocket/auth/discordbot/token_context.py +11 -0
- hyperpocket/auth/discordbot/token_handler.py +92 -0
- hyperpocket/auth/discordbot/token_schema.py +11 -0
- hyperpocket/auth/elevenlabs/README.md +9 -0
- hyperpocket/auth/elevenlabs/__init__.py +0 -0
- hyperpocket/auth/elevenlabs/context.py +15 -0
- hyperpocket/auth/elevenlabs/token_context.py +11 -0
- hyperpocket/auth/elevenlabs/token_handler.py +92 -0
- hyperpocket/auth/elevenlabs/token_schema.py +11 -0
- hyperpocket/auth/exa/README.md +9 -0
- hyperpocket/auth/exa/__init__.py +0 -0
- hyperpocket/auth/exa/context.py +15 -0
- hyperpocket/auth/exa/token_context.py +11 -0
- hyperpocket/auth/exa/token_handler.py +85 -0
- hyperpocket/auth/exa/token_schema.py +11 -0
- hyperpocket/auth/facebook/README.md +13 -0
- hyperpocket/auth/facebook/__init__.py +0 -0
- hyperpocket/auth/facebook/context.py +15 -0
- hyperpocket/auth/facebook/oauth2_context.py +33 -0
- hyperpocket/auth/facebook/oauth2_handler.py +134 -0
- hyperpocket/auth/facebook/oauth2_schema.py +17 -0
- hyperpocket/auth/finage/README.md +9 -0
- hyperpocket/auth/finage/__init__.py +0 -0
- hyperpocket/auth/finage/context.py +15 -0
- hyperpocket/auth/finage/token_context.py +11 -0
- hyperpocket/auth/finage/token_handler.py +89 -0
- hyperpocket/auth/finage/token_schema.py +11 -0
- hyperpocket/auth/github/README.md +14 -0
- hyperpocket/auth/google/README.md +13 -0
- hyperpocket/auth/gumloop/README.md +9 -0
- hyperpocket/auth/happyrobot/README.md +9 -0
- hyperpocket/auth/happyrobot/__init__.py +0 -0
- hyperpocket/auth/happyrobot/context.py +15 -0
- hyperpocket/auth/happyrobot/token_context.py +11 -0
- hyperpocket/auth/happyrobot/token_handler.py +92 -0
- hyperpocket/auth/happyrobot/token_schema.py +9 -0
- hyperpocket/auth/heygen/README.md +9 -0
- hyperpocket/auth/heygen/__init__.py +0 -0
- hyperpocket/auth/heygen/context.py +15 -0
- hyperpocket/auth/heygen/token_context.py +11 -0
- hyperpocket/auth/heygen/token_handler.py +89 -0
- hyperpocket/auth/heygen/token_schema.py +11 -0
- hyperpocket/auth/hubspot/README.md +14 -0
- hyperpocket/auth/hubspot/__init__.py +0 -0
- hyperpocket/auth/hubspot/context.py +15 -0
- hyperpocket/auth/hubspot/oauth2_context.py +35 -0
- hyperpocket/auth/hubspot/oauth2_handler.py +142 -0
- hyperpocket/auth/hubspot/oauth2_schema.py +17 -0
- hyperpocket/auth/hubspot/token_context.py +11 -0
- hyperpocket/auth/hubspot/token_handler.py +92 -0
- hyperpocket/auth/hubspot/token_schema.py +11 -0
- hyperpocket/auth/jira/README.md +14 -0
- hyperpocket/auth/jira/__init__.py +0 -0
- hyperpocket/auth/jira/context.py +15 -0
- hyperpocket/auth/jira/oauth2_context.py +35 -0
- hyperpocket/auth/jira/oauth2_handler.py +135 -0
- hyperpocket/auth/jira/oauth2_schema.py +17 -0
- hyperpocket/auth/jira/token_context.py +11 -0
- hyperpocket/auth/jira/token_handler.py +87 -0
- hyperpocket/auth/jira/token_schema.py +11 -0
- hyperpocket/auth/klaviyo/README.md +10 -0
- hyperpocket/auth/klaviyo/__init__.py +0 -0
- hyperpocket/auth/klaviyo/context.py +15 -0
- hyperpocket/auth/klaviyo/token_context.py +11 -0
- hyperpocket/auth/klaviyo/token_handler.py +92 -0
- hyperpocket/auth/klaviyo/token_schema.py +11 -0
- hyperpocket/auth/lever/README.md +9 -0
- hyperpocket/auth/lever/__init__.py +0 -0
- hyperpocket/auth/lever/context.py +15 -0
- hyperpocket/auth/lever/token_context.py +11 -0
- hyperpocket/auth/lever/token_handler.py +89 -0
- hyperpocket/auth/lever/token_schema.py +11 -0
- hyperpocket/auth/lever_sandbox/README.md +9 -0
- hyperpocket/auth/lever_sandbox/__init__.py +0 -0
- hyperpocket/auth/lever_sandbox/context.py +15 -0
- hyperpocket/auth/lever_sandbox/token_context.py +11 -0
- hyperpocket/auth/lever_sandbox/token_handler.py +94 -0
- hyperpocket/auth/lever_sandbox/token_schema.py +11 -0
- hyperpocket/auth/linear/README.md +17 -0
- hyperpocket/auth/linear/context.py +1 -1
- hyperpocket/auth/linear/oauth2_context.py +33 -0
- hyperpocket/auth/linear/oauth2_handler.py +155 -0
- hyperpocket/auth/linear/oauth2_schema.py +17 -0
- hyperpocket/auth/linkedin/README.md +16 -0
- hyperpocket/auth/linkedin/__init__.py +0 -0
- hyperpocket/auth/linkedin/context.py +15 -0
- hyperpocket/auth/linkedin/oauth2_context.py +33 -0
- hyperpocket/auth/linkedin/oauth2_handler.py +154 -0
- hyperpocket/auth/linkedin/oauth2_schema.py +18 -0
- hyperpocket/auth/listennotes/README.md +12 -0
- hyperpocket/auth/listennotes/__init__.py +0 -0
- hyperpocket/auth/listennotes/context.py +15 -0
- hyperpocket/auth/listennotes/token_context.py +11 -0
- hyperpocket/auth/listennotes/token_handler.py +92 -0
- hyperpocket/auth/listennotes/token_schema.py +11 -0
- hyperpocket/auth/mailchimp/README.md +16 -0
- hyperpocket/auth/mailchimp/__init__.py +0 -0
- hyperpocket/auth/mailchimp/context.py +15 -0
- hyperpocket/auth/mailchimp/oauth2_context.py +33 -0
- hyperpocket/auth/mailchimp/oauth2_handler.py +153 -0
- hyperpocket/auth/mailchimp/oauth2_schema.py +17 -0
- hyperpocket/auth/mem0/README.md +11 -0
- hyperpocket/auth/mem0/__init__.py +0 -0
- hyperpocket/auth/mem0/context.py +15 -0
- hyperpocket/auth/mem0/token_context.py +11 -0
- hyperpocket/auth/mem0/token_handler.py +87 -0
- hyperpocket/auth/mem0/token_schema.py +11 -0
- hyperpocket/auth/microsoft_clarity/README.md +12 -0
- hyperpocket/auth/microsoft_clarity/__init__.py +0 -0
- hyperpocket/auth/microsoft_clarity/context.py +15 -0
- hyperpocket/auth/microsoft_clarity/token_context.py +15 -0
- hyperpocket/auth/microsoft_clarity/token_handler.py +102 -0
- hyperpocket/auth/microsoft_clarity/token_schema.py +11 -0
- hyperpocket/auth/neon/README.md +11 -0
- hyperpocket/auth/neon/__init__.py +0 -0
- hyperpocket/auth/neon/context.py +15 -0
- hyperpocket/auth/neon/token_context.py +11 -0
- hyperpocket/auth/neon/token_handler.py +87 -0
- hyperpocket/auth/neon/token_schema.py +11 -0
- hyperpocket/auth/ngrok/README.md +12 -0
- hyperpocket/auth/ngrok/__init__.py +0 -0
- hyperpocket/auth/ngrok/context.py +15 -0
- hyperpocket/auth/ngrok/token_context.py +11 -0
- hyperpocket/auth/ngrok/token_handler.py +89 -0
- hyperpocket/auth/ngrok/token_schema.py +11 -0
- hyperpocket/auth/notion/README.md +10 -20
- hyperpocket/auth/notion/oauth2_context.py +33 -0
- hyperpocket/auth/notion/oauth2_handler.py +152 -0
- hyperpocket/auth/notion/oauth2_schema.py +22 -0
- hyperpocket/auth/oncehub/README.md +11 -0
- hyperpocket/auth/oncehub/__init__.py +0 -0
- hyperpocket/auth/oncehub/context.py +15 -0
- hyperpocket/auth/oncehub/token_context.py +11 -0
- hyperpocket/auth/oncehub/token_handler.py +92 -0
- hyperpocket/auth/oncehub/token_schema.py +11 -0
- hyperpocket/auth/pagerduty/README.md +12 -0
- hyperpocket/auth/pagerduty/__init__.py +0 -0
- hyperpocket/auth/pagerduty/context.py +15 -0
- hyperpocket/auth/pagerduty/token_context.py +11 -0
- hyperpocket/auth/pagerduty/token_handler.py +92 -0
- hyperpocket/auth/pagerduty/token_schema.py +11 -0
- hyperpocket/auth/pandadoc/README.md +12 -0
- hyperpocket/auth/pandadoc/__init__.py +0 -0
- hyperpocket/auth/pandadoc/context.py +15 -0
- hyperpocket/auth/pandadoc/token_context.py +11 -0
- hyperpocket/auth/pandadoc/token_handler.py +92 -0
- hyperpocket/auth/pandadoc/token_schema.py +11 -0
- hyperpocket/auth/pipedrive/README.md +12 -0
- hyperpocket/auth/pipedrive/__init__.py +0 -0
- hyperpocket/auth/pipedrive/context.py +15 -0
- hyperpocket/auth/pipedrive/token_context.py +11 -0
- hyperpocket/auth/pipedrive/token_handler.py +92 -0
- hyperpocket/auth/pipedrive/token_schema.py +11 -0
- hyperpocket/auth/posthog/README.md +12 -0
- hyperpocket/auth/posthog/__init__.py +0 -0
- hyperpocket/auth/posthog/context.py +15 -0
- hyperpocket/auth/posthog/token_context.py +11 -0
- hyperpocket/auth/posthog/token_handler.py +92 -0
- hyperpocket/auth/posthog/token_schema.py +11 -0
- hyperpocket/auth/provider.py +58 -0
- hyperpocket/auth/ravenseotools/README.md +12 -0
- hyperpocket/auth/ravenseotools/__init__.py +0 -0
- hyperpocket/auth/ravenseotools/context.py +15 -0
- hyperpocket/auth/ravenseotools/token_context.py +11 -0
- hyperpocket/auth/ravenseotools/token_handler.py +94 -0
- hyperpocket/auth/ravenseotools/token_schema.py +11 -0
- hyperpocket/auth/reddit/README.md +16 -0
- hyperpocket/auth/salesforce/README.md +16 -0
- hyperpocket/auth/salesforce/__init__.py +0 -0
- hyperpocket/auth/salesforce/context.py +15 -0
- hyperpocket/auth/salesforce/oauth2_context.py +33 -0
- hyperpocket/auth/salesforce/oauth2_handler.py +136 -0
- hyperpocket/auth/salesforce/oauth2_schema.py +21 -0
- hyperpocket/auth/semantic_scholar/__init__.py +0 -0
- hyperpocket/auth/semantic_scholar/context.py +12 -0
- hyperpocket/auth/semantic_scholar/token_context.py +11 -0
- hyperpocket/auth/semantic_scholar/token_handler.py +64 -0
- hyperpocket/auth/semantic_scholar/token_schema.py +7 -0
- hyperpocket/auth/sendgrid/README.md +12 -0
- hyperpocket/auth/sendgrid/__init__.py +0 -0
- hyperpocket/auth/sendgrid/context.py +15 -0
- hyperpocket/auth/sendgrid/token_context.py +11 -0
- hyperpocket/auth/sendgrid/token_handler.py +92 -0
- hyperpocket/auth/sendgrid/token_schema.py +11 -0
- hyperpocket/auth/serpapi/README.md +13 -0
- hyperpocket/auth/serpapi/token_context.py +2 -4
- hyperpocket/auth/serpapi/token_handler.py +44 -16
- hyperpocket/auth/slack/README.md +17 -0
- hyperpocket/auth/spotify/README.md +15 -0
- hyperpocket/auth/spotify/__init__.py +0 -0
- hyperpocket/auth/spotify/context.py +15 -0
- hyperpocket/auth/spotify/oauth2_context.py +33 -0
- hyperpocket/auth/spotify/oauth2_handler.py +163 -0
- hyperpocket/auth/spotify/oauth2_schema.py +18 -0
- hyperpocket/auth/stripe/README.md +12 -0
- hyperpocket/auth/stripe/__init__.py +0 -0
- hyperpocket/auth/stripe/context.py +15 -0
- hyperpocket/auth/stripe/token_context.py +11 -0
- hyperpocket/auth/stripe/token_handler.py +89 -0
- hyperpocket/auth/stripe/token_schema.py +11 -0
- hyperpocket/auth/supabase/README.md +11 -0
- hyperpocket/auth/supabase/__init__.py +0 -0
- hyperpocket/auth/supabase/context.py +15 -0
- hyperpocket/auth/supabase/token_context.py +11 -0
- hyperpocket/auth/supabase/token_handler.py +92 -0
- hyperpocket/auth/supabase/token_schema.py +11 -0
- hyperpocket/auth/tavily/README.md +11 -0
- hyperpocket/auth/tavily/__init__.py +0 -0
- hyperpocket/auth/tavily/context.py +15 -0
- hyperpocket/auth/tavily/token_context.py +11 -0
- hyperpocket/auth/tavily/token_handler.py +89 -0
- hyperpocket/auth/tavily/token_schema.py +11 -0
- hyperpocket/auth/timekit/README.md +11 -0
- hyperpocket/auth/timekit/__init__.py +0 -0
- hyperpocket/auth/timekit/context.py +15 -0
- hyperpocket/auth/timekit/token_context.py +11 -0
- hyperpocket/auth/timekit/token_handler.py +92 -0
- hyperpocket/auth/timekit/token_schema.py +11 -0
- hyperpocket/auth/trello/README.md +12 -0
- hyperpocket/auth/trello/__init__.py +0 -0
- hyperpocket/auth/trello/context.py +15 -0
- hyperpocket/auth/trello/token_context.py +11 -0
- hyperpocket/auth/trello/token_handler.py +89 -0
- hyperpocket/auth/trello/token_schema.py +11 -0
- hyperpocket/auth/wandb/README.md +11 -0
- hyperpocket/auth/wandb/__init__.py +0 -0
- hyperpocket/auth/wandb/context.py +15 -0
- hyperpocket/auth/wandb/token_context.py +11 -0
- hyperpocket/auth/wandb/token_handler.py +89 -0
- hyperpocket/auth/wandb/token_schema.py +9 -0
- hyperpocket/auth/workiom/README.md +12 -0
- hyperpocket/auth/workiom/__init__.py +0 -0
- hyperpocket/auth/workiom/context.py +15 -0
- hyperpocket/auth/workiom/token_context.py +11 -0
- hyperpocket/auth/workiom/token_handler.py +92 -0
- hyperpocket/auth/workiom/token_schema.py +11 -0
- hyperpocket/auth/x/README.md +15 -0
- hyperpocket/auth/zoom/README.md +16 -0
- hyperpocket/auth/zoom/__init__.py +0 -0
- hyperpocket/auth/zoom/context.py +15 -0
- hyperpocket/auth/zoom/oauth2_context.py +33 -0
- hyperpocket/auth/zoom/oauth2_handler.py +153 -0
- hyperpocket/auth/zoom/oauth2_schema.py +19 -0
- hyperpocket/cli/__main__.py +4 -1
- hyperpocket/cli/auth_oauth2.py +79 -38
- hyperpocket/cli/auth_token.py +28 -16
- hyperpocket/cli/codegen/auth/__init__.py +4 -1
- hyperpocket/cli/codegen/auth/auth_context_template.py +1 -1
- hyperpocket/cli/codegen/auth/auth_oauth2_context_template.py +5 -4
- hyperpocket/cli/codegen/auth/auth_oauth2_handler_template.py +20 -45
- hyperpocket/cli/codegen/auth/auth_oauth2_schema_template.py +4 -3
- hyperpocket/cli/codegen/auth/auth_token_context_template.py +6 -6
- hyperpocket/cli/codegen/auth/auth_token_handler_template.py +14 -14
- hyperpocket/cli/codegen/auth/auth_token_schema_template.py +3 -3
- hyperpocket/cli/codegen/auth/server_auth_template.py +20 -5
- hyperpocket/cli/codegen/tool/__init__.py +1 -1
- hyperpocket/cli/codegen/tool/tool_main_template.py +1 -0
- hyperpocket/cli/{tool.py → tool_create.py} +24 -19
- hyperpocket/cli/tool_export.py +240 -0
- hyperpocket/config/auth.py +78 -13
- hyperpocket/pocket_core.py +5 -3
- hyperpocket/server/auth/activeloop.py +25 -0
- hyperpocket/server/auth/adobe.py +14 -0
- hyperpocket/server/auth/affinity.py +14 -0
- hyperpocket/server/auth/agentql.py +25 -0
- hyperpocket/server/auth/ahrefs.py +14 -0
- hyperpocket/server/auth/airtable.py +14 -0
- hyperpocket/server/auth/alchemy.py +14 -0
- hyperpocket/server/auth/altoviz.py +14 -0
- hyperpocket/server/auth/asana.py +25 -0
- hyperpocket/server/auth/bamboohr.py +14 -0
- hyperpocket/server/auth/bitbucket.py +25 -0
- hyperpocket/server/auth/bitwarden.py +14 -0
- hyperpocket/server/auth/brevo.py +14 -0
- hyperpocket/server/auth/brex.py +14 -0
- hyperpocket/server/auth/cal.py +14 -0
- hyperpocket/server/auth/canvas.py +14 -0
- hyperpocket/server/auth/clickup.py +14 -0
- hyperpocket/server/auth/cloudflare.py +14 -0
- hyperpocket/server/auth/dailybot.py +14 -0
- hyperpocket/server/auth/datadog.py +14 -0
- hyperpocket/server/auth/discord.py +25 -0
- hyperpocket/server/auth/discordbot.py +14 -0
- hyperpocket/server/auth/elevenlabs.py +14 -0
- hyperpocket/server/auth/exa.py +14 -0
- hyperpocket/server/auth/facebook.py +25 -0
- hyperpocket/server/auth/finage.py +14 -0
- hyperpocket/server/auth/happyrobot.py +26 -0
- hyperpocket/server/auth/heygen.py +14 -0
- hyperpocket/server/auth/hubspot.py +26 -0
- hyperpocket/server/auth/jira.py +25 -0
- hyperpocket/server/auth/klaviyo.py +14 -0
- hyperpocket/server/auth/lever.py +14 -0
- hyperpocket/server/auth/lever_sandbox.py +14 -0
- hyperpocket/server/auth/linear.py +21 -2
- hyperpocket/server/auth/linkedin.py +25 -0
- hyperpocket/server/auth/listennotes.py +14 -0
- hyperpocket/server/auth/mailchimp.py +25 -0
- hyperpocket/server/auth/mem0.py +14 -0
- hyperpocket/server/auth/microsoft_clarity.py +14 -0
- hyperpocket/server/auth/neon.py +14 -0
- hyperpocket/server/auth/ngrok.py +14 -0
- hyperpocket/server/auth/notion.py +20 -1
- hyperpocket/server/auth/oncehub.py +14 -0
- hyperpocket/server/auth/pagerduty.py +14 -0
- hyperpocket/server/auth/pandadoc.py +14 -0
- hyperpocket/server/auth/pipedrive.py +14 -0
- hyperpocket/server/auth/posthog.py +14 -0
- hyperpocket/server/auth/ravenseotools.py +14 -0
- hyperpocket/server/auth/salesforce.py +25 -0
- hyperpocket/server/auth/semantic_scholar.py +27 -0
- hyperpocket/server/auth/sendgrid.py +14 -0
- hyperpocket/server/auth/serpapi.py +5 -5
- hyperpocket/server/auth/spotify.py +25 -0
- hyperpocket/server/auth/stripe.py +14 -0
- hyperpocket/server/auth/supabase.py +14 -0
- hyperpocket/server/auth/tavily.py +14 -0
- hyperpocket/server/auth/timekit.py +14 -0
- hyperpocket/server/auth/trello.py +14 -0
- hyperpocket/server/auth/wandb.py +25 -0
- hyperpocket/server/auth/workiom.py +14 -0
- hyperpocket/server/auth/zoom.py +25 -0
- hyperpocket/server/server.py +9 -6
- {hyperpocket-0.3.4.dist-info → hyperpocket-0.3.6.dist-info}/METADATA +1 -1
- hyperpocket-0.3.6.dist-info/RECORD +593 -0
- hyperpocket-0.3.4.dist-info/RECORD +0 -163
- {hyperpocket-0.3.4.dist-info → hyperpocket-0.3.6.dist-info}/WHEEL +0 -0
- {hyperpocket-0.3.4.dist-info → hyperpocket-0.3.6.dist-info}/entry_points.txt +0 -0
@@ -0,0 +1,92 @@
|
|
1
|
+
from typing import Optional
|
2
|
+
from urllib.parse import urljoin, urlencode
|
3
|
+
|
4
|
+
from hyperpocket.auth import AuthProvider
|
5
|
+
from hyperpocket.auth.context import AuthContext
|
6
|
+
from hyperpocket.auth.handler import AuthHandlerInterface, AuthenticateRequest
|
7
|
+
from hyperpocket.auth.bitwarden.token_context import BitwardenTokenAuthContext
|
8
|
+
from hyperpocket.auth.bitwarden.token_schema import (
|
9
|
+
BitwardenTokenResponse,
|
10
|
+
BitwardenTokenRequest,
|
11
|
+
)
|
12
|
+
from hyperpocket.config import config
|
13
|
+
from hyperpocket.futures import FutureStore
|
14
|
+
|
15
|
+
|
16
|
+
class BitwardenTokenAuthHandler(AuthHandlerInterface):
|
17
|
+
name: str = "bitwarden-token"
|
18
|
+
description: str = (
|
19
|
+
"This handler is used to authenticate users using the Bitwarden token."
|
20
|
+
)
|
21
|
+
scoped: bool = False
|
22
|
+
|
23
|
+
_TOKEN_URL: str = urljoin(
|
24
|
+
config().public_base_url + "/",
|
25
|
+
f"{config().callback_url_rewrite_prefix}/auth/token",
|
26
|
+
)
|
27
|
+
|
28
|
+
@staticmethod
|
29
|
+
def provider() -> AuthProvider:
|
30
|
+
return AuthProvider.BITWARDEN
|
31
|
+
|
32
|
+
@staticmethod
|
33
|
+
def recommended_scopes() -> set[str]:
|
34
|
+
return set()
|
35
|
+
|
36
|
+
def prepare(
|
37
|
+
self,
|
38
|
+
auth_req: BitwardenTokenRequest,
|
39
|
+
thread_id: str,
|
40
|
+
profile: str,
|
41
|
+
future_uid: str,
|
42
|
+
*args,
|
43
|
+
**kwargs,
|
44
|
+
) -> str:
|
45
|
+
redirect_uri = urljoin(
|
46
|
+
config().public_base_url + "/",
|
47
|
+
f"{config().callback_url_rewrite_prefix}/auth/bitwarden/token/callback",
|
48
|
+
)
|
49
|
+
url = self._make_auth_url(
|
50
|
+
auth_req=auth_req, redirect_uri=redirect_uri, state=future_uid
|
51
|
+
)
|
52
|
+
FutureStore.create_future(
|
53
|
+
future_uid,
|
54
|
+
data={
|
55
|
+
"redirect_uri": redirect_uri,
|
56
|
+
"thread_id": thread_id,
|
57
|
+
"profile": profile,
|
58
|
+
},
|
59
|
+
)
|
60
|
+
|
61
|
+
return f"User needs to authenticate using the following URL: {url}"
|
62
|
+
|
63
|
+
async def authenticate(
|
64
|
+
self, auth_req: BitwardenTokenRequest, future_uid: str, *args, **kwargs
|
65
|
+
) -> AuthContext:
|
66
|
+
future_data = FutureStore.get_future(future_uid)
|
67
|
+
access_token = await future_data.future
|
68
|
+
|
69
|
+
response = BitwardenTokenResponse(access_token=access_token)
|
70
|
+
context = BitwardenTokenAuthContext.from_bitwarden_token_response(response)
|
71
|
+
|
72
|
+
return context
|
73
|
+
|
74
|
+
async def refresh(
|
75
|
+
self, auth_req: BitwardenTokenRequest, context: AuthContext, *args, **kwargs
|
76
|
+
) -> AuthContext:
|
77
|
+
raise Exception("Bitwarden token doesn't support refresh")
|
78
|
+
|
79
|
+
def _make_auth_url(
|
80
|
+
self, auth_req: BitwardenTokenRequest, redirect_uri: str, state: str
|
81
|
+
):
|
82
|
+
params = {
|
83
|
+
"redirect_uri": redirect_uri,
|
84
|
+
"state": state,
|
85
|
+
}
|
86
|
+
auth_url = f"{self._TOKEN_URL}?{urlencode(params)}"
|
87
|
+
return auth_url
|
88
|
+
|
89
|
+
def make_request(
|
90
|
+
self, auth_scopes: Optional[list[str]] = None, **kwargs
|
91
|
+
) -> BitwardenTokenRequest:
|
92
|
+
return BitwardenTokenRequest()
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from typing import List, Optional
|
2
|
+
from pydantic import BaseModel
|
3
|
+
from hyperpocket.auth.schema import AuthenticateRequest, AuthenticateResponse
|
4
|
+
|
5
|
+
|
6
|
+
class BitwardenTokenRequest(AuthenticateRequest):
|
7
|
+
pass
|
8
|
+
|
9
|
+
|
10
|
+
class BitwardenTokenResponse(AuthenticateResponse):
|
11
|
+
access_token: str
|
File without changes
|
@@ -0,0 +1,15 @@
|
|
1
|
+
from hyperpocket.auth.context import AuthContext
|
2
|
+
|
3
|
+
|
4
|
+
class BrevoAuthContext(AuthContext):
|
5
|
+
_ACCESS_TOKEN_KEY: str = "BREVO_TOKEN"
|
6
|
+
|
7
|
+
def to_dict(self) -> dict[str, str]:
|
8
|
+
return {
|
9
|
+
self._ACCESS_TOKEN_KEY: self.access_token,
|
10
|
+
}
|
11
|
+
|
12
|
+
def to_profiled_dict(self, profile: str) -> dict[str, str]:
|
13
|
+
return {
|
14
|
+
f"{profile.upper()}_{self._ACCESS_TOKEN_KEY}": self.access_token,
|
15
|
+
}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from hyperpocket.auth.brevo.context import BrevoAuthContext
|
2
|
+
from hyperpocket.auth.brevo.token_schema import BrevoTokenResponse
|
3
|
+
|
4
|
+
|
5
|
+
class BrevoTokenAuthContext(BrevoAuthContext):
|
6
|
+
@classmethod
|
7
|
+
def from_brevo_token_response(cls, response: BrevoTokenResponse):
|
8
|
+
description = f"Brevo Token Context logged in"
|
9
|
+
return cls(
|
10
|
+
access_token=response.access_token, description=description, expires_at=None
|
11
|
+
)
|
@@ -0,0 +1,89 @@
|
|
1
|
+
from typing import Optional
|
2
|
+
from urllib.parse import urljoin, urlencode
|
3
|
+
|
4
|
+
from hyperpocket.auth import AuthProvider
|
5
|
+
from hyperpocket.auth.context import AuthContext
|
6
|
+
from hyperpocket.auth.handler import AuthHandlerInterface, AuthenticateRequest
|
7
|
+
from hyperpocket.auth.brevo.token_context import BrevoTokenAuthContext
|
8
|
+
from hyperpocket.auth.brevo.token_schema import BrevoTokenResponse, BrevoTokenRequest
|
9
|
+
from hyperpocket.config import config
|
10
|
+
from hyperpocket.futures import FutureStore
|
11
|
+
|
12
|
+
|
13
|
+
class BrevoTokenAuthHandler(AuthHandlerInterface):
|
14
|
+
name: str = "brevo-token"
|
15
|
+
description: str = (
|
16
|
+
"This handler is used to authenticate users using the Brevo token."
|
17
|
+
)
|
18
|
+
scoped: bool = False
|
19
|
+
|
20
|
+
_TOKEN_URL: str = urljoin(
|
21
|
+
config().public_base_url + "/",
|
22
|
+
f"{config().callback_url_rewrite_prefix}/auth/token",
|
23
|
+
)
|
24
|
+
|
25
|
+
@staticmethod
|
26
|
+
def provider() -> AuthProvider:
|
27
|
+
return AuthProvider.BREVO
|
28
|
+
|
29
|
+
@staticmethod
|
30
|
+
def recommended_scopes() -> set[str]:
|
31
|
+
return set()
|
32
|
+
|
33
|
+
def prepare(
|
34
|
+
self,
|
35
|
+
auth_req: BrevoTokenRequest,
|
36
|
+
thread_id: str,
|
37
|
+
profile: str,
|
38
|
+
future_uid: str,
|
39
|
+
*args,
|
40
|
+
**kwargs,
|
41
|
+
) -> str:
|
42
|
+
redirect_uri = urljoin(
|
43
|
+
config().public_base_url + "/",
|
44
|
+
f"{config().callback_url_rewrite_prefix}/auth/brevo/token/callback",
|
45
|
+
)
|
46
|
+
url = self._make_auth_url(
|
47
|
+
auth_req=auth_req, redirect_uri=redirect_uri, state=future_uid
|
48
|
+
)
|
49
|
+
FutureStore.create_future(
|
50
|
+
future_uid,
|
51
|
+
data={
|
52
|
+
"redirect_uri": redirect_uri,
|
53
|
+
"thread_id": thread_id,
|
54
|
+
"profile": profile,
|
55
|
+
},
|
56
|
+
)
|
57
|
+
|
58
|
+
return f"User needs to authenticate using the following URL: {url}"
|
59
|
+
|
60
|
+
async def authenticate(
|
61
|
+
self, auth_req: BrevoTokenRequest, future_uid: str, *args, **kwargs
|
62
|
+
) -> AuthContext:
|
63
|
+
future_data = FutureStore.get_future(future_uid)
|
64
|
+
access_token = await future_data.future
|
65
|
+
|
66
|
+
response = BrevoTokenResponse(access_token=access_token)
|
67
|
+
context = BrevoTokenAuthContext.from_brevo_token_response(response)
|
68
|
+
|
69
|
+
return context
|
70
|
+
|
71
|
+
async def refresh(
|
72
|
+
self, auth_req: BrevoTokenRequest, context: AuthContext, *args, **kwargs
|
73
|
+
) -> AuthContext:
|
74
|
+
raise Exception("Brevo token doesn't support refresh")
|
75
|
+
|
76
|
+
def _make_auth_url(
|
77
|
+
self, auth_req: BrevoTokenRequest, redirect_uri: str, state: str
|
78
|
+
):
|
79
|
+
params = {
|
80
|
+
"redirect_uri": redirect_uri,
|
81
|
+
"state": state,
|
82
|
+
}
|
83
|
+
auth_url = f"{self._TOKEN_URL}?{urlencode(params)}"
|
84
|
+
return auth_url
|
85
|
+
|
86
|
+
def make_request(
|
87
|
+
self, auth_scopes: Optional[list[str]] = None, **kwargs
|
88
|
+
) -> BrevoTokenRequest:
|
89
|
+
return BrevoTokenRequest()
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from typing import List, Optional
|
2
|
+
from pydantic import BaseModel
|
3
|
+
from hyperpocket.auth.schema import AuthenticateRequest, AuthenticateResponse
|
4
|
+
|
5
|
+
|
6
|
+
class BrevoTokenRequest(AuthenticateRequest):
|
7
|
+
pass
|
8
|
+
|
9
|
+
|
10
|
+
class BrevoTokenResponse(AuthenticateResponse):
|
11
|
+
access_token: str
|
File without changes
|
@@ -0,0 +1,15 @@
|
|
1
|
+
from hyperpocket.auth.context import AuthContext
|
2
|
+
|
3
|
+
|
4
|
+
class BrexAuthContext(AuthContext):
|
5
|
+
_ACCESS_TOKEN_KEY: str = "BREX_TOKEN"
|
6
|
+
|
7
|
+
def to_dict(self) -> dict[str, str]:
|
8
|
+
return {
|
9
|
+
self._ACCESS_TOKEN_KEY: self.access_token,
|
10
|
+
}
|
11
|
+
|
12
|
+
def to_profiled_dict(self, profile: str) -> dict[str, str]:
|
13
|
+
return {
|
14
|
+
f"{profile.upper()}_{self._ACCESS_TOKEN_KEY}": self.access_token,
|
15
|
+
}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from hyperpocket.auth.brex.context import BrexAuthContext
|
2
|
+
from hyperpocket.auth.brex.token_schema import BrexTokenResponse
|
3
|
+
|
4
|
+
|
5
|
+
class BrexTokenAuthContext(BrexAuthContext):
|
6
|
+
@classmethod
|
7
|
+
def from_brex_token_response(cls, response: BrexTokenResponse):
|
8
|
+
description = f"Brex Token Context logged in"
|
9
|
+
return cls(
|
10
|
+
access_token=response.access_token, description=description, expires_at=None
|
11
|
+
)
|
@@ -0,0 +1,87 @@
|
|
1
|
+
from typing import Optional
|
2
|
+
from urllib.parse import urljoin, urlencode
|
3
|
+
|
4
|
+
from hyperpocket.auth import AuthProvider
|
5
|
+
from hyperpocket.auth.context import AuthContext
|
6
|
+
from hyperpocket.auth.handler import AuthHandlerInterface, AuthenticateRequest
|
7
|
+
from hyperpocket.auth.brex.token_context import BrexTokenAuthContext
|
8
|
+
from hyperpocket.auth.brex.token_schema import BrexTokenResponse, BrexTokenRequest
|
9
|
+
from hyperpocket.config import config
|
10
|
+
from hyperpocket.futures import FutureStore
|
11
|
+
|
12
|
+
|
13
|
+
class BrexTokenAuthHandler(AuthHandlerInterface):
|
14
|
+
name: str = "brex-token"
|
15
|
+
description: str = (
|
16
|
+
"This handler is used to authenticate users using the Brex token."
|
17
|
+
)
|
18
|
+
scoped: bool = False
|
19
|
+
|
20
|
+
_TOKEN_URL: str = urljoin(
|
21
|
+
config().public_base_url + "/",
|
22
|
+
f"{config().callback_url_rewrite_prefix}/auth/token",
|
23
|
+
)
|
24
|
+
|
25
|
+
@staticmethod
|
26
|
+
def provider() -> AuthProvider:
|
27
|
+
return AuthProvider.BREX
|
28
|
+
|
29
|
+
@staticmethod
|
30
|
+
def recommended_scopes() -> set[str]:
|
31
|
+
return set()
|
32
|
+
|
33
|
+
def prepare(
|
34
|
+
self,
|
35
|
+
auth_req: BrexTokenRequest,
|
36
|
+
thread_id: str,
|
37
|
+
profile: str,
|
38
|
+
future_uid: str,
|
39
|
+
*args,
|
40
|
+
**kwargs,
|
41
|
+
) -> str:
|
42
|
+
redirect_uri = urljoin(
|
43
|
+
config().public_base_url + "/",
|
44
|
+
f"{config().callback_url_rewrite_prefix}/auth/brex/token/callback",
|
45
|
+
)
|
46
|
+
url = self._make_auth_url(
|
47
|
+
auth_req=auth_req, redirect_uri=redirect_uri, state=future_uid
|
48
|
+
)
|
49
|
+
FutureStore.create_future(
|
50
|
+
future_uid,
|
51
|
+
data={
|
52
|
+
"redirect_uri": redirect_uri,
|
53
|
+
"thread_id": thread_id,
|
54
|
+
"profile": profile,
|
55
|
+
},
|
56
|
+
)
|
57
|
+
|
58
|
+
return f"User needs to authenticate using the following URL: {url}"
|
59
|
+
|
60
|
+
async def authenticate(
|
61
|
+
self, auth_req: BrexTokenRequest, future_uid: str, *args, **kwargs
|
62
|
+
) -> AuthContext:
|
63
|
+
future_data = FutureStore.get_future(future_uid)
|
64
|
+
access_token = await future_data.future
|
65
|
+
|
66
|
+
response = BrexTokenResponse(access_token=access_token)
|
67
|
+
context = BrexTokenAuthContext.from_brex_token_response(response)
|
68
|
+
|
69
|
+
return context
|
70
|
+
|
71
|
+
async def refresh(
|
72
|
+
self, auth_req: BrexTokenRequest, context: AuthContext, *args, **kwargs
|
73
|
+
) -> AuthContext:
|
74
|
+
raise Exception("Brex token doesn't support refresh")
|
75
|
+
|
76
|
+
def _make_auth_url(self, auth_req: BrexTokenRequest, redirect_uri: str, state: str):
|
77
|
+
params = {
|
78
|
+
"redirect_uri": redirect_uri,
|
79
|
+
"state": state,
|
80
|
+
}
|
81
|
+
auth_url = f"{self._TOKEN_URL}?{urlencode(params)}"
|
82
|
+
return auth_url
|
83
|
+
|
84
|
+
def make_request(
|
85
|
+
self, auth_scopes: Optional[list[str]] = None, **kwargs
|
86
|
+
) -> BrexTokenRequest:
|
87
|
+
return BrexTokenRequest()
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from typing import List, Optional
|
2
|
+
from pydantic import BaseModel
|
3
|
+
from hyperpocket.auth.schema import AuthenticateRequest, AuthenticateResponse
|
4
|
+
|
5
|
+
|
6
|
+
class BrexTokenRequest(AuthenticateRequest):
|
7
|
+
pass
|
8
|
+
|
9
|
+
|
10
|
+
class BrexTokenResponse(AuthenticateResponse):
|
11
|
+
access_token: str
|
File without changes
|
@@ -0,0 +1,15 @@
|
|
1
|
+
from hyperpocket.auth.context import AuthContext
|
2
|
+
|
3
|
+
|
4
|
+
class CalAuthContext(AuthContext):
|
5
|
+
_ACCESS_TOKEN_KEY: str = "CAL_TOKEN"
|
6
|
+
|
7
|
+
def to_dict(self) -> dict[str, str]:
|
8
|
+
return {
|
9
|
+
self._ACCESS_TOKEN_KEY: self.access_token,
|
10
|
+
}
|
11
|
+
|
12
|
+
def to_profiled_dict(self, profile: str) -> dict[str, str]:
|
13
|
+
return {
|
14
|
+
f"{profile.upper()}_{self._ACCESS_TOKEN_KEY}": self.access_token,
|
15
|
+
}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from hyperpocket.auth.cal.context import CalAuthContext
|
2
|
+
from hyperpocket.auth.cal.token_schema import CalTokenResponse
|
3
|
+
|
4
|
+
|
5
|
+
class CalTokenAuthContext(CalAuthContext):
|
6
|
+
@classmethod
|
7
|
+
def from_cal_token_response(cls, response: CalTokenResponse):
|
8
|
+
description = f"Cal Token Context logged in"
|
9
|
+
return cls(
|
10
|
+
access_token=response.access_token, description=description, expires_at=None
|
11
|
+
)
|
@@ -0,0 +1,85 @@
|
|
1
|
+
from typing import Optional
|
2
|
+
from urllib.parse import urljoin, urlencode
|
3
|
+
|
4
|
+
from hyperpocket.auth import AuthProvider
|
5
|
+
from hyperpocket.auth.context import AuthContext
|
6
|
+
from hyperpocket.auth.handler import AuthHandlerInterface, AuthenticateRequest
|
7
|
+
from hyperpocket.auth.cal.token_context import CalTokenAuthContext
|
8
|
+
from hyperpocket.auth.cal.token_schema import CalTokenResponse, CalTokenRequest
|
9
|
+
from hyperpocket.config import config
|
10
|
+
from hyperpocket.futures import FutureStore
|
11
|
+
|
12
|
+
|
13
|
+
class CalTokenAuthHandler(AuthHandlerInterface):
|
14
|
+
name: str = "cal-token"
|
15
|
+
description: str = "This handler is used to authenticate users using the Cal token."
|
16
|
+
scoped: bool = False
|
17
|
+
|
18
|
+
_TOKEN_URL: str = urljoin(
|
19
|
+
config().public_base_url + "/",
|
20
|
+
f"{config().callback_url_rewrite_prefix}/auth/token",
|
21
|
+
)
|
22
|
+
|
23
|
+
@staticmethod
|
24
|
+
def provider() -> AuthProvider:
|
25
|
+
return AuthProvider.CAL
|
26
|
+
|
27
|
+
@staticmethod
|
28
|
+
def recommended_scopes() -> set[str]:
|
29
|
+
return set()
|
30
|
+
|
31
|
+
def prepare(
|
32
|
+
self,
|
33
|
+
auth_req: CalTokenRequest,
|
34
|
+
thread_id: str,
|
35
|
+
profile: str,
|
36
|
+
future_uid: str,
|
37
|
+
*args,
|
38
|
+
**kwargs,
|
39
|
+
) -> str:
|
40
|
+
redirect_uri = urljoin(
|
41
|
+
config().public_base_url + "/",
|
42
|
+
f"{config().callback_url_rewrite_prefix}/auth/cal/token/callback",
|
43
|
+
)
|
44
|
+
url = self._make_auth_url(
|
45
|
+
auth_req=auth_req, redirect_uri=redirect_uri, state=future_uid
|
46
|
+
)
|
47
|
+
FutureStore.create_future(
|
48
|
+
future_uid,
|
49
|
+
data={
|
50
|
+
"redirect_uri": redirect_uri,
|
51
|
+
"thread_id": thread_id,
|
52
|
+
"profile": profile,
|
53
|
+
},
|
54
|
+
)
|
55
|
+
|
56
|
+
return f"User needs to authenticate using the following URL: {url}"
|
57
|
+
|
58
|
+
async def authenticate(
|
59
|
+
self, auth_req: CalTokenRequest, future_uid: str, *args, **kwargs
|
60
|
+
) -> AuthContext:
|
61
|
+
future_data = FutureStore.get_future(future_uid)
|
62
|
+
access_token = await future_data.future
|
63
|
+
|
64
|
+
response = CalTokenResponse(access_token=access_token)
|
65
|
+
context = CalTokenAuthContext.from_cal_token_response(response)
|
66
|
+
|
67
|
+
return context
|
68
|
+
|
69
|
+
async def refresh(
|
70
|
+
self, auth_req: CalTokenRequest, context: AuthContext, *args, **kwargs
|
71
|
+
) -> AuthContext:
|
72
|
+
raise Exception("Cal token doesn't support refresh")
|
73
|
+
|
74
|
+
def _make_auth_url(self, auth_req: CalTokenRequest, redirect_uri: str, state: str):
|
75
|
+
params = {
|
76
|
+
"redirect_uri": redirect_uri,
|
77
|
+
"state": state,
|
78
|
+
}
|
79
|
+
auth_url = f"{self._TOKEN_URL}?{urlencode(params)}"
|
80
|
+
return auth_url
|
81
|
+
|
82
|
+
def make_request(
|
83
|
+
self, auth_scopes: Optional[list[str]] = None, **kwargs
|
84
|
+
) -> CalTokenRequest:
|
85
|
+
return CalTokenRequest()
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from typing import List, Optional
|
2
|
+
from pydantic import BaseModel
|
3
|
+
from hyperpocket.auth.schema import AuthenticateRequest, AuthenticateResponse
|
4
|
+
|
5
|
+
|
6
|
+
class CalTokenRequest(AuthenticateRequest):
|
7
|
+
pass
|
8
|
+
|
9
|
+
|
10
|
+
class CalTokenResponse(AuthenticateResponse):
|
11
|
+
access_token: str
|
@@ -0,0 +1,13 @@
|
|
1
|
+
# Calendly Authentication
|
2
|
+
|
3
|
+
## Supported Authentication Types
|
4
|
+
|
5
|
+
- OAuth2
|
6
|
+
|
7
|
+
## How to Create an OAuth2 App
|
8
|
+
|
9
|
+
- See here: [link](https://developer.calendly.com/api-docs/3cefb59b832eb-calendly-o-auth-2-0)
|
10
|
+
|
11
|
+
## Additional Resources
|
12
|
+
|
13
|
+
- [Official Documentation](https://developer.calendly.com)
|
File without changes
|
@@ -0,0 +1,15 @@
|
|
1
|
+
from hyperpocket.auth.context import AuthContext
|
2
|
+
|
3
|
+
|
4
|
+
class CanvasAuthContext(AuthContext):
|
5
|
+
_ACCESS_TOKEN_KEY: str = "CANVAS_TOKEN"
|
6
|
+
|
7
|
+
def to_dict(self) -> dict[str, str]:
|
8
|
+
return {
|
9
|
+
self._ACCESS_TOKEN_KEY: self.access_token,
|
10
|
+
}
|
11
|
+
|
12
|
+
def to_profiled_dict(self, profile: str) -> dict[str, str]:
|
13
|
+
return {
|
14
|
+
f"{profile.upper()}_{self._ACCESS_TOKEN_KEY}": self.access_token,
|
15
|
+
}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
from hyperpocket.auth.canvas.context import CanvasAuthContext
|
2
|
+
from hyperpocket.auth.canvas.token_schema import CanvasTokenResponse
|
3
|
+
|
4
|
+
|
5
|
+
class CanvasTokenAuthContext(CanvasAuthContext):
|
6
|
+
@classmethod
|
7
|
+
def from_canvas_token_response(cls, response: CanvasTokenResponse):
|
8
|
+
description = f"Canvas Token Context logged in"
|
9
|
+
return cls(
|
10
|
+
access_token=response.access_token, description=description, expires_at=None
|
11
|
+
)
|
@@ -0,0 +1,89 @@
|
|
1
|
+
from typing import Optional
|
2
|
+
from urllib.parse import urljoin, urlencode
|
3
|
+
|
4
|
+
from hyperpocket.auth import AuthProvider
|
5
|
+
from hyperpocket.auth.context import AuthContext
|
6
|
+
from hyperpocket.auth.handler import AuthHandlerInterface, AuthenticateRequest
|
7
|
+
from hyperpocket.auth.canvas.token_context import CanvasTokenAuthContext
|
8
|
+
from hyperpocket.auth.canvas.token_schema import CanvasTokenResponse, CanvasTokenRequest
|
9
|
+
from hyperpocket.config import config
|
10
|
+
from hyperpocket.futures import FutureStore
|
11
|
+
|
12
|
+
|
13
|
+
class CanvasTokenAuthHandler(AuthHandlerInterface):
|
14
|
+
name: str = "canvas-token"
|
15
|
+
description: str = (
|
16
|
+
"This handler is used to authenticate users using the Canvas token."
|
17
|
+
)
|
18
|
+
scoped: bool = False
|
19
|
+
|
20
|
+
_TOKEN_URL: str = urljoin(
|
21
|
+
config().public_base_url + "/",
|
22
|
+
f"{config().callback_url_rewrite_prefix}/auth/token",
|
23
|
+
)
|
24
|
+
|
25
|
+
@staticmethod
|
26
|
+
def provider() -> AuthProvider:
|
27
|
+
return AuthProvider.CANVAS
|
28
|
+
|
29
|
+
@staticmethod
|
30
|
+
def recommended_scopes() -> set[str]:
|
31
|
+
return set()
|
32
|
+
|
33
|
+
def prepare(
|
34
|
+
self,
|
35
|
+
auth_req: CanvasTokenRequest,
|
36
|
+
thread_id: str,
|
37
|
+
profile: str,
|
38
|
+
future_uid: str,
|
39
|
+
*args,
|
40
|
+
**kwargs,
|
41
|
+
) -> str:
|
42
|
+
redirect_uri = urljoin(
|
43
|
+
config().public_base_url + "/",
|
44
|
+
f"{config().callback_url_rewrite_prefix}/auth/canvas/token/callback",
|
45
|
+
)
|
46
|
+
url = self._make_auth_url(
|
47
|
+
auth_req=auth_req, redirect_uri=redirect_uri, state=future_uid
|
48
|
+
)
|
49
|
+
FutureStore.create_future(
|
50
|
+
future_uid,
|
51
|
+
data={
|
52
|
+
"redirect_uri": redirect_uri,
|
53
|
+
"thread_id": thread_id,
|
54
|
+
"profile": profile,
|
55
|
+
},
|
56
|
+
)
|
57
|
+
|
58
|
+
return f"User needs to authenticate using the following URL: {url}"
|
59
|
+
|
60
|
+
async def authenticate(
|
61
|
+
self, auth_req: CanvasTokenRequest, future_uid: str, *args, **kwargs
|
62
|
+
) -> AuthContext:
|
63
|
+
future_data = FutureStore.get_future(future_uid)
|
64
|
+
access_token = await future_data.future
|
65
|
+
|
66
|
+
response = CanvasTokenResponse(access_token=access_token)
|
67
|
+
context = CanvasTokenAuthContext.from_canvas_token_response(response)
|
68
|
+
|
69
|
+
return context
|
70
|
+
|
71
|
+
async def refresh(
|
72
|
+
self, auth_req: CanvasTokenRequest, context: AuthContext, *args, **kwargs
|
73
|
+
) -> AuthContext:
|
74
|
+
raise Exception("Canvas token doesn't support refresh")
|
75
|
+
|
76
|
+
def _make_auth_url(
|
77
|
+
self, auth_req: CanvasTokenRequest, redirect_uri: str, state: str
|
78
|
+
):
|
79
|
+
params = {
|
80
|
+
"redirect_uri": redirect_uri,
|
81
|
+
"state": state,
|
82
|
+
}
|
83
|
+
auth_url = f"{self._TOKEN_URL}?{urlencode(params)}"
|
84
|
+
return auth_url
|
85
|
+
|
86
|
+
def make_request(
|
87
|
+
self, auth_scopes: Optional[list[str]] = None, **kwargs
|
88
|
+
) -> CanvasTokenRequest:
|
89
|
+
return CanvasTokenRequest()
|