@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,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* <div class="provider" style={{backgroundColor: "#000", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
|
|
3
|
+
* <span>Built-in <b>Threads</b> integration.</span>
|
|
4
|
+
* <a href="https://www.threads.net/">
|
|
5
|
+
* <img style={{display: "block"}} src="https://authjs.dev/img/providers/threads.svg" height="48" />
|
|
6
|
+
* </a>
|
|
7
|
+
* </div>
|
|
8
|
+
*
|
|
9
|
+
* @module providers/threads
|
|
10
|
+
*/
|
|
11
|
+
import type { OAuthConfig, OAuthUserConfig } from "./index.js";
|
|
12
|
+
/**
|
|
13
|
+
* [User](https://developers.facebook.com/docs/threads/reference/user)
|
|
14
|
+
*/
|
|
15
|
+
export interface ThreadsProfile {
|
|
16
|
+
data: {
|
|
17
|
+
/**
|
|
18
|
+
* Unique identifier of this user. This is returned as a string in order to avoid complications with languages and tools
|
|
19
|
+
* that cannot handle large integers.
|
|
20
|
+
*/
|
|
21
|
+
id: string;
|
|
22
|
+
/**
|
|
23
|
+
* The Threads handle (username) of this user.
|
|
24
|
+
*
|
|
25
|
+
* To return this field, add `fields=username` in the authorization request's query parameter.
|
|
26
|
+
*/
|
|
27
|
+
username?: string;
|
|
28
|
+
/**
|
|
29
|
+
* The URL to the profile image for this user, as shown on the user's profile.
|
|
30
|
+
*
|
|
31
|
+
* To return this field, add `fields=threads_profile_picture_url` in the authorization request's query parameter.
|
|
32
|
+
*/
|
|
33
|
+
threads_profile_picture_url?: string;
|
|
34
|
+
/**
|
|
35
|
+
* The text of this user's profile biography (also known as bio), if the user provided one.
|
|
36
|
+
*
|
|
37
|
+
* To return this field, add `fields=threads_biography` in the authorization request's query parameter.
|
|
38
|
+
*/
|
|
39
|
+
threads_biography?: string;
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Add Threads login to your page.
|
|
44
|
+
*
|
|
45
|
+
* ### Setup
|
|
46
|
+
*
|
|
47
|
+
* #### Callback URL
|
|
48
|
+
* ```
|
|
49
|
+
* https://example.com/api/auth/callback/threads
|
|
50
|
+
* ```
|
|
51
|
+
*
|
|
52
|
+
* #### Configuration
|
|
53
|
+
*```ts
|
|
54
|
+
* import { Auth } from "@auth/core"
|
|
55
|
+
* import Threads from "@auth/core/providers/threads"
|
|
56
|
+
*
|
|
57
|
+
* const request = new Request(origin)
|
|
58
|
+
* const response = await Auth(request, {
|
|
59
|
+
* providers: [
|
|
60
|
+
* Threads({
|
|
61
|
+
* clientId: THREADS_CLIENT_ID,
|
|
62
|
+
* clientSecret: THREADS_CLIENT_SECRET,
|
|
63
|
+
* }),
|
|
64
|
+
* ],
|
|
65
|
+
* })
|
|
66
|
+
* ```
|
|
67
|
+
*
|
|
68
|
+
* ### Resources
|
|
69
|
+
*
|
|
70
|
+
* - [Threads OAuth documentation](https://developers.facebook.com/docs/threads)
|
|
71
|
+
* - [Threads OAuth apps](https://developers.facebook.com/apps/)
|
|
72
|
+
*
|
|
73
|
+
* ### Notes
|
|
74
|
+
*
|
|
75
|
+
* :::warning
|
|
76
|
+
*
|
|
77
|
+
* Email address is not returned by the Threads API.
|
|
78
|
+
*
|
|
79
|
+
* :::
|
|
80
|
+
*
|
|
81
|
+
* :::tip
|
|
82
|
+
*
|
|
83
|
+
* Threads required callback URL to be configured in your Facebook app and Facebook required you to use **https** even for localhost! In order to do that, you either need to [add an SSL to your localhost](https://www.freecodecamp.org/news/how-to-get-https-working-on-your-local-development-environment-in-5-minutes-7af615770eec/) or use a proxy such as [ngrok](https://ngrok.com/docs).
|
|
84
|
+
*
|
|
85
|
+
* :::
|
|
86
|
+
*
|
|
87
|
+
* By default, Auth.js assumes that the Threads provider is
|
|
88
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
89
|
+
*
|
|
90
|
+
* :::tip
|
|
91
|
+
*
|
|
92
|
+
* The Threads provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/threads.ts).
|
|
93
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
94
|
+
*
|
|
95
|
+
* :::
|
|
96
|
+
*
|
|
97
|
+
* :::info **Disclaimer**
|
|
98
|
+
*
|
|
99
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
100
|
+
*
|
|
101
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
102
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
103
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
104
|
+
*
|
|
105
|
+
* :::
|
|
106
|
+
*/
|
|
107
|
+
export default function Threads(config: OAuthUserConfig<ThreadsProfile>): OAuthConfig<ThreadsProfile>;
|
|
108
|
+
//# sourceMappingURL=threads.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"threads.d.ts","sourceRoot":"","sources":["../src/providers/threads.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE9D;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE;QACJ;;;WAGG;QACH,EAAE,EAAE,MAAM,CAAA;QACV;;;;WAIG;QACH,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB;;;;WAIG;QACH,2BAA2B,CAAC,EAAE,MAAM,CAAA;QACpC;;;;WAIG;QACH,iBAAiB,CAAC,EAAE,MAAM,CAAA;KAC3B,CAAA;CACF;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgEG;AACH,MAAM,CAAC,OAAO,UAAU,OAAO,CAC7B,MAAM,EAAE,eAAe,CAAC,cAAc,CAAC,GACtC,WAAW,CAAC,cAAc,CAAC,CAwB7B"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Add Threads login to your page.
|
|
3
|
+
*
|
|
4
|
+
* ### Setup
|
|
5
|
+
*
|
|
6
|
+
* #### Callback URL
|
|
7
|
+
* ```
|
|
8
|
+
* https://example.com/api/auth/callback/threads
|
|
9
|
+
* ```
|
|
10
|
+
*
|
|
11
|
+
* #### Configuration
|
|
12
|
+
*```ts
|
|
13
|
+
* import { Auth } from "@auth/core"
|
|
14
|
+
* import Threads from "@auth/core/providers/threads"
|
|
15
|
+
*
|
|
16
|
+
* const request = new Request(origin)
|
|
17
|
+
* const response = await Auth(request, {
|
|
18
|
+
* providers: [
|
|
19
|
+
* Threads({
|
|
20
|
+
* clientId: THREADS_CLIENT_ID,
|
|
21
|
+
* clientSecret: THREADS_CLIENT_SECRET,
|
|
22
|
+
* }),
|
|
23
|
+
* ],
|
|
24
|
+
* })
|
|
25
|
+
* ```
|
|
26
|
+
*
|
|
27
|
+
* ### Resources
|
|
28
|
+
*
|
|
29
|
+
* - [Threads OAuth documentation](https://developers.facebook.com/docs/threads)
|
|
30
|
+
* - [Threads OAuth apps](https://developers.facebook.com/apps/)
|
|
31
|
+
*
|
|
32
|
+
* ### Notes
|
|
33
|
+
*
|
|
34
|
+
* :::warning
|
|
35
|
+
*
|
|
36
|
+
* Email address is not returned by the Threads API.
|
|
37
|
+
*
|
|
38
|
+
* :::
|
|
39
|
+
*
|
|
40
|
+
* :::tip
|
|
41
|
+
*
|
|
42
|
+
* Threads required callback URL to be configured in your Facebook app and Facebook required you to use **https** even for localhost! In order to do that, you either need to [add an SSL to your localhost](https://www.freecodecamp.org/news/how-to-get-https-working-on-your-local-development-environment-in-5-minutes-7af615770eec/) or use a proxy such as [ngrok](https://ngrok.com/docs).
|
|
43
|
+
*
|
|
44
|
+
* :::
|
|
45
|
+
*
|
|
46
|
+
* By default, Auth.js assumes that the Threads provider is
|
|
47
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
48
|
+
*
|
|
49
|
+
* :::tip
|
|
50
|
+
*
|
|
51
|
+
* The Threads provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/threads.ts).
|
|
52
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
53
|
+
*
|
|
54
|
+
* :::
|
|
55
|
+
*
|
|
56
|
+
* :::info **Disclaimer**
|
|
57
|
+
*
|
|
58
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
59
|
+
*
|
|
60
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
61
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
62
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
63
|
+
*
|
|
64
|
+
* :::
|
|
65
|
+
*/
|
|
66
|
+
export default function Threads(config) {
|
|
67
|
+
return {
|
|
68
|
+
id: "threads",
|
|
69
|
+
name: "Threads",
|
|
70
|
+
type: "oauth",
|
|
71
|
+
checks: ["state"],
|
|
72
|
+
authorization: "https://threads.net/oauth/authorize?scope=threads_basic",
|
|
73
|
+
token: "https://graph.threads.net/oauth/access_token",
|
|
74
|
+
userinfo: "https://graph.threads.net/v1.0/me?fields=id,username,threads_profile_picture_url",
|
|
75
|
+
client: {
|
|
76
|
+
token_endpoint_auth_method: "client_secret_post",
|
|
77
|
+
},
|
|
78
|
+
profile({ data }) {
|
|
79
|
+
return {
|
|
80
|
+
id: data.id,
|
|
81
|
+
name: data.username || null,
|
|
82
|
+
email: null,
|
|
83
|
+
image: data.threads_profile_picture_url || null,
|
|
84
|
+
};
|
|
85
|
+
},
|
|
86
|
+
style: { bg: "#000", text: "#fff" },
|
|
87
|
+
options: config,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import type { OAuthConfig, OAuthUserConfig } from "./index.js";
|
|
2
|
+
/**
|
|
3
|
+
* [More info](https://developers.tiktok.com/doc/tiktok-api-v2-get-user-info/)
|
|
4
|
+
*/
|
|
5
|
+
export interface TiktokProfile {
|
|
6
|
+
data: {
|
|
7
|
+
user: {
|
|
8
|
+
/**
|
|
9
|
+
* The unique identification of the user in the current application.Open id
|
|
10
|
+
* for the client.
|
|
11
|
+
*
|
|
12
|
+
* To return this field, add `fields=open_id` in the user profile request's query parameter.
|
|
13
|
+
*/
|
|
14
|
+
open_id: string;
|
|
15
|
+
/**
|
|
16
|
+
* The unique identification of the user across different apps for the same developer.
|
|
17
|
+
* For example, if a partner has X number of clients,
|
|
18
|
+
* it will get X number of open_id for the same TikTok user,
|
|
19
|
+
* but one persistent union_id for the particular user.
|
|
20
|
+
*
|
|
21
|
+
* To return this field, add `fields=union_id` in the user profile request's query parameter.
|
|
22
|
+
*/
|
|
23
|
+
union_id?: string;
|
|
24
|
+
/**
|
|
25
|
+
* User's profile image.
|
|
26
|
+
*
|
|
27
|
+
* To return this field, add `fields=avatar_url` in the user profile request's query parameter.
|
|
28
|
+
*/
|
|
29
|
+
avatar_url: string;
|
|
30
|
+
/**
|
|
31
|
+
* User`s profile image in 100x100 size.
|
|
32
|
+
*
|
|
33
|
+
* To return this field, add `fields=avatar_url_100` in the user profile request's query parameter.
|
|
34
|
+
*/
|
|
35
|
+
avatar_url_100?: string;
|
|
36
|
+
/**
|
|
37
|
+
* User's profile image with higher resolution
|
|
38
|
+
*
|
|
39
|
+
* To return this field, add `fields=avatar_url_100` in the user profile request's query parameter.
|
|
40
|
+
*/
|
|
41
|
+
avatar_large_url?: string;
|
|
42
|
+
/**
|
|
43
|
+
* User's profile name
|
|
44
|
+
*
|
|
45
|
+
* To return this field, add `fields=display_name` in the user profile request's query parameter.
|
|
46
|
+
*/
|
|
47
|
+
display_name: string;
|
|
48
|
+
/**
|
|
49
|
+
* User's username.
|
|
50
|
+
*
|
|
51
|
+
* To return this field, add `fields=username` in the user profile request's query parameter.
|
|
52
|
+
*/
|
|
53
|
+
username: string;
|
|
54
|
+
/** @note Email is currently unsupported by TikTok */
|
|
55
|
+
email?: string;
|
|
56
|
+
/**
|
|
57
|
+
* User's bio description if there is a valid one.
|
|
58
|
+
*
|
|
59
|
+
* To return this field, add `fields=bio_description` in the user profile request's query parameter.
|
|
60
|
+
*/
|
|
61
|
+
bio_description?: string;
|
|
62
|
+
/**
|
|
63
|
+
* The link to user's TikTok profile page.
|
|
64
|
+
*
|
|
65
|
+
* To return this field, add `fields=profile_deep_link` in the user profile request's query parameter.
|
|
66
|
+
*/
|
|
67
|
+
profile_deep_link?: string;
|
|
68
|
+
/**
|
|
69
|
+
* Whether TikTok has provided a verified badge to the account after confirming
|
|
70
|
+
* that it belongs to the user it represents.
|
|
71
|
+
*
|
|
72
|
+
* To return this field, add `fields=is_verified` in the user profile request's query parameter.
|
|
73
|
+
*/
|
|
74
|
+
is_verified?: boolean;
|
|
75
|
+
/**
|
|
76
|
+
* User's followers count.
|
|
77
|
+
*
|
|
78
|
+
* To return this field, add `fields=follower_count` in the user profile request's query parameter.
|
|
79
|
+
*/
|
|
80
|
+
follower_count?: number;
|
|
81
|
+
/**
|
|
82
|
+
* The number of accounts that the user is following.
|
|
83
|
+
*
|
|
84
|
+
* To return this field, add `fields=following_count` in the user profile request's query parameter.
|
|
85
|
+
*/
|
|
86
|
+
following_count?: number;
|
|
87
|
+
/**
|
|
88
|
+
* The total number of likes received by the user across all of their videos.
|
|
89
|
+
*
|
|
90
|
+
* To return this field, add `fields=likes_count` in the user profile request's query parameter.
|
|
91
|
+
*/
|
|
92
|
+
likes_count?: number;
|
|
93
|
+
/**
|
|
94
|
+
* The total number of publicly posted videos by the user.
|
|
95
|
+
*
|
|
96
|
+
* To return this field, add `fields=video_count` in the user profile request's query parameter.
|
|
97
|
+
*/
|
|
98
|
+
video_count?: number;
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
error: {
|
|
102
|
+
/**
|
|
103
|
+
* The error category in string.
|
|
104
|
+
*/
|
|
105
|
+
code: string;
|
|
106
|
+
/**
|
|
107
|
+
* The error message in string.
|
|
108
|
+
*/
|
|
109
|
+
message: string;
|
|
110
|
+
/**
|
|
111
|
+
* The error message in string.
|
|
112
|
+
*/
|
|
113
|
+
log_id: string;
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Add TikTok login to your page.
|
|
118
|
+
*
|
|
119
|
+
* ### Setup
|
|
120
|
+
*
|
|
121
|
+
* #### Callback URL
|
|
122
|
+
* ```
|
|
123
|
+
* https://example.com/api/auth/callback/tiktok
|
|
124
|
+
* ```
|
|
125
|
+
*
|
|
126
|
+
* #### Configuration
|
|
127
|
+
* You can omit the client and secret if you have set the `AUTH_TIKTOK_ID` and `AUTH_TIKTOK_SECRET` environment variables.
|
|
128
|
+
* Remeber that the AUTH_TIKTOK_ID is the Client Key in the TikTok Application
|
|
129
|
+
*```ts
|
|
130
|
+
* import { Auth } from "@auth/core"
|
|
131
|
+
* import TikTok from "@auth/core/providers/tiktok"
|
|
132
|
+
*
|
|
133
|
+
* const request = new Request(origin)
|
|
134
|
+
* const response = await Auth(request, {
|
|
135
|
+
* providers: [
|
|
136
|
+
* TikTok({ clientId: AUTH_TIKTOK_ID, clientSecret: AUTH_TIKTOK_SECRET }),
|
|
137
|
+
* ],
|
|
138
|
+
* })
|
|
139
|
+
* ```
|
|
140
|
+
*
|
|
141
|
+
* ### Resources
|
|
142
|
+
* - [TikTok app console](https://developers.tiktok.com/)
|
|
143
|
+
* - [TikTok login kit documentation](https://developers.tiktok.com/doc/login-kit-web/)
|
|
144
|
+
* - [Available Scopes](https://developers.tiktok.com/doc/tiktok-api-scopes/)
|
|
145
|
+
* - [Sandbox for testing](https://developers.tiktok.com/blog/introducing-sandbox)
|
|
146
|
+
*
|
|
147
|
+
*
|
|
148
|
+
* ### Notes
|
|
149
|
+
*
|
|
150
|
+
* :::tip
|
|
151
|
+
*
|
|
152
|
+
* 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.
|
|
153
|
+
* If you need to test your implementation, you can use the sandbox feature and ngrok for testing in localhost.
|
|
154
|
+
*
|
|
155
|
+
* :::
|
|
156
|
+
*
|
|
157
|
+
* :::tip
|
|
158
|
+
*
|
|
159
|
+
* Email address is not supported by TikTok.
|
|
160
|
+
*
|
|
161
|
+
* :::
|
|
162
|
+
*
|
|
163
|
+
* :::tip
|
|
164
|
+
*
|
|
165
|
+
* AUTH_TIKTOK_ID will be the Client Key in the TikTok Application
|
|
166
|
+
*
|
|
167
|
+
* :::
|
|
168
|
+
*
|
|
169
|
+
* By default, Auth.js assumes that the TikTok provider is
|
|
170
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
171
|
+
*
|
|
172
|
+
* :::tip
|
|
173
|
+
*
|
|
174
|
+
* The TikTok provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/tiktok.ts).
|
|
175
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
176
|
+
*
|
|
177
|
+
* If You Need to Customize the TikTok Provider, You Can Use the Following Configuration as a custom provider
|
|
178
|
+
*
|
|
179
|
+
* ```ts
|
|
180
|
+
* {
|
|
181
|
+
* async [customFetch](...args) {
|
|
182
|
+
* const url = new URL(args[0] instanceof Request ? args[0].url : args[0]);
|
|
183
|
+
* if (url.pathname.endsWith("/token/")) {
|
|
184
|
+
* const [url, request] = args;
|
|
185
|
+
* const customHeaders = {
|
|
186
|
+
* ...request?.headers,
|
|
187
|
+
* "content-type": "application/x-www-form-urlencoded",
|
|
188
|
+
* };
|
|
189
|
+
*
|
|
190
|
+
* const customBody = new URLSearchParams(request?.body as string);
|
|
191
|
+
* customBody.append("client_key", process.env.AUTH_TIKTOK_ID!);
|
|
192
|
+
*
|
|
193
|
+
* const response = await fetch(url, {
|
|
194
|
+
* ...request,
|
|
195
|
+
* headers: customHeaders,
|
|
196
|
+
* body: customBody.toString(),
|
|
197
|
+
* });
|
|
198
|
+
* const json = await response.json();
|
|
199
|
+
* return Response.json({ ...json });
|
|
200
|
+
* }
|
|
201
|
+
* return fetch(...args);
|
|
202
|
+
* },
|
|
203
|
+
*
|
|
204
|
+
* id: "tiktok",
|
|
205
|
+
* name: "TikTok",
|
|
206
|
+
* type: "oauth",
|
|
207
|
+
* client: {
|
|
208
|
+
* token_endpoint_auth_method: "client_secret_post",
|
|
209
|
+
* },
|
|
210
|
+
*
|
|
211
|
+
* authorization: {
|
|
212
|
+
* url: "https://www.tiktok.com/v2/auth/authorize",
|
|
213
|
+
* params: {
|
|
214
|
+
* client_key: options.clientId,
|
|
215
|
+
* scope: "user.info.profile", //Add scopes you need eg(user.info.profile,user.info.stats,video.list)
|
|
216
|
+
* },
|
|
217
|
+
* },
|
|
218
|
+
*
|
|
219
|
+
* token: "https://open.tiktokapis.com/v2/oauth/token/",
|
|
220
|
+
*
|
|
221
|
+
* 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)
|
|
222
|
+
*
|
|
223
|
+
* profile(profile) {
|
|
224
|
+
* return {
|
|
225
|
+
* id: profile.data.user.open_id,
|
|
226
|
+
* name: profile.data.user.display_name,
|
|
227
|
+
* image: profile.data.user.avatar_url,
|
|
228
|
+
* email: profile.data.user.email || profile.data.user.username || null,
|
|
229
|
+
* };
|
|
230
|
+
* },
|
|
231
|
+
* }
|
|
232
|
+
*
|
|
233
|
+
* ```
|
|
234
|
+
*
|
|
235
|
+
* :::
|
|
236
|
+
*
|
|
237
|
+
* :::info **Disclaimer**
|
|
238
|
+
*
|
|
239
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
240
|
+
*
|
|
241
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
242
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
243
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
244
|
+
*
|
|
245
|
+
* :::
|
|
246
|
+
*/
|
|
247
|
+
export default function TikTok(options: OAuthUserConfig<TiktokProfile>): OAuthConfig<TiktokProfile>;
|
|
248
|
+
//# sourceMappingURL=tiktok.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tiktok.d.ts","sourceRoot":"","sources":["../src/providers/tiktok.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE9D;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ;;;;;eAKG;YACH,OAAO,EAAE,MAAM,CAAA;YACf;;;;;;;eAOG;YACH,QAAQ,CAAC,EAAE,MAAM,CAAA;YACjB;;;;eAIG;YACH,UAAU,EAAE,MAAM,CAAA;YAClB;;;;eAIG;YACH,cAAc,CAAC,EAAE,MAAM,CAAA;YACvB;;;;eAIG;YACH,gBAAgB,CAAC,EAAE,MAAM,CAAA;YACzB;;;;eAIG;YACH,YAAY,EAAE,MAAM,CAAA;YACpB;;;;eAIG;YACH,QAAQ,EAAE,MAAM,CAAA;YAChB,sDAAsD;YACtD,KAAK,CAAC,EAAE,MAAM,CAAA;YACd;;;;eAIG;YACH,eAAe,CAAC,EAAE,MAAM,CAAA;YACxB;;;;eAIG;YACH,iBAAiB,CAAC,EAAE,MAAM,CAAA;YAC1B;;;;;eAKG;YACH,WAAW,CAAC,EAAE,OAAO,CAAA;YACrB;;;;eAIG;YACH,cAAc,CAAC,EAAE,MAAM,CAAA;YACvB;;;;eAIG;YACH,eAAe,CAAC,EAAE,MAAM,CAAA;YACxB;;;;eAIG;YACH,WAAW,CAAC,EAAE,MAAM,CAAA;YACpB;;;;eAIG;YACH,WAAW,CAAC,EAAE,MAAM,CAAA;SACrB,CAAA;KACF,CAAA;IACD,KAAK,EAAE;QACL;;WAEG;QACH,IAAI,EAAE,MAAM,CAAA;QACZ;;WAEG;QACH,OAAO,EAAE,MAAM,CAAA;QACf;;WAEG;QACH,MAAM,EAAE,MAAM,CAAA;KACf,CAAA;CACF;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkIG;AACH,MAAM,CAAC,OAAO,UAAU,MAAM,CAC5B,OAAO,EAAE,eAAe,CAAC,aAAa,CAAC,GACtC,WAAW,CAAC,aAAa,CAAC,CAyD5B"}
|
|
@@ -0,0 +1,195 @@
|
|
|
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
|
+
/**
|
|
13
|
+
* Add TikTok login to your page.
|
|
14
|
+
*
|
|
15
|
+
* ### Setup
|
|
16
|
+
*
|
|
17
|
+
* #### Callback URL
|
|
18
|
+
* ```
|
|
19
|
+
* https://example.com/api/auth/callback/tiktok
|
|
20
|
+
* ```
|
|
21
|
+
*
|
|
22
|
+
* #### Configuration
|
|
23
|
+
* You can omit the client and secret if you have set the `AUTH_TIKTOK_ID` and `AUTH_TIKTOK_SECRET` environment variables.
|
|
24
|
+
* Remeber that the AUTH_TIKTOK_ID is the Client Key in the TikTok Application
|
|
25
|
+
*```ts
|
|
26
|
+
* import { Auth } from "@auth/core"
|
|
27
|
+
* import TikTok from "@auth/core/providers/tiktok"
|
|
28
|
+
*
|
|
29
|
+
* const request = new Request(origin)
|
|
30
|
+
* const response = await Auth(request, {
|
|
31
|
+
* providers: [
|
|
32
|
+
* TikTok({ clientId: AUTH_TIKTOK_ID, clientSecret: AUTH_TIKTOK_SECRET }),
|
|
33
|
+
* ],
|
|
34
|
+
* })
|
|
35
|
+
* ```
|
|
36
|
+
*
|
|
37
|
+
* ### Resources
|
|
38
|
+
* - [TikTok app console](https://developers.tiktok.com/)
|
|
39
|
+
* - [TikTok login kit documentation](https://developers.tiktok.com/doc/login-kit-web/)
|
|
40
|
+
* - [Available Scopes](https://developers.tiktok.com/doc/tiktok-api-scopes/)
|
|
41
|
+
* - [Sandbox for testing](https://developers.tiktok.com/blog/introducing-sandbox)
|
|
42
|
+
*
|
|
43
|
+
*
|
|
44
|
+
* ### Notes
|
|
45
|
+
*
|
|
46
|
+
* :::tip
|
|
47
|
+
*
|
|
48
|
+
* 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.
|
|
49
|
+
* If you need to test your implementation, you can use the sandbox feature and ngrok for testing in localhost.
|
|
50
|
+
*
|
|
51
|
+
* :::
|
|
52
|
+
*
|
|
53
|
+
* :::tip
|
|
54
|
+
*
|
|
55
|
+
* Email address is not supported by TikTok.
|
|
56
|
+
*
|
|
57
|
+
* :::
|
|
58
|
+
*
|
|
59
|
+
* :::tip
|
|
60
|
+
*
|
|
61
|
+
* AUTH_TIKTOK_ID will be the Client Key in the TikTok Application
|
|
62
|
+
*
|
|
63
|
+
* :::
|
|
64
|
+
*
|
|
65
|
+
* By default, Auth.js assumes that the TikTok provider is
|
|
66
|
+
* based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
|
|
67
|
+
*
|
|
68
|
+
* :::tip
|
|
69
|
+
*
|
|
70
|
+
* The TikTok provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/tiktok.ts).
|
|
71
|
+
* To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
|
|
72
|
+
*
|
|
73
|
+
* If You Need to Customize the TikTok Provider, You Can Use the Following Configuration as a custom provider
|
|
74
|
+
*
|
|
75
|
+
* ```ts
|
|
76
|
+
* {
|
|
77
|
+
* async [customFetch](...args) {
|
|
78
|
+
* const url = new URL(args[0] instanceof Request ? args[0].url : args[0]);
|
|
79
|
+
* if (url.pathname.endsWith("/token/")) {
|
|
80
|
+
* const [url, request] = args;
|
|
81
|
+
* const customHeaders = {
|
|
82
|
+
* ...request?.headers,
|
|
83
|
+
* "content-type": "application/x-www-form-urlencoded",
|
|
84
|
+
* };
|
|
85
|
+
*
|
|
86
|
+
* const customBody = new URLSearchParams(request?.body as string);
|
|
87
|
+
* customBody.append("client_key", process.env.AUTH_TIKTOK_ID!);
|
|
88
|
+
*
|
|
89
|
+
* const response = await fetch(url, {
|
|
90
|
+
* ...request,
|
|
91
|
+
* headers: customHeaders,
|
|
92
|
+
* body: customBody.toString(),
|
|
93
|
+
* });
|
|
94
|
+
* const json = await response.json();
|
|
95
|
+
* return Response.json({ ...json });
|
|
96
|
+
* }
|
|
97
|
+
* return fetch(...args);
|
|
98
|
+
* },
|
|
99
|
+
*
|
|
100
|
+
* id: "tiktok",
|
|
101
|
+
* name: "TikTok",
|
|
102
|
+
* type: "oauth",
|
|
103
|
+
* client: {
|
|
104
|
+
* token_endpoint_auth_method: "client_secret_post",
|
|
105
|
+
* },
|
|
106
|
+
*
|
|
107
|
+
* authorization: {
|
|
108
|
+
* url: "https://www.tiktok.com/v2/auth/authorize",
|
|
109
|
+
* params: {
|
|
110
|
+
* client_key: options.clientId,
|
|
111
|
+
* scope: "user.info.profile", //Add scopes you need eg(user.info.profile,user.info.stats,video.list)
|
|
112
|
+
* },
|
|
113
|
+
* },
|
|
114
|
+
*
|
|
115
|
+
* token: "https://open.tiktokapis.com/v2/oauth/token/",
|
|
116
|
+
*
|
|
117
|
+
* 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)
|
|
118
|
+
*
|
|
119
|
+
* profile(profile) {
|
|
120
|
+
* return {
|
|
121
|
+
* id: profile.data.user.open_id,
|
|
122
|
+
* name: profile.data.user.display_name,
|
|
123
|
+
* image: profile.data.user.avatar_url,
|
|
124
|
+
* email: profile.data.user.email || profile.data.user.username || null,
|
|
125
|
+
* };
|
|
126
|
+
* },
|
|
127
|
+
* }
|
|
128
|
+
*
|
|
129
|
+
* ```
|
|
130
|
+
*
|
|
131
|
+
* :::
|
|
132
|
+
*
|
|
133
|
+
* :::info **Disclaimer**
|
|
134
|
+
*
|
|
135
|
+
* If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
|
|
136
|
+
*
|
|
137
|
+
* Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
|
|
138
|
+
* the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
|
|
139
|
+
* we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
|
|
140
|
+
*
|
|
141
|
+
* :::
|
|
142
|
+
*/
|
|
143
|
+
export default function TikTok(options) {
|
|
144
|
+
return {
|
|
145
|
+
async [customFetch](...args) {
|
|
146
|
+
const url = new URL(args[0] instanceof Request ? args[0].url : args[0]);
|
|
147
|
+
if (url.pathname.endsWith("/token/")) {
|
|
148
|
+
const [url, request] = args;
|
|
149
|
+
const customHeaders = {
|
|
150
|
+
...request?.headers,
|
|
151
|
+
"content-type": "application/x-www-form-urlencoded",
|
|
152
|
+
};
|
|
153
|
+
const customBody = new URLSearchParams(request?.body);
|
|
154
|
+
customBody.append("client_key", options.clientId);
|
|
155
|
+
const response = await fetch(url, {
|
|
156
|
+
...request,
|
|
157
|
+
headers: customHeaders,
|
|
158
|
+
body: customBody.toString(),
|
|
159
|
+
});
|
|
160
|
+
const json = await response.json();
|
|
161
|
+
return Response.json({ ...json });
|
|
162
|
+
}
|
|
163
|
+
return fetch(...args);
|
|
164
|
+
},
|
|
165
|
+
id: "tiktok",
|
|
166
|
+
name: "TikTok",
|
|
167
|
+
type: "oauth",
|
|
168
|
+
client: {
|
|
169
|
+
token_endpoint_auth_method: "client_secret_post",
|
|
170
|
+
},
|
|
171
|
+
authorization: {
|
|
172
|
+
url: "https://www.tiktok.com/v2/auth/authorize",
|
|
173
|
+
params: {
|
|
174
|
+
client_key: options.clientId,
|
|
175
|
+
scope: "user.info.basic",
|
|
176
|
+
},
|
|
177
|
+
},
|
|
178
|
+
token: "https://open.tiktokapis.com/v2/oauth/token/",
|
|
179
|
+
userinfo: "https://open.tiktokapis.com/v2/user/info/?fields=open_id,avatar_url,display_name",
|
|
180
|
+
profile(profile) {
|
|
181
|
+
return {
|
|
182
|
+
id: profile.data.user.open_id,
|
|
183
|
+
name: profile.data.user.display_name,
|
|
184
|
+
image: profile.data.user.avatar_url,
|
|
185
|
+
// Email address is not supported by TikTok.
|
|
186
|
+
email: null,
|
|
187
|
+
};
|
|
188
|
+
},
|
|
189
|
+
style: {
|
|
190
|
+
bg: "#000",
|
|
191
|
+
text: "#fff",
|
|
192
|
+
},
|
|
193
|
+
options,
|
|
194
|
+
};
|
|
195
|
+
}
|