xref: /webtrees/app/Statistics/Repository/LatestUserRepository.php (revision 8add1155cb77caede54752196ff44696d1346431)
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