[Library | Trunk]: Fix parse roles for userinfo
git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@59250 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
parent
99198fb0d9
commit
c1977b1404
|
@ -31,7 +31,7 @@ export class ConnectSubscriberGuard implements CanActivate {
|
||||||
if (communityDomain) {
|
if (communityDomain) {
|
||||||
community = communityDomain;
|
community = communityDomain;
|
||||||
}
|
}
|
||||||
if (Session.isSubscriber('community', community, user)) {
|
if (Session.isSubscribedTo('community', community, user)) {
|
||||||
return of(true);
|
return of(true);
|
||||||
}
|
}
|
||||||
return this.subscribeService.isSubscribedToCommunity(properties, community)
|
return this.subscribeService.isSubscribedToCommunity(properties, community)
|
||||||
|
|
|
@ -80,8 +80,8 @@ export class Session{
|
||||||
user.role.indexOf('USER_MANAGER') !== -1);
|
user.role.indexOf('USER_MANAGER') !== -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static isSubscriber(type: string, id: string, user: User): boolean {
|
public static isSubscribedTo(type: string, id: string, user: User): boolean {
|
||||||
return user && user.role.indexOf(type.toUpperCase() + '_' + id.toUpperCase()) !== -1
|
return user && user.role.indexOf(type.toUpperCase() + '_' + id.toUpperCase()) !== -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static isManager(type: string, id: string, user: User): boolean {
|
public static isManager(type: string, id: string, user: User): boolean {
|
||||||
|
|
|
@ -5,7 +5,6 @@ import {COOKIE, User} from "../login/utils/helper.class";
|
||||||
import {catchError, map, timeout} from "rxjs/operators";
|
import {catchError, map, timeout} from "rxjs/operators";
|
||||||
import {NavigationEnd, Router} from "@angular/router";
|
import {NavigationEnd, Router} from "@angular/router";
|
||||||
import {properties} from "../../../environments/environment";
|
import {properties} from "../../../environments/environment";
|
||||||
import {CustomOptions} from "./servicesUtils/customOptions.class";
|
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
|
@ -18,20 +17,7 @@ export class UserManagementService {
|
||||||
constructor(private http: HttpClient,
|
constructor(private http: HttpClient,
|
||||||
private router: Router) {
|
private router: Router) {
|
||||||
this.promise = new Promise<any>((resolve => {
|
this.promise = new Promise<any>((resolve => {
|
||||||
const token = COOKIE.getCookie('AccessToken');
|
this.updateUserInfo(resolve);
|
||||||
if (!token) {
|
|
||||||
this.getUserInfoSubject.next(null);
|
|
||||||
resolve();
|
|
||||||
} else {
|
|
||||||
this.http.get<User>(properties.userInfoUrl + token).pipe(map(userInfo => {
|
|
||||||
return this.parseUserInfo(userInfo);
|
|
||||||
})).pipe(timeout(3000), catchError(() => {
|
|
||||||
return of(null);
|
|
||||||
})).subscribe(user => {
|
|
||||||
this.getUserInfoSubject.next(user);
|
|
||||||
resolve();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}));
|
}));
|
||||||
this.router.events.subscribe(event => {
|
this.router.events.subscribe(event => {
|
||||||
if (event instanceof NavigationEnd) {
|
if (event instanceof NavigationEnd) {
|
||||||
|
@ -52,17 +38,25 @@ export class UserManagementService {
|
||||||
}
|
}
|
||||||
|
|
||||||
public updateUserInfo(resolve: Function = null) {
|
public updateUserInfo(resolve: Function = null) {
|
||||||
this.http.get<User>(properties.userInfoUrl, CustomOptions.registryOptions()).pipe(map(userInfo => {
|
const token = COOKIE.getCookie('AccessToken');
|
||||||
|
if (!token) {
|
||||||
|
this.getUserInfoSubject.next(null);
|
||||||
|
if(resolve) {
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.http.get<User>(properties.userInfoUrl + token).pipe(map(userInfo => {
|
||||||
return this.parseUserInfo(userInfo);
|
return this.parseUserInfo(userInfo);
|
||||||
})).pipe(timeout(3000), catchError(() => {
|
})).pipe(timeout(3000), catchError(() => {
|
||||||
return of(null);
|
return of(null);
|
||||||
})).subscribe(user => {
|
})).subscribe(user => {
|
||||||
this.getUserInfoSubject.next(user);
|
this.getUserInfoSubject.next(user);
|
||||||
if (resolve) {
|
if(resolve) {
|
||||||
resolve();
|
resolve();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private async getUserInfoAsync(): Promise<User> {
|
private async getUserInfoAsync(): Promise<User> {
|
||||||
await this.promise;
|
await this.promise;
|
||||||
|
@ -87,12 +81,14 @@ export class UserManagementService {
|
||||||
user.fullname = "Anonymous user";
|
user.fullname = "Anonymous user";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
user.role = [];
|
||||||
if (info.edu_person_entitlements) {
|
if (info.edu_person_entitlements) {
|
||||||
user.role = info.edu_person_entitlements;
|
user.role = info.edu_person_entitlements;
|
||||||
} else if (info.roles) {
|
}
|
||||||
user.role = info.roles;
|
if (info.roles) {
|
||||||
} else {
|
info.roles.forEach(role => {
|
||||||
user.role = [];
|
user.role.push(role);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
user.expirationDate = info.exp_date;
|
user.expirationDate = info.exp_date;
|
||||||
return user;
|
return user;
|
||||||
|
|
Loading…
Reference in New Issue