UNPKG

@idea-ionic/auth0

Version:
99 lines 12.4 kB
import { Injectable, inject } from '@angular/core'; import { firstValueFrom } from 'rxjs'; import { AuthService } from '@auth0/auth0-angular'; import { Platform } from '@ionic/angular/standalone'; import { Browser } from '@capacitor/browser'; import { Auth0User } from 'idea-toolbox'; import { IDEAEnvironment } from '@idea-ionic/common'; import * as i0 from "@angular/core"; export class IDEAAuth0Service { constructor() { this._env = inject(IDEAEnvironment); this._platform = inject(Platform); this._auth0 = inject(AuthService); } /** * The internal Auth0's service. */ get __raw() { return this._auth0; } isMobileDevice() { return this._platform.is('capacitor'); } /** * Open (if needed) Auth0's Universal Login page, to authenticate a user. * @param afterRedirectTo where to go after a successful login */ goToLogin(afterRedirectTo) { this.isMobileDevice() ? this.loginWithMobile(afterRedirectTo) : this.loginWithSPA(afterRedirectTo); } async loginWithSPA(afterRedirectTo) { await firstValueFrom(this._auth0.loginWithRedirect({ appState: { target: afterRedirectTo } })); } async loginWithMobile(afterRedirectTo) { await firstValueFrom(this._auth0.loginWithRedirect({ appState: { target: afterRedirectTo }, openUrl: url => Browser.open({ url }) })); } /** * Open (if needed) Auth0's Universal Login page, to logout a user. */ goToLogout() { this.isMobileDevice() ? this.logoutWithMobile() : this.logoutWithSPA(); } async logoutWithSPA() { await firstValueFrom(this._auth0.logout({ logoutParams: { returnTo: document.location.origin } })); } async logoutWithMobile() { await firstValueFrom(this._auth0.logout({ logoutParams: { localOnly: true }, openUrl: url => Browser.open({ url }) })); } /** * Handle the callback after a login or logout in Auth0 Universal Login page. * In order to work, it has to be used in `app.component.ts`, as explained in the following snippet: * ``` export class AppComponent { constructor(private ngZone: NgZone, private auth0: IDEAAuth0Service) { App.addListener('appUrlOpen', ({ url }): void => this.ngZone.run((): void => this.auth0.handleCallbackOnMobileDevices(url)) ); } } * ``` */ async handleCallbackOnMobileDevices(url) { if (url?.startsWith(this._env.auth0.callbackUri)) { if (url.includes('state=') && (url.includes('error=') || url.includes('code='))) await firstValueFrom(this._auth0.handleRedirectCallback(url)); await Browser.close(); } } /** * Get the ID token, to use for authenticating API requests to the back-end. */ async getIdToken() { const { __raw } = await firstValueFrom(this._auth0.idTokenClaims$); return __raw; } /** * Whether the user is currently authenticated. */ async isUserAuthenticated() { return await firstValueFrom(this._auth0.isAuthenticated$); } /** * Get the current user and its data. */ async getUser() { const user = await firstValueFrom(this._auth0.user$); if (user) return new Auth0User(user); else return null; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: IDEAAuth0Service, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: IDEAAuth0Service, providedIn: 'root' }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: IDEAAuth0Service, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth0.service.js","sourceRoot":"","sources":["../../../../modules/auth0/src/auth0.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { firstValueFrom } from 'rxjs';\nimport { AuthService } from '@auth0/auth0-angular';\nimport { Platform } from '@ionic/angular/standalone';\nimport { Browser } from '@capacitor/browser';\nimport { Auth0User } from 'idea-toolbox';\nimport { IDEAEnvironment } from '@idea-ionic/common';\n\n@Injectable({ providedIn: 'root' })\nexport class IDEAAuth0Service {\n  protected _env = inject(IDEAEnvironment);\n  private _platform = inject(Platform);\n  private _auth0 = inject(AuthService);\n\n  /**\n   * The internal Auth0's service.\n   */\n  get __raw(): AuthService {\n    return this._auth0;\n  }\n\n  private isMobileDevice(): boolean {\n    return this._platform.is('capacitor');\n  }\n\n  /**\n   * Open (if needed) Auth0's Universal Login page, to authenticate a user.\n   * @param afterRedirectTo where to go after a successful login\n   */\n  goToLogin(afterRedirectTo?: string): void {\n    this.isMobileDevice() ? this.loginWithMobile(afterRedirectTo) : this.loginWithSPA(afterRedirectTo);\n  }\n  private async loginWithSPA(afterRedirectTo?: string): Promise<void> {\n    await firstValueFrom(this._auth0.loginWithRedirect({ appState: { target: afterRedirectTo } }));\n  }\n  private async loginWithMobile(afterRedirectTo?: string): Promise<void> {\n    await firstValueFrom(\n      this._auth0.loginWithRedirect({ appState: { target: afterRedirectTo }, openUrl: url => Browser.open({ url }) })\n    );\n  }\n\n  /**\n   * Open (if needed) Auth0's Universal Login page, to logout a user.\n   */\n  goToLogout(): void {\n    this.isMobileDevice() ? this.logoutWithMobile() : this.logoutWithSPA();\n  }\n  private async logoutWithSPA(): Promise<void> {\n    await firstValueFrom(this._auth0.logout({ logoutParams: { returnTo: document.location.origin } }));\n  }\n  private async logoutWithMobile(): Promise<void> {\n    await firstValueFrom(\n      this._auth0.logout({ logoutParams: { localOnly: true }, openUrl: url => Browser.open({ url }) })\n    );\n  }\n\n  /**\n   * Handle the callback after a login or logout in Auth0 Universal Login page.\n   * In order to work, it has to be used in `app.component.ts`, as explained in the following snippet:\n   * ```\n      export class AppComponent {\n        constructor(private ngZone: NgZone, private auth0: IDEAAuth0Service) {\n          App.addListener('appUrlOpen', ({ url }): void =>\n            this.ngZone.run((): void => this.auth0.handleCallbackOnMobileDevices(url))\n          );\n        }\n      }\n   * ```\n   */\n  async handleCallbackOnMobileDevices(url: string): Promise<void> {\n    if (url?.startsWith(this._env.auth0.callbackUri)) {\n      if (url.includes('state=') && (url.includes('error=') || url.includes('code=')))\n        await firstValueFrom(this._auth0.handleRedirectCallback(url));\n      await Browser.close();\n    }\n  }\n\n  /**\n   * Get the ID token, to use for authenticating API requests to the back-end.\n   */\n  async getIdToken(): Promise<string> {\n    const { __raw } = await firstValueFrom(this._auth0.idTokenClaims$);\n    return __raw;\n  }\n  /**\n   * Whether the user is currently authenticated.\n   */\n  async isUserAuthenticated(): Promise<boolean> {\n    return await firstValueFrom(this._auth0.isAuthenticated$);\n  }\n  /**\n   * Get the current user and its data.\n   */\n  async getUser(): Promise<Auth0User> {\n    const user = await firstValueFrom(this._auth0.user$);\n    if (user) return new Auth0User(user);\n    else return null;\n  }\n}\n"]}