Improve recovery from corrupted downloads
This commit is contained in:
parent
a46a4a67b9
commit
572849b9dd
3 changed files with 21 additions and 10 deletions
|
@ -19,6 +19,7 @@ import {
|
|||
ValidatingPassThrough,
|
||||
} from '@signalapp/libsignal-client/dist/incremental_mac';
|
||||
import type { ChunkSizeChoice } from '@signalapp/libsignal-client/dist/incremental_mac';
|
||||
import { isAbsolute } from 'path';
|
||||
|
||||
import * as log from './logging/log';
|
||||
import {
|
||||
|
@ -37,7 +38,7 @@ import { finalStream } from './util/finalStream';
|
|||
import { getIvAndDecipher } from './util/getIvAndDecipher';
|
||||
import { getMacAndUpdateHmac } from './util/getMacAndUpdateHmac';
|
||||
import { trimPadding } from './util/trimPadding';
|
||||
import { strictAssert } from './util/assert';
|
||||
import { assertDev, strictAssert } from './util/assert';
|
||||
import * as Errors from './types/errors';
|
||||
import { isNotNil } from './util/isNotNil';
|
||||
import { missingCaseError } from './util/missingCaseError';
|
||||
|
@ -733,11 +734,17 @@ export function getPlaintextHashForInMemoryAttachment(
|
|||
* Unlinks a file without throwing an error if it doesn't exist.
|
||||
* Throws an error if it fails to unlink for any other reason.
|
||||
*/
|
||||
export async function safeUnlink(filePath: string): Promise<void> {
|
||||
export async function safeUnlink(absoluteFilePath: string): Promise<void> {
|
||||
assertDev(
|
||||
isAbsolute(absoluteFilePath),
|
||||
'safeUnlink: a relative path was passed instead of an absolute one'
|
||||
);
|
||||
|
||||
try {
|
||||
await unlink(filePath);
|
||||
await unlink(absoluteFilePath);
|
||||
} catch (error) {
|
||||
// Ignore if file doesn't exist
|
||||
|
||||
if (error.code !== 'ENOENT') {
|
||||
log.error('Failed to unlink', error);
|
||||
throw error;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue