@idea-ionic/auth0
Version:
99 lines • 12.4 kB
JavaScript
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"]}