Documentation
Providers
LinkedIn

LinkedIn Provider

linkedin-logo

If you need a detailed guide on how to setup a provider pleaser refer to the Getting Started and Making your first integration guides.

Important notes

  • When creating a LinkedIn app, you need to enable the "Sign In with LinkedIn using OpenID Connect" product in the "Products" tab.
  • Does not return a refresh_token per default, however the access token is valid for 2 months. However if you're a Marketing Developer Platform (MDP) partner, you will get a refresh_token.

Resources

Setup

Callback URL

https://your-app.com/api/auth/integration/linkedin

Environment variables

.env.local
AUTH_LINKEDIN_ID=your-client-id
AUTH_LINKEDIN_SECRET=your-client-secret

Add the provider to the auth.ts file.

auth.ts
import { NextIntegrate } from 'next-integrate';
 
export const { auth } = NextIntegrate({
  // The URL of the app, e.g. https://example.com, set in the .env file.
  // If you want to modify the redirect URL, to be prefixed with something else,
  // you can do it here like this:
  // base_url: process.env.BASE_URL! + "/some-prefix",
  // This will change the redirect URL to eg. https://example.com/some-prefix/api/auth/integration/google
  base_url: process.env.BASE_URL!,
  providers: [
    {
      provider: 'linkedin',
      client_id: process.env.AUTH_LINKEDIN_ID!,
      client_secret: process.env.AUTH_LINKEDIN_SECRET!,
      integrations: [],
    },
  ],
});

Add an integration

auth.ts
import { NextIntegrate } from 'next-integrate';
 
export const { auth } = NextIntegrate({
  // The URL of the app, e.g. https://example.com, set in the .env file.
  // If you want to modify the redirect URL, to be prefixed with something else,
  // you can do it here like this:
  // base_url: process.env.BASE_URL! + "/some-prefix",
  // This will change the redirect URL to eg. https://example.com/some-prefix/api/auth/integration/google
  base_url: process.env.BASE_URL!,
  providers: [
    {
      provider: 'linkedin',
      client_id: process.env.AUTH_LINKEDIN_ID!,
      client_secret: process.env.AUTH_LINKEDIN_SECRET!,
      integrations: [
        {
          name: 'some_custom_name',
          options: {
            scope: 'email',
          },
          callback: async (data) => {
            // This is where you can save the data to a database, or do something else with it.
          },
        },
      ],
    },
  ],
});

Usage

To use the your new integration, you can use the <Integrate /> component found in the Getting Started Guide.

import Integrate from '@/components/integrate';
 
export default function Home() {
  return (
    <main>
      <Integrate provider="linkedin" name="some_custom_name">
        Get LinkedIn User Info
      </Integrate>
    </main>
  );
}

Options

You can pass various parameters on the options object to customize the integration. The parameters are specific to the LinkedIn provider, please refer to the documentation (opens in a new tab), to verify the information if needed.

parametertyperequireddescription
scopestringtrueA list of permissions separated by spaces, you can find your available scopes in the auth tab of your LinkedIn app.