xref: /webtrees/app/Http/RequestHandlers/EmailPreferencesAction.php (revision 30e63383b10bafff54347985dcdbd10c40c33f62)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2021 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\User;
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 = $request->getAttribute('user');
61        assert($user instanceof User);
62
63        $params = (array) $request->getParsedBody();
64
65        Site::setPreference('SMTP_ACTIVE', $params['SMTP_ACTIVE']);
66        Site::setPreference('SMTP_DISP_NAME', $params['SMTP_DISP_NAME']);
67        Site::setPreference('SMTP_FROM_NAME', $params['SMTP_FROM_NAME']);
68        Site::setPreference('SMTP_HOST', $params['SMTP_HOST']);
69        Site::setPreference('SMTP_PORT', $params['SMTP_PORT']);
70        Site::setPreference('SMTP_AUTH', $params['SMTP_AUTH']);
71        Site::setPreference('SMTP_AUTH_USER', $params['SMTP_AUTH_USER']);
72        Site::setPreference('SMTP_SSL', $params['SMTP_SSL']);
73        Site::setPreference('SMTP_HELO', $params['SMTP_HELO']);
74        Site::setPreference('DKIM_DOMAIN', $params['DKIM_DOMAIN']);
75        Site::setPreference('DKIM_SELECTOR', $params['DKIM_SELECTOR']);
76        Site::setPreference('DKIM_KEY', $params['DKIM_KEY']);
77
78        if ($params['SMTP_AUTH_PASS'] !== '') {
79            Site::setPreference('SMTP_AUTH_PASS', $params['SMTP_AUTH_PASS']);
80        }
81
82        FlashMessages::addMessage(I18N::translate('The website preferences have been updated.'), 'success');
83
84        $test = $params['test'] ?? '';
85
86        if ($test === 'on') {
87            $success = $this->email_service->send(new SiteUser(), $user, $user, 'test', 'test', 'test');
88
89            if ($success) {
90                FlashMessages::addMessage(I18N::translate('The message was successfully sent to %s.', e($user->email())), 'success');
91            } else {
92                FlashMessages::addMessage(I18N::translate('The message was not sent.'), 'danger');
93            }
94
95            return redirect(route(EmailPreferencesPage::class));
96        }
97
98        return redirect(route(ControlPanel::class));
99    }
100}
101