Enhance email settings functionality by adding sender address support (#668)
Co-authored-by: Julien Nahum <julien@nahum.net>
This commit is contained in:
@@ -22,29 +22,33 @@ class EmailSettingsRequest extends FormRequest
|
||||
*/
|
||||
public function rules()
|
||||
{
|
||||
$allFieldsPresent = $this->filled(['host', 'port', 'username', 'password']);
|
||||
$allFieldsPresent = $this->filled(['host', 'port', 'username', 'password', 'sender_address']);
|
||||
|
||||
return [
|
||||
'host' => [
|
||||
$allFieldsPresent ? 'required' : 'nullable',
|
||||
'required_with:port,username,password',
|
||||
'required_with:port,username,password,sender_address',
|
||||
'string',
|
||||
],
|
||||
'port' => [
|
||||
$allFieldsPresent ? 'required' : 'nullable',
|
||||
'required_with:host,username,password',
|
||||
'required_with:host,username,password,sender_address',
|
||||
'integer',
|
||||
],
|
||||
'username' => [
|
||||
$allFieldsPresent ? 'required' : 'nullable',
|
||||
'required_with:host,port,password',
|
||||
'required_with:host,port,password,sender_address',
|
||||
'string',
|
||||
],
|
||||
'password' => [
|
||||
$allFieldsPresent ? 'required' : 'nullable',
|
||||
'required_with:host,port,username',
|
||||
'required_with:host,port,username,sender_address',
|
||||
'string',
|
||||
],
|
||||
'sender_address' => [
|
||||
'nullable',
|
||||
'email',
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
@@ -98,6 +98,17 @@ class FormEmailNotification extends Notification
|
||||
|
||||
private function getFromEmail(): string
|
||||
{
|
||||
$workspace = $this->event->form->workspace;
|
||||
$emailSettings = $workspace->settings['email_settings'] ?? [];
|
||||
|
||||
if (
|
||||
$workspace->is_pro
|
||||
&& $emailSettings
|
||||
&& !empty($emailSettings['sender_address'])
|
||||
) {
|
||||
return $emailSettings['sender_address'];
|
||||
}
|
||||
|
||||
if (
|
||||
config('app.self_hosted')
|
||||
&& isset($this->integrationData->sender_email)
|
||||
|
||||
Reference in New Issue
Block a user