Проверьте Id_token или access_token на identityserver4 - PullRequest
0 голосов
/ 06 декабря 2018

Я использую Identityserver4 с неявным потоком моего приложения Angular.В настоящее время я сталкиваюсь с некоторыми проблемами аутентификации, и для этого мне нужно проверить токен, сгенерированный IDS, и токен, который есть в моем угловом клиенте после аутентификации.

Я не знаю Как получить токен в IdentityServer при аутентификации клиента?

вот мой код, связанный с oidc, в угловом формате:

import { Injectable } from '@angular/core';
import { UserManager, UserManagerSettings, User, WebStorageStateStore } from 'oidc-client';
import { AppConfigService } from '../../app-config.service';
// import { Config } from '../../../app-config';

@Injectable()
export class AuthService {
private manager;
private user: User = null;

constructor(private appConfig: AppConfigService) {
    this.manager = new UserManager(getClientSettings(appConfig));
    this.manager.getUser().then(user => {
        this.user = user;
    });
    this.manager.events.addUserLoaded( user => {
        this.user = user;
    });
}
public get UserId() {
    if (this.user && this.user != null && this.user.profile && this.user.profile.sub) {
        return this.user.profile.sub;
    }
    return null;
}
public get User() {
    if (this.user && this.user != null && this.user.profile && this.user.profile != null) {
        return this.user.profile;
    }
    return null;
}
public isLoggedIn(): boolean {
    return this.user != null && !this.user.expired;
}

public getClaims(): any {
    return this.user.profile;
}

public getAuthorizationHeaderValue(): string {
    //
    return `${this.user.token_type} ${this.user.access_token}`;

}

public startAuthentication(): Promise<void> {
    return this.manager.signinRedirect();
}
public signout(): Promise<void> {
    localStorage.removeItem('user');
    return this.manager.signoutRedirect();
}
public signoutRedirectCallback(): Promise<any> {
    //   localStorage.removeItem('user');
    return this.manager.signoutRedirectCallback();
}

public completeAuthentication(): Promise<void> {
    return this.manager.signinRedirectCallback().then(user => {
        this.user = user;
    });
}
public silentRefresh(): Promise<void> {
    console.log('before');
    return this.manager.signinSilentCallback(); // .then(t => console.log(t))
    // .catch((err) => {
    // console.log(err);
    // });
}
public signinSilent(): Promise<User> {
    return this.manager.signinSilent();
}

}

export function getClientSettings(appConfig: AppConfigService): 
UserManagerSettings {
console.log('in auth service', appConfig.getConfig('IDS_ENDPOINT'));
return {
    authority: appConfig.getConfig('IDS_ENDPOINT'), // 'https://localhost:44360/',
    client_id: appConfig.getConfig('IDS_CLIENT'),
    redirect_uri: appConfig.getConfig('IDS_redirectUrl'), // 'http://localhost:4200/auth-callback',
    post_logout_redirect_uri: appConfig.getConfig('IDS_LogoutUrl'), // 'http://localhost:4200/',
    response_type: 'id_token token',
    scope: 'openid profile roles smsapi country subscriptionlevel permissions',
    filterProtocolClaims: true,
    loadUserInfo: true,
    automaticSilentRenew: true,
    accessTokenExpiringNotificationTime: 60,
    silent_redirect_uri: appConfig.getConfig('IDS_refreshUrl')
   // userStore: new WebStorageStateStore({ store: window.localStorage })
};

}

Любая помощь?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...