I have an interceptor that adds a token in the headers. However, if I use it after a POST request, my observer in the subscription does not start.
interceptor:
intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
this.authService = this.inj.get(AuthService);
if (!this.authService.isLoggedIn()) {
return next.handle(req);
}
const changedReq = req.clone({headers: req.headers.set('Authorization', `Bearer ${this.authService.getToken()}`)});
return next.handle(changedReq);
}
Services:
saveBeer(beerForm: BeerForm): Observable<Response> {
let body = JSON.stringify(beerForm);
let headers = new HttpHeaders({
'Content-Type': 'application/json'
});
return this.http.post(this.apiUrl, body, {headers: headers});
}
Component:
onSubmitCreateBeer(): void {
this.beerService.saveBeer(this.beerForm)
.takeUntil(this.ngUnsubscribe)
.subscribe(
(response: Response) => {
// On response
this.router.navigate(['/beers']);
}, error => {
// On error
}, () => {
// On complete
});
}
My problem is that the answer does not work, so my navigation step does not work. If I turn off the interceptor, everything will work.
Any ideas?
source
share