b2b.service.js 33.1 KB
/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import { Headers, Http, RequestOptions } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import { of } from 'rxjs';
import { AppConfigService } from '../app-config/app-config.service';
import * as _ from 'lodash';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
import 'rxjs/add/operator/map';
var B2bService = /** @class */ (function () {
    function B2bService(http, appConfigService) {
        this.http = http;
        this.appConfigService = appConfigService;
        this.verifyTokenUrl = '';
        this.downloadTokenUrl = '';
        this._verifyToken = new BehaviorSubject({});
        this.verifyToken = {
            'username': '$username',
            'sessionId': '$sessionId',
            'groupIntegrationNames': ['groupName1', 'groupName2', 'groupName3'],
            'menus': ['menu1', 'menu2'],
            'menuPermissions': [
                { 'menuName': 'menu1', 'permissions': ['add', 'edit', 'delete'] },
                { 'menuName': 'menu2', 'permissions': ['view', 'add', 'edit'] }
            ],
            'attachmentToken': {
                'token': 'DOWNLOADS_AEB496F6DED34FFF93F668412E3CDD38',
                'expire': '2018-09-21 09:00:00'
            }
        };
        this.config = appConfigService.getConfig();
        // console.log('b2b config',this.config);
        this.verifyTokenUrl = _.get(this.config, 'apiServers.portal-backend.verifyToken');
        this.downloadTokenUrl = _.get(this.config, 'apiServers.portal-backend.downloadToken');
    }
    /**
     * @return {?}
     */
    B2bService.prototype.verify = /**
     * @return {?}
     */
    function () {
        var _this = this;
        /** @type {?} */
        var body = {
            'microIntegrationName': _.get(this.config, 'microIntegrationName')
        };
        return this.http.post(this.verifyTokenUrl, body, this.jwt()).map(function (res) {
            // console.log(res.json());
            // console.log(res);
            res = res.json();
            if (+res['resultCode'] === 20000) {
                _this.verifyToken = res['resultData'];
                _this._verifyToken.next(res['resultData']);
            }
            // else if(+res['resultCode'] === 40100){
            //   let __resultData = res['resultData'];
            //   this.checkSession(__resultData.userMessage);
            // }
            // console.log(this.verifyToken);
            return res;
        }).catch(function (error) { return Observable.throw(error.json().error || 'Server error'); }).toPromise();
    };
    /**
     * @return {?}
     */
    B2bService.prototype.subscribeVerifyToken = /**
     * @return {?}
     */
    function () {
        return this._verifyToken.asObservable();
    };
    /**
     * @return {?}
     */
    B2bService.prototype.getVerifyToken = /**
     * @return {?}
     */
    function () {
        return this._verifyToken.getValue();
    };
    /**
     * @param {?} userMessage
     * @return {?}
     */
    B2bService.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'
        }));
    };
    /** รับค่า role ที่มีสิทธิ์ */
    // isCheckGroup(rolePermission) {
    //     console.log("rolePermission",rolePermission);
    //     /** mockup response*/
    //     let verify = [];
    //     this.verifyToken.menuPermissions.forEach(menuPermissions => {
    //         if (menuPermissions.menuName === rolePermission.role) {
    //             verify = menuPermissions.permissions;
    //         }
    //     });
    //     console.log("verify",verify);
    //     const checkArrary = _.intersection(verify, rolePermission.component);
    //     console.log("checkArrary",checkArrary);
    //     if (checkArrary.length !== 0) {
    //         return true;
    //     } else {
    //         return false;
    //     }
    // }
    /**
     * รับค่า role ที่มีสิทธิ์
     * @param {?} route
     * @return {?}
     */
    B2bService.prototype.isCheckGroup = /**
     * รับค่า role ที่มีสิทธิ์
     * @param {?} route
     * @return {?}
     */
    function (route) {
        var e_1, _a;
        /** @type {?} */
        var verify = [];
        try {
            for (var _b = tslib_1.__values(this.verifyToken.menuPermissions), _c = _b.next(); !_c.done; _c = _b.next()) {
                var menuPermissions = _c.value;
                /** @type {?} */
                var url = menuPermissions.url || "";
                /** @type {?} */
                var splitPath = url.split('?');
                splitPath = splitPath.length > 0 ? splitPath[0].split('/') : [];
                /** @type {?} */
                var path = void 0; // ดึง path สุดท้าย
                for (var i = 0; i <= splitPath.length; i++) {
                    // console.log('isCheckGroup splitPath[i]', splitPath[i]);
                    if (splitPath[i] === '#') {
                        path = splitPath[i + 1]; // ดึง path หลัง #
                        break;
                    }
                }
                // console.log("isCheckGroup path", path);
                if (path === route.route) {
                    verify = menuPermissions.permissions;
                }
            }
        }
        catch (e_1_1) { e_1 = { error: e_1_1 }; }
        finally {
            try {
                if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
            }
            finally { if (e_1) throw e_1.error; }
        }
        /** @type {?} */
        var checkArrary = _.intersection(verify, route.component);
        // console.log("isCheckGroup checkArrary", checkArrary);
        if (checkArrary.length !== 0) {
            return true;
        }
        else {
            return false;
        }
    };
    /** รับค่า guard ที่มีสิทธิ์ */
    /**
     * รับค่า guard ที่มีสิทธิ์
     * @param {?} role
     * @return {?}
     */
    B2bService.prototype.isCheckGuard = /**
     * รับค่า guard ที่มีสิทธิ์
     * @param {?} role
     * @return {?}
     */
    function (role) {
        /** *
         * mockup response
          @type {?} */
        var checkArrary = _.intersection(this.verifyToken.menus, [role]);
        // console.log("checkArrary",checkArrary);
        if (checkArrary.length !== 0) {
            return true;
        }
        else {
            return false;
        }
    };
    /**
     * @return {?}
     */
    B2bService.prototype.verifyDemo = /**
     * @return {?}
     */
    function () {
        /** @type {?} */
        var token = sessionStorage.getItem('token');
        // console.log('token', token);
        if (token && token === 'demo') {
            return of({
                'resultCode': '20000',
                'resultDescription': 'Success',
                'resultData': {
                    'b2bToken': '$b2bToken'
                }
            }).toPromise();
        }
        return of({
            'resultCode': '40000',
            'resultDescription': '',
        }).toPromise();
    };
    /**
     * @return {?}
     */
    B2bService.prototype.jwt = /**
     * @return {?}
     */
    function () {
        /** @type {?} */
        var token = sessionStorage.getItem('token');
        if (token) {
            /** @type {?} */
            var headers = new Headers({ 'Authorization': 'Bearer ' + token, 'Content-Type': 'application/json', 'x-token': '1' });
            return new RequestOptions({ headers: headers });
        }
    };
    /**
     * @return {?}
     */
    B2bService.prototype.getAttachmentToken = /**
     * @return {?}
     */
    function () {
        return tslib_1.__awaiter(this, void 0, void 0, function () {
            var now, expireDate, checkDateValid, response, e_2;
            return tslib_1.__generator(this, function (_a) {
                switch (_a.label) {
                    case 0:
                        now = new Date();
                        expireDate = new Date(this.verifyToken.attachmentToken.expire);
                        checkDateValid = now <= expireDate;
                        if (!checkDateValid) return [3 /*break*/, 1];
                        return [2 /*return*/, this.verifyToken.attachmentToken.token];
                    case 1:
                        _a.trys.push([1, 3, , 4]);
                        return [4 /*yield*/, this.http.post(this.downloadTokenUrl, {}, this.jwt()).map(function (res) {
                                return res.json();
                            }).catch(function (error) { return Observable.throw(error.json().error || 'Server error'); }).toPromise()];
                    case 2:
                        response = _a.sent();
                        // console.log('response ',response);
                        if (+response['resultCode'] === 20000) {
                            this.verifyToken.attachmentToken = response['resultData'];
                            return [2 /*return*/, response['resultData'].token];
                        }
                        // else if(+response['resultCode'] === 40100){
                        //   let __resultData = response['resultData'];
                        //   this.checkSession(__resultData.userMessage);
                        //   return '';
                        // }
                        else {
                            return [2 /*return*/, ''];
                        }
                        return [3 /*break*/, 4];
                    case 3:
                        e_2 = _a.sent();
                        console.log('error ', e_2);
                        return [2 /*return*/, ''];
                    case 4: return [2 /*return*/];
                }
            });
        });
    };
    /** รับค่า guard ที่มีสิทธิ์ */
    /**
     * รับค่า guard ที่มีสิทธิ์
     * @param {?} route
     * @return {?}
     */
    B2bService.prototype.isCheckGuardRoutePath = /**
     * รับค่า guard ที่มีสิทธิ์
     * @param {?} route
     * @return {?}
     */
    function (route) {
        var e_3, _a;
        try {
            // console.log("route",route);
            // console.log("this.verifyToken",this.verifyToken);
            for (var _b = tslib_1.__values(this.verifyToken.menuPermissions), _c = _b.next(); !_c.done; _c = _b.next()) {
                var menuPermissions = _c.value;
                /** @type {?} */
                var url = menuPermissions.url || "";
                /** @type {?} */
                var splitPath = url.split('?');
                splitPath = splitPath.length > 0 ? splitPath[0].split('/') : [];
                /** @type {?} */
                var path = void 0; // ดึง path สุดท้าย
                for (var i = 0; i <= splitPath.length; i++) {
                    // console.log('splitPath[i]', splitPath[i]);
                    if (splitPath[i] === '#') {
                        path = splitPath[i + 1]; // ดึง path หลัง #
                        break;
                    }
                }
                // console.log("path",path);
                if (path === route) {
                    return true;
                }
            }
        }
        catch (e_3_1) { e_3 = { error: e_3_1 }; }
        finally {
            try {
                if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
            }
            finally { if (e_3) throw e_3.error; }
        }
        return false;
    };
    B2bService.decorators = [
        { type: Injectable }
    ];
    /** @nocollapse */
    B2bService.ctorParameters = function () { return [
        { type: Http },
        { type: AppConfigService }
    ]; };
    return B2bService;
}());
export { B2bService };
if (false) {
    /** @type {?} */
    B2bService.prototype.verifyTokenUrl;
    /** @type {?} */
    B2bService.prototype.downloadTokenUrl;
    /** @type {?} */
    B2bService.prototype._verifyToken;
    /** @type {?} */
    B2bService.prototype.config;
    /** @type {?} */
    B2bService.prototype.verifyToken;
    /** @type {?} */
    B2bService.prototype.http;
    /** @type {?} */
    B2bService.prototype.appConfigService;
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"b2b.service.js","sourceRoot":"ng://soc-app-library/","sources":["lib/_services/b2b.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Headers, Http, RequestOptions, Response } from '@angular/http';\nimport { Observable } from 'rxjs/Observable';\nimport { of } from 'rxjs';\nimport { AppConfigService } from '../app-config/app-config.service';\nimport * as _ from 'lodash';\nimport { BehaviorSubject } from 'rxjs/BehaviorSubject';\nimport 'rxjs/add/operator/map';\n\n@Injectable()\nexport class B2bService {\n    verifyTokenUrl = '';\n    downloadTokenUrl = '';\n    _verifyToken: any = new BehaviorSubject({});\n    config: any;\n    verifyToken: any = {\n        'username': '$username',\n        'sessionId': '$sessionId',\n        'groupIntegrationNames': ['groupName1', 'groupName2', 'groupName3'],\n        'menus': ['menu1', 'menu2'],\n        'menuPermissions': [\n            { 'menuName': 'menu1', 'permissions': ['add', 'edit', 'delete'] },\n            { 'menuName': 'menu2', 'permissions': ['view', 'add', 'edit'] }\n        ],\n        'attachmentToken': {\n            'token': 'DOWNLOADS_AEB496F6DED34FFF93F668412E3CDD38',\n            'expire': '2018-09-21 09:00:00'\n        }\n    };\n    constructor(private http: Http,\n                private appConfigService: AppConfigService,\n    ) {\n        this.config = appConfigService.getConfig();\n        // console.log('b2b config',this.config);\n        this.verifyTokenUrl = _.get(this.config, 'apiServers.portal-backend.verifyToken');\n        this.downloadTokenUrl = _.get(this.config, 'apiServers.portal-backend.downloadToken');\n    }\n    verify() {\n        // return this.http.get(this.config.apiVerifyToken + this.url, this.jwt()).toPromise();\n        const body = {\n            'microIntegrationName': _.get(this.config, 'microIntegrationName')\n        };\n        return this.http.post(this.verifyTokenUrl, body, this.jwt()).map((res: Response) => {\n            // console.log(res.json());\n            // console.log(res);\n            res = res.json();\n            if (+res['resultCode'] === 20000) {\n                this.verifyToken = res['resultData'];\n                this._verifyToken.next(res['resultData']);\n            }\n            // else if(+res['resultCode'] === 40100){\n            //   let __resultData = res['resultData'];\n            //   this.checkSession(__resultData.userMessage);\n            // }\n            // console.log(this.verifyToken);\n            return res;\n        }).catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n    }\n\n    public subscribeVerifyToken() {\n        return this._verifyToken.asObservable();\n    }\n\n\n    public getVerifyToken() {\n        return this._verifyToken.getValue();\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\n    /** รับค่า role ที่มีสิทธิ์ */\n    // isCheckGroup(rolePermission) {\n    //     console.log(\"rolePermission\",rolePermission);\n    //     /** mockup response*/\n    //     let verify = [];\n    //     this.verifyToken.menuPermissions.forEach(menuPermissions => {\n    //         if (menuPermissions.menuName === rolePermission.role) {\n    //             verify = menuPermissions.permissions;\n    //         }\n    //     });\n    //     console.log(\"verify\",verify);\n\n    //     const checkArrary = _.intersection(verify, rolePermission.component);\n    //     console.log(\"checkArrary\",checkArrary);\n    //     if (checkArrary.length !== 0) {\n    //         return true;\n    //     } else {\n    //         return false;\n    //     }\n    // }\n\n    isCheckGroup(route) {\n        // console.log(\"isCheckGroup route\", route);\n        // console.log(\"isCheckGroup this.verifyToken\", this.verifyToken);\n        let verify = [];\n        for (let menuPermissions of this.verifyToken.menuPermissions) {\n            // console.log(\"isCheckGroup menuPermissions\", menuPermissions);\n            let url = menuPermissions.url || \"\";\n            let splitPath = url.split('?');\n            splitPath = splitPath.length > 0 ? splitPath[0].split('/') : []; // split path\n            let path; // ดึง path สุดท้าย\n            for (let i = 0; i <= splitPath.length; i++) {\n                // console.log('isCheckGroup splitPath[i]', splitPath[i]);\n                if (splitPath[i] === '#') {\n                    path = splitPath[i + 1]; // ดึง path หลัง #\n                    break;\n                }\n            }\n            // console.log(\"isCheckGroup path\", path);\n            if (path === route.route) {\n                verify = menuPermissions.permissions;\n            }\n        }\n        // console.log(\"isCheckGroup verify\", verify);\n\n        const checkArrary = _.intersection(verify, route.component);\n        // console.log(\"isCheckGroup checkArrary\", checkArrary);\n        if (checkArrary.length !== 0) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    /** รับค่า guard ที่มีสิทธิ์ */\n    isCheckGuard(role) {\n        // console.log(\"role\",role);\n        /** mockup response*/\n\n        // console.log(this.verifyToken.menus);\n        const checkArrary = _.intersection(this.verifyToken.menus, [role]);\n        // console.log(\"checkArrary\",checkArrary);\n        if (checkArrary.length !== 0) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    verifyDemo() {\n        const token = sessionStorage.getItem('token');\n        // console.log('token', token);\n        if (token && token === 'demo') {\n            return of({\n                'resultCode': '20000',\n                'resultDescription': 'Success',\n                'resultData': {\n                    'b2bToken': '$b2bToken'\n                }\n            }).toPromise();\n        }\n        return of({\n            'resultCode': '40000',\n            'resultDescription': '',\n        }).toPromise();\n    }\n\n    private jwt() {\n        // create authorization header with jwt token\n        const token = sessionStorage.getItem('token');\n\n        if (token) {\n            const headers = new Headers({ 'Authorization': 'Bearer ' + token , 'Content-Type': 'application/json', 'x-token': '1' });\n            return new RequestOptions({ headers: headers });\n        }\n    }\n\n    async getAttachmentToken(){\n\n        let now = new Date();\n        let expireDate = new Date(this.verifyToken.attachmentToken.expire);\n        // console.log(\"now\",now);\n        // console.log(\"expireDate\",expireDate);\n        let checkDateValid = now <= expireDate;\n        // console.log(\"checkDateValid\",checkDateValid);\n        if(checkDateValid){\n            return this.verifyToken.attachmentToken.token;\n        }else{\n            try{\n                let response = await this.http.post(this.downloadTokenUrl, {}, this.jwt()).map((res: Response) => {\n                    return res.json();\n                }).catch((error: any) => Observable.throw(error.json().error || 'Server error')).toPromise();\n                // console.log('response ',response);\n                if (+response['resultCode'] === 20000) {\n                    this.verifyToken.attachmentToken = response['resultData'];\n                    return response['resultData'].token;\n                }\n                // else if(+response['resultCode'] === 40100){\n                //   let __resultData = response['resultData'];\n                //   this.checkSession(__resultData.userMessage);\n                //   return '';\n                // }\n                else{\n                    return '';\n                }\n            }catch (e){\n                console.log('error ',e);\n                return '';\n            }\n        }\n    }\n    /** รับค่า guard ที่มีสิทธิ์ */\n    isCheckGuardRoutePath(route) {\n        // console.log(\"route\",route);\n        // console.log(\"this.verifyToken\",this.verifyToken);\n        for(let menuPermissions of this.verifyToken.menuPermissions){\n            // console.log(\"menuPermissions\",menuPermissions);\n            let url = menuPermissions.url || \"\";\n            let splitPath = url.split('?');\n            splitPath = splitPath.length > 0 ? splitPath[0].split('/') : []; // split path\n            let path; // ดึง path สุดท้าย\n            for (let i = 0; i <= splitPath.length; i++) {\n                // console.log('splitPath[i]', splitPath[i]);\n                if (splitPath[i] === '#') {\n                    path = splitPath[i+1]; // ดึง path หลัง #\n                    break;\n                }\n            }\n            // console.log(\"path\",path);\n            if (path === route) {\n                return true;\n            }\n        }\n        return false;\n    }\n}\n"]}