blob: f462bc3fb37b5c79f09fd905d151490a7f7fcf9d [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
import {Injectable} from '@angular/core';
import {Actions, Effect} from '@ngrx/effects';
import {Observable} from 'rxjs/Observable';
import {Action} from '@ngrx/store';
import {of} from 'rxjs/observable/of';
import * as roleActions from '../role.actions';
import {IdentityService} from '/home/pembe/Desktop/fineract-cn-web-app/src/app/sevices/identity/identity.service';
import {emptySearchResult} from '../../../common/store/search.reducer';
import {Role} from '/home/pembe/Desktop/fineract-cn-web-app/src/app/sevices/identity/domain/role.model';
const SYSTEM_ROLES: string[] = ['pharaoh', 'scheduler'];
@Injectable()
export class RoleSearchApiEffects {
@Effect()
search$: Observable<Action> = this.actions$
.ofType(roleActions.SEARCH)
.debounceTime(300)
.switchMap(() => {
const nextSearch$ = this.actions$.ofType(roleActions.SEARCH).skip(1);
return this.identityService.listRoles()
.takeUntil(nextSearch$)
.map(this.excludeSystemRoles)
.map(roles => new roleActions.SearchCompleteAction({
elements: roles,
totalPages: 1,
totalElements: roles.length
}))
.catch(() => of(new roleActions.SearchCompleteAction(emptySearchResult())));
});
private excludeSystemRoles(roles: Role[]): Role[] {
return roles.filter(role => SYSTEM_ROLES.indexOf(role.identifier) === -1);
}
constructor(private actions$: Actions, private identityService: IdentityService) { }
}