. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fig\Http\Message\StatusCodeInterface; use Fisharebest\Webtrees\I18N; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use function app; /** * Trait ModuleAnalyticsTrait - default implementation of ModuleAnalyticsInterface */ trait ModuleAnalyticsTrait { /** * @return string */ abstract public function name(): string; /** * Should we add this tracker? * * @return bool */ public function analyticsCanShow(): bool { $request = app(ServerRequestInterface::class); // If the browser sets the DNT header, then we won't use analytics. $dnt = $request->getServerParams()['HTTP_DNT'] ?? ''; if ($dnt === '1') { return false; } foreach ($this->analyticsParameters() as $parameter) { if ($parameter === '') { return false; } } return true; } /** * The parameters that need to be embedded in the snippet. * * @return string[] */ public function analyticsParameters(): array { return []; } /** * A sentence describing what this module does. * * @return string */ public function description(): string { return I18N::translate('Tracking and analytics'); } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function getAdminAction(ServerRequestInterface $request): ResponseInterface { $this->layout = 'layouts/administration'; return $this->viewResponse('admin/analytics-edit', [ 'action' => route('module', ['module' => $this->name(), 'action' => 'Admin']), 'form_fields' => $this->analyticsFormFields(), 'preview' => $this->analyticsSnippet($this->analyticsParameters()), 'title' => $this->title(), ]); } /** * @param string $view_name * @param mixed[] $view_data * @param int $status * * @return ResponseInterface */ abstract protected function viewResponse(string $view_name, array $view_data, $status = StatusCodeInterface::STATUS_OK): ResponseInterface; /** * Form fields to edit the parameters. * * @return string */ public function analyticsFormFields(): string { return ''; } /** * Embed placeholders in the snippet. * * @param string[] $parameters * * @return string */ public function analyticsSnippet(array $parameters): string { return ''; } /** * How should this module be identified in the control panel, etc.? * * @return string */ abstract public function title(): string; /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function postAdminAction(ServerRequestInterface $request): ResponseInterface { foreach (array_keys($this->analyticsParameters()) as $parameter) { $new_value = $request->getParsedBody()[$parameter]; $this->setPreference($parameter, $new_value); } return redirect(route('analytics')); } /** * Set a module setting. * Since module settings are NOT NULL, setting a value to NULL will cause * it to be deleted. * * @param string $setting_name * @param string $setting_value * * @return void */ abstract public function setPreference(string $setting_name, string $setting_value): void; }