ILIAS  release_6 Revision v6.24-5-g0c8bfefb3b8
All Data Structures Namespaces Files Functions Variables Modules Pages
class.ilObjWikiAccess.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (c) 1998-2009 ILIAS open source, Extended GPL, see docs/LICENSE */
3 
4 include_once("./Services/Object/classes/class.ilObjectAccess.php");
5 
16 {
20  protected $user;
21 
25  protected $lng;
26 
30  protected $rbacsystem;
31 
35  protected $access;
36 
37 
41  public function __construct()
42  {
43  global $DIC;
44 
45  $this->user = $DIC->user();
46  $this->lng = $DIC->language();
47  $this->rbacsystem = $DIC->rbac()->system();
48  $this->access = $DIC->access();
49  }
50 
51 
64  public static function _getCommands()
65  {
66  $commands = array(
67  array("permission" => "read", "cmd" => "view", "lang_var" => "show",
68  "default" => true),
69  array("permission" => "write", "cmd" => "editSettings", "lang_var" => "settings")
70  );
71 
72  return $commands;
73  }
74 
87  public function _checkAccess($a_cmd, $a_permission, $a_ref_id, $a_obj_id, $a_user_id = "")
88  {
90  $lng = $this->lng;
92  $ilAccess = $this->access;
93 
94  if ($a_user_id == "") {
95  $a_user_id = $ilUser->getId();
96  }
97 
98  switch ($a_cmd) {
99  case "view":
100 
101  if (!ilObjWikiAccess::_lookupOnline($a_obj_id)
102  && !$rbacsystem->checkAccessOfUser($a_user_id, 'write', $a_ref_id)) {
103  $ilAccess->addInfoItem(IL_NO_OBJECT_ACCESS, $lng->txt("offline"));
104  return false;
105  }
106  break;
107 
108  // for permission query feature
109  case "infoScreen":
110  if (!ilObjWikiAccess::_lookupOnline($a_obj_id)) {
111  $ilAccess->addInfoItem(IL_NO_OBJECT_ACCESS, $lng->txt("offline"));
112  } else {
113  $ilAccess->addInfoItem(IL_STATUS_MESSAGE, $lng->txt("online"));
114  }
115  break;
116 
117  }
118  switch ($a_permission) {
119  case "read":
120  case "visible":
121  if (!ilObjWikiAccess::_lookupOnline($a_obj_id) &&
122  (!$rbacsystem->checkAccessOfUser($a_user_id, 'write', $a_ref_id))) {
123  $ilAccess->addInfoItem(IL_NO_OBJECT_ACCESS, $lng->txt("offline"));
124  return false;
125  }
126 
127  include_once("./Modules/Exercise/RepoObjectAssignment/classes/class.ilExcRepoObjAssignment.php");
128  $info = ilExcRepoObjAssignment::getInstance()->getAccessInfo($a_ref_id, $a_user_id);
129  if (!$info->isGranted()) {
130  $ilAccess->addInfoItem(IL_NO_OBJECT_ACCESS, implode(" / ", $info->getNotGrantedReasons()));
131  return false;
132  }
133  break;
134  }
135 
136  return true;
137  }
138 
142  public static function _checkGoto($a_target)
143  {
144  global $DIC;
145 
146  $ilAccess = $DIC->access();
147  // echo "-".$a_target."-"; exit;
148  $t_arr = explode("_", $a_target);
149 
150  if ($t_arr[0] != "wiki" || (((int) $t_arr[1]) <= 0) && $t_arr[1] != "wpage") {
151  return false;
152  }
153 
154  if ($t_arr[1] == "wpage") {
155  $wpg_id = (int) $t_arr[2];
156  include_once("./Modules/Wiki/classes/class.ilWikiPage.php");
157  $w_id = ilWikiPage::lookupWikiId($wpg_id);
158  if ((int) $t_arr[3] > 0) {
159  $refs = array((int) $t_arr[3]);
160  } else {
161  $refs = ilObject::_getAllReferences($w_id);
162  }
163  foreach ($refs as $r) {
164  if ($ilAccess->checkAccess("read", "", $r) ||
165  $ilAccess->checkAccess("visible", "", $r) ) {
166  return true;
167  }
168  }
169  } elseif ($ilAccess->checkAccess("read", "", $t_arr[1]) ||
170  $ilAccess->checkAccess("visible", "", $t_arr[1])) {
171  return true;
172  }
173  return false;
174  }
175 
181  public static function _lookupOnline($a_id)
182  {
183  global $DIC;
184 
185  $ilDB = $DIC->database();
186 
187  $q = "SELECT * FROM il_wiki_data WHERE id = " .
188  $ilDB->quote($a_id, "integer");
189  $wk_set = $ilDB->query($q);
190  $wk_rec = $ilDB->fetchAssoc($wk_set);
191 
192  return $wk_rec["is_online"];
193  }
194 
200  public static function _lookupOnlineStatus($a_ids)
201  {
202  global $DIC;
203 
204  $ilDB = $DIC->database();
205 
206  $q = "SELECT id, is_online FROM il_wiki_data WHERE " .
207  $ilDB->in("id", $a_ids, false, "integer");
208  $lm_set = $ilDB->query($q);
209  $status = [];
210  while ($r = $ilDB->fetchAssoc($lm_set)) {
211  $status[$r["id"]] = $r["is_online"];
212  }
213  return $status;
214  }
215 
216 
222  public static function _lookupPublicFiles($a_id)
223  {
224  global $DIC;
225 
226  $ilDB = $DIC->database();
227 
228  $q = "SELECT * FROM il_wiki_data WHERE id = " .
229  $ilDB->quote($a_id, "integer");
230  $wk_set = $ilDB->query($q);
231  $wk_rec = $ilDB->fetchAssoc($wk_set);
232 
233  return $wk_rec["public_files"];
234  }
235 }
static getInstance()
Get instance.
const IL_NO_OBJECT_ACCESS
static _getCommands()
get commands
user()
Definition: user.php:4
static _getAllReferences($a_id)
get all reference ids of object
static _checkGoto($a_target)
check whether goto script will succeed
static lookupWikiId($a_page_id)
Lookup wiki id.
const IL_STATUS_MESSAGE
$ilUser
Definition: imgupload.php:18
static _lookupPublicFiles($a_id)
Check wether files should be public.
$lm_set
__construct()
Constructor.
_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...
global $ilDB
static _lookupOnlineStatus($a_ids)
Check wether learning module is online (legacy version)
$DIC
Definition: xapitoken.php:46
static _lookupOnline($a_id)
Check wether wiki cast is online.
Class ilObjWikiAccess.