Je suis en train d'obtenir le résultat d'une méthode qui retourne un observable pour passer dans la deuxième demanderésultat passe angular2 de requête HTTP dans mergemap requête http
this.runfirstmethod(headers).mergeMap(response => this.http[verb](url, response).map(res => res.json()))
C'est tout ce que je fais, je pense que je Je fais quelque chose de mal parce que je ne peux pas obtenir les en-têtes de buildAzureHeaders.
service
buildAzureHeaders(headers): Observable<Headers> {
if (headers == null) {
headers = new Headers();
}
if (JSON.parse(localStorage.getItem('azureToken')).token == null || this.azureAccessToken == null) {
this.Adal4Service.acquireToken("https://graph.windows.net").map(token => {
this.azureAccessToken = token;
localStorage.setItem('azureToken', token);
headers.append('Authorization', "Bearer " + token);
return Observable.of(headers);
});
} else {
headers.append('Authorization', "Bearer " + localStorage.setItem('azureToken', JSON.parse(localStorage.getItem('azureToken')).token));
console.log("Headers: " + headers);
return Observable.of(headers);
}
}
invokeRequest(verb, url, headers?, body?): Observable<any> {
return this.buildAzureHeaders(headers).switchMap(builtHeaders => this.http[verb](url, builtHeaders))
}
composant
this.ApiAuthService.invokeRequest("get","https://graph.windows.net/aseracare.com/users?api-version=1.6").subscribe(res => {
console.log(res);
});
Vous recherchez 'switchMap'? – hlfrmn
Je le pense, je travaille encore dessus mais switchmap semble être ce dont j'ai besoin. – user1552172