Pass abortSignal to sendToGroup

This commit is contained in:
Fedor Indutny 2022-05-23 15:08:13 -07:00 committed by GitHub
parent 7afe3fcca2
commit 3be95e821e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 49 additions and 26 deletions

View file

@ -92,7 +92,7 @@ export async function sendDeleteForEveryone(
await conversation.queueJob(
'conversationQueue/sendDeleteForEveryone',
async () => {
async abortSignal => {
log.info(
`Sending deleteForEveryone to conversation ${logId}`,
`with timestamp ${timestamp}`,
@ -209,6 +209,7 @@ export async function sendDeleteForEveryone(
messageIds,
send: async () =>
window.Signal.Util.sendToGroup({
abortSignal,
contentHint,
groupSendOptions: {
groupV1: conversation.getGroupV1Info(recipients),

View file

@ -90,27 +90,30 @@ export async function sendGroupUpdate(
};
try {
await conversation.queueJob('conversationQueue/sendGroupUpdate', async () =>
wrapWithSyncMessageSend({
conversation,
logId,
messageIds: [],
send: async () =>
window.Signal.Util.sendToGroup({
groupSendOptions: {
groupV2,
timestamp,
profileKey,
},
contentHint,
messageId: undefined,
sendOptions,
sendTarget: conversation.toSenderKeyTarget(),
sendType,
}),
sendType,
timestamp,
})
await conversation.queueJob(
'conversationQueue/sendGroupUpdate',
async abortSignal =>
wrapWithSyncMessageSend({
conversation,
logId,
messageIds: [],
send: async () =>
window.Signal.Util.sendToGroup({
abortSignal,
groupSendOptions: {
groupV2,
timestamp,
profileKey,
},
contentHint,
messageId: undefined,
sendOptions,
sendTarget: conversation.toSenderKeyTarget(),
sendType,
}),
sendType,
timestamp,
})
);
} catch (error: unknown) {
await handleMultipleSendErrors({

View file

@ -199,8 +199,9 @@ export async function sendNormalMessage(
log.info('sending group message');
innerPromise = conversation.queueJob(
'conversationQueue/sendNormalMessage',
() =>
abortSignal =>
window.Signal.Util.sendToGroup({
abortSignal,
contentHint: ContentHint.RESENDABLE,
groupSendOptions: {
attachments,

View file

@ -242,7 +242,7 @@ export async function sendReaction(
log.info('sending group reaction message');
promise = conversation.queueJob(
'conversationQueue/sendReaction',
() => {
abortSignal => {
// Note: this will happen for all old jobs queued before 5.32.x
if (isGroupV2(conversation.attributes) && !isNumber(revision)) {
log.error('No revision provided, but conversation is GroupV2');
@ -256,6 +256,7 @@ export async function sendReaction(
}
return window.Signal.Util.sendToGroup({
abortSignal,
contentHint: ContentHint.RESENDABLE,
groupSendOptions: {
groupV1: conversation.getGroupV1Info(

View file

@ -3440,7 +3440,10 @@ export class ConversationModel extends window.Backbone
return null;
}
queueJob<T>(name: string, callback: () => Promise<T>): Promise<T> {
queueJob<T>(
name: string,
callback: (abortSignal: AbortSignal) => Promise<T>
): Promise<T> {
this.jobQueue = this.jobQueue || new window.PQueue({ concurrency: 1 });
const taskWithTimeout = createTaskWithTimeout(
@ -3448,6 +3451,9 @@ export class ConversationModel extends window.Backbone
`conversation ${this.idForLogging()}`
);
const abortController = new AbortController();
const { signal: abortSignal } = abortController;
const queuedAt = Date.now();
return this.jobQueue.add(async () => {
const startedAt = Date.now();
@ -3458,7 +3464,10 @@ export class ConversationModel extends window.Backbone
}
try {
return await taskWithTimeout();
return await taskWithTimeout(abortSignal);
} catch (error) {
abortController.abort();
throw error;
} finally {
const duration = Date.now() - startedAt;

View file

@ -89,6 +89,7 @@ export type SenderKeyTargetType = {
};
export async function sendToGroup({
abortSignal,
contentHint,
groupSendOptions,
isPartialSend,
@ -97,6 +98,7 @@ export async function sendToGroup({
sendTarget,
sendType,
}: {
abortSignal?: AbortSignal;
contentHint: number;
groupSendOptions: GroupSendOptionsType;
isPartialSend?: boolean;
@ -120,6 +122,12 @@ export async function sendToGroup({
protoAttributes
);
// Attachment upload might take too long to succeed - we don't want to proceed
// with the send if the caller aborted this call.
if (abortSignal?.aborted) {
throw new Error('sendToGroup was aborted');
}
return sendContentMessageToGroup({
contentHint,
contentMessage,