xref: /webtrees/app/Http/RequestHandlers/EmailPreferencesAction.php (revision d11be7027e34e3121be11cc025421873364403f9)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2023 webtrees development team
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <https://www.gnu.org/licenses/>.
16 */
17
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22use Fisharebest\Webtrees\FlashMessages;
23use Fisharebest\Webtrees\I18N;
24use Fisharebest\Webtrees\Services\EmailService;
25use Fisharebest\Webtrees\Site;
26use Fisharebest\Webtrees\SiteUser;
27use Fisharebest\Webtrees\Validator;
28use Psr\Http\Message\ResponseInterface;
29use Psr\Http\Message\ServerRequestInterface;
30use Psr\Http\Server\RequestHandlerInterface;
31
32use function e;
33use function redirect;
34use function route;
35
36/**
37 * Edit the email preferences.
38 */
39class EmailPreferencesAction implements RequestHandlerInterface
40{
41    private EmailService $email_service;
42
43    /**
44     * AdminSiteController constructor.
45     *
46     * @param EmailService $email_service
47     */
48    public function __construct(EmailService $email_service)
49    {
50        $this->email_service = $email_service;
51    }
52
53    /**
54     * @param ServerRequestInterface $request
55     *
56     * @return ResponseInterface
57     */
58    public function handle(ServerRequestInterface $request): ResponseInterface
59    {
60        $user          = Validator::attributes($request)->user();
61        $active        = Validator::parsedBody($request)->string('SMTP_ACTIVE');
62        $disp_name     = Validator::parsedBody($request)->string('SMTP_DISP_NAME');
63        $from_name     = Validator::parsedBody($request)->string('SMTP_FROM_NAME');
64        $host          = Validator::parsedBody($request)->string('SMTP_HOST');
65        $port          = Validator::parsedBody($request)->string('SMTP_PORT');
66        $auth          = Validator::parsedBody($request)->string('SMTP_AUTH');
67        $auth_user     = Validator::parsedBody($request)->string('SMTP_AUTH_USER');
68        $auth_pass     = Validator::parsedBody($request)->string('SMTP_AUTH_PASS');
69        $ssl           = Validator::parsedBody($request)->string('SMTP_SSL');
70        $helo          = Validator::parsedBody($request)->string('SMTP_HELO');
71        $dkim_domain   = Validator::parsedBody($request)->string('DKIM_DOMAIN');
72        $dkim_selector = Validator::parsedBody($request)->string('DKIM_SELECTOR');
73        $dkim_key      = Validator::parsedBody($request)->string('DKIM_KEY');
74        $test          = Validator::parsedBody($request)->boolean('test', false);
75
76
77        Site::setPreference('SMTP_ACTIVE', $active);
78        Site::setPreference('SMTP_DISP_NAME', $disp_name);
79        Site::setPreference('SMTP_FROM_NAME', $from_name);
80        Site::setPreference('SMTP_HOST', $host);
81        Site::setPreference('SMTP_PORT', $port);
82        Site::setPreference('SMTP_AUTH', $auth);
83        Site::setPreference('SMTP_AUTH_USER', $auth_user);
84        Site::setPreference('SMTP_SSL', $ssl);
85        Site::setPreference('SMTP_HELO', $helo);
86        Site::setPreference('DKIM_DOMAIN', $dkim_domain);
87        Site::setPreference('DKIM_SELECTOR', $dkim_selector);
88        Site::setPreference('DKIM_KEY', $dkim_key);
89
90        if ($auth_pass !== '') {
91            Site::setPreference('SMTP_AUTH_PASS', $auth_pass);
92        }
93
94        FlashMessages::addMessage(I18N::translate('The website preferences have been updated.'), 'success');
95
96        if ($test) {
97            $success = $this->email_service->send(new SiteUser(), $user, $user, 'test', 'test', 'test');
98
99            if ($success) {
100                FlashMessages::addMessage(I18N::translate('The message was successfully sent to %s.', e($user->email())), 'success');
101            } else {
102                FlashMessages::addMessage(I18N::translate('The message was not sent.'), 'danger');
103            }
104
105            return redirect(route(EmailPreferencesPage::class));
106        }
107
108        return redirect(route(ControlPanel::class));
109    }
110}
111