1*8add1155SRico Sonntag<?php 2*8add1155SRico Sonntag/** 3*8add1155SRico Sonntag * webtrees: online genealogy 4*8add1155SRico Sonntag * Copyright (C) 2018 webtrees development team 5*8add1155SRico Sonntag * This program is free software: you can redistribute it and/or modify 6*8add1155SRico Sonntag * it under the terms of the GNU General Public License as published by 7*8add1155SRico Sonntag * the Free Software Foundation, either version 3 of the License, or 8*8add1155SRico Sonntag * (at your option) any later version. 9*8add1155SRico Sonntag * This program is distributed in the hope that it will be useful, 10*8add1155SRico Sonntag * but WITHOUT ANY WARRANTY; without even the implied warranty of 11*8add1155SRico Sonntag * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12*8add1155SRico Sonntag * GNU General Public License for more details. 13*8add1155SRico Sonntag * You should have received a copy of the GNU General Public License 14*8add1155SRico Sonntag * along with this program. If not, see <http://www.gnu.org/licenses/>. 15*8add1155SRico Sonntag */ 16*8add1155SRico Sonntagdeclare(strict_types=1); 17*8add1155SRico Sonntag 18*8add1155SRico Sonntagnamespace Fisharebest\Webtrees\Statistics\Repository; 19*8add1155SRico Sonntag 20*8add1155SRico Sonntaguse Fisharebest\Webtrees\Auth; 21*8add1155SRico Sonntaguse Fisharebest\Webtrees\Functions\FunctionsDate; 22*8add1155SRico Sonntaguse Fisharebest\Webtrees\I18N; 23*8add1155SRico Sonntaguse Fisharebest\Webtrees\Statistics\Repository\Interfaces\LatestUserRepositoryInterface; 24*8add1155SRico Sonntaguse Fisharebest\Webtrees\User; 25*8add1155SRico Sonntaguse Illuminate\Database\Capsule\Manager as DB; 26*8add1155SRico Sonntaguse Illuminate\Database\Query\Builder; 27*8add1155SRico Sonntaguse Illuminate\Database\Query\JoinClause; 28*8add1155SRico Sonntag 29*8add1155SRico Sonntag/** 30*8add1155SRico Sonntag * A repository providing methods for latest user related statistics. 31*8add1155SRico Sonntag */ 32*8add1155SRico Sonntagclass LatestUserRepository implements LatestUserRepositoryInterface 33*8add1155SRico Sonntag{ 34*8add1155SRico Sonntag /** 35*8add1155SRico Sonntag * Find the newest user on the site. 36*8add1155SRico Sonntag * 37*8add1155SRico Sonntag * If no user has registered (i.e. all created by the admin), then 38*8add1155SRico Sonntag * return the current user. 39*8add1155SRico Sonntag * 40*8add1155SRico Sonntag * @return User 41*8add1155SRico Sonntag */ 42*8add1155SRico Sonntag private function latestUserQuery(): User 43*8add1155SRico Sonntag { 44*8add1155SRico Sonntag static $user; 45*8add1155SRico Sonntag 46*8add1155SRico Sonntag if ($user instanceof User) { 47*8add1155SRico Sonntag return $user; 48*8add1155SRico Sonntag } 49*8add1155SRico Sonntag 50*8add1155SRico Sonntag $user_id = DB::table('user as u') 51*8add1155SRico Sonntag ->select(['u.user_id']) 52*8add1155SRico Sonntag ->leftJoin('user_setting as us', function (JoinClause $join) { 53*8add1155SRico Sonntag $join->on(function (Builder $query) { 54*8add1155SRico Sonntag $query->whereColumn('u.user_id', '=', 'us.user_id') 55*8add1155SRico Sonntag ->where('us.setting_name', '=', 'reg_timestamp'); 56*8add1155SRico Sonntag }); 57*8add1155SRico Sonntag }) 58*8add1155SRico Sonntag ->orderByDesc('us.setting_value') 59*8add1155SRico Sonntag ->value('user_id'); 60*8add1155SRico Sonntag 61*8add1155SRico Sonntag $user = User::find($user_id) ?? Auth::user(); 62*8add1155SRico Sonntag 63*8add1155SRico Sonntag return $user; 64*8add1155SRico Sonntag } 65*8add1155SRico Sonntag 66*8add1155SRico Sonntag /** 67*8add1155SRico Sonntag * @inheritDoc 68*8add1155SRico Sonntag */ 69*8add1155SRico Sonntag public function latestUserId(): string 70*8add1155SRico Sonntag { 71*8add1155SRico Sonntag return (string) $this->latestUserQuery()->id(); 72*8add1155SRico Sonntag } 73*8add1155SRico Sonntag 74*8add1155SRico Sonntag /** 75*8add1155SRico Sonntag * @inheritDoc 76*8add1155SRico Sonntag */ 77*8add1155SRico Sonntag public function latestUserName(): string 78*8add1155SRico Sonntag { 79*8add1155SRico Sonntag return e($this->latestUserQuery()->getUserName()); 80*8add1155SRico Sonntag } 81*8add1155SRico Sonntag 82*8add1155SRico Sonntag /** 83*8add1155SRico Sonntag * @inheritDoc 84*8add1155SRico Sonntag */ 85*8add1155SRico Sonntag public function latestUserFullName(): string 86*8add1155SRico Sonntag { 87*8add1155SRico Sonntag return e($this->latestUserQuery()->getRealName()); 88*8add1155SRico Sonntag } 89*8add1155SRico Sonntag 90*8add1155SRico Sonntag /** 91*8add1155SRico Sonntag * @inheritDoc 92*8add1155SRico Sonntag */ 93*8add1155SRico Sonntag public function latestUserRegDate(string $format = null): string 94*8add1155SRico Sonntag { 95*8add1155SRico Sonntag $format = $format ?? I18N::dateFormat(); 96*8add1155SRico Sonntag $user = $this->latestUserQuery(); 97*8add1155SRico Sonntag 98*8add1155SRico Sonntag return FunctionsDate::timestampToGedcomDate( 99*8add1155SRico Sonntag (int) $user->getPreference('reg_timestamp') 100*8add1155SRico Sonntag )->display(false, $format); 101*8add1155SRico Sonntag } 102*8add1155SRico Sonntag 103*8add1155SRico Sonntag /** 104*8add1155SRico Sonntag * @inheritDoc 105*8add1155SRico Sonntag */ 106*8add1155SRico Sonntag public function latestUserRegTime(string $format = null): string 107*8add1155SRico Sonntag { 108*8add1155SRico Sonntag $format = $format ?? str_replace('%', '', I18N::timeFormat()); 109*8add1155SRico Sonntag $user = $this->latestUserQuery(); 110*8add1155SRico Sonntag 111*8add1155SRico Sonntag return date($format, (int) $user->getPreference('reg_timestamp')); 112*8add1155SRico Sonntag } 113*8add1155SRico Sonntag 114*8add1155SRico Sonntag /** 115*8add1155SRico Sonntag * @inheritDoc 116*8add1155SRico Sonntag */ 117*8add1155SRico Sonntag public function latestUserLoggedin(string $yes = null, string $no = null): string 118*8add1155SRico Sonntag { 119*8add1155SRico Sonntag $yes = $yes ?? I18N::translate('yes'); 120*8add1155SRico Sonntag $no = $no ?? I18N::translate('no'); 121*8add1155SRico Sonntag $user = $this->latestUserQuery(); 122*8add1155SRico Sonntag 123*8add1155SRico Sonntag $is_logged_in = DB::table('session') 124*8add1155SRico Sonntag ->selectRaw('1') 125*8add1155SRico Sonntag ->where('user_id', '=', $user->id()) 126*8add1155SRico Sonntag ->first(); 127*8add1155SRico Sonntag 128*8add1155SRico Sonntag return $is_logged_in ? $yes : $no; 129*8add1155SRico Sonntag } 130*8add1155SRico Sonntag} 131