. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Contracts\UserInterface; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Services\ModuleService; use Fisharebest\Webtrees\Services\UserService; use Fisharebest\Webtrees\Tree; use Fisharebest\Webtrees\Validator; use Illuminate\Support\Collection; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use function view; /** * Class PrivacyPolicy - to comply with the GDPR and similar local laws. */ class PrivacyPolicy extends AbstractModule implements ModuleFooterInterface { use ModuleFooterTrait; private ModuleService $module_service; private UserService $user_service; /** * Dependency injection. * * @param ModuleService $module_service * @param UserService $user_service */ public function __construct(ModuleService $module_service, UserService $user_service) { $this->module_service = $module_service; $this->user_service = $user_service; } /** * How should this module be labelled on tabs, footers, etc.? * * @return string */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Privacy policy'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Cookie warning” module */ return I18N::translate('Show a privacy policy.'); } /** * The default position for this footer. It can be changed in the control panel. * * @return int */ public function defaultFooterOrder(): int { return 4; } /** * A footer, to be added at the bottom of every page. * * @param ServerRequestInterface $request * * @return string */ public function getFooter(ServerRequestInterface $request): string { $tree = Validator::attributes($request)->treeOptional(); $user = Validator::attributes($request)->user(); if ($tree === null) { return ''; } return view('modules/privacy-policy/footer', [ 'tree' => $tree, 'uses_analytics' => $this->analyticsModules($tree, $user)->isNotEmpty(), ]); } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function getPageAction(ServerRequestInterface $request): ResponseInterface { $tree = Validator::attributes($request)->tree(); $user = Validator::attributes($request)->user(); $title = I18N::translate('Privacy policy'); return $this->viewResponse('modules/privacy-policy/page', [ 'administrators' => $this->user_service->administrators(), 'analytics' => $this->analyticsModules($tree, $user), 'title' => $title, 'tree' => $tree, ]); } /** * @param Tree $tree * @param UserInterface $user * * @return Collection */ protected function analyticsModules(Tree $tree, UserInterface $user): Collection { return $this->module_service ->findByComponent(ModuleAnalyticsInterface::class, $tree, $user) ->filter(static fn (ModuleAnalyticsInterface $module): bool => $module->isTracker()); } }