ILIAS  release_5-4 Revision v5.4.26-12-gabc799a52e6
All Data Structures Namespaces Files Functions Variables Typedefs Modules Pages
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 
24 include_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 }
static _isSubscriber($a_obj_id, $a_usr_id)
check if user is subscriber
global $DIC
Definition: saml.php:7
_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...
foreach($_POST as $key=> $value) $res
$lng
$ilUser
Definition: imgupload.php:18
static _getCommands()
get list of command/permission combinations
$query
static _lookupRegistration($a_obj_id)
lookup registrations
static _isOnList($a_usr_id, $a_obj_id)
Check if a user on the waiting list.
static _checkGoto($a_target)
check whether goto script will succeed
$row
Class ilObjectAccess.
global $ilDB
static _lookupRegistered($a_usr_id, $a_obj_id)
lookup if user has registered