permission.guard.js 16.2 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";
var PermissionGuard = /** @class */ (function () {
    function PermissionGuard(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 {?}
     */
    PermissionGuard.prototype.canActivate = /**
     * @param {?} next
     * @param {?} state
     * @return {?}
     */
    function (next, state) {
        console.log(next.queryParams);
        /** @type {?} */
        var 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 {?} */
            var 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 {?}
     */
    PermissionGuard.prototype.getPermission = /**
     * @param {?} next
     * @return {?}
     */
    function (next) {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var verifyToken, path, configData, __resultData;
            return tslib_1.__generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this.dataservice.verify()];
                    case 1:
                        verifyToken = _a.sent();
                        console.log("verifyToken", verifyToken, verifyToken['resultCode'] === '40100');
                        if (verifyToken['resultCode'] == '20000') {
                            path = this.getUrlPath(next);
                            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 [2 /*return*/, true];
                                }
                                else
                                    return [2 /*return*/, false];
                            }
                            else
                                return [2 /*return*/, true];
                        }
                        else if (verifyToken['resultCode'] === '40100') {
                            __resultData = verifyToken['resultData'];
                            this.checkSession(__resultData.userMessage);
                            return [2 /*return*/, false];
                        }
                        else {
                            return [2 /*return*/, false];
                        }
                        return [2 /*return*/];
                }
            });
        });
    };
    /**
     * @param {?} userMessage
     * @return {?}
     */
    PermissionGuard.prototype.checkSession = /**
     * @param {?} userMessage
     * @return {?}
     */
    function (userMessage) {
        console.log('checkSession');
        /** @type {?} */
        var 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 {?}
     */
    PermissionGuard.prototype.getUrlPath = /**
     * @param {?} url
     * @return {?}
     */
    function (url) {
        console.log('path ', url.routeConfig.path);
        return url.routeConfig.path;
    };
    /**
     * @param {?} path
     * @return {?}
     */
    PermissionGuard.prototype.getConfigByUrl = /**
     * @param {?} path
     * @return {?}
     */
    function (path) {
        var e_1, _a;
        /** @type {?} */
        var permissionConfig = this.config.permission;
        /** @type {?} */
        var permissionData = null;
        try {
            for (var permissionConfig_1 = tslib_1.__values(permissionConfig), permissionConfig_1_1 = permissionConfig_1.next(); !permissionConfig_1_1.done; permissionConfig_1_1 = permissionConfig_1.next()) {
                var data = permissionConfig_1_1.value;
                if (path == data.routingPath) {
                    permissionData = data;
                    break;
                }
            }
        }
        catch (e_1_1) { e_1 = { error: e_1_1 }; }
        finally {
            try {
                if (permissionConfig_1_1 && !permissionConfig_1_1.done && (_a = permissionConfig_1.return)) _a.call(permissionConfig_1);
            }
            finally { if (e_1) throw e_1.error; }
        }
        console.log('Data ', permissionData);
        return permissionData;
    };
    PermissionGuard.decorators = [
        { type: Injectable, args: [{
                    providedIn: 'root'
                },] }
    ];
    /** @nocollapse */
    PermissionGuard.ctorParameters = function () { return [
        { 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" });
    return PermissionGuard;
}());
export { PermissionGuard };
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;;;;;;IAOhD,yBAAmB,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,qCAAW;;;;;IAAX,UAAY,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,IAAM,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,uCAAa;;;;IAAnB,UAAoB,IAAI;;;;;4BAEF,qBAAM,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,EAAA;;wBAA7C,WAAW,GAAG,SAA+B;wBACjD,OAAO,CAAC,GAAG,CAAC,aAAa,EAAC,WAAW,EAAE,WAAW,CAAC,YAAY,CAAC,KAAK,OAAO,CAAC,CAAC;wBAC9E,IAAI,WAAW,CAAC,YAAY,CAAC,IAAI,OAAO,EAAE;4BAElC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;4BAC7B,UAAU,GAAG,IAAI,CAAC;4BACtB,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;4BACvC,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;4BACvC,IAAI,UAAU,EAAE;gCACZ,IAAI,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,UAAU,CAAC,WAAW,KAAK,EAAE,EAAC;oCAChG,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,IAAI,CAAC,CAAC;oCAC5C,sBAAO,IAAI,EAAC;iCACf;;oCACI,sBAAO,KAAK,EAAC;6BACrB;;gCAAM,sBAAO,IAAI,EAAC;yBACtB;6BAAK,IAAG,WAAW,CAAC,YAAY,CAAC,KAAK,OAAO,EAAC;4BACzC,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC,CAAC;4BAC7C,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;4BAC5C,sBAAO,KAAK,EAAC;yBACd;6BACG;4BAEF,sBAAO,KAAK,EAAC;yBACd;;;;;KACJ;;;;;IAED,sCAAY;;;;IAAZ,UAAa,WAAW;QACtB,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;;QAC5B,IAAM,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,oCAAU;;;;IAAV,UAAW,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,wCAAc;;;;IAAd,UAAe,IAAI;;;QACf,IAAM,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;;QAChD,IAAI,cAAc,GAAG,IAAI,CAAC;;YAC1B,KAAgB,IAAA,qBAAA,iBAAA,gBAAgB,CAAA,kDAAA,gFAAC;gBAA7B,IAAI,IAAI,6BAAA;gBACR,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,EAAE;oBAC1B,cAAc,GAAG,IAAI,CAAC;oBACtB,MAAM;iBACT;aACJ;;;;;;;;;QACD,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;QACrC,OAAO,cAAc,CAAC;KACzB;;gBAlGJ,UAAU,SAAC;oBACR,UAAU,EAAE,MAAM;iBACrB;;;;gBAXG,MAAM;gBAEN,cAAc;gBAMV,UAAU;gBADV,gBAAgB;;;0BATxB;;SAca,eAAe","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"]}