UNPKG

angularx-social-login

Version:

Social login and authentication module for Angular 9+. Supports authentication with Google, Facebook, Amazon, and VK. Can be extended to other providers also.

165 lines 24.7 kB
import { BaseLoginProvider } from '../entities/base-login-provider'; import { SocialUser } from '../entities/social-user'; /** * Protocol modes supported by MSAL. */ export var ProtocolMode; (function (ProtocolMode) { ProtocolMode["AAD"] = "AAD"; ProtocolMode["OIDC"] = "OIDC"; })(ProtocolMode || (ProtocolMode = {})); const COMMON_AUTHORITY = 'https://login.microsoftonline.com/common/'; /** * Microsoft Authentication using MSAL v2: https://github.com/AzureAD/microsoft-authentication-library-for-js/tree/dev/lib/msal-browser */ export class MicrosoftLoginProvider extends BaseLoginProvider { constructor(clientId, initOptions) { super(); this.clientId = clientId; this.initOptions = { redirect_uri: location.origin, authority: COMMON_AUTHORITY, scopes: ['openid', 'profile', 'User.Read'], knownAuthorities: [], protocolMode: ProtocolMode.AAD, clientCapabilities: [], cacheLocation: 'sessionStorage' }; this.initOptions = Object.assign(Object.assign({}, this.initOptions), initOptions); } initialize() { return new Promise((resolve, reject) => { this.loadScript(MicrosoftLoginProvider.PROVIDER_ID, 'https://alcdn.msauth.net/browser/2.1.0/js/msal-browser.js', () => { try { const config = { auth: { clientId: this.clientId, redirectUri: this.initOptions.redirect_uri, authority: this.initOptions.authority, knownAuthorities: this.initOptions.knownAuthorities, protocolMode: this.initOptions.protocolMode, clientCapabilities: this.initOptions.clientCapabilities }, cache: !this.initOptions.cacheLocation ? null : { cacheLocation: this.initOptions.cacheLocation } }; this._instance = new msal.PublicClientApplication(config); resolve(); } catch (e) { reject(e); } }); }); } getSocialUser(loginResponse) { return new Promise((resolve, reject) => { //After login, use Microsoft Graph API to get user info let meRequest = new XMLHttpRequest(); meRequest.onreadystatechange = () => { if (meRequest.readyState == 4) { try { if (meRequest.status == 200) { let userInfo = JSON.parse(meRequest.responseText); let user = new SocialUser(); user.provider = MicrosoftLoginProvider.PROVIDER_ID; user.id = loginResponse.idToken; user.name = loginResponse.idTokenClaims.name; user.email = loginResponse.account.username; user.idToken = loginResponse.idToken; user.response = loginResponse; user.firstName = userInfo.givenName; user.lastName = userInfo.surname; resolve(user); } else { reject(`Error retrieving user info: ${meRequest.status}`); } } catch (err) { reject(err); } } }; //Microsoft Graph ME Endpoint: https://docs.microsoft.com/en-us/graph/api/user-get?view=graph-rest-1.0&tabs=http meRequest.open('GET', 'https://graph.microsoft.com/v1.0/me'); meRequest.setRequestHeader('Authorization', `Bearer ${loginResponse.accessToken}`); try { meRequest.send(); } catch (err) { reject(err); } }); } getLoginStatus() { return new Promise((resolve, reject) => { const accounts = this._instance.getAllAccounts(); if (accounts.length > 0) { try { this._instance.ssoSilent({ scopes: this.initOptions.scopes, loginHint: accounts[0].username }) .then(loginResponse => { this.getSocialUser(loginResponse) .then(user => resolve(user)) .catch(err => reject(err)); }) .catch(err => reject(err)); } catch (err) { reject(err); } } else { reject(`No user is currently logged in with ${MicrosoftLoginProvider.PROVIDER_ID}`); } }); } signIn() { return new Promise((resolve, reject) => { try { this._instance.loginPopup({ scopes: this.initOptions.scopes }) .then(loginResponse => { this.getSocialUser(loginResponse) .then(user => resolve(user)) .catch(err => reject(err)); }) .catch(err => reject(err)); } catch (err) { reject(err); } }); } signOut(revoke) { return new Promise((resolve, reject) => { try { const accounts = this._instance.getAllAccounts(); //TODO: This redirects to a Microsoft page, then sends us back to redirect_uri... this doesn't seem to match other providers //Open issues: // https://github.com/abacritt/angularx-social-login/issues/306 // https://github.com/AzureAD/microsoft-authentication-library-for-js/issues/2563 this._instance.logout({ account: accounts[0], postLogoutRedirectUri: this.initOptions.redirect_uri }) .then(() => { resolve(); }) .catch(err => { reject(err); }); } catch (err) { reject(err); } }); } } MicrosoftLoginProvider.PROVIDER_ID = 'MICROSOFT'; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"microsoft-login-provider.js","sourceRoot":"C:/Users/JADUTTA/dev/web/angularx-social-login/projects/lib/src/","sources":["providers/microsoft-login-provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseLoginProvider } from '../entities/base-login-provider';\r\nimport { SocialUser } from '../entities/social-user';\r\n\r\n/**\r\n * Protocol modes supported by MSAL.\r\n */\r\nexport enum ProtocolMode {\r\n  AAD = 'AAD',\r\n  OIDC = 'OIDC'\r\n}\r\n\r\n/**\r\n * Initialization Options for Microsoft Provider: https://github.com/AzureAD/microsoft-authentication-library-for-js/blob/dev/lib/msal-browser/docs/initialization.md\r\n * Details (not all options are supported): https://github.com/AzureAD/microsoft-authentication-library-for-js/blob/dev/lib/msal-browser/docs/configuration.md\r\n */\r\nexport type MicrosoftOptions = {\r\n  redirect_uri: string,\r\n  authority?: string,\r\n  knownAuthorities?: string[],\r\n  protocolMode?: ProtocolMode,\r\n  clientCapabilities?: string[],\r\n  cacheLocation?: string,\r\n  scopes?: string[]\r\n};\r\n\r\n// Collection of internal MSAL interfaces from: https://github.com/AzureAD/microsoft-authentication-library-for-js/tree/dev/lib/msal-browser/src\r\n\r\ninterface MSALAccount {\r\n  environment: string;\r\n  homeAccountId: string;\r\n  tenantId: string;\r\n  username: string;\r\n}\r\n\r\ninterface MSGraphUserInfo {\r\n  businessPhones: string[];\r\n  displayName: string;\r\n  givenName: string;\r\n  id: string;\r\n  jobTitle: string;\r\n  mail: string;\r\n  mobilePhone: string;\r\n  officeLocation: string;\r\n  preferredLanguage: string;\r\n  surname: string;\r\n  userPrincipalName: string;\r\n}\r\n\r\ninterface MSALLoginRequest {\r\n  scopes?: string[];\r\n  sid?: string;\r\n  loginHint?: string;\r\n  domainHint?: string;\r\n}\r\n\r\ninterface MSALLoginResponse {\r\n  accessToken: string;\r\n  account: MSALAccount;\r\n  expiresOn: Date;\r\n  extExpiresOn: Date;\r\n  familyId: string;\r\n  fromCache: boolean;\r\n  idToken: string;\r\n  idTokenClaims: any;\r\n  scopes: string[];\r\n  state: string;\r\n  tenantId: string;\r\n  uniqueId: string;\r\n}\r\n\r\ninterface MSALLogoutRequest {\r\n  account?: MSALAccount;\r\n  postLogoutRedirectUri?: string;\r\n  authority?: string;\r\n  correlationId?: string;\r\n}\r\n\r\ninterface MSALClientApplication {\r\n  getAllAccounts(): MSALAccount[];\r\n  logout(logoutRequest?: MSALLogoutRequest): Promise<void>;\r\n  loginPopup(loginRequest: MSALLoginRequest): Promise<MSALLoginResponse>;\r\n  ssoSilent(loginRequest: MSALLoginRequest): Promise<MSALLoginResponse>;\r\n  acquireTokenSilent(loginRequest: MSALLoginRequest): Promise<MSALLoginResponse>;\r\n  getAccountByHomeId(homeAccountId: string): MSALAccount;\r\n}\r\n\r\ndeclare let msal: any;\r\n\r\nconst COMMON_AUTHORITY: string = 'https://login.microsoftonline.com/common/';\r\n\r\n/**\r\n * Microsoft Authentication using MSAL v2: https://github.com/AzureAD/microsoft-authentication-library-for-js/tree/dev/lib/msal-browser\r\n */\r\nexport class MicrosoftLoginProvider extends BaseLoginProvider {\r\n  private _instance: MSALClientApplication;\r\n  public static readonly PROVIDER_ID: string = 'MICROSOFT';\r\n\r\n  private initOptions: MicrosoftOptions = {\r\n    redirect_uri: location.origin,\r\n    authority: COMMON_AUTHORITY,\r\n    scopes: ['openid', 'profile', 'User.Read'],\r\n    knownAuthorities: [],\r\n    protocolMode: ProtocolMode.AAD,\r\n    clientCapabilities: [],\r\n    cacheLocation: 'sessionStorage'\r\n  };\r\n\r\n  constructor(\r\n    private clientId: string,\r\n    initOptions?: MicrosoftOptions\r\n  ) {\r\n    super();\r\n\r\n    this.initOptions = {\r\n      ...this.initOptions,\r\n      ...initOptions\r\n    };\r\n  }\r\n\r\n  initialize(): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      this.loadScript(\r\n        MicrosoftLoginProvider.PROVIDER_ID,\r\n        'https://alcdn.msauth.net/browser/2.1.0/js/msal-browser.js',\r\n        () => {\r\n          try {\r\n            const config = {\r\n              auth: {\r\n                clientId: this.clientId,\r\n                redirectUri: this.initOptions.redirect_uri,\r\n                authority: this.initOptions.authority,\r\n                knownAuthorities: this.initOptions.knownAuthorities,\r\n                protocolMode: this.initOptions.protocolMode,\r\n                clientCapabilities: this.initOptions.clientCapabilities\r\n              },\r\n              cache: !this.initOptions.cacheLocation ? null : {\r\n                cacheLocation: this.initOptions.cacheLocation\r\n              }\r\n            };\r\n\r\n            this._instance = new msal.PublicClientApplication(config);\r\n            resolve();\r\n          } catch (e) {\r\n            reject(e);\r\n          }\r\n        }\r\n      );\r\n    });\r\n  }\r\n\r\n  private getSocialUser(loginResponse): Promise<SocialUser> {\r\n    return new Promise<SocialUser>((resolve, reject) => {\r\n      //After login, use Microsoft Graph API to get user info\r\n      let meRequest = new XMLHttpRequest();\r\n      meRequest.onreadystatechange = () => {\r\n        if (meRequest.readyState == 4) {\r\n          try {\r\n            if (meRequest.status == 200) {\r\n              let userInfo = <MSGraphUserInfo>JSON.parse(meRequest.responseText);\r\n\r\n              let user: SocialUser = new SocialUser();\r\n              user.provider = MicrosoftLoginProvider.PROVIDER_ID;\r\n              user.id = loginResponse.idToken;\r\n              user.name = loginResponse.idTokenClaims.name;\r\n              user.email = loginResponse.account.username;\r\n              user.idToken = loginResponse.idToken;\r\n              user.response = loginResponse;\r\n              user.firstName = userInfo.givenName;\r\n              user.lastName = userInfo.surname;\r\n\r\n              resolve(user);\r\n            } else {\r\n              reject(`Error retrieving user info: ${meRequest.status}`);\r\n            }\r\n          } catch (err) {\r\n            reject(err);\r\n          }\r\n        }\r\n      };\r\n\r\n      //Microsoft Graph ME Endpoint: https://docs.microsoft.com/en-us/graph/api/user-get?view=graph-rest-1.0&tabs=http\r\n      meRequest.open('GET', 'https://graph.microsoft.com/v1.0/me');\r\n      meRequest.setRequestHeader('Authorization', `Bearer ${loginResponse.accessToken}`);\r\n      try {\r\n        meRequest.send();\r\n      } catch (err) {\r\n        reject(err);\r\n      }\r\n    });\r\n  }\r\n\r\n  getLoginStatus(): Promise<SocialUser> {\r\n    return new Promise<SocialUser>((resolve, reject) => {\r\n      const accounts = this._instance.getAllAccounts();\r\n      if (accounts.length > 0) {\r\n        try {\r\n          this._instance.ssoSilent({\r\n            scopes: this.initOptions.scopes,\r\n            loginHint: accounts[0].username\r\n          })\r\n            .then(loginResponse => {\r\n              this.getSocialUser(loginResponse)\r\n                .then(user => resolve(user))\r\n                .catch(err => reject(err));\r\n            })\r\n            .catch(err => reject(err));\r\n        } catch (err) {\r\n          reject(err);\r\n        }\r\n      } else {\r\n        reject(`No user is currently logged in with ${MicrosoftLoginProvider.PROVIDER_ID}`);\r\n      }\r\n    });\r\n  }\r\n\r\n  signIn(): Promise<SocialUser> {\r\n    return new Promise<SocialUser>((resolve, reject) => {\r\n      try {\r\n        this._instance.loginPopup({\r\n          scopes: this.initOptions.scopes\r\n        })\r\n          .then(loginResponse => {\r\n            this.getSocialUser(loginResponse)\r\n              .then(user => resolve(user))\r\n              .catch(err => reject(err));\r\n          })\r\n          .catch(err => reject(err));\r\n      } catch (err) {\r\n        reject(err);\r\n      }\r\n    });\r\n  }\r\n\r\n  signOut(revoke?: boolean): Promise<any> {\r\n    return new Promise<any>((resolve, reject) => {\r\n      try {\r\n        const accounts = this._instance.getAllAccounts();\r\n        //TODO: This redirects to a Microsoft page, then sends us back to redirect_uri... this doesn't seem to match other providers\r\n        //Open issues:\r\n        // https://github.com/abacritt/angularx-social-login/issues/306\r\n        // https://github.com/AzureAD/microsoft-authentication-library-for-js/issues/2563\r\n        this._instance.logout({\r\n          account: accounts[0],\r\n          postLogoutRedirectUri: this.initOptions.redirect_uri\r\n        })\r\n          .then(() => {\r\n            resolve();\r\n          })\r\n          .catch(err => {\r\n            reject(err);\r\n          });\r\n      } catch (err) {\r\n        reject(err);\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}