@mulverse/mulguard-core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/adapters.d.ts +522 -0
- package/adapters.d.ts.map +1 -0
- package/adapters.js +170 -0
- package/errors.d.ts +429 -0
- package/errors.d.ts.map +1 -0
- package/errors.js +473 -0
- package/index.d.ts +547 -0
- package/index.d.ts.map +1 -0
- package/index.js +142 -0
- package/jwt.d.ts +132 -0
- package/jwt.d.ts.map +1 -0
- package/jwt.js +123 -0
- package/lib/actions/callback/handle-login.d.ts +35 -0
- package/lib/actions/callback/handle-login.d.ts.map +1 -0
- package/lib/actions/callback/handle-login.js +275 -0
- package/lib/actions/callback/index.d.ts +5 -0
- package/lib/actions/callback/index.d.ts.map +1 -0
- package/lib/actions/callback/index.js +409 -0
- package/lib/actions/callback/oauth/callback.d.ts +36 -0
- package/lib/actions/callback/oauth/callback.d.ts.map +1 -0
- package/lib/actions/callback/oauth/callback.js +248 -0
- package/lib/actions/callback/oauth/checks.d.ts +70 -0
- package/lib/actions/callback/oauth/checks.d.ts.map +1 -0
- package/lib/actions/callback/oauth/checks.js +188 -0
- package/lib/actions/callback/oauth/csrf-token.d.ts +33 -0
- package/lib/actions/callback/oauth/csrf-token.d.ts.map +1 -0
- package/lib/actions/callback/oauth/csrf-token.js +39 -0
- package/lib/actions/index.d.ts +6 -0
- package/lib/actions/index.d.ts.map +1 -0
- package/lib/actions/index.js +5 -0
- package/lib/actions/session.d.ts +5 -0
- package/lib/actions/session.d.ts.map +1 -0
- package/lib/actions/session.js +127 -0
- package/lib/actions/signin/authorization-url.d.ts +12 -0
- package/lib/actions/signin/authorization-url.d.ts.map +1 -0
- package/lib/actions/signin/authorization-url.js +94 -0
- package/lib/actions/signin/index.d.ts +4 -0
- package/lib/actions/signin/index.d.ts.map +1 -0
- package/lib/actions/signin/index.js +22 -0
- package/lib/actions/signin/send-token.d.ts +10 -0
- package/lib/actions/signin/send-token.d.ts.map +1 -0
- package/lib/actions/signin/send-token.js +98 -0
- package/lib/actions/signout.d.ts +11 -0
- package/lib/actions/signout.d.ts.map +1 -0
- package/lib/actions/signout.js +30 -0
- package/lib/actions/webauthn-options.d.ts +8 -0
- package/lib/actions/webauthn-options.d.ts.map +1 -0
- package/lib/actions/webauthn-options.js +60 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +70 -0
- package/lib/init.d.ts +25 -0
- package/lib/init.d.ts.map +1 -0
- package/lib/init.js +172 -0
- package/lib/pages/error.d.ts +17 -0
- package/lib/pages/error.d.ts.map +1 -0
- package/lib/pages/error.js +40 -0
- package/lib/pages/index.d.ts +42 -0
- package/lib/pages/index.d.ts.map +1 -0
- package/lib/pages/index.js +136 -0
- package/lib/pages/signin.d.ts +10 -0
- package/lib/pages/signin.d.ts.map +1 -0
- package/lib/pages/signin.js +75 -0
- package/lib/pages/signout.d.ts +8 -0
- package/lib/pages/signout.d.ts.map +1 -0
- package/lib/pages/signout.js +17 -0
- package/lib/pages/styles.d.ts +3 -0
- package/lib/pages/styles.d.ts.map +1 -0
- package/lib/pages/styles.js +381 -0
- package/lib/pages/verify-request.d.ts +8 -0
- package/lib/pages/verify-request.d.ts.map +1 -0
- package/lib/pages/verify-request.js +11 -0
- package/lib/symbols.d.ts +50 -0
- package/lib/symbols.d.ts.map +1 -0
- package/lib/symbols.js +57 -0
- package/lib/utils/actions.d.ts +3 -0
- package/lib/utils/actions.d.ts.map +1 -0
- package/lib/utils/actions.js +14 -0
- package/lib/utils/assert.d.ts +14 -0
- package/lib/utils/assert.d.ts.map +1 -0
- package/lib/utils/assert.js +168 -0
- package/lib/utils/callback-url.d.ts +17 -0
- package/lib/utils/callback-url.d.ts.map +1 -0
- package/lib/utils/callback-url.js +27 -0
- package/lib/utils/cookie.d.ts +111 -0
- package/lib/utils/cookie.d.ts.map +1 -0
- package/lib/utils/cookie.js +205 -0
- package/lib/utils/date.d.ts +7 -0
- package/lib/utils/date.d.ts.map +1 -0
- package/lib/utils/date.js +8 -0
- package/lib/utils/email.d.ts +20 -0
- package/lib/utils/email.d.ts.map +1 -0
- package/lib/utils/email.js +57 -0
- package/lib/utils/env.d.ts +9 -0
- package/lib/utils/env.d.ts.map +1 -0
- package/lib/utils/env.js +96 -0
- package/lib/utils/logger.d.ts +18 -0
- package/lib/utils/logger.d.ts.map +1 -0
- package/lib/utils/logger.js +50 -0
- package/lib/utils/merge.d.ts +3 -0
- package/lib/utils/merge.d.ts.map +1 -0
- package/lib/utils/merge.js +23 -0
- package/lib/utils/providers.d.ts +19 -0
- package/lib/utils/providers.d.ts.map +1 -0
- package/lib/utils/providers.js +149 -0
- package/lib/utils/session.d.ts +7 -0
- package/lib/utils/session.d.ts.map +1 -0
- package/lib/utils/session.js +29 -0
- package/lib/utils/web.d.ts +10 -0
- package/lib/utils/web.d.ts.map +1 -0
- package/lib/utils/web.js +109 -0
- package/lib/utils/webauthn-client.d.ts +30 -0
- package/lib/utils/webauthn-client.d.ts.map +1 -0
- package/lib/utils/webauthn-client.js +197 -0
- package/lib/utils/webauthn-utils.d.ts +81 -0
- package/lib/utils/webauthn-utils.d.ts.map +1 -0
- package/lib/utils/webauthn-utils.js +343 -0
- package/lib/vendored/cookie.d.ts +120 -0
- package/lib/vendored/cookie.d.ts.map +1 -0
- package/lib/vendored/cookie.js +237 -0
- package/package.json +118 -0
- package/providers/42-school.d.ts +240 -0
- package/providers/42-school.d.ts.map +1 -0
- package/providers/42-school.js +78 -0
- package/providers/apple.d.ts +149 -0
- package/providers/apple.d.ts.map +1 -0
- package/providers/apple.js +104 -0
- package/providers/asgardeo.d.ts +102 -0
- package/providers/asgardeo.d.ts.map +1 -0
- package/providers/asgardeo.js +93 -0
- package/providers/atlassian.d.ts +94 -0
- package/providers/atlassian.d.ts.map +1 -0
- package/providers/atlassian.js +84 -0
- package/providers/auth0.d.ts +116 -0
- package/providers/auth0.d.ts.map +1 -0
- package/providers/auth0.js +49 -0
- package/providers/authentik.d.ts +90 -0
- package/providers/authentik.d.ts.map +1 -0
- package/providers/authentik.js +65 -0
- package/providers/azure-ad-b2c.d.ts +104 -0
- package/providers/azure-ad-b2c.d.ts.map +1 -0
- package/providers/azure-ad-b2c.js +100 -0
- package/providers/azure-ad.d.ts +19 -0
- package/providers/azure-ad.d.ts.map +1 -0
- package/providers/azure-ad.js +23 -0
- package/providers/azure-devops.d.ts +128 -0
- package/providers/azure-devops.d.ts.map +1 -0
- package/providers/azure-devops.js +158 -0
- package/providers/bankid-no.d.ts +134 -0
- package/providers/bankid-no.d.ts.map +1 -0
- package/providers/bankid-no.js +65 -0
- package/providers/battlenet.d.ts +85 -0
- package/providers/battlenet.d.ts.map +1 -0
- package/providers/battlenet.js +81 -0
- package/providers/beyondidentity.d.ts +77 -0
- package/providers/beyondidentity.d.ts.map +1 -0
- package/providers/beyondidentity.js +84 -0
- package/providers/bitbucket.d.ts +89 -0
- package/providers/bitbucket.d.ts.map +1 -0
- package/providers/bitbucket.js +92 -0
- package/providers/box.d.ts +63 -0
- package/providers/box.d.ts.map +1 -0
- package/providers/box.js +73 -0
- package/providers/boxyhq-saml.d.ts +121 -0
- package/providers/boxyhq-saml.d.ts.map +1 -0
- package/providers/boxyhq-saml.js +127 -0
- package/providers/bungie.d.ts +167 -0
- package/providers/bungie.d.ts.map +1 -0
- package/providers/bungie.js +174 -0
- package/providers/click-up.d.ts +75 -0
- package/providers/click-up.d.ts.map +1 -0
- package/providers/click-up.js +89 -0
- package/providers/cognito.d.ts +81 -0
- package/providers/cognito.d.ts.map +1 -0
- package/providers/cognito.js +73 -0
- package/providers/coinbase.d.ts +69 -0
- package/providers/coinbase.d.ts.map +1 -0
- package/providers/coinbase.js +78 -0
- package/providers/concept2.d.ts +81 -0
- package/providers/concept2.d.ts.map +1 -0
- package/providers/concept2.js +86 -0
- package/providers/credentials.d.ts +132 -0
- package/providers/credentials.d.ts.map +1 -0
- package/providers/credentials.js +74 -0
- package/providers/descope.d.ts +91 -0
- package/providers/descope.d.ts.map +1 -0
- package/providers/descope.js +78 -0
- package/providers/discord.d.ts +139 -0
- package/providers/discord.d.ts.map +1 -0
- package/providers/discord.js +86 -0
- package/providers/dribbble.d.ts +88 -0
- package/providers/dribbble.d.ts.map +1 -0
- package/providers/dribbble.js +85 -0
- package/providers/dropbox.d.ts +65 -0
- package/providers/dropbox.d.ts.map +1 -0
- package/providers/dropbox.js +88 -0
- package/providers/duende-identity-server6.d.ts +91 -0
- package/providers/duende-identity-server6.d.ts.map +1 -0
- package/providers/duende-identity-server6.js +80 -0
- package/providers/email.d.ts +41 -0
- package/providers/email.d.ts.map +1 -0
- package/providers/email.js +18 -0
- package/providers/eventbrite.d.ts +78 -0
- package/providers/eventbrite.d.ts.map +1 -0
- package/providers/eventbrite.js +88 -0
- package/providers/eveonline.d.ts +94 -0
- package/providers/eveonline.d.ts.map +1 -0
- package/providers/eveonline.js +92 -0
- package/providers/facebook.d.ts +84 -0
- package/providers/facebook.d.ts.map +1 -0
- package/providers/facebook.js +93 -0
- package/providers/faceit.d.ts +64 -0
- package/providers/faceit.d.ts.map +1 -0
- package/providers/faceit.js +74 -0
- package/providers/figma.d.ts +75 -0
- package/providers/figma.d.ts.map +1 -0
- package/providers/figma.js +81 -0
- package/providers/forwardemail.d.ts +4 -0
- package/providers/forwardemail.d.ts.map +1 -0
- package/providers/forwardemail.js +32 -0
- package/providers/foursquare.d.ts +71 -0
- package/providers/foursquare.d.ts.map +1 -0
- package/providers/foursquare.js +91 -0
- package/providers/freshbooks.d.ts +66 -0
- package/providers/freshbooks.d.ts.map +1 -0
- package/providers/freshbooks.js +76 -0
- package/providers/frontegg.d.ts +95 -0
- package/providers/frontegg.d.ts.map +1 -0
- package/providers/frontegg.js +88 -0
- package/providers/fusionauth.d.ts +279 -0
- package/providers/fusionauth.d.ts.map +1 -0
- package/providers/fusionauth.js +292 -0
- package/providers/github.d.ts +127 -0
- package/providers/github.d.ts.map +1 -0
- package/providers/github.js +115 -0
- package/providers/gitlab.d.ts +115 -0
- package/providers/gitlab.d.ts.map +1 -0
- package/providers/gitlab.js +75 -0
- package/providers/google.d.ts +138 -0
- package/providers/google.d.ts.map +1 -0
- package/providers/google.js +119 -0
- package/providers/hubspot.d.ts +76 -0
- package/providers/hubspot.d.ts.map +1 -0
- package/providers/hubspot.js +93 -0
- package/providers/huggingface.d.ts +216 -0
- package/providers/huggingface.d.ts.map +1 -0
- package/providers/huggingface.js +101 -0
- package/providers/identity-server4.d.ts +69 -0
- package/providers/identity-server4.d.ts.map +1 -0
- package/providers/identity-server4.js +64 -0
- package/providers/index.d.ts +61 -0
- package/providers/index.d.ts.map +1 -0
- package/providers/index.js +3 -0
- package/providers/instagram.d.ts +74 -0
- package/providers/instagram.d.ts.map +1 -0
- package/providers/instagram.js +87 -0
- package/providers/kakao.d.ts +148 -0
- package/providers/kakao.d.ts.map +1 -0
- package/providers/kakao.js +103 -0
- package/providers/keycloak.d.ts +100 -0
- package/providers/keycloak.d.ts.map +1 -0
- package/providers/keycloak.js +73 -0
- package/providers/kinde.d.ts +73 -0
- package/providers/kinde.d.ts.map +1 -0
- package/providers/kinde.js +51 -0
- package/providers/line.d.ts +83 -0
- package/providers/line.d.ts.map +1 -0
- package/providers/line.js +73 -0
- package/providers/linkedin.d.ts +77 -0
- package/providers/linkedin.d.ts.map +1 -0
- package/providers/linkedin.js +65 -0
- package/providers/logto.d.ts +98 -0
- package/providers/logto.d.ts.map +1 -0
- package/providers/logto.js +81 -0
- package/providers/loops.d.ts +40 -0
- package/providers/loops.d.ts.map +1 -0
- package/providers/loops.js +59 -0
- package/providers/mailchimp.d.ts +66 -0
- package/providers/mailchimp.d.ts.map +1 -0
- package/providers/mailchimp.js +76 -0
- package/providers/mailgun.d.ts +55 -0
- package/providers/mailgun.d.ts.map +1 -0
- package/providers/mailgun.js +74 -0
- package/providers/mailru.d.ts +63 -0
- package/providers/mailru.d.ts.map +1 -0
- package/providers/mailru.js +61 -0
- package/providers/mastodon.d.ts +90 -0
- package/providers/mastodon.d.ts.map +1 -0
- package/providers/mastodon.js +75 -0
- package/providers/mattermost.d.ts +132 -0
- package/providers/mattermost.d.ts.map +1 -0
- package/providers/mattermost.js +83 -0
- package/providers/medium.d.ts +68 -0
- package/providers/medium.d.ts.map +1 -0
- package/providers/medium.js +84 -0
- package/providers/microsoft-entra-id.d.ts +428 -0
- package/providers/microsoft-entra-id.d.ts.map +1 -0
- package/providers/microsoft-entra-id.js +156 -0
- package/providers/naver.d.ts +80 -0
- package/providers/naver.d.ts.map +1 -0
- package/providers/naver.js +79 -0
- package/providers/netlify.d.ts +66 -0
- package/providers/netlify.d.ts.map +1 -0
- package/providers/netlify.js +85 -0
- package/providers/netsuite.d.ts +189 -0
- package/providers/netsuite.d.ts.map +1 -0
- package/providers/netsuite.js +170 -0
- package/providers/nextcloud.d.ts +150 -0
- package/providers/nextcloud.d.ts.map +1 -0
- package/providers/nextcloud.js +99 -0
- package/providers/nodemailer.d.ts +27 -0
- package/providers/nodemailer.d.ts.map +1 -0
- package/providers/nodemailer.js +34 -0
- package/providers/notion.d.ts +99 -0
- package/providers/notion.d.ts.map +1 -0
- package/providers/notion.js +110 -0
- package/providers/oauth.d.ts +188 -0
- package/providers/oauth.d.ts.map +1 -0
- package/providers/oauth.js +1 -0
- package/providers/okta.d.ts +99 -0
- package/providers/okta.d.ts.map +1 -0
- package/providers/okta.js +63 -0
- package/providers/onelogin.d.ts +65 -0
- package/providers/onelogin.d.ts.map +1 -0
- package/providers/onelogin.js +61 -0
- package/providers/ory-hydra.d.ts +79 -0
- package/providers/ory-hydra.d.ts.map +1 -0
- package/providers/ory-hydra.js +67 -0
- package/providers/osso.d.ts +79 -0
- package/providers/osso.d.ts.map +1 -0
- package/providers/osso.js +77 -0
- package/providers/osu.d.ts +116 -0
- package/providers/osu.d.ts.map +1 -0
- package/providers/osu.js +75 -0
- package/providers/passage.d.ts +88 -0
- package/providers/passage.d.ts.map +1 -0
- package/providers/passage.js +75 -0
- package/providers/passkey.d.ts +65 -0
- package/providers/passkey.d.ts.map +1 -0
- package/providers/passkey.js +87 -0
- package/providers/patreon.d.ts +73 -0
- package/providers/patreon.d.ts.map +1 -0
- package/providers/patreon.js +77 -0
- package/providers/ping-id.d.ts +57 -0
- package/providers/ping-id.d.ts.map +1 -0
- package/providers/ping-id.js +40 -0
- package/providers/pinterest.d.ts +79 -0
- package/providers/pinterest.d.ts.map +1 -0
- package/providers/pinterest.js +85 -0
- package/providers/pipedrive.d.ts +99 -0
- package/providers/pipedrive.d.ts.map +1 -0
- package/providers/pipedrive.js +71 -0
- package/providers/postmark.d.ts +4 -0
- package/providers/postmark.d.ts.map +1 -0
- package/providers/postmark.js +36 -0
- package/providers/provider-types.d.ts +3 -0
- package/providers/provider-types.d.ts.map +1 -0
- package/providers/provider-types.js +1 -0
- package/providers/reddit.d.ts +88 -0
- package/providers/reddit.d.ts.map +1 -0
- package/providers/reddit.js +90 -0
- package/providers/resend.d.ts +4 -0
- package/providers/resend.d.ts.map +1 -0
- package/providers/resend.js +32 -0
- package/providers/roblox.d.ts +67 -0
- package/providers/roblox.d.ts.map +1 -0
- package/providers/roblox.js +53 -0
- package/providers/salesforce.d.ts +59 -0
- package/providers/salesforce.d.ts.map +1 -0
- package/providers/salesforce.js +52 -0
- package/providers/sendgrid.d.ts +4 -0
- package/providers/sendgrid.d.ts.map +1 -0
- package/providers/sendgrid.js +35 -0
- package/providers/simplelogin.d.ts +87 -0
- package/providers/simplelogin.d.ts.map +1 -0
- package/providers/simplelogin.js +83 -0
- package/providers/slack.d.ts +102 -0
- package/providers/slack.d.ts.map +1 -0
- package/providers/slack.js +69 -0
- package/providers/spotify.d.ts +75 -0
- package/providers/spotify.d.ts.map +1 -0
- package/providers/spotify.js +73 -0
- package/providers/strava.d.ts +68 -0
- package/providers/strava.d.ts.map +1 -0
- package/providers/strava.js +80 -0
- package/providers/threads.d.ts +108 -0
- package/providers/threads.d.ts.map +1 -0
- package/providers/threads.js +89 -0
- package/providers/tiktok.d.ts +248 -0
- package/providers/tiktok.d.ts.map +1 -0
- package/providers/tiktok.js +195 -0
- package/providers/todoist.d.ts +76 -0
- package/providers/todoist.d.ts.map +1 -0
- package/providers/todoist.js +97 -0
- package/providers/trakt.d.ts +93 -0
- package/providers/trakt.d.ts.map +1 -0
- package/providers/trakt.js +91 -0
- package/providers/twitch.d.ts +71 -0
- package/providers/twitch.d.ts.map +1 -0
- package/providers/twitch.js +96 -0
- package/providers/twitter.d.ts +183 -0
- package/providers/twitter.d.ts.map +1 -0
- package/providers/twitter.js +100 -0
- package/providers/united-effects.d.ts +80 -0
- package/providers/united-effects.d.ts.map +1 -0
- package/providers/united-effects.js +72 -0
- package/providers/vipps.d.ts +71 -0
- package/providers/vipps.d.ts.map +1 -0
- package/providers/vipps.js +33 -0
- package/providers/vk.d.ts +334 -0
- package/providers/vk.d.ts.map +1 -0
- package/providers/vk.js +103 -0
- package/providers/webauthn.d.ts +148 -0
- package/providers/webauthn.d.ts.map +1 -0
- package/providers/webauthn.js +128 -0
- package/providers/webex.d.ts +78 -0
- package/providers/webex.d.ts.map +1 -0
- package/providers/webex.js +73 -0
- package/providers/wechat.d.ts +78 -0
- package/providers/wechat.d.ts.map +1 -0
- package/providers/wechat.js +105 -0
- package/providers/wikimedia.d.ts +99 -0
- package/providers/wikimedia.d.ts.map +1 -0
- package/providers/wikimedia.js +90 -0
- package/providers/wordpress.d.ts +65 -0
- package/providers/wordpress.d.ts.map +1 -0
- package/providers/wordpress.js +71 -0
- package/providers/workos.d.ts +154 -0
- package/providers/workos.d.ts.map +1 -0
- package/providers/workos.js +143 -0
- package/providers/yandex.d.ts +131 -0
- package/providers/yandex.d.ts.map +1 -0
- package/providers/yandex.js +80 -0
- package/providers/zitadel.d.ts +117 -0
- package/providers/zitadel.d.ts.map +1 -0
- package/providers/zitadel.js +95 -0
- package/providers/zoho.d.ts +63 -0
- package/providers/zoho.d.ts.map +1 -0
- package/providers/zoho.js +79 -0
- package/providers/zoom.d.ts +93 -0
- package/providers/zoom.d.ts.map +1 -0
- package/providers/zoom.js +82 -0
- package/src/adapters/server-actions-helpers.ts +126 -0
- package/src/adapters.ts +603 -0
- package/src/errors.ts +551 -0
- package/src/index.ts +689 -0
- package/src/jwt.ts +283 -0
- package/src/lib/actions/callback/handle-login.ts +334 -0
- package/src/lib/actions/callback/index.ts +554 -0
- package/src/lib/actions/callback/oauth/callback.ts +347 -0
- package/src/lib/actions/callback/oauth/checks.ts +258 -0
- package/src/lib/actions/callback/oauth/csrf-token.ts +60 -0
- package/src/lib/actions/index.ts +5 -0
- package/src/lib/actions/session.ts +167 -0
- package/src/lib/actions/signin/authorization-url.ts +123 -0
- package/src/lib/actions/signin/index.ts +37 -0
- package/src/lib/actions/signin/send-token.ts +124 -0
- package/src/lib/actions/signout.ts +38 -0
- package/src/lib/actions/webauthn-options.ts +100 -0
- package/src/lib/index.ts +97 -0
- package/src/lib/init.ts +236 -0
- package/src/lib/pages/error.tsx +106 -0
- package/src/lib/pages/index.ts +181 -0
- package/src/lib/pages/signin.tsx +255 -0
- package/src/lib/pages/signout.tsx +49 -0
- package/src/lib/pages/styles.css +377 -0
- package/src/lib/pages/styles.ts +381 -0
- package/src/lib/pages/verify-request.tsx +36 -0
- package/src/lib/symbols.ts +60 -0
- package/src/lib/utils/actions.ts +17 -0
- package/src/lib/utils/assert.ts +259 -0
- package/src/lib/utils/callback-url.ts +42 -0
- package/src/lib/utils/cookie.ts +248 -0
- package/src/lib/utils/date.ts +8 -0
- package/src/lib/utils/email.ts +65 -0
- package/src/lib/utils/env.ts +113 -0
- package/src/lib/utils/logger.ts +75 -0
- package/src/lib/utils/merge.ts +30 -0
- package/src/lib/utils/providers.ts +203 -0
- package/src/lib/utils/session.ts +41 -0
- package/src/lib/utils/web.ts +151 -0
- package/src/lib/utils/webauthn-client.js +229 -0
- package/src/lib/utils/webauthn-utils.ts +531 -0
- package/src/lib/vendored/cookie.ts +383 -0
- package/src/providers/42-school.ts +256 -0
- package/src/providers/apple.ts +206 -0
- package/src/providers/asgardeo.ts +118 -0
- package/src/providers/atlassian.ts +120 -0
- package/src/providers/auth0.ts +127 -0
- package/src/providers/authentik.ts +100 -0
- package/src/providers/azure-ad-b2c.ts +124 -0
- package/src/providers/azure-ad.ts +30 -0
- package/src/providers/azure-devops.ts +184 -0
- package/src/providers/bankid-no.ts +161 -0
- package/src/providers/battlenet.ts +107 -0
- package/src/providers/beyondidentity.ts +102 -0
- package/src/providers/bitbucket.ts +122 -0
- package/src/providers/box.ts +87 -0
- package/src/providers/boxyhq-saml.ts +148 -0
- package/src/providers/bungie.ts +192 -0
- package/src/providers/click-up.ts +104 -0
- package/src/providers/cognito.ts +94 -0
- package/src/providers/coinbase.ts +93 -0
- package/src/providers/concept2.ts +108 -0
- package/src/providers/credentials.ts +157 -0
- package/src/providers/descope.ts +105 -0
- package/src/providers/discord.ts +176 -0
- package/src/providers/dribbble.ts +122 -0
- package/src/providers/dropbox.ts +102 -0
- package/src/providers/duende-identity-server6.ts +101 -0
- package/src/providers/email.ts +60 -0
- package/src/providers/eventbrite.ts +105 -0
- package/src/providers/eveonline.ts +117 -0
- package/src/providers/facebook.ts +119 -0
- package/src/providers/faceit.ts +90 -0
- package/src/providers/figma.ts +105 -0
- package/src/providers/forwardemail.ts +37 -0
- package/src/providers/foursquare.ts +105 -0
- package/src/providers/freshbooks.ts +90 -0
- package/src/providers/frontegg.ts +111 -0
- package/src/providers/fusionauth.ts +336 -0
- package/src/providers/github.ts +187 -0
- package/src/providers/gitlab.ts +140 -0
- package/src/providers/google.ts +152 -0
- package/src/providers/hubspot.ts +117 -0
- package/src/providers/huggingface.ts +234 -0
- package/src/providers/identity-server4.ts +78 -0
- package/src/providers/index.ts +115 -0
- package/src/providers/instagram.ts +103 -0
- package/src/providers/kakao.ts +184 -0
- package/src/providers/keycloak.ts +111 -0
- package/src/providers/kinde.ts +85 -0
- package/src/providers/line.ts +99 -0
- package/src/providers/linkedin.ts +91 -0
- package/src/providers/logto.ts +122 -0
- package/src/providers/loops.ts +79 -0
- package/src/providers/mailchimp.ts +90 -0
- package/src/providers/mailgun.ts +98 -0
- package/src/providers/mailru.ts +75 -0
- package/src/providers/mastodon.ts +112 -0
- package/src/providers/mattermost.ts +154 -0
- package/src/providers/medium.ts +89 -0
- package/src/providers/microsoft-entra-id.ts +497 -0
- package/src/providers/naver.ts +102 -0
- package/src/providers/netlify.ts +90 -0
- package/src/providers/netsuite.ts +225 -0
- package/src/providers/nextcloud.ts +207 -0
- package/src/providers/nodemailer.ts +84 -0
- package/src/providers/notion.ts +166 -0
- package/src/providers/oauth.ts +310 -0
- package/src/providers/okta.ts +111 -0
- package/src/providers/onelogin.ts +75 -0
- package/src/providers/ory-hydra.ts +93 -0
- package/src/providers/osso.ts +91 -0
- package/src/providers/osu.ts +138 -0
- package/src/providers/passage.ts +103 -0
- package/src/providers/passkey.ts +94 -0
- package/src/providers/patreon.ts +98 -0
- package/src/providers/ping-id.ts +68 -0
- package/src/providers/pinterest.ts +106 -0
- package/src/providers/pipedrive.ts +120 -0
- package/src/providers/postmark.ts +38 -0
- package/src/providers/provider-types.ts +107 -0
- package/src/providers/reddit.ts +104 -0
- package/src/providers/resend.ts +35 -0
- package/src/providers/roblox.ts +94 -0
- package/src/providers/salesforce.ts +73 -0
- package/src/providers/sendgrid.ts +36 -0
- package/src/providers/simplelogin.ts +107 -0
- package/src/providers/slack.ts +115 -0
- package/src/providers/spotify.ts +99 -0
- package/src/providers/strava.ts +101 -0
- package/src/providers/threads.ts +135 -0
- package/src/providers/tiktok.ts +319 -0
- package/src/providers/todoist.ts +122 -0
- package/src/providers/trakt.ts +120 -0
- package/src/providers/twitch.ts +121 -0
- package/src/providers/twitter.ts +207 -0
- package/src/providers/united-effects.ts +89 -0
- package/src/providers/vipps.ts +86 -0
- package/src/providers/vk.ts +401 -0
- package/src/providers/webauthn.ts +296 -0
- package/src/providers/webex.ts +102 -0
- package/src/providers/wechat.ts +141 -0
- package/src/providers/wikimedia.ts +258 -0
- package/src/providers/wordpress.ts +86 -0
- package/src/providers/workos.ts +180 -0
- package/src/providers/yandex.ts +159 -0
- package/src/providers/zitadel.ts +128 -0
- package/src/providers/zoho.ts +84 -0
- package/src/providers/zoom.ts +119 -0
- package/src/types.ts +430 -0
- package/src/warnings.ts +21 -0
- package/types.d.ts +309 -0
- package/types.d.ts.map +1 -0
- package/types.js +53 -0
- package/warnings.d.ts +17 -0
- package/warnings.d.ts.map +1 -0
- package/warnings.js +1 -0
|
@@ -0,0 +1,319 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* <div class="provider" style={{backgroundColor: "#000", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
|
|
3
|
+
* <span>Built-in <b>TikTok</b> integration.</span>
|
|
4
|
+
* <a href="https://www.tiktok.com/">
|
|
5
|
+
* <img style={{display: "block"}} src="https://authjs.dev/img/providers/tiktok.svg" height="48" />
|
|
6
|
+
* </a>
|
|
7
|
+
* </div>
|
|
8
|
+
*
|
|
9
|
+
* @module providers/tiktok
|
|
10
|
+
*/
|
|
11
|
+
import { customFetch } from "../lib/symbols.js"
|
|
12
|
+
import type { OAuthConfig, OAuthUserConfig } from "./index.js"
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* [More info](https://developers.tiktok.com/doc/tiktok-api-v2-get-user-info/)
|
|
16
|
+
*/
|
|
17
|
+
export interface TiktokProfile {
|
|
18
|
+
data: {
|
|
19
|
+
user: {
|
|
20
|
+
/**
|
|
21
|
+
* The unique identification of the user in the current application.Open id
|
|
22
|
+
* for the client.
|
|
23
|
+
*
|
|
24
|
+
* To return this field, add `fields=open_id` in the user profile request's query parameter.
|
|
25
|
+
*/
|
|
26
|
+
open_id: string
|
|
27
|
+
/**
|
|
28
|
+
* The unique identification of the user across different apps for the same developer.
|
|
29
|
+
* For example, if a partner has X number of clients,
|
|
30
|
+
* it will get X number of open_id for the same TikTok user,
|
|
31
|
+
* but one persistent union_id for the particular user.
|
|
32
|
+
*
|
|
33
|
+
* To return this field, add `fields=union_id` in the user profile request's query parameter.
|
|
34
|
+
*/
|
|
35
|
+
union_id?: string
|
|
36
|
+
/**
|
|
37
|
+
* User's profile image.
|
|
38
|
+
*
|
|
39
|
+
* To return this field, add `fields=avatar_url` in the user profile request's query parameter.
|
|
40
|
+
*/
|
|
41
|
+
avatar_url: string
|
|
42
|
+
/**
|
|
43
|
+
* User`s profile image in 100x100 size.
|
|
44
|
+
*
|
|
45
|
+
* To return this field, add `fields=avatar_url_100` in the user profile request's query parameter.
|
|
46
|
+
*/
|
|
47
|
+
avatar_url_100?: string
|
|
48
|
+
/**
|
|
49
|
+
* User's profile image with higher resolution
|
|
50
|
+
*
|
|
51
|
+
* To return this field, add `fields=avatar_url_100` in the user profile request's query parameter.
|
|
52
|
+
*/
|
|
53
|
+
avatar_large_url?: string
|
|
54
|
+
/**
|
|
55
|
+
* User's profile name
|
|
56
|
+
*
|
|
57
|
+
* To return this field, add `fields=display_name` in the user profile request's query parameter.
|
|
58
|
+
*/
|
|
59
|
+
display_name: string
|
|
60
|
+
/**
|
|
61
|
+
* User's username.
|
|
62
|
+
*
|
|
63
|
+
* To return this field, add `fields=username` in the user profile request's query parameter.
|
|
64
|
+
*/
|
|
65
|
+
username: string
|
|
66
|
+
/** @note Email is currently unsupported by TikTok */
|
|
67
|
+
email?: string
|
|
68
|
+
/**
|
|
69
|
+
* User's bio description if there is a valid one.
|
|
70
|
+
*
|
|
71
|
+
* To return this field, add `fields=bio_description` in the user profile request's query parameter.
|
|
72
|
+
*/
|
|
73
|
+
bio_description?: string
|
|
74
|
+
/**
|
|
75
|
+
* The link to user's TikTok profile page.
|
|
76
|
+
*
|
|
77
|
+
* To return this field, add `fields=profile_deep_link` in the user profile request's query parameter.
|
|
78
|
+
*/
|
|
79
|
+
profile_deep_link?: string
|
|
80
|
+
/**
|
|
81
|
+
* Whether TikTok has provided a verified badge to the account after confirming
|
|
82
|
+
* that it belongs to the user it represents.
|
|
83
|
+
*
|
|
84
|
+
* To return this field, add `fields=is_verified` in the user profile request's query parameter.
|
|
85
|
+
*/
|
|
86
|
+
is_verified?: boolean
|
|
87
|
+
/**
|
|
88
|
+
* User's followers count.
|
|
89
|
+
*
|
|
90
|
+
* To return this field, add `fields=follower_count` in the user profile request's query parameter.
|
|
91
|
+
*/
|
|
92
|
+
follower_count?: number
|
|
93
|
+
/**
|
|
94
|
+
* The number of accounts that the user is following.
|
|
95
|
+
*
|
|
96
|
+
* To return this field, add `fields=following_count` in the user profile request's query parameter.
|
|
97
|
+
*/
|
|
98
|
+
following_count?: number
|
|
99
|
+
/**
|
|
100
|
+
* The total number of likes received by the user across all of their videos.
|
|
101
|
+
*
|
|
102
|
+
* To return this field, add `fields=likes_count` in the user profile request's query parameter.
|
|
103
|
+
*/
|
|
104
|
+
likes_count?: number
|
|
105
|
+
/**
|
|
106
|
+
* The total number of publicly posted videos by the user.
|
|
107
|
+
*
|
|
108
|
+
* To return this field, add `fields=video_count` in the user profile request's query parameter.
|
|
109
|
+
*/
|
|
110
|
+
video_count?: number
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
error: {
|
|
114
|
+
/**
|
|
115
|
+
* The error category in string.
|
|
116
|
+
*/
|
|
117
|
+
code: string
|
|
118
|
+
/**
|
|
119
|
+
* The error message in string.
|
|
120
|
+
*/
|
|
121
|
+
message: string
|
|
122
|
+
/**
|
|
123
|
+
* The error message in string.
|
|
124
|
+
*/
|
|
125
|
+
log_id: string
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* Add TikTok login to your page.
|
|
131
|
+
*
|
|
132
|
+
* ### Setup
|
|
133
|
+
*
|
|
134
|
+
* #### Callback URL
|
|
135
|
+
* ```
|
|
136
|
+
* https://example.com/api/auth/callback/tiktok
|
|
137
|
+
* ```
|
|
138
|
+
*
|
|
139
|
+
* #### Configuration
|
|
140
|
+
* You can omit the client and secret if you have set the `AUTH_TIKTOK_ID` and `AUTH_TIKTOK_SECRET` environment variables.
|
|
141
|
+
* Remeber that the AUTH_TIKTOK_ID is the Client Key in the TikTok Application
|
|
142
|
+
*```ts
|
|
143
|
+
* import { Auth } from "@auth/core"
|
|
144
|
+
* import TikTok from "@auth/core/providers/tiktok"
|
|
145
|
+
*
|
|
146
|
+
* const request = new Request(origin)
|
|
147
|
+
* const response = await Auth(request, {
|
|
148
|
+
* providers: [
|
|
149
|
+
* TikTok({ clientId: AUTH_TIKTOK_ID, clientSecret: AUTH_TIKTOK_SECRET }),
|
|
150
|
+
* ],
|
|
151
|
+
* })
|
|
152
|
+
* ```
|
|
153
|
+
*
|
|
154
|
+
* ### Resources
|
|
155
|
+
* - [TikTok app console](https://developers.tiktok.com/)
|
|
156
|
+
* - [TikTok login kit documentation](https://developers.tiktok.com/doc/login-kit-web/)
|
|
157
|
+
* - [Available Scopes](https://developers.tiktok.com/doc/tiktok-api-scopes/)
|
|
158
|
+
* - [Sandbox for testing](https://developers.tiktok.com/blog/introducing-sandbox)
|
|
159
|
+
*
|
|
160
|
+
*
|
|
161
|
+
* ### Notes
|
|
162
|
+
*
|
|
163
|
+
* :::tip
|
|
164
|
+
*
|
|
165
|
+
* Production applications cannot use localhost URLs to sign in with TikTok. You need add the domain and Callback/Redirect url's to your TikTok app and have them review and approved by the TikTok Team.
|
|
166
|
+
* If you need to test your implementation, you can use the sandbox feature and ngrok for testing in localhost.
|
|
167
|
+
*
|
|
168
|
+
* :::
|
|
169
|
+
*
|
|
170
|
+
* :::tip
|
|
171
|
+
*
|
|
172
|
+
* Email address is not supported by TikTok.
|
|
173
|
+
*
|
|
174
|
+
* :::
|
|
175
|
+
*
|
|
176
|
+
* :::tip
|
|
177
|
+
*
|
|
178
|
+
* AUTH_TIKTOK_ID will be the Client Key in the TikTok Application
|
|
179
|
+
*
|
|
180
|
+
* :::
|
|
181
|
+
*
|
|
182
|
+
* By default, Auth.js assumes that the TikTok provider is
|
|
183
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
184
|
+
*
|
|
185
|
+
* :::tip
|
|
186
|
+
*
|
|
187
|
+
* The TikTok provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/tiktok.ts).
|
|
188
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
189
|
+
*
|
|
190
|
+
* If You Need to Customize the TikTok Provider, You Can Use the Following Configuration as a custom provider
|
|
191
|
+
*
|
|
192
|
+
* ```ts
|
|
193
|
+
* {
|
|
194
|
+
* async [customFetch](...args) {
|
|
195
|
+
* const url = new URL(args[0] instanceof Request ? args[0].url : args[0]);
|
|
196
|
+
* if (url.pathname.endsWith("/token/")) {
|
|
197
|
+
* const [url, request] = args;
|
|
198
|
+
* const customHeaders = {
|
|
199
|
+
* ...request?.headers,
|
|
200
|
+
* "content-type": "application/x-www-form-urlencoded",
|
|
201
|
+
* };
|
|
202
|
+
*
|
|
203
|
+
* const customBody = new URLSearchParams(request?.body as string);
|
|
204
|
+
* customBody.append("client_key", process.env.AUTH_TIKTOK_ID!);
|
|
205
|
+
*
|
|
206
|
+
* const response = await fetch(url, {
|
|
207
|
+
* ...request,
|
|
208
|
+
* headers: customHeaders,
|
|
209
|
+
* body: customBody.toString(),
|
|
210
|
+
* });
|
|
211
|
+
* const json = await response.json();
|
|
212
|
+
* return Response.json({ ...json });
|
|
213
|
+
* }
|
|
214
|
+
* return fetch(...args);
|
|
215
|
+
* },
|
|
216
|
+
*
|
|
217
|
+
* id: "tiktok",
|
|
218
|
+
* name: "TikTok",
|
|
219
|
+
* type: "oauth",
|
|
220
|
+
* client: {
|
|
221
|
+
* token_endpoint_auth_method: "client_secret_post",
|
|
222
|
+
* },
|
|
223
|
+
*
|
|
224
|
+
* authorization: {
|
|
225
|
+
* url: "https://www.tiktok.com/v2/auth/authorize",
|
|
226
|
+
* params: {
|
|
227
|
+
* client_key: options.clientId,
|
|
228
|
+
* scope: "user.info.profile", //Add scopes you need eg(user.info.profile,user.info.stats,video.list)
|
|
229
|
+
* },
|
|
230
|
+
* },
|
|
231
|
+
*
|
|
232
|
+
* token: "https://open.tiktokapis.com/v2/oauth/token/",
|
|
233
|
+
*
|
|
234
|
+
* userinfo: "https://open.tiktokapis.com/v2/user/info/?fields=open_id,avatar_url,display_name,username", //Add fields you need eg(open_id,avatar_url,display_name,username)
|
|
235
|
+
*
|
|
236
|
+
* profile(profile) {
|
|
237
|
+
* return {
|
|
238
|
+
* id: profile.data.user.open_id,
|
|
239
|
+
* name: profile.data.user.display_name,
|
|
240
|
+
* image: profile.data.user.avatar_url,
|
|
241
|
+
* email: profile.data.user.email || profile.data.user.username || null,
|
|
242
|
+
* };
|
|
243
|
+
* },
|
|
244
|
+
* }
|
|
245
|
+
*
|
|
246
|
+
* ```
|
|
247
|
+
*
|
|
248
|
+
* :::
|
|
249
|
+
*
|
|
250
|
+
* :::info **Disclaimer**
|
|
251
|
+
*
|
|
252
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
253
|
+
*
|
|
254
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
255
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
256
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
257
|
+
*
|
|
258
|
+
* :::
|
|
259
|
+
*/
|
|
260
|
+
export default function TikTok(
|
|
261
|
+
options: OAuthUserConfig<TiktokProfile>
|
|
262
|
+
): OAuthConfig<TiktokProfile> {
|
|
263
|
+
return {
|
|
264
|
+
async [customFetch](...args) {
|
|
265
|
+
const url = new URL(args[0] instanceof Request ? args[0].url : args[0])
|
|
266
|
+
if (url.pathname.endsWith("/token/")) {
|
|
267
|
+
const [url, request] = args
|
|
268
|
+
|
|
269
|
+
const customHeaders = {
|
|
270
|
+
...request?.headers,
|
|
271
|
+
"content-type": "application/x-www-form-urlencoded",
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
const customBody = new URLSearchParams(request?.body as string)
|
|
275
|
+
customBody.append("client_key", options.clientId!)
|
|
276
|
+
const response = await fetch(url, {
|
|
277
|
+
...request,
|
|
278
|
+
headers: customHeaders,
|
|
279
|
+
body: customBody.toString(),
|
|
280
|
+
})
|
|
281
|
+
const json = await response.json()
|
|
282
|
+
return Response.json({ ...json })
|
|
283
|
+
}
|
|
284
|
+
return fetch(...args)
|
|
285
|
+
},
|
|
286
|
+
id: "tiktok",
|
|
287
|
+
name: "TikTok",
|
|
288
|
+
type: "oauth",
|
|
289
|
+
client: {
|
|
290
|
+
token_endpoint_auth_method: "client_secret_post",
|
|
291
|
+
},
|
|
292
|
+
authorization: {
|
|
293
|
+
url: "https://www.tiktok.com/v2/auth/authorize",
|
|
294
|
+
params: {
|
|
295
|
+
client_key: options.clientId,
|
|
296
|
+
scope: "user.info.basic",
|
|
297
|
+
},
|
|
298
|
+
},
|
|
299
|
+
|
|
300
|
+
token: "https://open.tiktokapis.com/v2/oauth/token/",
|
|
301
|
+
userinfo:
|
|
302
|
+
"https://open.tiktokapis.com/v2/user/info/?fields=open_id,avatar_url,display_name",
|
|
303
|
+
|
|
304
|
+
profile(profile) {
|
|
305
|
+
return {
|
|
306
|
+
id: profile.data.user.open_id,
|
|
307
|
+
name: profile.data.user.display_name,
|
|
308
|
+
image: profile.data.user.avatar_url,
|
|
309
|
+
// Email address is not supported by TikTok.
|
|
310
|
+
email: null,
|
|
311
|
+
}
|
|
312
|
+
},
|
|
313
|
+
style: {
|
|
314
|
+
bg: "#000",
|
|
315
|
+
text: "#fff",
|
|
316
|
+
},
|
|
317
|
+
options,
|
|
318
|
+
}
|
|
319
|
+
}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* <div class="provider" style={{backgroundColor: "#000", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
|
|
3
|
+
* <span>Built-in <b>Todoist</b> integration.</span>
|
|
4
|
+
* <a href="https://www.todoist.com/">
|
|
5
|
+
* <img style={{display: "block"}} src="https://authjs.dev/img/providers/todoist.svg" height="48" />
|
|
6
|
+
* </a>
|
|
7
|
+
* </div>
|
|
8
|
+
*
|
|
9
|
+
* @module providers/todoist
|
|
10
|
+
*/
|
|
11
|
+
import type { OAuthConfig, OAuthUserConfig } from "./index.js"
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* @see https://developer.todoist.com/sync/v9/#user
|
|
15
|
+
*/
|
|
16
|
+
interface TodoistProfile extends Record<string, any> {
|
|
17
|
+
avatar_big: string
|
|
18
|
+
email: string
|
|
19
|
+
full_name: string
|
|
20
|
+
id: string
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Add Todoist login to your page.
|
|
25
|
+
*
|
|
26
|
+
* ### Setup
|
|
27
|
+
*
|
|
28
|
+
* #### Callback URL
|
|
29
|
+
* ```
|
|
30
|
+
* https://example.com/api/auth/callback/todoist
|
|
31
|
+
* ```
|
|
32
|
+
*
|
|
33
|
+
* #### Configuration
|
|
34
|
+
*```ts
|
|
35
|
+
* import { Auth } from "@auth/core"
|
|
36
|
+
* import Todoist from "@auth/core/providers/todoist"
|
|
37
|
+
*
|
|
38
|
+
* const request = new Request(origin)
|
|
39
|
+
* const response = await Auth(request, {
|
|
40
|
+
* providers: [
|
|
41
|
+
* Todoist({
|
|
42
|
+
* clientId: TODOIST_CLIENT_ID,
|
|
43
|
+
* clientSecret: TODOIST_CLIENT_SECRET,
|
|
44
|
+
* }),
|
|
45
|
+
* ],
|
|
46
|
+
* })
|
|
47
|
+
* ```
|
|
48
|
+
*
|
|
49
|
+
* ### Resources
|
|
50
|
+
*
|
|
51
|
+
* - [Todoist OAuth documentation](https://developer.todoist.com/guides/#oauth)
|
|
52
|
+
* - [Todoist configuration](https://developer.todoist.com/appconsole.html)
|
|
53
|
+
*
|
|
54
|
+
* ### Notes
|
|
55
|
+
*
|
|
56
|
+
* By default, Auth.js assumes that the Todoist provider is
|
|
57
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
58
|
+
*
|
|
59
|
+
* :::tip
|
|
60
|
+
*
|
|
61
|
+
* The Todoist provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/todoist.ts).
|
|
62
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
63
|
+
*
|
|
64
|
+
* :::
|
|
65
|
+
*
|
|
66
|
+
* :::info **Disclaimer**
|
|
67
|
+
*
|
|
68
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
69
|
+
*
|
|
70
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
71
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
72
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
73
|
+
*
|
|
74
|
+
* :::
|
|
75
|
+
*/
|
|
76
|
+
export default function TodoistProvider<P extends TodoistProfile>(
|
|
77
|
+
options: OAuthUserConfig<P>
|
|
78
|
+
): OAuthConfig<P> {
|
|
79
|
+
return {
|
|
80
|
+
id: "todoist",
|
|
81
|
+
name: "Todoist",
|
|
82
|
+
type: "oauth",
|
|
83
|
+
authorization: {
|
|
84
|
+
url: "https://todoist.com/oauth/authorize",
|
|
85
|
+
params: { scope: "data:read" },
|
|
86
|
+
},
|
|
87
|
+
token: "https://todoist.com/oauth/access_token",
|
|
88
|
+
client: {
|
|
89
|
+
token_endpoint_auth_method: "client_secret_post",
|
|
90
|
+
},
|
|
91
|
+
userinfo: {
|
|
92
|
+
async request({ tokens }) {
|
|
93
|
+
// To obtain Todoist user info, we need to call the Sync API
|
|
94
|
+
// See https://developer.todoist.com/sync/v9
|
|
95
|
+
const res = await fetch("https://api.todoist.com/sync/v9/sync", {
|
|
96
|
+
method: "POST",
|
|
97
|
+
headers: {
|
|
98
|
+
Authorization: `Bearer ${tokens.access_token}`,
|
|
99
|
+
"Content-Type": "application/json",
|
|
100
|
+
},
|
|
101
|
+
body: JSON.stringify({
|
|
102
|
+
sync_token: "*",
|
|
103
|
+
resource_types: '["user"]',
|
|
104
|
+
}),
|
|
105
|
+
})
|
|
106
|
+
|
|
107
|
+
const { user: profile } = await res.json()
|
|
108
|
+
return profile
|
|
109
|
+
},
|
|
110
|
+
},
|
|
111
|
+
profile(profile) {
|
|
112
|
+
return {
|
|
113
|
+
id: profile.id,
|
|
114
|
+
email: profile.email,
|
|
115
|
+
name: profile.full_name,
|
|
116
|
+
image: profile.avatar_big,
|
|
117
|
+
}
|
|
118
|
+
},
|
|
119
|
+
style: { text: "#000", bg: "#E44332" },
|
|
120
|
+
options,
|
|
121
|
+
}
|
|
122
|
+
}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* <div class="provider" style={{backgroundColor: "#000", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
|
|
3
|
+
* <span>Built-in <b>Trakt</b> integration.</span>
|
|
4
|
+
* <a href="https://www.trakt.tv/">
|
|
5
|
+
* <img style={{display: "block"}} src="https://authjs.dev/img/providers/trakt.svg" height="48" />
|
|
6
|
+
* </a>
|
|
7
|
+
* </div>
|
|
8
|
+
*
|
|
9
|
+
* @module providers/trakt
|
|
10
|
+
*/
|
|
11
|
+
import type { OAuthConfig, OAuthUserConfig } from "./index.js"
|
|
12
|
+
|
|
13
|
+
export interface TraktUser extends Record<string, any> {
|
|
14
|
+
username: string
|
|
15
|
+
private: boolean
|
|
16
|
+
name: string
|
|
17
|
+
vip: boolean
|
|
18
|
+
vip_ep: boolean
|
|
19
|
+
ids: { slug: string }
|
|
20
|
+
joined_at: string
|
|
21
|
+
location: string | null
|
|
22
|
+
about: string | null
|
|
23
|
+
gender: string | null
|
|
24
|
+
age: number | null
|
|
25
|
+
images: { avatar: { full: string } }
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Add Trakt login to your page.
|
|
30
|
+
*
|
|
31
|
+
* ### Setup
|
|
32
|
+
*
|
|
33
|
+
* #### Callback URL
|
|
34
|
+
* ```
|
|
35
|
+
* https://example.com/api/auth/callback/trakt
|
|
36
|
+
* ```
|
|
37
|
+
*
|
|
38
|
+
* #### Configuration
|
|
39
|
+
*```ts
|
|
40
|
+
* import { Auth } from "@auth/core"
|
|
41
|
+
* import Trakt from "@auth/core/providers/trakt"
|
|
42
|
+
*
|
|
43
|
+
* const request = new Request(origin)
|
|
44
|
+
* const response = await Auth(request, {
|
|
45
|
+
* providers: [
|
|
46
|
+
* Trakt({ clientId: TRAKT_CLIENT_ID, clientSecret: TRAKT_CLIENT_SECRET }),
|
|
47
|
+
* ],
|
|
48
|
+
* })
|
|
49
|
+
* ```
|
|
50
|
+
*
|
|
51
|
+
* ### Resources
|
|
52
|
+
*
|
|
53
|
+
* - [Trakt OAuth documentation](https://trakt.docs.apiary.io/#reference/authentication-oauth)
|
|
54
|
+
*
|
|
55
|
+
* If you're using the api in production by calling `api.trakt.tv`. Follow the example. If you wish to develop on Trakt's sandbox environment by calling `api-staging.trakt.tv`, change the URLs.
|
|
56
|
+
*
|
|
57
|
+
* Start by creating an OAuth app on Trakt for production or development. Then set the Client ID and Client Secret as TRAKT_ID and TRAKT_SECRET in .env.
|
|
58
|
+
*
|
|
59
|
+
* ### Notes
|
|
60
|
+
*
|
|
61
|
+
* By default, Auth.js assumes that the Trakt provider is
|
|
62
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
63
|
+
*
|
|
64
|
+
* :::danger
|
|
65
|
+
*
|
|
66
|
+
* - Trakt does not allow hotlinking images. Even the authenticated user's profile picture.
|
|
67
|
+
* - Trakt does not supply the authenticated user's email.
|
|
68
|
+
*
|
|
69
|
+
* :::
|
|
70
|
+
*
|
|
71
|
+
* :::tip
|
|
72
|
+
*
|
|
73
|
+
* The Trakt provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/trakt.ts).
|
|
74
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
75
|
+
*
|
|
76
|
+
* :::
|
|
77
|
+
*
|
|
78
|
+
* :::info **Disclaimer**
|
|
79
|
+
*
|
|
80
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
81
|
+
*
|
|
82
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
83
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
84
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
85
|
+
*
|
|
86
|
+
* :::
|
|
87
|
+
*/
|
|
88
|
+
export default function Trakt<P extends TraktUser>(
|
|
89
|
+
options: OAuthUserConfig<P>
|
|
90
|
+
): OAuthConfig<P> {
|
|
91
|
+
return {
|
|
92
|
+
id: "trakt",
|
|
93
|
+
name: "Trakt",
|
|
94
|
+
type: "oauth",
|
|
95
|
+
authorization: "https://trakt.tv/oauth/authorize?scope=",
|
|
96
|
+
token: "https://api.trakt.tv/oauth/token",
|
|
97
|
+
userinfo: {
|
|
98
|
+
url: "https://api.trakt.tv/users/me?extended=full",
|
|
99
|
+
async request({ tokens, provider }) {
|
|
100
|
+
return await fetch(provider.userinfo?.url as URL, {
|
|
101
|
+
headers: {
|
|
102
|
+
Authorization: `Bearer ${tokens.access_token}`,
|
|
103
|
+
"trakt-api-version": "2",
|
|
104
|
+
"trakt-api-key": provider.clientId,
|
|
105
|
+
},
|
|
106
|
+
}).then(async (res) => await res.json())
|
|
107
|
+
},
|
|
108
|
+
},
|
|
109
|
+
profile(profile) {
|
|
110
|
+
return {
|
|
111
|
+
id: profile.ids.slug,
|
|
112
|
+
name: profile.name,
|
|
113
|
+
email: null, // trakt does not provide user emails
|
|
114
|
+
image: profile.images.avatar.full, // trakt does not allow hotlinking
|
|
115
|
+
}
|
|
116
|
+
},
|
|
117
|
+
style: { bg: "#ED2224", text: "#fff" },
|
|
118
|
+
options,
|
|
119
|
+
}
|
|
120
|
+
}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* <div class="provider" style={{backgroundColor: "#000", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
|
|
3
|
+
* <span>Built-in <b>Twitch</b> integration.</span>
|
|
4
|
+
* <a href="https://www.twitch.tv/">
|
|
5
|
+
* <img style={{display: "block"}} src="https://authjs.dev/img/providers/twitch.svg" height="48" />
|
|
6
|
+
* </a>
|
|
7
|
+
* </div>
|
|
8
|
+
*
|
|
9
|
+
* @module providers/twitch
|
|
10
|
+
*/
|
|
11
|
+
import type { OIDCConfig, OIDCUserConfig } from "./index.js"
|
|
12
|
+
|
|
13
|
+
export interface TwitchProfile extends Record<string, any> {
|
|
14
|
+
sub: string
|
|
15
|
+
preferred_username: string
|
|
16
|
+
email: string
|
|
17
|
+
picture: string
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Add Twitch login to your page.
|
|
22
|
+
*
|
|
23
|
+
* ### Setup
|
|
24
|
+
*
|
|
25
|
+
* #### Callback URL
|
|
26
|
+
* ```
|
|
27
|
+
* https://example.com/api/auth/callback/twitch
|
|
28
|
+
* ```
|
|
29
|
+
*
|
|
30
|
+
* #### Configuration
|
|
31
|
+
*```ts
|
|
32
|
+
* import { Auth } from "@auth/core"
|
|
33
|
+
* import Twitch from "@auth/core/providers/twitch"
|
|
34
|
+
*
|
|
35
|
+
* const request = new Request(origin)
|
|
36
|
+
* const response = await Auth(request, {
|
|
37
|
+
* providers: [
|
|
38
|
+
* Twitch({ clientId: TWITCH_CLIENT_ID, clientSecret: TWITCH_CLIENT_SECRET }),
|
|
39
|
+
* ],
|
|
40
|
+
* })
|
|
41
|
+
* ```
|
|
42
|
+
*
|
|
43
|
+
* ### Resources
|
|
44
|
+
*
|
|
45
|
+
* - [Twitch app documentation](https://dev.twitch.tv/console/apps)
|
|
46
|
+
*
|
|
47
|
+
* Add the following redirect URL into the console `http://<your-next-app-url>/api/auth/callback/twitch`
|
|
48
|
+
*
|
|
49
|
+
*
|
|
50
|
+
* ### Notes
|
|
51
|
+
*
|
|
52
|
+
* By default, Auth.js assumes that the Twitch provider is
|
|
53
|
+
* based on the [Open ID Connect](https://openid.net/specs/openid-connect-core-1_0.html) specification.
|
|
54
|
+
*
|
|
55
|
+
* :::tip
|
|
56
|
+
*
|
|
57
|
+
* The Twitch provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/twitch.ts).
|
|
58
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
59
|
+
*
|
|
60
|
+
* :::
|
|
61
|
+
*
|
|
62
|
+
* :::info **Disclaimer**
|
|
63
|
+
*
|
|
64
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
65
|
+
*
|
|
66
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
67
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
68
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
69
|
+
*
|
|
70
|
+
* :::
|
|
71
|
+
*/
|
|
72
|
+
export default function Twitch(
|
|
73
|
+
config: OIDCUserConfig<TwitchProfile>
|
|
74
|
+
): OIDCConfig<TwitchProfile> {
|
|
75
|
+
return {
|
|
76
|
+
issuer: "https://id.twitch.tv/oauth2",
|
|
77
|
+
id: "twitch",
|
|
78
|
+
name: "Twitch",
|
|
79
|
+
type: "oidc",
|
|
80
|
+
client: { token_endpoint_auth_method: "client_secret_post" },
|
|
81
|
+
authorization: {
|
|
82
|
+
params: {
|
|
83
|
+
scope: "openid user:read:email",
|
|
84
|
+
claims: {
|
|
85
|
+
id_token: { email: null, picture: null, preferred_username: null },
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
token: {
|
|
90
|
+
async conform(response) {
|
|
91
|
+
const body = await response.json()
|
|
92
|
+
if (response.ok) {
|
|
93
|
+
if (typeof body.scope === "string") {
|
|
94
|
+
console.warn(
|
|
95
|
+
"'scope' is a string. Redundant workaround, please open an issue."
|
|
96
|
+
)
|
|
97
|
+
} else if (Array.isArray(body.scope)) {
|
|
98
|
+
body.scope = body.scope.join(" ")
|
|
99
|
+
return new Response(JSON.stringify(body), response)
|
|
100
|
+
} else if ("scope" in body) {
|
|
101
|
+
delete body.scope
|
|
102
|
+
return new Response(JSON.stringify(body), response)
|
|
103
|
+
}
|
|
104
|
+
} else {
|
|
105
|
+
const { message: error_description, error } = body
|
|
106
|
+
if (typeof error !== "string") {
|
|
107
|
+
return new Response(
|
|
108
|
+
JSON.stringify({ error: "invalid_request", error_description }),
|
|
109
|
+
response
|
|
110
|
+
)
|
|
111
|
+
}
|
|
112
|
+
console.warn(
|
|
113
|
+
"Response has 'error'. Redundant workaround, please open an issue."
|
|
114
|
+
)
|
|
115
|
+
}
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
style: { bg: "#65459B", text: "#fff" },
|
|
119
|
+
options: config,
|
|
120
|
+
}
|
|
121
|
+
}
|