LinkedIn OAuth2.0 for 5HTP
5HTP module for easily handling the LinkedIn OAuth2.0 process, and retrieve and final access token.
This module is only compatible with projects based on 5HTP, an experimental Full Stack framework designed for performance and productivity.
data:image/s3,"s3://crabby-images/d39b6/d39b63a05565d459cbfa0dd9a35547b40a1020fc" alt="npm"
Installation
npm i --save 5htp-auth-linkedin
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
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 module 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 { ForbiddenAccess } from '@server/common';
route.get('/auth/linkedin', { }, async ({ response }) => {
const redirectUri = await $.linkedinAuth.requestAuthCode(
{ actionName: 'linkedinLogin' }
['r_emailaddress', 'r_liteprofile'],
);
return response.redirect(redirectUri);
});
route.get('/auth/linkedin/callback', { }, async ({ request }) => {
const res = await $.linkedinAuth.handleResponse(linkedInResponse);
if ('error' in res)
throw new ForbiddenAccess(res.error.message);
console.log('Access token:', res.accessToken);
if (res.context.actionName === 'linkedinLogin') {
}
return true;
});