mirror of
https://github.com/documenso/documenso.git
synced 2025-11-13 00:03:33 +10:00
## Description Adds support for rejecting a given document informing the document owner. Flows for resolving a rejection don't currently exist so it's up to the document owner to reach out to the recipient and work out a way to move forward via a new document or offline agreement. ## Related Issue ## Changes Made - Added new rejection properties to the recipient schema - Added API endpoints to support rejection - Added email templates for notifying the document owner and recipient - Added a dialog on the signing page to start the rejection flow. ## Testing Performed - Manually tested the flow end to end - Automated tests are planned
122 lines
3.8 KiB
TypeScript
122 lines
3.8 KiB
TypeScript
import { TRPCError } from '@trpc/server';
|
|
|
|
import { completeDocumentWithToken } from '@documenso/lib/server-only/document/complete-document-with-token';
|
|
import { rejectDocumentWithToken } from '@documenso/lib/server-only/document/reject-document-with-token';
|
|
import { setRecipientsForDocument } from '@documenso/lib/server-only/recipient/set-recipients-for-document';
|
|
import { setRecipientsForTemplate } from '@documenso/lib/server-only/recipient/set-recipients-for-template';
|
|
import { extractNextApiRequestMetadata } from '@documenso/lib/universal/extract-request-metadata';
|
|
|
|
import { authenticatedProcedure, procedure, router } from '../trpc';
|
|
import {
|
|
ZAddSignersMutationSchema,
|
|
ZAddTemplateSignersMutationSchema,
|
|
ZCompleteDocumentWithTokenMutationSchema,
|
|
ZRejectDocumentWithTokenMutationSchema,
|
|
} from './schema';
|
|
|
|
export const recipientRouter = router({
|
|
addSigners: authenticatedProcedure
|
|
.input(ZAddSignersMutationSchema)
|
|
.mutation(async ({ input, ctx }) => {
|
|
try {
|
|
const { documentId, teamId, signers } = input;
|
|
|
|
return await setRecipientsForDocument({
|
|
userId: ctx.user.id,
|
|
documentId,
|
|
teamId,
|
|
recipients: signers.map((signer) => ({
|
|
id: signer.nativeId,
|
|
email: signer.email,
|
|
name: signer.name,
|
|
role: signer.role,
|
|
signingOrder: signer.signingOrder,
|
|
actionAuth: signer.actionAuth,
|
|
})),
|
|
requestMetadata: extractNextApiRequestMetadata(ctx.req),
|
|
});
|
|
} catch (err) {
|
|
console.error(err);
|
|
|
|
throw new TRPCError({
|
|
code: 'BAD_REQUEST',
|
|
message: 'We were unable to set this field. Please try again later.',
|
|
});
|
|
}
|
|
}),
|
|
|
|
addTemplateSigners: authenticatedProcedure
|
|
.input(ZAddTemplateSignersMutationSchema)
|
|
.mutation(async ({ input, ctx }) => {
|
|
try {
|
|
const { templateId, signers, teamId } = input;
|
|
|
|
return await setRecipientsForTemplate({
|
|
userId: ctx.user.id,
|
|
teamId,
|
|
templateId,
|
|
recipients: signers.map((signer) => ({
|
|
id: signer.nativeId,
|
|
email: signer.email,
|
|
name: signer.name,
|
|
role: signer.role,
|
|
signingOrder: signer.signingOrder,
|
|
actionAuth: signer.actionAuth,
|
|
})),
|
|
});
|
|
} catch (err) {
|
|
console.error(err);
|
|
|
|
throw new TRPCError({
|
|
code: 'BAD_REQUEST',
|
|
message: 'We were unable to set this field. Please try again later.',
|
|
});
|
|
}
|
|
}),
|
|
|
|
completeDocumentWithToken: procedure
|
|
.input(ZCompleteDocumentWithTokenMutationSchema)
|
|
.mutation(async ({ input, ctx }) => {
|
|
try {
|
|
const { token, documentId, authOptions } = input;
|
|
|
|
return await completeDocumentWithToken({
|
|
token,
|
|
documentId,
|
|
authOptions,
|
|
userId: ctx.user?.id,
|
|
requestMetadata: extractNextApiRequestMetadata(ctx.req),
|
|
});
|
|
} catch (err) {
|
|
console.error(err);
|
|
|
|
throw new TRPCError({
|
|
code: 'BAD_REQUEST',
|
|
message: 'We were unable to sign this field. Please try again later.',
|
|
});
|
|
}
|
|
}),
|
|
|
|
rejectDocumentWithToken: procedure
|
|
.input(ZRejectDocumentWithTokenMutationSchema)
|
|
.mutation(async ({ input, ctx }) => {
|
|
try {
|
|
const { token, documentId, reason } = input;
|
|
|
|
return await rejectDocumentWithToken({
|
|
token,
|
|
documentId,
|
|
reason,
|
|
requestMetadata: extractNextApiRequestMetadata(ctx.req),
|
|
});
|
|
} catch (err) {
|
|
console.error(err);
|
|
|
|
throw new TRPCError({
|
|
code: 'BAD_REQUEST',
|
|
message: 'We were unable to handle this request. Please try again later.',
|
|
});
|
|
}
|
|
}),
|
|
});
|