permission.guard.js 14.4 KB
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import { Router, ActivatedRoute } from '@angular/router';
import { AppConfigService } from '../app-config/app-config.service';
import { B2bService } from '../_services/b2b.service';
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
import * as i2 from "../_services/b2b.service";
import * as i3 from "../app-config/app-config.service";
export class PermissionGuard {
    /**
     * @param {?} router
     * @param {?} route
     * @param {?} dataservice
     * @param {?} appConfigService
     */
    constructor(router, route, dataservice, appConfigService) {
        this.router = router;
        this.route = route;
        this.dataservice = dataservice;
        this.appConfigService = appConfigService;
        this.config = appConfigService.getConfig();
    }
    /**
     * @param {?} next
     * @param {?} state
     * @return {?}
     */
    canActivate(next, state) {
        console.log(next.queryParams);
        /** @type {?} */
        let params = next.queryParams;
        if (params["token"]) {
            sessionStorage.setItem('token', params["token"]);
            // token = params.token
            return this.getPermission(next);
        }
        else if (params["token"] === '') {
            return false;
        }
        else {
            /** @type {?} */
            const token = sessionStorage.getItem('token');
            if (token) {
                return this.getPermission(next);
            }
            else {
                return false;
            }
        }
        // const path = this.getUrlPath(next);
        // let configData = null;
        // configData = this.getConfigByUrl(path);
        // if (configData) {
        //     if (this.dataservice.isCheckGuard(configData.role)) {
        //         return true;
        //     }
        //     else { return false; }
        // } else { return true; }
    }
    /**
     * @param {?} next
     * @return {?}
     */
    getPermission(next) {
        return tslib_1.__awaiter(this, void 0, void 0, function* () {
            /** @type {?} */
            let verifyToken = yield this.dataservice.verify();
            console.log("verifyToken", verifyToken, verifyToken['resultCode'] === '40100');
            if (verifyToken['resultCode'] == '20000') {
                /** @type {?} */
                let path = this.getUrlPath(next);
                /** @type {?} */
                let configData = null;
                configData = this.getConfigByUrl(path);
                console.log('configData ', configData);
                if (configData) {
                    if (this.dataservice.isCheckGuardRoutePath(configData.routingPath) || configData.routingPath === '') {
                        console.log('isCheckGuardRoutePath ', true);
                        return true;
                    }
                    else
                        return false;
                }
                else
                    return true;
            }
            else if (verifyToken['resultCode'] === '40100') {
                /** @type {?} */
                let __resultData = verifyToken['resultData'];
                this.checkSession(__resultData.userMessage);
                return false;
            }
            else {
                return false;
            }
        });
    }
    /**
     * @param {?} userMessage
     * @return {?}
     */
    checkSession(userMessage) {
        console.log('checkSession');
        /** @type {?} */
        const token = sessionStorage.getItem('token');
        window.parent.postMessage(JSON.stringify({
            command: "checkSession",
            message: token,
            userMessage: userMessage || 'Unknow'
        }), '*');
        console.log('checkSession', JSON.stringify({
            command: "checkSession",
            message: token,
            userMessage: userMessage || 'Unknow'
        }));
    }
    /**
     * @param {?} url
     * @return {?}
     */
    getUrlPath(url) {
        console.log('path ', url.routeConfig.path);
        return url.routeConfig.path;
    }
    /**
     * @param {?} path
     * @return {?}
     */
    getConfigByUrl(path) {
        /** @type {?} */
        const permissionConfig = this.config.permission;
        /** @type {?} */
        let permissionData = null;
        for (let data of permissionConfig) {
            if (path == data.routingPath) {
                permissionData = data;
                break;
            }
        }
        console.log('Data ', permissionData);
        return permissionData;
    }
}
PermissionGuard.decorators = [
    { type: Injectable, args: [{
                providedIn: 'root'
            },] }
];
/** @nocollapse */
PermissionGuard.ctorParameters = () => [
    { type: Router },
    { type: ActivatedRoute },
    { type: B2bService },
    { type: AppConfigService }
];
/** @nocollapse */ PermissionGuard.ngInjectableDef = i0.defineInjectable({ factory: function PermissionGuard_Factory() { return new PermissionGuard(i0.inject(i1.Router), i0.inject(i1.ActivatedRoute), i0.inject(i2.B2bService), i0.inject(i3.AppConfigService)); }, token: PermissionGuard, providedIn: "root" });
if (false) {
    /** @type {?} */
    PermissionGuard.prototype.config;
    /** @type {?} */
    PermissionGuard.prototype.router;
    /** @type {?} */
    PermissionGuard.prototype.route;
    /** @type {?} */
    PermissionGuard.prototype.dataservice;
    /** @type {?} */
    PermissionGuard.prototype.appConfigService;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permission.guard.js","sourceRoot":"ng://soc-app-library/","sources":["lib/_guard/permission.guard.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,eAAe,CAAC;AACzC,OAAO,EACH,MAAM,EAEN,cAAc,EAGjB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAC,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAC,UAAU,EAAC,MAAM,0BAA0B,CAAC;;;;;AAIpD,MAAM;;;;;;;IAGF,YAAmB,MAAc,EAAU,KAAqB,EAAU,WAAuB,EAAU,gBAAkC;QAA1H,WAAM,GAAN,MAAM,CAAQ;QAAU,UAAK,GAAL,KAAK,CAAgB;QAAU,gBAAW,GAAX,WAAW,CAAY;QAAU,qBAAgB,GAAhB,gBAAgB,CAAkB;QACzI,IAAI,CAAC,MAAM,GAAG,gBAAgB,CAAC,SAAS,EAAE,CAAC;KAC9C;;;;;;IAED,WAAW,CAAC,IAA4B,EAC5B,KAA0B;QAClC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;;QAC9B,IAAI,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC;QAC9B,IAAI,MAAM,WAAQ;YACd,cAAc,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,UAAO,CAAC;;YAE9C,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SACnC;aAAM,IAAI,MAAM,cAAW,EAAE,EAAE;YAC5B,OAAO,KAAK,CAAC;SAChB;aAAM;;YACH,MAAM,KAAK,GAAG,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAC9C,IAAI,KAAK,EAAE;gBACP,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;aACnC;iBAAM;gBACH,OAAO,KAAK,CAAC;aAChB;SACJ;;;;;;;;;;KAUJ;;;;;IAEK,aAAa,CAAC,IAAI;;;YAEpB,IAAI,WAAW,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YAClD,OAAO,CAAC,GAAG,CAAC,aAAa,EAAC,WAAW,EAAE,WAAW,CAAC,YAAY,CAAC,KAAK,OAAO,CAAC,CAAC;YAC9E,IAAI,WAAW,CAAC,YAAY,CAAC,IAAI,OAAO,EAAE;;gBAEtC,IAAI,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;;gBACjC,IAAI,UAAU,GAAG,IAAI,CAAC;gBACtB,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;gBACvC,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;gBACvC,IAAI,UAAU,EAAE;oBACZ,IAAI,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,UAAU,CAAC,WAAW,KAAK,EAAE,EAAC;wBAChG,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,IAAI,CAAC,CAAC;wBAC5C,OAAO,IAAI,CAAC;qBACf;;wBACI,OAAO,KAAK,CAAC;iBACrB;;oBAAM,OAAO,IAAI,CAAC;aACtB;iBAAK,IAAG,WAAW,CAAC,YAAY,CAAC,KAAK,OAAO,EAAC;;gBAC7C,IAAI,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC,CAAC;gBAC7C,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;gBAC5C,OAAO,KAAK,CAAC;aACd;iBACG;gBAEF,OAAO,KAAK,CAAC;aACd;;KACJ;;;;;IAED,YAAY,CAAC,WAAW;QACtB,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;;QAC5B,MAAM,KAAK,GAAG,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC9C,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC;YACrC,OAAO,EAAC,cAAc;YACtB,OAAO,EAAE,KAAK;YACd,WAAW,EAAE,WAAW,IAAI,QAAQ;SACvC,CAAC,EAAE,GAAG,CAAC,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,cAAc,EAAC,IAAI,CAAC,SAAS,CAAC;YACtC,OAAO,EAAC,cAAc;YACtB,OAAO,EAAE,KAAK;YACd,WAAW,EAAE,WAAW,IAAI,QAAQ;SACvC,CAAC,CAAC,CAAC;KACL;;;;;IAED,UAAU,CAAC,GAAG;QACV,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC3C,OAAO,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC;KAC/B;;;;;IAED,cAAc,CAAC,IAAI;;QACf,MAAM,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;;QAChD,IAAI,cAAc,GAAG,IAAI,CAAC;QAC1B,KAAI,IAAI,IAAI,IAAI,gBAAgB,EAAC;YAC7B,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,EAAE;gBAC1B,cAAc,GAAG,IAAI,CAAC;gBACtB,MAAM;aACT;SACJ;QACD,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;QACrC,OAAO,cAAc,CAAC;KACzB;;;YAlGJ,UAAU,SAAC;gBACR,UAAU,EAAE,MAAM;aACrB;;;;YAXG,MAAM;YAEN,cAAc;YAMV,UAAU;YADV,gBAAgB","sourcesContent":["import {Injectable} from '@angular/core';\nimport {\n    Router,\n    CanActivate,\n    ActivatedRoute,\n    ActivatedRouteSnapshot,\n    RouterStateSnapshot\n} from '@angular/router';\nimport {Observable} from 'rxjs';\nimport {AppConfigService} from '../app-config/app-config.service';\nimport {B2bService} from '../_services/b2b.service';\n@Injectable({\n    providedIn: 'root'\n})\nexport class PermissionGuard implements CanActivate {\n    config: any;\n\n    constructor(public router: Router, private route: ActivatedRoute, private dataservice: B2bService, private appConfigService: AppConfigService) {\n        this.config = appConfigService.getConfig();\n    }\n\n    canActivate(next: ActivatedRouteSnapshot,\n                state: RouterStateSnapshot): any {\n        console.log(next.queryParams);\n        let params = next.queryParams;\n        if (params.token) {\n            sessionStorage.setItem('token', params.token);\n            // token = params.token\n            return this.getPermission(next);\n        } else if (params.token === '') {\n            return false;\n        } else {\n            const token = sessionStorage.getItem('token');\n            if (token) {\n                return this.getPermission(next);\n            } else {\n                return false;\n            }\n        }\n        // const path = this.getUrlPath(next);\n        // let configData = null;\n        // configData = this.getConfigByUrl(path);\n        // if (configData) {\n        //     if (this.dataservice.isCheckGuard(configData.role)) {\n        //         return true;\n        //     }\n        //     else { return false; }\n        // } else { return true; }\n    }\n\n    async getPermission(next) {\n\n        let verifyToken = await this.dataservice.verify();\n        console.log(\"verifyToken\",verifyToken ,verifyToken['resultCode'] === '40100');\n        if (verifyToken['resultCode'] == '20000') {\n            // this.store.token = {token: verifyToken['resultData']};\n            let path = this.getUrlPath(next);\n            let configData = null;\n            configData = this.getConfigByUrl(path);\n            console.log('configData ', configData);\n            if (configData) {\n                if (this.dataservice.isCheckGuardRoutePath(configData.routingPath) || configData.routingPath === ''){\n                    console.log('isCheckGuardRoutePath ', true);\n                    return true;\n                }\n                else return false;\n            } else return true;\n        }else if(verifyToken['resultCode'] === '40100'){\n          let __resultData = verifyToken['resultData'];\n          this.checkSession(__resultData.userMessage);\n          return false;\n        }\n        else{\n\n          return false;\n        }\n    }\n\n    checkSession(userMessage){\n      console.log('checkSession');\n      const token = sessionStorage.getItem('token');\n      window.parent.postMessage(JSON.stringify({\n          command:\"checkSession\",\n          message: token,\n          userMessage: userMessage || 'Unknow'\n      }), '*');\n      console.log('checkSession',JSON.stringify({\n          command:\"checkSession\",\n          message: token,\n          userMessage: userMessage || 'Unknow'\n      }));\n    }\n\n    getUrlPath(url) {\n        console.log('path ', url.routeConfig.path);\n        return url.routeConfig.path;\n    }\n\n    getConfigByUrl(path) {\n        const permissionConfig = this.config.permission;\n        let permissionData = null;\n        for(let data of permissionConfig){\n            if (path == data.routingPath) {\n                permissionData = data;\n                break;\n            }\n        }\n        console.log('Data ', permissionData);\n        return permissionData;\n    }\n\n\n}\n"]}