From e6fa583941deee190dd825e8696e04c66910d0fe Mon Sep 17 00:00:00 2001 From: Vladyslav Date: Sun, 7 Jul 2024 01:12:20 +0300 Subject: [PATCH 1/3] add Frontegg provider --- .github/ISSUE_TEMPLATE/2_bug_provider.yml | 1 + apps/dev/nextjs/.env.local.example | 4 + docs/public/img/providers/frontegg.svg | 52 ++++++++++ packages/core/src/providers/frontegg.ts | 110 ++++++++++++++++++++++ 4 files changed, 167 insertions(+) create mode 100644 docs/public/img/providers/frontegg.svg create mode 100644 packages/core/src/providers/frontegg.ts diff --git a/.github/ISSUE_TEMPLATE/2_bug_provider.yml b/.github/ISSUE_TEMPLATE/2_bug_provider.yml index a5c8041863..48477b136a 100644 --- a/.github/ISSUE_TEMPLATE/2_bug_provider.yml +++ b/.github/ISSUE_TEMPLATE/2_bug_provider.yml @@ -54,6 +54,7 @@ body: - "Identity Server 4" - "Instagram" - "Kakao" + - "Frontegg" - "Keycloak" - "Line" - "LinkedIn" diff --git a/apps/dev/nextjs/.env.local.example b/apps/dev/nextjs/.env.local.example index 70e5ece6f0..ea3533df18 100644 --- a/apps/dev/nextjs/.env.local.example +++ b/apps/dev/nextjs/.env.local.example @@ -57,6 +57,10 @@ AUTH_TWITTER_SECRET= AUTH_WIKIMEDIA_ID= AUTH_WIKIMEDIA_SECRET= +AUTH_FRONTEGG_ID= +AUTH_FRONTEGG_SECRET= +AUTH_FRONTEGG_ISSUER= + # Yandex OAuth. new app -> https://oauth.yandex.com/client/new/id AUTH_YANDEX_ID= AUTH_YANDEX_SECRET= diff --git a/docs/public/img/providers/frontegg.svg b/docs/public/img/providers/frontegg.svg new file mode 100644 index 0000000000..749ab73241 --- /dev/null +++ b/docs/public/img/providers/frontegg.svg @@ -0,0 +1,52 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/packages/core/src/providers/frontegg.ts b/packages/core/src/providers/frontegg.ts new file mode 100644 index 0000000000..4e9212dba2 --- /dev/null +++ b/packages/core/src/providers/frontegg.ts @@ -0,0 +1,110 @@ +/** + *
+ * + * Built-in sign in with Frontegg integration. + * + * + * + * + *
+ * + * @module providers/frontegg + */ + +import type { OIDCConfig, OIDCUserConfig } from "./index.js" + +/** The returned user profile from Frontegg when using the profile callback. [Reference](https://docs.frontegg.com/docs/admin-portal-profile). */ +export interface FronteggProfile { + /** The user's unique Frontegg ID */ + sub: string + /** The user's name */ + name: string + /** The user's email */ + email: string + /** A boolean indicating if the user's email is verified */ + email_verified: boolean + /** The user's picture */ + profilePictureUrl: string + /** The user's roles */ + roles: string[] + /** The user's custom attributes */ + [claim: string]: unknown +} + +/** + * + * ### Setup + * + * #### Callback URL + * ``` + * https://example.com/api/auth/callback/frontegg + * ``` + * + * #### Configuration + * ```ts + * import { Auth } from "@auth/core" + * import Frontegg from "@auth/core/providers/frontegg" + * + * const request = new Request(origin) + * const response = await Auth(request, { + * providers: [ + * Frontegg({ + * clientId: AUTH_FRONTEGG_ID, + * clientSecret: AUTH_FRONTEGG_SECRET, + * issuer: AUTH_FRONTEGG_ISSUER + * }), + * ], + * }) + * ``` + * + * ### Configuring Frontegg + * + * Follow these steps: + * + * Log into the [Frontegg](https://portal.frontegg.com) + * + * Authentication > Login method > Hosted login > Add your callback url here <{{APP_URL}}/api/auth/callback/frontegg> + * + * Then, create a `.env.local` file in the project root add the following entries: + * + * Get the following from the Frontegg's portal: + * ``` + * AUTH_FRONTEGG_ID="" # Environments > Your environment > Env settings + * AUTH_FRONTEGG_ISSUER="" # Environments > Your environment > Env settings > Domains > Domain name + * ``` + * + * ### Resources + * + * - [Frontegg Docs](https://docs.frontegg.com/docs/how-to-use-our-docs) + * + * ### Notes + * + * The Frontegg provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/frontegg.ts). To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers). + * + * :::info + * By default, Auth.js assumes that the Frontegg provider is based on the [OIDC](https://openid.net/specs/openid-connect-core-1_0.html) spec + * ::: + * + * ## Help + * + * If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue). + * + * Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from + * the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec, + * we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions). + */ +export default function Frontegg( + options: OIDCUserConfig +): OIDCConfig { + return { + id: "frontegg", + name: "Frontegg", + type: "oidc", + authorization: `${options.issuer}/oauth/authorize`, + token: `${options.issuer}/oauth/token`, + userinfo: `${options.issuer}/identity/resources/users/v2/me`, + wellKnown: `${options.issuer}/oauth/.well-known/openid-configuration`, + issuer: options.issuer, + options, + } +} From 0b8c923e3a02ad43f9cc93a8fe2f30eb5b88352d Mon Sep 17 00:00:00 2001 From: Vladyslav Date: Mon, 8 Jul 2024 22:26:30 +0300 Subject: [PATCH 2/3] change frontegg svg and add AUTH_FRONTEGG_SECRET key --- docs/public/img/providers/frontegg.svg | 57 +++---------------------- packages/core/src/providers/frontegg.ts | 1 + 2 files changed, 6 insertions(+), 52 deletions(-) diff --git a/docs/public/img/providers/frontegg.svg b/docs/public/img/providers/frontegg.svg index 749ab73241..bbe054debb 100644 --- a/docs/public/img/providers/frontegg.svg +++ b/docs/public/img/providers/frontegg.svg @@ -1,52 +1,5 @@ - - - - - - - - - - - - \ No newline at end of file + + + + + diff --git a/packages/core/src/providers/frontegg.ts b/packages/core/src/providers/frontegg.ts index 4e9212dba2..cebc5c27b8 100644 --- a/packages/core/src/providers/frontegg.ts +++ b/packages/core/src/providers/frontegg.ts @@ -70,6 +70,7 @@ export interface FronteggProfile { * Get the following from the Frontegg's portal: * ``` * AUTH_FRONTEGG_ID="" # Environments > Your environment > Env settings + * AUTH_FRONTEGG_SECRET="" # Environments > Your environment > Env settings * AUTH_FRONTEGG_ISSUER="" # Environments > Your environment > Env settings > Domains > Domain name * ``` * From 0fd02b5cc1c0ab1de9e87ccc97027e874f1ffca6 Mon Sep 17 00:00:00 2001 From: Vladyslav Date: Mon, 8 Jul 2024 22:59:08 +0300 Subject: [PATCH 3/3] add frontegg.mdx --- .../getting-started/providers/frontegg.mdx | 90 +++++++++++++++++++ packages/core/src/providers/frontegg.ts | 2 +- 2 files changed, 91 insertions(+), 1 deletion(-) create mode 100644 docs/pages/getting-started/providers/frontegg.mdx diff --git a/docs/pages/getting-started/providers/frontegg.mdx b/docs/pages/getting-started/providers/frontegg.mdx new file mode 100644 index 0000000000..d731d7124b --- /dev/null +++ b/docs/pages/getting-started/providers/frontegg.mdx @@ -0,0 +1,90 @@ +import { Callout } from "nextra/components" +import { Code } from "@/components/Code" + + + +# Frontegg Provider + +## Resources + +- [Frontegg documentation](https://docs.frontegg.com/docs/how-to-use-our-docs) + +## Setup + +### Callback URL + + + + + ```bash + https://example.com/api/auth/callback/frontegg + ``` + + + + + ```bash + https://example.com/auth/callback/frontegg + ``` + + + + +### Environment Variables + +``` +AUTH_FRONTEGG_ID +AUTH_FRONTEGG_SECRET +AUTH_FRONTEGG_ISSUER +``` + +### Configuration + +Follow these steps: + +Log into the [Frontegg portal](https://portal.frontegg.com) + +Get the following from the Frontegg's portal: + +AUTH_FRONTEGG_ID="" # Environments > Your environment > Env settings +AUTH_FRONTEGG_SECRET="" # Environments > Your environment > Env settings +AUTH_FRONTEGG_ISSUER="" # Environments > Your environment > Env settings > Domains > Domain name + +Add the required environment variables from above to your `.env.local` file. + + + + + ```ts filename="/auth.ts" + import NextAuth from "next-auth" + import Frontegg from "next-auth/providers/frontegg" + + export const { handlers, auth, signIn, signOut } = NextAuth({ + providers: [Frontegg], + }) + ``` + + + + + ```ts filename="/src/auth.ts" + import { SvelteKitAuth } from "@auth/sveltekit" + import Frontegg from "@auth/sveltekit/providers/frontegg" + + export const { handle, signIn, signOut } = SvelteKitAuth({ + providers: [Frontegg], + }) + ``` + + + + + ```ts filename="/src/app.ts" + import { ExpressAuth } from "@auth/express" + import Frontegg from "@auth/express/providers/frontegg" + + app.use("/auth/*", ExpressAuth({ providers: [Frontegg] })) + ``` + + + diff --git a/packages/core/src/providers/frontegg.ts b/packages/core/src/providers/frontegg.ts index cebc5c27b8..15890c5c8d 100644 --- a/packages/core/src/providers/frontegg.ts +++ b/packages/core/src/providers/frontegg.ts @@ -61,7 +61,7 @@ export interface FronteggProfile { * * Follow these steps: * - * Log into the [Frontegg](https://portal.frontegg.com) + * Log into the [Frontegg portal](https://portal.frontegg.com) * * Authentication > Login method > Hosted login > Add your callback url here <{{APP_URL}}/api/auth/callback/frontegg> *