Я работаю над приложением angular2, в котором я делаю вызов отдыха через HTTp, как показано ниже:
login(email, password) {
let headers = new Headers();
headers.append('Content-Type', 'application/x-www-form-urlencoded');
let options = new RequestOptions({ headers: headers });
let body = `identity=${email}&password=${password}`;
return this.http.post(`${this._configService.getBaseUrl()}/login`, body, options)
.map((res: any) => {
let response: any = JSON.parse(res._body);
if (response.success == 0) {
Observable.throw(response); // not working
} else if (response.success == 1) {
console.log('success');
localStorage.setItem('auth_token', 'authenticated');
this.loggedIn = true;
return response;
}
});
}
В основном я хочу, чтобы мой компонент получил ответ и ошибку в моем подписном вызове.
то есть.
this._authenticateService.login(this.loginObj['identity'],this.loginObj['password']).subscribe(
(success)=>{
this.credentialsError=null;
this.loginObj={};
this._router.navigate(['dashboard']);
},
(error)=>{
console.log(error);
this.credentialsError=error;
}
);
но мой api всегда возвращает успех, поскольку он определен таким образом.
Итак, я хочу знать, как я могу сбросить сообщение об ошибке, если response.success == 0
, так что он будет доступен внутри аргумента ошибки моего обратного вызова для подписки.