summaryrefslogtreecommitdiffstats
path: root/application/controllers/ManageUserDevicesController.php
blob: db054d10fb1d0989611fe41c9e5de27e0bca1829 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php
/* Icinga Web 2 | (c) 2021 Icinga GmbH | GPLv2+ */

namespace Icinga\Controllers;

use Icinga\Common\Database;
use Icinga\Web\Notification;
use Icinga\Web\RememberMe;
use Icinga\Web\RememberMeUserList;
use Icinga\Web\RememberMeUserDevicesList;
use ipl\Web\Compat\CompatController;
use ipl\Web\Url;

/**
 * ManageUserDevicesController
 *
 * you need 'application/sessions' permission to use this controller
 */
class ManageUserDevicesController extends CompatController
{
    use Database;

    public function init()
    {
        $this->assertPermission('application/sessions');
    }

    public function indexAction()
    {
        $this->getTabs()
            ->add(
                'manage-user-devices',
                array(
                    'title'             => $this->translate('List of users who stay logged in'),
                    'label'             => $this->translate('Users'),
                    'url'               => 'manage-user-devices',
                    'data-base-target'  => '_self'
                )
            )->activate('manage-user-devices');

        $usersList = (new RememberMeUserList())
            ->setUsers(RememberMe::getAllUser())
            ->setUrl('manage-user-devices/devices');

        $this->addContent($usersList);

        if (! $this->hasDb()) {
            Notification::warning(
                $this->translate("Users can't stay logged in without a database configuration backend")
            );
        }
    }

    public function devicesAction()
    {
        $this->getTabs()
            ->add(
                'manage-devices',
                array(
                    'title' => $this->translate('List of devices'),
                    'label' => $this->translate('Devices'),
                    'url'   => 'manage-user-devices/devices'
                )
            )->activate('manage-devices');

        $name = $this->params->getRequired('name');
        $data = (new RememberMeUserDevicesList())
            ->setDevicesList(RememberMe::getAllByUsername($name))
            ->setUsername($name)
            ->setUrl('manage-user-devices/delete');

        $this->addContent($data);
    }

    public function deleteAction()
    {
        (new RememberMe())->remove($this->params->getRequired('fingerprint'));

        $this->redirectNow(
            Url::fromPath('manage-user-devices/devices')
                ->addParams(['name' => $this->params->getRequired('name')])
        );
    }
}