. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Statistics\Repository; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Carbon; use Fisharebest\Webtrees\Contracts\UserInterface; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Services\UserService; use Fisharebest\Webtrees\Statistics\Repository\Interfaces\LatestUserRepositoryInterface; use Illuminate\Database\Capsule\Manager as DB; use Illuminate\Database\Query\Builder; use Illuminate\Database\Query\JoinClause; use function date; use function e; use function str_replace; /** * A repository providing methods for latest user related statistics. */ class LatestUserRepository implements LatestUserRepositoryInterface { private UserService $user_service; /** * LatestUserRepository constructor. * * @param UserService $user_service */ public function __construct(UserService $user_service) { $this->user_service = $user_service; } /** * @return string */ public function latestUserId(): string { return (string) $this->latestUserQuery()->id(); } /** * Find the newest user on the site. * If no user has registered (i.e. all created by the admin), then * return the current user. * * @return UserInterface */ private function latestUserQuery(): UserInterface { static $user; if ($user instanceof UserInterface) { return $user; } $user_id = DB::table('user as u') ->select(['u.user_id']) ->leftJoin('user_setting as us', static function (JoinClause $join): void { $join->on(static function (Builder $query): void { $query->whereColumn('u.user_id', '=', 'us.user_id') ->where('us.setting_name', '=', UserInterface::PREF_TIMESTAMP_REGISTERED); }); }) ->orderByDesc('us.setting_value') ->value('user_id'); if ($user_id !== null) { $user_id = (int) $user_id; } $user = $this->user_service->find($user_id) ?? Auth::user(); return $user; } /** * @return string */ public function latestUserName(): string { return e($this->latestUserQuery()->userName()); } /** * @return string */ public function latestUserFullName(): string { return e($this->latestUserQuery()->realName()); } /** * @param string|null $format * * @return string */ public function latestUserRegDate(string $format = null): string { $format = $format ?? I18N::dateFormat(); $user = $this->latestUserQuery(); $timestamp = (int) $user->getPreference(UserInterface::PREF_TIMESTAMP_REGISTERED); return Carbon::createFromTimestamp($timestamp)->format(strtr($format, ['%' => ''])); } /** * @param string|null $format * * @return string */ public function latestUserRegTime(string $format = null): string { $format = $format ?? str_replace('%', '', I18N::timeFormat()); $user = $this->latestUserQuery(); return date($format, (int) $user->getPreference(UserInterface::PREF_TIMESTAMP_REGISTERED)); } /** * @param string|null $yes * @param string|null $no * * @return string */ public function latestUserLoggedin(string $yes = null, string $no = null): string { $yes = $yes ?? I18N::translate('yes'); $no = $no ?? I18N::translate('no'); $user = $this->latestUserQuery(); $is_logged_in = DB::table('session') ->selectRaw('1') ->where('user_id', '=', $user->id()) ->first(); return $is_logged_in ? $yes : $no; } }