/** * @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":"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","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"]}