alert = $alert; $this->config = $config; $this->encrypter = $encrypter; $this->kernel = $kernel; $this->settings = $settings; } /** * Render UI for editing mail settings. This UI should only display if * the server is configured to send mail using SMTP. * * @return \Illuminate\View\View */ public function index(): View { return view('admin.settings.mail', [ 'disabled' => $this->config->get('mail.driver') !== 'smtp', ]); } /** * Handle request to update SMTP mail settings. * * @param \Pterodactyl\Http\Requests\Admin\Settings\MailSettingsFormRequest $request * @return \Illuminate\Http\RedirectResponse * * @throws DisplayException * @throws \Pterodactyl\Exceptions\Model\DataValidationException * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException */ public function update(MailSettingsFormRequest $request): RedirectResponse { if ($this->config->get('mail.driver') !== 'smtp') { throw $this->smtpNotSelectedException(); } $values = $request->normalize(); if (array_get($values, 'mail:password') === '!e') { $values['mail:password'] = ''; } foreach ($values as $key => $value) { if (in_array($key, SettingsServiceProvider::getEncryptedKeys()) && ! empty($value)) { $value = $this->encrypter->encrypt($value); } $this->settings->set('settings::' . $key, $value); } $this->kernel->call('queue:restart'); $this->alert->success('Mail settings have been updated successfully and the queue worker was restarted to apply these changes.')->flash(); return redirect()->route('admin.settings.mail'); } /** * Submit a request to send a test mail message. * * @throws DisplayException * @param Request $request * @return \Illuminate\Http\RedirectResponse */ public function test(Request $request): RedirectResponse { if ($this->config->get('mail.driver') !== 'smtp') { throw $this->smtpNotSelectedException(); } try { Log::debug('Sending test message to ' . $request->user()->email); Notification::route('mail', $request->user()->email) ->notify(new MailTested($request->user())); } catch (Exception $exception) { $this->alert->danger(trans('base.mail.test_failed'))->flash(); return redirect()->route('admin.settings.mail'); } $this->alert->success(trans('base.mail.test_succeeded'))->flash(); return redirect()->route('admin.settings.mail'); } /** * Generate a display exception for non-SMTP configurations. * * @return DisplayException */ private function smtpNotSelectedException() { return new DisplayException('This feature is only available if SMTP is the selected email driver for the Panel.'); } }