Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

vipera-npm-registry / motif-web-admin-core   js

Repository URL to install this package:

Version: 0.3.1 

/ esm2015 / lib / sections / OAuth2 / components / oauth2-section.component.js

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
import { Component, ViewChild, Input } from '@angular/core';
import { PluginView } from 'web-console-core';
import { NGXLogger } from 'web-console-core';
import { GridComponent } from '@progress/kendo-angular-grid';
import { MotifQuerySort, MotifQueryResults } from 'web-console-core';
import { Oauth2Service } from '@wa-motif-open-api/oauth2-service';
import { HttpParams } from '@angular/common/http';
import * as _ from 'lodash';
import { DomainSelectorComboBoxComponent } from '../../../components/UI/selectors/domain-selector-combobox-component';
import { WCNotificationCenter, NotificationType } from 'web-console-ui-kit';
import { WCSubscriptionHandler } from '../../../components/Commons/wc-subscription-handler';
/** @type {?} */
const LOG_TAG = "[OAuth2Section]";
let OAuth2SectionComponent = class OAuth2SectionComponent {
    /**
     * @param {?} logger
     * @param {?} oauth2Service
     * @param {?} notificationCenter
     */
    constructor(logger, oauth2Service, notificationCenter) {
        this.logger = logger;
        this.oauth2Service = oauth2Service;
        this.notificationCenter = notificationCenter;
        //Data
        this.refreshTokenList = [];
        this.accessTokenList = [];
        //Grid Options
        this.sort = [];
        this.groups = [];
        this.type = 'numeric';
        this.pageSize = 15;
        this.skip = 0;
        this.currentPage = 1;
        this.totalPages = 0;
        this.totalRecords = 0;
        this.isFieldSortable = false;
        this._subHandler = new WCSubscriptionHandler();
        this.logger.debug(LOG_TAG, 'Opening...');
    }
    /**
     * @return {?}
     */
    ngOnInit() {
        this.logger.debug(LOG_TAG, 'Initializing...');
    }
    /**
     * @return {?}
     */
    ngOnDestroy() {
        this.logger.debug(LOG_TAG, 'ngOnDestroy ');
        this.freeMem();
    }
    /**
     * @return {?}
     */
    freeMem() {
        this.refreshTokenList = null;
        this.accessTokenList = null;
        this.sort = null;
        this.groups = null;
        this.gridView = null;
        this._subHandler.unsubscribe();
        this._subHandler = null;
    }
    /**
     * @param {?} __0
     * @return {?}
     */
    pageChange({ skip, take }) {
        this.logger.debug(LOG_TAG, 'pageChange skip=', skip, ' take=', take);
        this.skip = skip;
        this.pageSize = take;
        /** @type {?} */
        const newPageIndex = this.calculatePageIndex(skip, take);
        this.loadData(this.domainSelector.selectedDomain.name, newPageIndex, this.pageSize);
    }
    /**
     * @private
     * @param {?} domain
     * @param {?} pageIndex
     * @param {?} pageSize
     * @return {?}
     */
    loadData(domain, pageIndex, pageSize) {
        if (this.domainSelector.selectedDomain) {
            this.logger.debug(LOG_TAG, 'loadData pageIndex=', pageIndex, ' pageSize=', pageSize);
            this.loading = true;
            /** @type {?} */
            const sort = this.buildQuerySort();
            this._subHandler.add(this.oauth2Service.getRefreshTokenList(this.domainSelector.selectedDomain.name, pageIndex, pageSize, sort.encode(new HttpParams()).get('sort'), 'response', false).subscribe((/**
             * @param {?} response
             * @return {?}
             */
            (response) => {
                /** @type {?} */
                const results = MotifQueryResults.fromHttpResponse(response);
                this.refreshTokenList = _.forEach(results.data, (/**
                 * @param {?} element
                 * @return {?}
                 */
                function (element) {
                    element.createTime = new Date(element.createTime);
                    element.expiryTime = new Date(element.expiryTime);
                }));
                this.totalPages = results.totalPages;
                this.totalRecords = results.totalRecords;
                this.currentPage = results.pageIndex;
                this.gridView = {
                    data: this.refreshTokenList,
                    total: results.totalRecords
                };
                this.currentPage = results.pageIndex;
                this.loading = false;
            }), (/**
             * @param {?} error
             * @return {?}
             */
            error => {
                this.logger.error(LOG_TAG, 'getRefreshTokenList failed: ', error);
                this.loading = false;
            })));
        }
    }
    /**
     * @private
     * @param {?} skip
     * @param {?} take
     * @return {?}
     */
    calculatePageIndex(skip, take) {
        return (skip / take) + 1;
    }
    /**
     * @private
     * @return {?}
     */
    buildQuerySort() {
        this.logger.debug(LOG_TAG, 'buildQuerySort: ', this.sort);
        /** @type {?} */
        let querySort = new MotifQuerySort();
        if (this.sort) {
            for (let i = 0; i < this.sort.length; i++) {
                /** @type {?} */
                let sortInfo = this.sort[i];
                if (sortInfo.dir && sortInfo.dir === 'asc') {
                    querySort.orderAscendingBy(sortInfo.field);
                }
                else if (sortInfo.dir && sortInfo.dir === 'desc') {
                    querySort.orderDescendingBy(sortInfo.field);
                }
            }
        }
        return querySort;
    }
    /**
     * Reload the list of users for the selected domain
     * @return {?}
     */
    refreshData() {
        this.logger.debug(LOG_TAG, 'refreshData domain=', this.domainSelector.selectedDomain.name, ' currentPage=', this.currentPage, ' pageSize=', this.pageSize);
        this.loadData(this.domainSelector.selectedDomain.name, this.currentPage, this.pageSize);
    }
    /**
     * Set the selcted domain
     * @param {?} domain
     * @return {?}
     */
    set selectedDomain(domain) {
        if (this.domainSelector.selectedDomain) {
            this.logger.debug(LOG_TAG, 'selectedDomain domain=', this.domainSelector.selectedDomain);
            this.loadData(this.domainSelector.selectedDomain.name, 1, this.pageSize);
        }
        else {
            this.gridView = undefined;
        }
    }
    /**
     * @param {?} sort
     * @return {?}
     */
    sortChange(sort) {
        this.logger.debug(LOG_TAG, 'sortChange sort=', this.sort);
        this.sort = sort;
        this.refreshData();
    }
    /**
     * @return {?}
     */
    doSort() {
        //this.gridView = process(orderBy(this.usersList, this.sort), { group: this.groups });
    }
    /**
     * @param {?} dataItem
     * @return {?}
     */
    onDeleteOKPressed(dataItem) {
        this.logger.debug(LOG_TAG, 'onDeleteOKPressed token=', dataItem.token);
        this._subHandler.add(this.oauth2Service.revokeRefreshToken(dataItem.token).subscribe((/**
         * @param {?} value
         * @return {?}
         */
        value => {
            this.refreshData();
            this.notificationCenter.post({
                name: 'RevokeRefreshTokenSuccess',
                title: 'Revoke Refresh Token',
                message: 'The Refresh Token has been successfully revoked',
                type: NotificationType.Success
            });
        }), (/**
         * @param {?} error
         * @return {?}
         */
        (error) => {
            this.notificationCenter.post({
                name: 'RevokeRefreshTokenError',
                title: 'Revoke Refresh Token',
                message: 'Refresh token could not be removed.',
                type: NotificationType.Error,
                error: error,
                closable: true
            });
        })));
    }
    /**
     * @param {?} dataItem
     * @return {?}
     */
    onDeleteCancelPressed(dataItem) {
        this.logger.debug(LOG_TAG, 'onDeleteCancelPressed');
    }
    /**
     * @param {?} domain
     * @return {?}
     */
    onDomainSelected(domain) {
        if (domain) {
            this.loadData(domain.name, 1, this.pageSize);
        }
        else {
            this.gridView = undefined;
        }
    }
    /**
     * @return {?}
     */
    onRefreshClicked() {
        this.refreshData();
    }
    /**
     * @return {?}
     */
    get canRefresh() {
        return (this.domainSelector.selectedDomain != null);
    }
};
OAuth2SectionComponent.decorators = [
    { type: Component, args: [{
                selector: 'wa-oauth2-section',
                template: "<wc-dashboard-header [title]=\"'OAuth2 Management'\"></wc-dashboard-header>\n<wc-loading-overlay [visible]='loading'></wc-loading-overlay>\n\n<div class=\"row spread\">\n    <div class=\"flex-toolbar\" style=\"display:flex;align-items: center;\">\n        <div style=\"margin-right:10px;width:60%;max-width: 400px;min-width: 250px;\">\n            <label>Domain</label>\n            <wc-domain-selector-combobox #domainSelector (domainSelected)=\"onDomainSelected($event)\" (selectionCancelled)=\"onDomainSelected(null)\"></wc-domain-selector-combobox>\n        </div>\n    </div>\n\n    <div class=\"flex-cmd\">\n        <kendo-buttongroup look=\"flat\">\n          <button\n            kendoButton\n            [toggleable]=\"false\"\n            [icon]=\"'refresh'\"\n            (click)=\"onRefreshClicked()\"\n            [disabled]=\"!canRefresh\"\n          >\n            Refresh\n          </button>\n        </kendo-buttongroup>\n      </div>\n    \n</div>\n\n<div class=\"row fill\">\n\n    <div style=\"height: 98%;\">\n\n        <kendo-grid style=\"flex:1;\" [data]=\"gridView\" [columnMenu]=\"true\" [resizable]=\"true\" [reorderable]=\"true\" [sort]=\"sort\" (sortChange)=\"sortChange($event)\" [sortable]=\"{ allowUnsort: true, mode: 'multiple' }\"\n            [scrollable]=\"true\" [pageSize]=\"pageSize\" [skip]=\"skip\" [pageable]=\"{\n                buttonCount: 5,\n                info: true,\n                type: type,\n                pageSizes: true,\n                previousNext: true\n                }\" (pageChange)=\"pageChange($event)\">\n            <kendo-grid-column field=\"createTime\" title=\"Created\" sortable=\"isFieldSortable\" format=\"{0:dd/MM/yyyy HH:mm:ss}\">\n            </kendo-grid-column>\n            <kendo-grid-column field=\"expiryTime\" title=\"Expiry Time\" format=\"{0:dd/MM/yyyy HH:mm:ss}\">\n            </kendo-grid-column>\n            <kendo-grid-column field=\"clientId\" title=\"Client ID\">\n            </kendo-grid-column>\n            <kendo-grid-column field=\"tokenType\" title=\"Type\">\n            </kendo-grid-column>\n            <kendo-grid-column field=\"token\" title=\"Token\">\n            </kendo-grid-column>\n            \n            <kendo-grid-column title=\"\" width=\"150\" minResizableWidth=\"140\">\n                <ng-template kendoGridCellTemplate let-dataItem let-columnIndex=\"columnIndex\" let-rowIndex=\"rowIndex\" let-column=\"column\">\n                        <wc-grid-editor-command\n                            motif-acl=\"com.vipera.osgi.foundation.oauth2.api.rest.Oauth2Api:CREATE:revoke\"\n                            motif-acl-hidden=\"true\" \n                            [alignMode]=\"'end'\"\n                            [hasConfirmation]=\"true\"\n                            [confirmationTitle]=\"'Revoke ?'\"\n                            [rowIndex]=\"rowIndex\" \n                            [columnIndex]=\"columnIndex\" \n                            [column]=\"column\" \n                            [commandIcon]=\"'wa-ico-no'\"\n                            [dataItem]=\"dataItem\"\n                            (commandConfirm)=\"onDeleteOKPressed(dataItem)\"  \n                            >\n                        </wc-grid-editor-command>\n                </ng-template>\n            </kendo-grid-column>\n\n            <div *kendoGridDetailTemplate=\"let dataItem\">\n                <wa-refresh-token-details [refreshToken]=\"dataItem\"></wa-refresh-token-details>\n            </div>\n        </kendo-grid>\n\n    </div>\n\n</div>\n",
                styles: [":host{display:flex;flex:1;flex-direction:column}:host ::ng-deep .grid-btn-editor.wc-table-delete-command{justify-content:center}:host ::ng-deep tr.k-grid-norecords.ng-star-inserted{text-align:left;display:contents}"]
            }] }
];
/** @nocollapse */
OAuth2SectionComponent.ctorParameters = () => [
    { type: NGXLogger },
    { type: Oauth2Service },
    { type: WCNotificationCenter }
];
OAuth2SectionComponent.propDecorators = {
    _grid: [{ type: ViewChild, args: [GridComponent,] }],
    domainSelector: [{ type: ViewChild, args: ['domainSelector',] }],
    selectedDomain: [{ type: Input }]
};
OAuth2SectionComponent = tslib_1.__decorate([
    PluginView("OAuth2", {
        iconName: "wa-ico-users",
        userData: {
            acl: {
                permissions: ['com.vipera.osgi.core.platform.api.rest.PlatformApi:READ:getDomains',
                    'com.vipera.osgi.foundation.oauth2.api.rest.Oauth2Api:READ:getRefreshTokenList',
                    'com.vipera.osgi.foundation.oauth2.api.rest.Oauth2Api:READ:getAccessTokenList']
            }
        }
    }),
    tslib_1.__metadata("design:paramtypes", [NGXLogger,
        Oauth2Service,
        WCNotificationCenter])
], OAuth2SectionComponent);
export { OAuth2SectionComponent };
if (false) {
    /** @type {?} */
    OAuth2SectionComponent.prototype._grid;
    /** @type {?} */
    OAuth2SectionComponent.prototype.domainSelector;
    /** @type {?} */
    OAuth2SectionComponent.prototype.refreshTokenList;
    /** @type {?} */
    OAuth2SectionComponent.prototype.accessTokenList;
    /** @type {?} */
    OAuth2SectionComponent.prototype.sort;
    /** @type {?} */
    OAuth2SectionComponent.prototype.groups;
    /** @type {?} */
    OAuth2SectionComponent.prototype.gridView;
    /** @type {?} */
    OAuth2SectionComponent.prototype.type;
    /** @type {?} */
    OAuth2SectionComponent.prototype.pageSize;
    /** @type {?} */
    OAuth2SectionComponent.prototype.skip;
    /** @type {?} */
    OAuth2SectionComponent.prototype.currentPage;
    /** @type {?} */
    OAuth2SectionComponent.prototype.totalPages;
    /** @type {?} */
    OAuth2SectionComponent.prototype.totalRecords;
    /** @type {?} */
    OAuth2SectionComponent.prototype.isFieldSortable;
    /** @type {?} */
    OAuth2SectionComponent.prototype.loading;
    /**
     * @type {?}
     * @private
     */
    OAuth2SectionComponent.prototype._subHandler;
    /**
     * @type {?}
     * @private
     */
    OAuth2SectionComponent.prototype.logger;
    /**
     * @type {?}
     * @private
     */
    OAuth2SectionComponent.prototype.oauth2Service;
    /**
     * @type {?}
     * @private
     */
    OAuth2SectionComponent.prototype.notificationCenter;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2-section.component.js","sourceRoot":"ng://motif-web-admin-core/","sources":["lib/sections/OAuth2/components/oauth2-section.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,SAAS,EAAU,SAAS,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAmB,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAE,aAAa,EAAuC,MAAM,mCAAmC,CAAC;AACvG,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,+BAA+B,EAAE,MAAM,qEAAqE,CAAC;AAEtH,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,qDAAqD,CAAC;;MAEtF,OAAO,GAAG,iBAAiB;IAiBpB,sBAAsB,SAAtB,sBAAsB;;;;;;IAyBjC,YAAoB,MAAiB,EAC3B,aAA4B,EAC5B,kBAAwC;QAF9B,WAAM,GAAN,MAAM,CAAW;QAC3B,kBAAa,GAAb,aAAa,CAAe;QAC5B,uBAAkB,GAAlB,kBAAkB,CAAsB;;QArB3C,qBAAgB,GAAwB,EAAE,CAAC;QAC3C,oBAAe,GAAuB,EAAE,CAAC;;QAGzC,SAAI,GAAqB,EAAE,CAAC;QAC5B,WAAM,GAAsB,EAAE,CAAC;QAE/B,SAAI,GAAwB,SAAS,CAAC;QACtC,aAAQ,GAAG,EAAE,CAAC;QACd,SAAI,GAAG,CAAC,CAAC;QACT,gBAAW,GAAG,CAAC,CAAC;QAChB,eAAU,GAAG,CAAC,CAAC;QACf,iBAAY,GAAG,CAAC,CAAC;QACjB,oBAAe,GAAG,KAAK,CAAC;QAIvB,gBAAW,GAA0B,IAAI,qBAAqB,EAAE,CAAC;QAOvE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;IAC3C,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;IAChD,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAG,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC;;;;IAEF,OAAO;QACL,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;;;;;IAEQ,UAAU,CAAC,EAAE,IAAI,EAAE,IAAI,EAAmB;QAC/C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;QACrE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;;cACf,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,IAAI,CAAC;QACxD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,EAAE,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtF,CAAC;;;;;;;;IAEO,QAAQ,CAAC,MAAc,EAAE,SAAiB,EAAE,QAAgB;QAClE,IAAI,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE;YACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,qBAAqB,EAAE,SAAS,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;YAErF,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;;kBACd,IAAI,GAAmB,IAAI,CAAC,cAAc,EAAE;YAEpD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,mBAAmB,CACvD,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,EACvC,SAAS,EAAE,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC,SAAS;;;;YAAC,CAAC,QAAQ,EAAE,EAAE;;sBAEpG,OAAO,GAAsB,iBAAiB,CAAC,gBAAgB,CAAC,QAAQ,CAAC;gBAC/E,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI;;;;gBAAE,UAAU,OAAO;oBAC/D,OAAO,CAAC,UAAU,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;oBAClD,OAAO,CAAC,UAAU,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBACpD,CAAC,EAAC,CAAC;gBACH,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;gBACrC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;gBACzC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;gBACrC,IAAI,CAAC,QAAQ,GAAG;oBACd,IAAI,EAAE,IAAI,CAAC,gBAAgB;oBAC3B,KAAK,EAAE,OAAO,CAAC,YAAY;iBAC5B,CAAC;gBACF,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;gBACrC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YAEvB,CAAC;;;;YAAE,KAAK,CAAC,EAAE;gBACT,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,8BAA8B,EAAE,KAAK,CAAC,CAAC;gBAClE,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACvB,CAAC,EAAC,CAAC,CAAC;SACL;IACH,CAAC;;;;;;;IAEO,kBAAkB,CAAC,IAAY,EAAE,IAAY;QACnD,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;;;;;IAEO,cAAc;QACpB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,kBAAkB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;;YACtD,SAAS,GAAG,IAAI,cAAc,EAAE;QACpC,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;oBACrC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC3B,IAAI,QAAQ,CAAC,GAAG,IAAI,QAAQ,CAAC,GAAG,KAAK,KAAK,EAAE;oBAC1C,SAAS,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;iBAC5C;qBAAM,IAAI,QAAQ,CAAC,GAAG,IAAI,QAAQ,CAAC,GAAG,KAAK,MAAM,EAAE;oBAClD,SAAS,CAAC,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;iBAC7C;aACF;SACF;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;;;;;IAKM,WAAW;QAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,qBAAqB,EAAE,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,EAAE,eAAe,EAAE,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3J,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC1F,CAAC;;;;;;IAKD,IACW,cAAc,CAAC,MAAc;QACtC,IAAI,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE;YACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,wBAAwB,EAAE,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;YACzF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC1E;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;SAC3B;IACH,CAAC;;;;;IAEM,UAAU,CAAC,IAAsB;QACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,kBAAkB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,WAAW,EAAE,CAAA;IACpB,CAAC;;;;IAEM,MAAM;QACX,sFAAsF;IACxF,CAAC;;;;;IAED,iBAAiB,CAAC,QAAa;QAC7B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,0BAA0B,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEvE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,SAAS;;;;QAAC,KAAK,CAAC,EAAE;YAC3F,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;gBAC3B,IAAI,EAAE,2BAA2B;gBACjC,KAAK,EAAE,sBAAsB;gBAC7B,OAAO,EAAE,iDAAiD;gBAC1D,IAAI,EAAE,gBAAgB,CAAC,OAAO;aACjC,CAAC,CAAC;QAEH,CAAC;;;;QAAE,CAAC,KAAK,EAAE,EAAE;YACX,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;gBAC3B,IAAI,EAAE,yBAAyB;gBAC/B,KAAK,EAAE,sBAAsB;gBAC7B,OAAO,EAAE,qCAAqC;gBAC9C,IAAI,EAAE,gBAAgB,CAAC,KAAK;gBAC5B,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,EAAC,CAAC,CAAC;IACN,CAAC;;;;;IAED,qBAAqB,CAAC,QAAa;QACjC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,uBAAuB,CAAC,CAAC;IACtD,CAAC;;;;;IAEM,gBAAgB,CAAC,MAAc;QACpC,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC9C;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;SAC3B;IAEH,CAAC;;;;IAED,gBAAgB;QACd,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;IAED,IAAW,UAAU;QACnB,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,IAAE,IAAI,CAAC,CAAC;IACpD,CAAC;CAEF,CAAA;;YA5MA,SAAS,SAAC;gBACT,QAAQ,EAAE,mBAAmB;gBAE7B,o/GAA8C;;aAC/C;;;;YAlBQ,SAAS;YAIT,aAAa;YAKb,oBAAoB;;;oBAsB1B,SAAS,SAAC,aAAa;6BACvB,SAAS,SAAC,gBAAgB;6BAyH1B,KAAK;;AA5HK,sBAAsB;IAVlC,UAAU,CAAC,QAAQ,EAAE;QACpB,QAAQ,EAAE,cAAc;QACxB,QAAQ,EAAE;YACN,GAAG,EAAE;gBACD,WAAW,EAAE,CAAC,oEAAoE;oBACpE,+EAA+E;oBAC/E,8EAA8E,CAAC;aAChG;SACJ;KACF,CAAC;6CA0B4B,SAAS;QACZ,aAAa;QACR,oBAAoB;GA3BvC,sBAAsB,CA6LlC;SA7LY,sBAAsB;;;IAEjC,uCAA+C;;IAC/C,gDAA6E;;IAG7E,kDAAkD;;IAClD,iDAAgD;;IAGhD,sCAAmC;;IACnC,wCAAsC;;IACtC,0CAA4B;;IAC5B,sCAA6C;;IAC7C,0CAAqB;;IACrB,sCAAgB;;IAChB,6CAAuB;;IACvB,4CAAsB;;IACtB,8CAAwB;;IACxB,iDAA+B;;IAE/B,yCAAiB;;;;;IAEjB,6CAAyE;;;;;IAE7D,wCAAyB;;;;;IACnC,+CAAoC;;;;;IACpC,oDAAgD","sourcesContent":["import { Component, OnInit, ViewChild, Input, OnDestroy } from '@angular/core';\nimport { PluginView } from 'web-console-core';\nimport { NGXLogger } from 'web-console-core';\nimport { SortDescriptor, GroupDescriptor, DataResult } from '@progress/kendo-data-query';\nimport { PageChangeEvent, GridComponent } from '@progress/kendo-angular-grid';\nimport { MotifQuerySort, MotifQueryResults } from 'web-console-core';\nimport { Oauth2Service, Validate, RefreshToken, AccessToken } from '@wa-motif-open-api/oauth2-service';\nimport { HttpParams } from '@angular/common/http';\nimport * as _ from 'lodash';\nimport { DomainSelectorComboBoxComponent } from '../../../components/UI/selectors/domain-selector-combobox-component';\nimport { Domain } from '@wa-motif-open-api/platform-service';\nimport { WCNotificationCenter, NotificationType } from 'web-console-ui-kit';\nimport { WCSubscriptionHandler } from '../../../components/Commons/wc-subscription-handler';\n\nconst LOG_TAG = \"[OAuth2Section]\";\n\n@Component({\n  selector: 'wa-oauth2-section',\n  styleUrls: ['./oauth2-section.component.scss'],\n  templateUrl: './oauth2-section.component.html'\n})\n@PluginView(\"OAuth2\", {\n  iconName: \"wa-ico-users\",\n  userData: {\n      acl: {\n          permissions: ['com.vipera.osgi.core.platform.api.rest.PlatformApi:READ:getDomains',\n                        'com.vipera.osgi.foundation.oauth2.api.rest.Oauth2Api:READ:getRefreshTokenList',\n                        'com.vipera.osgi.foundation.oauth2.api.rest.Oauth2Api:READ:getAccessTokenList']\n      }\n  }\n})\nexport class OAuth2SectionComponent implements OnInit, OnDestroy {\n\n  @ViewChild(GridComponent) _grid: GridComponent;\n  @ViewChild('domainSelector') domainSelector: DomainSelectorComboBoxComponent;\n\n  //Data\n  public refreshTokenList: Array<RefreshToken> = [];\n  public accessTokenList: Array<AccessToken> = [];\n\n  //Grid Options\n  public sort: SortDescriptor[] = [];\n  public groups: GroupDescriptor[] = [];\n  public gridView: DataResult;\n  public type: 'numeric' | 'input' = 'numeric';\n  public pageSize = 15;\n  public skip = 0;\n  public currentPage = 1;\n  public totalPages = 0;\n  public totalRecords = 0;\n  public isFieldSortable = false;\n\n  loading: boolean;\n\n  private _subHandler: WCSubscriptionHandler = new WCSubscriptionHandler();\n\n  constructor(private logger: NGXLogger,\n    private oauth2Service: Oauth2Service,\n    private notificationCenter: WCNotificationCenter\n        ) {\n\n    this.logger.debug(LOG_TAG, 'Opening...');\n  }\n\n  ngOnInit() {\n    this.logger.debug(LOG_TAG, 'Initializing...');\n  }\n\n  ngOnDestroy() {\n    this.logger.debug(LOG_TAG , 'ngOnDestroy ');\n    this.freeMem();\n }\n\nfreeMem() {\n  this.refreshTokenList = null;\n  this.accessTokenList = null;\n  this.sort = null;\n  this.groups = null;\n  this.gridView = null;\n  this._subHandler.unsubscribe();\n  this._subHandler = null;\n}\n\n  public pageChange({ skip, take }: PageChangeEvent): void {\n    this.logger.debug(LOG_TAG, 'pageChange skip=', skip, ' take=', take);\n    this.skip = skip;\n    this.pageSize = take;\n    const newPageIndex = this.calculatePageIndex(skip, take);\n    this.loadData(this.domainSelector.selectedDomain.name, newPageIndex, this.pageSize);\n  }\n\n  private loadData(domain: string, pageIndex: number, pageSize: number) {\n    if (this.domainSelector.selectedDomain) {\n      this.logger.debug(LOG_TAG, 'loadData pageIndex=', pageIndex, ' pageSize=', pageSize);\n\n      this.loading = true;\n      const sort: MotifQuerySort = this.buildQuerySort();\n\n    this._subHandler.add(this.oauth2Service.getRefreshTokenList(\n        this.domainSelector.selectedDomain.name,\n        pageIndex, pageSize, sort.encode(new HttpParams()).get('sort'), 'response', false).subscribe((response) => {\n\n        const results: MotifQueryResults = MotifQueryResults.fromHttpResponse(response);\n        this.refreshTokenList = _.forEach(results.data, function (element) {\n          element.createTime = new Date(element.createTime);\n          element.expiryTime = new Date(element.expiryTime);\n        });\n        this.totalPages = results.totalPages;\n        this.totalRecords = results.totalRecords;\n        this.currentPage = results.pageIndex;\n        this.gridView = {\n          data: this.refreshTokenList,\n          total: results.totalRecords\n        };\n        this.currentPage = results.pageIndex;\n        this.loading = false;\n\n      }, error => {\n        this.logger.error(LOG_TAG, 'getRefreshTokenList failed: ', error);\n        this.loading = false;\n      }));\n    }\n  }\n\n  private calculatePageIndex(skip: number, take: number): number {\n    return (skip / take) + 1;\n  }\n\n  private buildQuerySort(): MotifQuerySort {\n    this.logger.debug(LOG_TAG, 'buildQuerySort: ', this.sort);\n    let querySort = new MotifQuerySort();\n    if (this.sort) {\n      for (let i = 0; i < this.sort.length; i++) {\n        let sortInfo = this.sort[i];\n        if (sortInfo.dir && sortInfo.dir === 'asc') {\n          querySort.orderAscendingBy(sortInfo.field);\n        } else if (sortInfo.dir && sortInfo.dir === 'desc') {\n          querySort.orderDescendingBy(sortInfo.field);\n        }\n      }\n    }\n    return querySort;\n  }\n\n  /**\n   * Reload the list of users for the selected domain\n   */\n  public refreshData(): void {\n    this.logger.debug(LOG_TAG, 'refreshData domain=', this.domainSelector.selectedDomain.name, ' currentPage=', this.currentPage, ' pageSize=', this.pageSize);\n    this.loadData(this.domainSelector.selectedDomain.name, this.currentPage, this.pageSize);\n  }\n\n  /**\n   * Set the selcted domain\n   */\n  @Input()\n  public set selectedDomain(domain: Domain) {\n    if (this.domainSelector.selectedDomain) {\n      this.logger.debug(LOG_TAG, 'selectedDomain domain=', this.domainSelector.selectedDomain);\n      this.loadData(this.domainSelector.selectedDomain.name, 1, this.pageSize);\n    } else {\n      this.gridView = undefined;\n    }\n  }\n\n  public sortChange(sort: SortDescriptor[]): void {\n    this.logger.debug(LOG_TAG, 'sortChange sort=', this.sort);\n    this.sort = sort;\n    this.refreshData()\n  }\n\n  public doSort() {\n    //this.gridView = process(orderBy(this.usersList, this.sort), { group: this.groups });\n  }\n\n  onDeleteOKPressed(dataItem: any): void {\n    this.logger.debug(LOG_TAG, 'onDeleteOKPressed token=', dataItem.token);\n\n    this._subHandler.add(this.oauth2Service.revokeRefreshToken(dataItem.token).subscribe(value => {\n      this.refreshData();\n      this.notificationCenter.post({\n        name: 'RevokeRefreshTokenSuccess',\n        title: 'Revoke Refresh Token',\n        message: 'The Refresh Token has been successfully revoked',\n        type: NotificationType.Success\n    });\n\n    }, (error) => {\n      this.notificationCenter.post({\n        name: 'RevokeRefreshTokenError',\n        title: 'Revoke Refresh Token',\n        message: 'Refresh token could not be removed.',\n        type: NotificationType.Error,\n        error: error,\n        closable: true\n      });\n    }));\n  }\n\n  onDeleteCancelPressed(dataItem: any): void {\n    this.logger.debug(LOG_TAG, 'onDeleteCancelPressed');\n  }\n\n  public onDomainSelected(domain: Domain) {\n    if (domain) {\n      this.loadData(domain.name, 1, this.pageSize);\n    } else {\n      this.gridView = undefined;\n    }\n\n  }\n\n  onRefreshClicked() {\n    this.refreshData();\n  }\n\n  public get canRefresh(): boolean {\n    return (this.domainSelector.selectedDomain!=null);\n  }\n\n}\n"]}