ILIAS  release_5-4 Revision v5.4.26-12-gabc799a52e6
class.ilObjSessionAccess.php
Go to the documentation of this file.
1<?php
2/*
3 +-----------------------------------------------------------------------------+
4 | ILIAS open source |
5 +-----------------------------------------------------------------------------+
6 | Copyright (c) 1998-2006 ILIAS open source, University of Cologne |
7 | |
8 | This program is free software; you can redistribute it and/or |
9 | modify it under the terms of the GNU General Public License |
10 | as published by the Free Software Foundation; either version 2 |
11 | of the License, or (at your option) any later version. |
12 | |
13 | This program is distributed in the hope that it will be useful, |
14 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
15 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
16 | GNU General Public License for more details. |
17 | |
18 | You should have received a copy of the GNU General Public License |
19 | along with this program; if not, write to the Free Software |
20 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
21 +-----------------------------------------------------------------------------+
22*/
23
24include_once './Services/Object/classes/class.ilObjectAccess.php';
25
35{
36 protected static $registrations = null;
37 protected static $registered = null;
38
46 public static function _getCommands()
47 {
48 $commands = array(
49 array("permission" => "read", "cmd" => "infoScreen", "lang_var" => "info_short", "default" => true),
50 array("permission" => "read", "cmd" => "register", "lang_var" => "join_session"),
51 array("permission" => "read", "cmd" => "unregister", "lang_var" => "event_unregister"),
52 array("permission" => "write", "cmd" => "edit", "lang_var" => "settings"),
53 array("permission" => "manage_materials", "cmd" => "materials", "lang_var" => "crs_objective_add_mat"),
54 array('permission' => 'manage_members', 'cmd' => 'members', 'lang_var' => 'event_edit_members')
55 );
56
57 return $commands;
58 }
59
72 public function _checkAccess($a_cmd, $a_permission, $a_ref_id, $a_obj_id, $a_user_id = "")
73 {
74 global $DIC;
75
76 $ilUser = $DIC['ilUser'];
77 $lng = $DIC['lng'];
78 $rbacsystem = $DIC['rbacsystem'];
79 $ilAccess = $DIC['ilAccess'];
80
81 if (!$a_user_id) {
82 $a_user_id = $ilUser->getId();
83 }
84
85 switch ($a_cmd) {
86 case 'register':
87
88 if (!self::_lookupRegistration($a_obj_id)) {
89 return false;
90 }
91 if ($ilUser->isAnonymous()) {
92 return false;
93 }
94 if (self::_lookupRegistered($a_user_id, $a_obj_id)) {
95 return false;
96 }
97 if (\ilSessionParticipants::_isSubscriber($a_obj_id, $a_user_id)) {
98 return false;
99 }
100 include_once './Modules/Session/classes/class.ilSessionWaitingList.php';
101 if (ilSessionWaitingList::_isOnList($a_user_id, $a_obj_id)) {
102 return false;
103 }
104 break;
105
106 case 'unregister':
107 if (self::_lookupRegistration($a_obj_id) && $a_user_id != ANONYMOUS_USER_ID) {
108 return self::_lookupRegistered($a_user_id, $a_obj_id);
109 }
110 return false;
111 }
112 return true;
113 }
114
115
119 public static function _checkGoto($a_target)
120 {
121 global $DIC;
122
123 $ilAccess = $DIC['ilAccess'];
124
125 $t_arr = explode("_", $a_target);
126
127 if ($t_arr[0] != "sess" || ((int) $t_arr[1]) <= 0) {
128 return false;
129 }
130
131 if ($ilAccess->checkAccess("read", "", $t_arr[1])) {
132 return true;
133 }
134 return false;
135 }
136
145 public static function _lookupRegistration($a_obj_id)
146 {
147 if (!is_null(self::$registrations)) {
148 return self::$registrations[$a_obj_id];
149 }
150
151 global $DIC;
152
153 $ilDB = $DIC['ilDB'];
154
155 $query = "SELECT registration,obj_id FROM event ";
156 $res = $ilDB->query($query);
157 while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
158 self::$registrations[$row->obj_id] = (bool) $row->registration;
159 }
160 return self::$registrations[$a_obj_id];
161 }
162
172 public static function _lookupRegistered($a_usr_id, $a_obj_id)
173 {
174 if (isset(self::$registered[$a_usr_id])) {
175 return (bool) self::$registered[$a_usr_id][$a_obj_id];
176 }
177
178 global $DIC;
179
180 $ilDB = $DIC['ilDB'];
181 $ilUser = $DIC['ilUser'];
182
183 $query = "SELECT event_id, registered FROM event_participants WHERE usr_id = " . $ilDB->quote($ilUser->getId(), 'integer');
184 $res = $ilDB->query($query);
185 self::$registered[$a_usr_id] = array();
186 while ($row = $res->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
187 self::$registered[$a_usr_id][$row->event_id] = (bool) $row->registered;
188 }
189 return (bool) self::$registered[$a_usr_id][$a_obj_id];
190 }
191}
An exception for terminatinating execution or to throw for unit testing.
static _getCommands()
get list of command/permission combinations
static _lookupRegistration($a_obj_id)
lookup registrations
static _lookupRegistered($a_usr_id, $a_obj_id)
lookup if user has registered
_checkAccess($a_cmd, $a_permission, $a_ref_id, $a_obj_id, $a_user_id="")
checks wether a user may invoke a command or not (this method is called by ilAccessHandler::checkAcce...
static _checkGoto($a_target)
check whether goto script will succeed
Class ilObjectAccess.
static _isSubscriber($a_obj_id, $a_usr_id)
check if user is subscriber
static _isOnList($a_usr_id, $a_obj_id)
Check if a user on the waiting list.
$row
$query
global $DIC
Definition: saml.php:7
$lng
foreach($_POST as $key=> $value) $res
global $ilDB
$ilUser
Definition: imgupload.php:18