. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Statistics\Repository; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Carbon; use Fisharebest\Webtrees\Functions\FunctionsDate; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Services\UserService; use Fisharebest\Webtrees\Statistics\Repository\Interfaces\LatestUserRepositoryInterface; use Fisharebest\Webtrees\User; use Illuminate\Database\Capsule\Manager as DB; use Illuminate\Database\Query\Builder; use Illuminate\Database\Query\JoinClause; /** * A repository providing methods for latest user related statistics. */ class LatestUserRepository implements LatestUserRepositoryInterface { /** * @var UserService */ private $user_service; /** * LatestUserRepository constructor. * * @param UserService $user_service */ public function __construct(UserService $user_service) { $this->user_service = $user_service; } /** * 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 User */ private function latestUserQuery(): User { static $user; if ($user instanceof User) { return $user; } $user_id = DB::table('user as u') ->select(['u.user_id']) ->leftJoin('user_setting as us', function (JoinClause $join): void { $join->on(function (Builder $query): void { $query->whereColumn('u.user_id', '=', 'us.user_id') ->where('us.setting_name', '=', 'reg_timestamp'); }); }) ->orderByDesc('us.setting_value') ->value('user_id'); $user = $this->user_service->find($user_id) ?? Auth::user(); return $user; } /** * @inheritDoc */ public function latestUserId(): string { return (string) $this->latestUserQuery()->id(); } /** * @inheritDoc */ public function latestUserName(): string { return e($this->latestUserQuery()->userName()); } /** * @inheritDoc */ public function latestUserFullName(): string { return e($this->latestUserQuery()->realName()); } /** * @inheritDoc */ public function latestUserRegDate(string $format = null): string { $format = $format ?? I18N::dateFormat(); $user = $this->latestUserQuery(); $timestamp = (int) $user->getPreference('reg_timestamp'); return Carbon::createFromTimestamp($timestamp)->format(strtr($format, ['%' => ''])); } /** * @inheritDoc */ public function latestUserRegTime(string $format = null): string { $format = $format ?? str_replace('%', '', I18N::timeFormat()); $user = $this->latestUserQuery(); return date($format, (int) $user->getPreference('reg_timestamp')); } /** * @inheritDoc */ 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; } }