У меня есть приложение, которое использует файл cookie для входа в систему, который отправляется с большинством запросов / вызовов API для проверки пользователя.(Он устанавливается сервером после успешного входа в систему.)
Проблема заключается в том, что мое приложение выполняет одновременно несколько вызовов API при запуске, что приводит к вызовам с недействительными идентификаторами сеансов, которые затем воссоздаются на стороне сервера длякаждый из этих вызовов, таким образом, они заканчиваются различными идентификаторами сеансов => пользователь получает выход из системы.
Мой план состоит в том, чтобы отправить один вызов API, прежде чем разрешат все остальные.Но почему-то я не могу заставить его работать в правильном порядке.
Я придумал обещание, которое будет выполнено после того, как первый вызов завершится в моем конструкторе упаковщиков, например:
private firstCallMade: Promise<any>;
constructor(
private http: HttpClient,
private settings: SettingsProvider)
{
this.settings.getAsyncString("apiEndpoint").then(res =>
{
this.apiUrl = res;
this.firstCallMade = new Promise((resolve, reject) =>
{
this.http.get(this.apiUrl + this.firstCallEndpoint, { withCredentials: true })
.subscribe(
(result) => {
this.logger.system(this, 'First Call', `First call successful: ${JSON.stringify(result)}`);
resolve();
},
(error) => {
this.logger.system(this, 'First Call', `First call failed: ${JSON.stringify(error)}`);
resolve();
});
});
});
}
И в других методах-оболочках я использую его следующим образом:
get<T>(endpoint: string): Observable<T>
{
return new Observable<T>(subscriber =>
{
this.firstCallMade.then(_ =>
{
this.http.get<T>(this.apiUrl + endpoint)
.subscribe(
next => subscriber.next(next),
error => subscriber.error(error));
});
});
}
Но это не работает.
Мой код неверен?
РЕДАКТИРОВАТЬ ДЛЯРАЗЪЯСНЕНИЕ Что нужно, так это все, но первый вызов может идти одновременно после первого вызова (таким образом, устанавливаются правильные данные cookie для последующих вызовов).