aboutsummaryrefslogtreecommitdiff
path: root/lib/models/CalendarUser.class.php
blob: 02fdfceda230066f0a323f88c5895c8d75dc477d (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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
<?php
/**
 * CalendarUser.class.php - Model for users with access to other users calendar.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of
 * the License, or (at your option) any later version.
 *
 * @author      Peter Thienel <thienel@data-quest.de>
 * @license     http://www.gnu.org/licenses/gpl-2.0.html GPL version 2
 * @category    Stud.IP
 * @since       3.2
 */

class CalendarUser extends SimpleORMap
{
    protected static function configure($config = [])
    {
        $config['db_table'] = 'calendar_user';

        $config['has_one']['owner'] = [
            'class_name' => User::class,
            'foreign_key' => 'owner_id',
            'assoc_foreign_key' => 'user_id'
        ];
        $config['belongs_to']['user'] = [
            'class_name' => User::class,
            'foreign_key' => 'user_id'
        ];

        $config['additional_fields']['nachname']['get'] = function ($cu) {
            return $cu->user->nachname;
        };
        $config['additional_fields']['vorname']['get'] = function ($cu) {
            return $cu->user->vorname;
        };

        parent::configure($config);
    }

    public function setPerm($permission)
    {
        if ($permission == Calendar::PERMISSION_READABLE) {
            $this->permission = Calendar::PERMISSION_READABLE;
        } else if ($permission == Calendar::PERMISSION_WRITABLE) {
            $this->permission = Calendar::PERMISSION_WRITABLE;
        } else {
            throw new InvalidArgumentException(
                'Calendar permission must be of type PERMISSION_READABLE or PERMISSION_WRITABLE.');
        }
    }

    public static function getUsers($user_id, $permission = null)
    {
        $permission_array = [Calendar::PERMISSION_READABLE,
                Calendar::PERMISSION_WRITABLE];
        if (!$permission) {
            $permission = $permission_array;
        } else if (!in_array($permission, $permission_array)) {
            throw new InvalidArgumentException(
                'Calendar permission must be of type PERMISSION_READABLE or PERMISSION_WRITABLE.');
        } else {
            $permission = [$permission];
        }
        return SimpleORMapCollection::createFromArray(CalendarUser::findBySQL(
                'owner_id = ? AND permission IN(?)',
                [$user_id, $permission]));

    }

    public static function getOwners($user_id, $permission = null)
    {
        $permission_array = [Calendar::PERMISSION_READABLE,
                Calendar::PERMISSION_WRITABLE];
        if (!$permission) {
            $permission = $permission_array;
        } else if (!in_array($permission, $permission_array)) {
            throw new InvalidArgumentException(
                'Calendar permission must be of type PERMISSION_READABLE or PERMISSION_WRITABLE.');
        } else {
            $permission = [$permission];
        }
        $statement = DBManager::get()->prepare("
            SELECT *
            FROM calendar_user
                INNER JOIN auth_user_md5 ON (auth_user_md5.user_id = calendar_user.owner_id)
            WHERE calendar_user.user_id = :user_id
                AND calendar_user.permission IN (:permission)
            ORDER BY auth_user_md5.Nachname, auth_user_md5.Vorname
        ");
        $statement->execute([
            'user_id' => $user_id,
            'permission' => $permission
        ]);
        $calendar_users = [];
        foreach ($statement->fetchAll(PDO::FETCH_ASSOC) as $data) {
            $calendar_users[] = CalendarUser::buildExisting($data);
        }
        return SimpleORMapCollection::createFromArray($calendar_users);

    }
}