LinkedIn OAuth2.0 for 5HTP
Easy LinkedIn Authentication Plugin for 5HTP.
This plugin is only compatible with projects based on 5HTP, a early-stage Node/TS/Preact framework designed for performance and productivity.
data:image/s3,"s3://crabby-images/d39b6/d39b63a05565d459cbfa0dd9a35547b40a1020fc" alt="npm"
How it works basically
- The user clicks on the auth button
- He're redirected to the LinkedIn authorization page, asking to the user if he wants to login with your app and provide his data (email, etc ...)
5htp-auth-linkedin
receive an Authorization token, which is then converted to an access token you can finally use to make API requests on LinkedIn
Definitions
- 5HTP Service ID:
linkedinAuth
- Availability:
global
Methods:
$.linkedinAuth.requestAuthCode( context?: object, scopes?: string[] ): Promise<string>;
$.linkedinAuth.handleResponse( linkedInResponse: Request ): Promise<{
profile: { firstName: string, lastName: string, email: string },
context: object,
accessToken: string
}>;
Installation
npm i --save 5htp-auth-linkedin
Configuration
Step 1: Configure your app on Linkedin
- Create an app here: https://www.linkedin.com/developers/apps/new
- Then go in you app settings > Product and enable
Sign In with LinkedIn
- Go on the Auth tab and configure redirect URLs
Step 2: Update your config file
Enable this service plugin in your app by importing it in @/server/index.ts
:
import '5htp-auth-linkedin';
Then, add the following entry in @/server/config.ts
:
{
linkedinAuth: {
id: "<linkedin client ID>",
secret: "<linkedin secret key>",
callbackUrl: '/auth/linkedin/callback'
}
}
Usage
Step 1: In your frontend, create a redirection button
@/client/pages/auth.tsx
import React from 'react';
import route from '@router';
import Button from '@client/components/button';
route.page('/auth', {}, null, () => (
<Button link="/auth/linkedin" target="_blank">
Login with Linkedin
</Button>
)
Step 2: In your backend, create the redirection and handle LinkedIn's response
@/server/routes/auth.ts
import app, { $ } from '@server/app';
const route = $.route;
import { Forbidden } from '@common/errors';
route.get('/auth/linkedin', { }, async ({ response, user }) => {
const redirectUri = await $.linkedinAuth.requestAuthCode({
userId: user.id
});
return response.redirect(redirectUri);
});
route.get('/auth/linkedin/callback', { }, async ({ request }) => {
const {
profile,
context,
accessToken
} = await $.linkedinAuth.handleResponse(linkedInResponse);
return `
Hi ${profile.firstName} ${profile.lastName},
Your email is ${profile.email} and I also remind your user ID is ${res.context.userId}.
`
});