2021-09-02 22:31:21 +00:00
|
|
|
// Copyright 2021 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2021-09-17 18:27:53 +00:00
|
|
|
import type { LoggerType } from '../../types/Logging';
|
2021-09-02 22:31:21 +00:00
|
|
|
import { sleep } from '../../util/sleep';
|
|
|
|
import { parseRetryAfter } from '../../util/parseRetryAfter';
|
|
|
|
import { isRecord } from '../../util/isRecord';
|
2021-09-22 00:58:03 +00:00
|
|
|
import { HTTPError } from '../../textsecure/Errors';
|
2021-09-02 22:31:21 +00:00
|
|
|
|
2021-09-27 14:44:09 +00:00
|
|
|
export async function sleepFor413RetryAfterTime({
|
2021-09-02 22:31:21 +00:00
|
|
|
err,
|
|
|
|
log,
|
|
|
|
timeRemaining,
|
|
|
|
}: Readonly<{
|
|
|
|
err: unknown;
|
|
|
|
log: Pick<LoggerType, 'info'>;
|
|
|
|
timeRemaining: number;
|
|
|
|
}>): Promise<void> {
|
2021-09-27 14:44:09 +00:00
|
|
|
if (timeRemaining <= 0) {
|
2021-09-02 22:31:21 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const retryAfter = Math.min(
|
2021-09-27 14:44:09 +00:00
|
|
|
parseRetryAfter(findRetryAfterTime(err)),
|
2021-09-02 22:31:21 +00:00
|
|
|
timeRemaining
|
|
|
|
);
|
|
|
|
|
|
|
|
log.info(
|
|
|
|
`Got a 413 response code. Sleeping for ${retryAfter} millisecond(s)`
|
|
|
|
);
|
|
|
|
|
|
|
|
await sleep(retryAfter);
|
|
|
|
}
|
2021-09-27 14:44:09 +00:00
|
|
|
|
|
|
|
function findRetryAfterTime(err: unknown): unknown {
|
|
|
|
if (!isRecord(err)) {
|
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isRecord(err.responseHeaders)) {
|
|
|
|
return err.responseHeaders['retry-after'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (err.httpError instanceof HTTPError) {
|
|
|
|
return err.httpError.responseHeaders?.['retry-after'];
|
|
|
|
}
|
|
|
|
|
|
|
|
return undefined;
|
|
|
|
}
|