@universis/common
Version:
Universis - common directives and services
114 lines (113 loc) • 14.1 kB
JavaScript
import { Inject, Injectable, InjectionToken } from '@angular/core';
import { Router } from '@angular/router';
import { UserService } from '../services/user.service';
import { Observable } from 'rxjs';
import { ErrorService } from '../../error/error.service';
import { ConfigurationService } from '../../shared/services/configuration.service';
export let APP_LOCATIONS = new InjectionToken('app.locations');
export const DEFAULT_APP_LOCATIONS = [{
privilege: 'Location',
target: {
url: '^/auth/'
},
mask: 1
},
{
privilege: 'Location',
target: {
url: '^/error'
},
mask: 1
}
];
export class AuthGuard {
constructor(_router, _locations, _errorService, _configurationService, _userService) {
this._router = _router;
this._locations = _locations;
this._errorService = _errorService;
this._configurationService = _configurationService;
this._userService = _userService;
// merge app locations, if any
if (this._configurationService.settings && this._configurationService.settings.auth) {
// get extra locations
const appLocations = this._configurationService.settings.auth.locations;
if (Array.isArray(appLocations)) {
// get APP_LOCATIONS
if (this._locations) {
this._locations.unshift.apply(this._locations, appLocations);
}
}
}
this._locations.forEach((x) => {
if (typeof x.target.pattern === 'undefined' || x.target.pattern === null) {
x.target.pattern = new RegExp(x.target.url, 'i');
}
});
}
canActivateLocation(path, user) {
let groups = [];
if (user && user.groups) {
groups = user.groups.map((x) => {
return x.name;
});
}
return this._locations.find((x) => {
return x.target.pattern.test(path)
&& (typeof x.account === 'undefined' || groups.indexOf(x.account.name) >= 0)
&& (x.mask === 0 || ((x.mask & 1) === 1))
&& user;
});
}
canActivate(route, state) {
return this._canActivate(state);
}
canActivateChild(childRoute, state) {
return this._canActivate(state);
}
_canActivate(state) {
return new Observable(resolve => {
this._userService.getUser().then((res) => {
const location = this.canActivateLocation(state.url, res);
if (location && (typeof location.account === 'undefined')) {
return resolve.next(true);
}
if (res) {
if (location && (location.mask & 1) === 1) {
return resolve.next(true);
}
else {
if (location && location.redirectTo) {
this._router.navigate([location.redirectTo]);
return resolve.next(false);
}
// noinspection JSIgnoredPromiseFromCall
this._router.navigate(['/error/403.1'], {
queryParams: {
action: 'Error.LoginAsDiffrentUser',
continue: '/auth/loginAs'
}
});
return resolve.next(false);
}
}
// noinspection JSIgnoredPromiseFromCall
this._router.navigate(['/auth/login'], { queryParams: {
continue: state.url
} });
return resolve.next(false);
});
});
}
}
AuthGuard.decorators = [
{ type: Injectable }
];
/** @nocollapse */
AuthGuard.ctorParameters = () => [
{ type: Router },
{ type: Array, decorators: [{ type: Inject, args: [APP_LOCATIONS,] }] },
{ type: ErrorService },
{ type: ConfigurationService },
{ type: UserService }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.guard.js","sourceRoot":"ng://@universis/common/","sources":["auth/guards/auth.guard.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable, InjectionToken} from '@angular/core';\nimport {ActivatedRouteSnapshot, CanActivate, CanActivateChild, Router, RouterStateSnapshot} from '@angular/router';\nimport { UserService } from '../services/user.service';\nimport { Observable } from 'rxjs';\nimport { ErrorService } from '../../error/error.service';\nimport {ConfigurationService} from '../../shared/services/configuration.service';\nimport {LocationPermission} from './auth.guard.interfaces';\n\nexport let APP_LOCATIONS = new InjectionToken('app.locations');\n\nexport const DEFAULT_APP_LOCATIONS = [{\n    privilege: 'Location',\n    target: {\n        url: '^/auth/'\n    },\n    mask: 1\n  },\n  {\n    privilege: 'Location',\n    target: {\n        url: '^/error'\n    },\n    mask: 1\n  }\n];\n\n@Injectable()\nexport class AuthGuard implements CanActivate, CanActivateChild {\n\n  constructor(private _router: Router,\n    @Inject(APP_LOCATIONS) private _locations: Array<LocationPermission>,\n    private _errorService: ErrorService,\n    private _configurationService: ConfigurationService,\n    private _userService: UserService) {\n\n    // merge app locations, if any\n    if (this._configurationService.settings && this._configurationService.settings.auth) {\n      // get extra locations\n      const appLocations = this._configurationService.settings.auth.locations;\n      if (Array.isArray(appLocations)) {\n        // get APP_LOCATIONS\n        if (this._locations) {\n          this._locations.unshift.apply(this._locations, appLocations);\n        }\n      }\n    }\n    this._locations.forEach((x) => {\n      if (typeof x.target.pattern === 'undefined' || x.target.pattern === null) {\n        x.target.pattern = new RegExp(x.target.url, 'i');\n      }\n    });\n  }\n\n  public canActivateLocation(path: string, user: any): LocationPermission {\n\n    let groups = [];\n    if (user && user.groups) {\n      groups = user.groups.map((x) => {\n        return x.name;\n      });\n    }\n    return this._locations.find((x) => {\n      return x.target.pattern.test(path)\n        && (typeof x.account === 'undefined' || groups.indexOf(x.account.name) >= 0)\n        && (x.mask === 0 || ((x.mask & 1) === 1))\n        && user;\n    });\n\n  }\n\n\n  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | boolean {\n    return this._canActivate(state);\n  }\n\n  canActivateChild(childRoute: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean {\n    return this._canActivate(state);\n  }\n\n  private _canActivate(state: RouterStateSnapshot): Observable<boolean> | boolean {\n    return new Observable<boolean>(resolve => {\n      this._userService.getUser().then((res) => {\n        const location = this.canActivateLocation(state.url, res);\n        if (location && (typeof location.account === 'undefined')) {\n          return resolve.next(true);\n        }\n        if (res) {\n          if (location && (location.mask & 1) === 1) {\n            return resolve.next(true);\n          } else {\n            if (location && location.redirectTo) {\n              this._router.navigate([location.redirectTo]);\n              return resolve.next(false);\n            }\n            // noinspection JSIgnoredPromiseFromCall\n            this._router.navigate(['/error/403.1'], {\n              queryParams: {\n                action: 'Error.LoginAsDiffrentUser',\n                continue: '/auth/loginAs'\n              }\n            });\n            return resolve.next(false);\n          }\n        }\n        // noinspection JSIgnoredPromiseFromCall\n        this._router.navigate(['/auth/login'], { queryParams: {\n            continue: state.url\n          }});\n        return resolve.next(false);\n      });\n    });\n  }\n}\n"]}