Skip to content

Commit

Permalink
fix(CustomForm): Catch mailer transport exception when submitting cus…
Browse files Browse the repository at this point in the history
…tom-form answers
  • Loading branch information
ambroisemaupate committed Oct 20, 2023
1 parent ff2486b commit 52487e3
Show file tree
Hide file tree
Showing 3 changed files with 75 additions and 70 deletions.
83 changes: 48 additions & 35 deletions lib/RoadizCoreBundle/src/Controller/CustomFormController.php
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@ public function definitionAction(Request $request, int $id): JsonResponse
* @param Request $request
* @param int $id
* @return Response
* @throws Exception
* @throws Exception|FilesystemException
*/
public function postAction(Request $request, int $id): Response
{
Expand Down Expand Up @@ -221,7 +221,11 @@ public function postAction(Request $request, int $id): Response
* @param Request $request
* @param int $customFormId
* @return Response
<<<<<<< Updated upstream
* @throws Exception
=======
* @throws Exception|FilesystemException
>>>>>>> Stashed changes
*/
public function addAction(Request $request, int $customFormId): Response
{
Expand Down Expand Up @@ -275,6 +279,7 @@ public function sentAction(Request $request, int $customFormId): Response
* @throws LoaderError
* @throws RuntimeError
* @throws SyntaxError
* @deprecated Use async message handler to send email receipt from CustomFormAnswer.
*/
public function sendAnswer(
CustomFormAnswer $answer,
Expand Down Expand Up @@ -332,10 +337,7 @@ public function sendAnswer(
* @param string|null $emailSender
* @param bool $prefix
* @return array|Response
* @throws LoaderError
* @throws RuntimeError
* @throws SyntaxError
* @throws TransportExceptionInterface
* @throws SyntaxError|RuntimeError|LoaderError|FilesystemException
*/
public function prepareAndHandleCustomFormAssignation(
Request $request,
Expand Down Expand Up @@ -375,17 +377,6 @@ public function prepareAndHandleCustomFormAssignation(
$answer->toArray(false)
);

$msg = $this->translator->trans(
'customForm.%name%.send',
['%name%' => $customFormsEntity->getDisplayName()]
);

$session = $request->getSession();
if ($session instanceof Session) {
$session->getFlashBag()->add('confirm', $msg);
}
$this->logger->info($msg);

$assignation['title'] = $this->translator->trans(
'new.answer.form.%site%',
['%site%' => $customFormsEntity->getDisplayName()]
Expand All @@ -400,25 +391,47 @@ public function prepareAndHandleCustomFormAssignation(
/*
* Send answer notification
*/
$receiver = array_filter(
array_map('trim', explode(',', $customFormsEntity->getEmail() ?? ''))
);
$receiver = array_map(function (string $email) {
return new Address($email);
}, $receiver);
$this->sendAnswer(
$answer,
[
'mailContact' => $assignation['mailContact'],
'fields' => $assignation["emailFields"],
'customForm' => $customFormsEntity,
'title' => $this->translator->trans(
'new.answer.form.%site%',
['%site%' => $customFormsEntity->getDisplayName()]
),
],
$receiver
);
try {
$receiver = array_filter(
array_map('trim', explode(',', $customFormsEntity->getEmail() ?? ''))
);
$receiver = array_map(function (string $email) {
return new Address($email);
}, $receiver);
$this->sendAnswer(
$answer,
[
'mailContact' => $assignation['mailContact'],
'fields' => $assignation["emailFields"],
'customForm' => $customFormsEntity,
'title' => $this->translator->trans(
'new.answer.form.%site%',
['%site%' => $customFormsEntity->getDisplayName()]
),
],
$receiver
);

$msg = $this->translator->trans(
'customForm.%name%.send',
['%name%' => $customFormsEntity->getDisplayName()]
);

$session = $request->getSession();
if ($session instanceof Session) {
$session->getFlashBag()->add('confirm', $msg);
}
$this->logger->info($msg);

} catch (TransportExceptionInterface $e) {
// Do not fail if answer has been registered but email has not been sent.
$this->logger->warning('Custom form answer has been registered but email could not been sent.', [
'exception' => $e,
'message' => $e->getMessage(),
'customForm' => $customFormsEntity->getDisplayName(),
'answerId' => $answer->getId()
]);
}

return $response;
} catch (EntityAlreadyExistsException $e) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ public function __invoke(AbstractDocumentMessage $message): void

protected function isFileLocal(DocumentInterface $document): bool
{
return str_starts_with($this->documentsStorage->publicUrl($document->getMountPath()), '/');
return
$document->isPrivate() ||
str_starts_with($this->documentsStorage->publicUrl($document->getMountPath()), '/');
}
}
58 changes: 24 additions & 34 deletions lib/RoadizCoreBundle/src/Form/CustomFormsType.php
Original file line number Diff line number Diff line change
Expand Up @@ -140,38 +140,21 @@ protected function addSingleField(FormBuilderInterface $builder, CustomFormField
*/
protected function getTypeForField(CustomFormField $field): string
{
switch ($field->getType()) {
case AbstractField::ENUM_T:
case AbstractField::MULTIPLE_T:
case AbstractField::RADIO_GROUP_T:
case AbstractField::CHECK_GROUP_T:
return ChoiceType::class;
case AbstractField::DOCUMENTS_T:
return FileType::class;
case AbstractField::MARKDOWN_T:
return MarkdownType::class;
case AbstractField::COLOUR_T:
return ColorType::class;
case AbstractField::DATETIME_T:
return DateTimeType::class;
case AbstractField::DATE_T:
return DateType::class;
case AbstractField::RICHTEXT_T:
case AbstractField::TEXT_T:
return TextareaType::class;
case AbstractField::BOOLEAN_T:
return CheckboxType::class;
case AbstractField::INTEGER_T:
return IntegerType::class;
case AbstractField::DECIMAL_T:
return NumberType::class;
case AbstractField::EMAIL_T:
return EmailType::class;
case AbstractField::COUNTRY_T:
return CountryType::class;
default:
return TextType::class;
}
return match ($field->getType()) {
AbstractField::ENUM_T, AbstractField::MULTIPLE_T, AbstractField::RADIO_GROUP_T, AbstractField::CHECK_GROUP_T => ChoiceType::class,
AbstractField::DOCUMENTS_T => FileType::class,
AbstractField::MARKDOWN_T => MarkdownType::class,
AbstractField::COLOUR_T => ColorType::class,
AbstractField::DATETIME_T => DateTimeType::class,
AbstractField::DATE_T => DateType::class,
AbstractField::RICHTEXT_T, AbstractField::TEXT_T => TextareaType::class,
AbstractField::BOOLEAN_T => CheckboxType::class,
AbstractField::INTEGER_T => IntegerType::class,
AbstractField::DECIMAL_T => NumberType::class,
AbstractField::EMAIL_T => EmailType::class,
AbstractField::COUNTRY_T => CountryType::class,
default => TextType::class,
};
}

/**
Expand Down Expand Up @@ -248,6 +231,10 @@ protected function getOptionsForField(CustomFormField $field, array $formOptions
$mimeTypes = [
'application/pdf',
'application/x-pdf',
'image/avif',
'image/heif',
'image/heic',
'image/webp',
'image/jpeg',
'image/png',
'image/gif',
Expand All @@ -259,7 +246,7 @@ protected function getOptionsForField(CustomFormField $field, array $formOptions
$option['constraints'][] = new All([
'constraints' => [
new File([
'maxSize' => '10m',
'maxSize' => $formOptions['fileUploadMaxSize'],
'mimeTypes' => $mimeTypes
])
]
Expand Down Expand Up @@ -308,12 +295,15 @@ public function configureOptions(OptionsResolver $resolver): void
'recaptcha_name' => Recaptcha::FORM_NAME,
'forceExpanded' => false,
'csrf_protection' => false,
// You may reduce this value when you have multiple files upload fields
// to avoid hitting email server upload limit.
'fileUploadMaxSize' => '10m',
]);

$resolver->setRequired('customForm');

$resolver->setAllowedTypes('customForm', [CustomForm::class]);
$resolver->setAllowedTypes('forceExpanded', ['boolean']);
$resolver->setAllowedTypes('fileUploadMaxSize', ['string']);
$resolver->setAllowedTypes('recaptcha_name', ['string']);
}

Expand Down

0 comments on commit 52487e3

Please sign in to comment.