Я использую 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 })
};
}
Любая помощь?