4 include_once(
"./Services/DataSet/classes/class.ilDataSet.php");
30 $this->logger = $DIC->logger()->sess();
61 return "http://www.ilias.de/xml/Modules/Session/" . $a_entity;
70 protected function getTypes($a_entity, $a_version)
72 if ($a_entity ==
"sess") {
78 "Description" =>
"text",
80 "TutorName" =>
"text",
81 "TutorEmail" =>
"text",
82 "TutorPhone" =>
"text",
84 "Registration" =>
"integer",
85 "EventStart" =>
"text",
87 "StartingTime" =>
"integer",
88 "EndingTime" =>
"integer",
89 "Fulltime" =>
"integer" 95 "Description" =>
"text",
97 "TutorName" =>
"text",
98 "TutorEmail" =>
"text",
99 "TutorPhone" =>
"text",
101 "Registration" =>
"integer",
102 "EventStart" =>
"text",
103 "EventEnd" =>
"text",
104 "StartingTime" =>
"integer",
105 "EndingTime" =>
"integer",
106 "Fulltime" =>
"integer",
107 "LimitedRegistration" =>
"integer",
108 "WaitingList" =>
"integer",
109 "LimitUsers" =>
"integer" 115 "Description" =>
"text",
116 "Location" =>
"text",
117 "TutorName" =>
"text",
118 "TutorEmail" =>
"text",
119 "TutorPhone" =>
"text",
121 "Registration" =>
"integer",
122 "EventStart" =>
"text",
123 "EventEnd" =>
"text",
124 "StartingTime" =>
"integer",
125 "EndingTime" =>
"integer",
126 "Fulltime" =>
"integer",
127 "LimitedRegistration" =>
"integer",
128 "WaitingList" =>
"integer",
129 "AutoWait" =>
"integer",
130 "LimitUsers" =>
"integer",
131 "MinUsers" =>
"integer" 137 "Description" =>
"text",
138 "Location" =>
"text",
139 "TutorName" =>
"text",
140 "TutorEmail" =>
"text",
141 "TutorPhone" =>
"text",
143 "Registration" =>
"integer",
144 "EventStart" =>
"text",
145 "EventEnd" =>
"text",
146 "StartingTime" =>
"integer",
147 "EndingTime" =>
"integer",
148 "Fulltime" =>
"integer",
149 "LimitedRegistration" =>
"integer",
150 "WaitingList" =>
"integer",
151 "AutoWait" =>
"integer",
152 "LimitUsers" =>
"integer",
153 "MinUsers" =>
"integer",
154 'MailMembers' =>
'integer',
155 'ShowMembers' =>
'integer',
162 "Description" =>
"text",
163 "Location" =>
"text",
164 "TutorName" =>
"text",
165 "TutorEmail" =>
"text",
166 "TutorPhone" =>
"text",
168 "Registration" =>
"integer",
169 "EventStart" =>
"text",
170 "EventEnd" =>
"text",
171 "StartingTime" =>
"integer",
172 "EndingTime" =>
"integer",
173 "Fulltime" =>
"integer",
174 "LimitedRegistration" =>
"integer",
175 "WaitingList" =>
"integer",
176 "AutoWait" =>
"integer",
177 "LimitUsers" =>
"integer",
178 "MinUsers" =>
"integer",
179 'MailMembers' =>
'integer',
180 'ShowMembers' =>
'integer',
182 'ShowCannotPart' =>
'integer',
183 'RegistrationNotificationEnabled' =>
'integer',
184 'RegistrationNotificationOption' =>
'text' 189 if ($a_entity ==
"sess_item") {
190 switch ($a_version) {
197 "SessionId" =>
"integer",
210 public function readData($a_entity, $a_version, $a_ids, $a_field =
"")
214 $ilDB = $DIC[
'ilDB'];
216 if (!is_array($a_ids)) {
217 $a_ids = array($a_ids);
220 if ($a_entity ==
"sess") {
221 switch ($a_version) {
224 " location, tutor_name, tutor_email, tutor_phone, details, registration, " .
225 " e_start event_start, e_end event_end, starting_time, ending_time, fulltime " .
226 " FROM event ev JOIN object_data od ON (ev.obj_id = od.obj_id) " .
227 " JOIN event_appointment ea ON (ev.obj_id = ea.event_id) " .
229 $ilDB->in(
"ev.obj_id", $a_ids,
false,
"integer"));
232 $this->
getDirectDataFromQuery($q =
"SELECT ev.obj_id id, od.title title, odes.description description, " .
233 " location, tutor_name, tutor_email, tutor_phone, details, reg_type registration, " .
234 " reg_limited limited_registration, reg_waiting_list waiting_list, " .
235 " reg_limit_users limit_users, " .
236 " e_start event_start, e_end event_end, starting_time, ending_time, fulltime " .
237 " FROM event ev JOIN object_data od ON (ev.obj_id = od.obj_id) " .
238 " JOIN event_appointment ea ON (ev.obj_id = ea.event_id) " .
239 " JOIN object_description odes ON (ev.obj_id = odes.obj_id) " .
241 $ilDB->in(
"ev.obj_id", $a_ids,
false,
"integer"));
244 $this->
getDirectDataFromQuery($q =
"SELECT ev.obj_id id, od.title title, odes.description description, " .
245 " location, tutor_name, tutor_email, tutor_phone, details, reg_type registration, " .
246 " reg_limited limited_registration, reg_waiting_list waiting_list, reg_auto_wait auto_wait, " .
247 " reg_limit_users limit_users, reg_min_users min_users, " .
248 " e_start event_start, e_end event_end, starting_time, ending_time, fulltime " .
249 " FROM event ev JOIN object_data od ON (ev.obj_id = od.obj_id) " .
250 " JOIN event_appointment ea ON (ev.obj_id = ea.event_id) " .
251 " JOIN object_description odes ON (ev.obj_id = odes.obj_id) " .
253 $ilDB->in(
"ev.obj_id", $a_ids,
false,
"integer"));
256 $this->
getDirectDataFromQuery($q =
"SELECT ev.obj_id id, od.title title, odes.description description, " .
257 " location, tutor_name, tutor_email, tutor_phone, details, reg_type registration, " .
258 " reg_limited limited_registration, reg_waiting_list waiting_list, reg_auto_wait auto_wait, " .
259 " reg_limit_users limit_users, reg_min_users min_users, " .
260 " e_start event_start, e_end event_end, starting_time, ending_time, fulltime, mail_members, show_members " .
261 " FROM event ev JOIN object_data od ON (ev.obj_id = od.obj_id) " .
262 " JOIN event_appointment ea ON (ev.obj_id = ea.event_id) " .
263 " JOIN object_description odes ON (ev.obj_id = odes.obj_id) " .
265 $ilDB->in(
"ev.obj_id", $a_ids,
false,
"integer"));
270 $this->
getDirectDataFromQuery($q =
"SELECT ev.obj_id id, od.title title, odes.description description, " .
271 " location, tutor_name, tutor_email, tutor_phone, details, reg_type registration, " .
272 " reg_limited limited_registration, reg_waiting_list waiting_list, reg_auto_wait auto_wait, " .
273 " reg_limit_users limit_users, reg_min_users min_users, " .
274 " e_start event_start, e_end event_end, starting_time, ending_time, fulltime, mail_members, show_members, " .
275 " show_cannot_part, reg_notification registration_notification_enabled, " .
276 " notification_opt registration_notification_option " .
277 " FROM event ev JOIN object_data od ON (ev.obj_id = od.obj_id) " .
278 " JOIN event_appointment ea ON (ev.obj_id = ea.event_id) " .
279 " JOIN object_description odes ON (ev.obj_id = odes.obj_id) " .
281 $ilDB->in(
"ev.obj_id", $a_ids,
false,
"integer"));
288 if ($a_entity ==
"sess_item") {
289 switch ($a_version) {
296 " FROM event_items " .
298 $ilDB->in(
"event_id", $a_ids,
false,
"integer"));
312 if ($a_entity ==
"sess") {
314 if (!$a_set[
"Fulltime"]) {
316 #$start = new ilDateTime($a_set["EventStart"], IL_CAL_DATETIME); 317 #$a_set["EventStart"] = $start->get(IL_CAL_DATETIME,'','UTC'); 318 #$end = new ilDateTime($a_set["EventEnd"], IL_CAL_DATETIME); 319 #$a_set["EventEnd"] = $end->get(IL_CAL_DATETIME,'','UTC'); 322 if ($a_entity ==
"sess_item") {
339 "sess_item" => array(
"ids" => $a_rec[
"Id"])
353 public function importRecord($a_entity, $a_types, $a_rec, $a_mapping, $a_schema_version)
357 include_once(
"./Modules/Session/classes/class.ilObjSession.php");
358 include_once(
"./Modules/Session/classes/class.ilSessionAppointment.php");
360 if ($new_id = $a_mapping->getMapping(
'Services/Container',
'objs', $a_rec[
'Id'])) {
364 $this->logger->debug(
'Session creation without existing instance');
366 $newObj->setType(
"sess");
367 $newObj->create(
true);
369 $newObj->setTitle($a_rec[
"Title"]);
370 $newObj->setDescription($a_rec[
"Description"]);
371 $newObj->setLocation($a_rec[
"Location"]);
372 $newObj->setName($a_rec[
"TutorName"]);
373 $newObj->setPhone($a_rec[
"TutorPhone"]);
374 $newObj->setEmail($a_rec[
"TutorEmail"]);
375 $newObj->setDetails($a_rec[
"Details"]);
377 switch ($a_schema_version) {
380 if (isset($a_rec[
'MailMembers'])) {
381 $newObj->setMailToMembersType($a_rec[
'MailMembers']);
383 if (isset($a_rec[
'ShowMembers'])) {
384 $newObj->setShowMembers($a_rec[
'ShowMembers']);
386 if (isset($a_rec[
'ShowCannotPart'])) {
387 $newObj->enableCannotParticipateOption((
bool) $a_rec[
'ShowCannotPart']);
389 if (isset($a_rec[
'RegistrationNotificationEnabled'])) {
390 $newObj->setRegistrationNotificationEnabled((
bool) $a_rec[
'RegistrationNotificationEnabled']);
392 if (isset($a_rec[
'RegistrationNotificationOption'])) {
393 $newObj->setRegistrationNotificationOption((
string) $a_rec[
'RegistrationNotificationOption']);
399 $newObj->setRegistrationType($a_rec[
"Registration"]);
401 $newObj->enableRegistrationUserLimit($a_rec[
"LimitedRegistration"]);
402 $newObj->setRegistrationMaxUsers($a_rec[
"LimitUsers"]);
403 $newObj->enableRegistrationWaitingList($a_rec[
"WaitingList"]);
405 if (isset($a_rec[
"MinUsers"])) {
406 $newObj->setRegistrationMinUsers($a_rec[
"MinUsers"]);
409 if (isset($a_rec[
"AutoWait"])) {
410 $newObj->setWaitingListAutoFill($a_rec[
"AutoWait"]);
415 $newObj->update(
true);
422 $app->setStart($a_rec[
"EventStart"]);
423 $app->setEnd($a_rec[
"EventEnd"]);
426 $app->toggleFullTime($a_rec[
"Fulltime"]);
427 $app->setSessionId($newObj->getId());
433 $this->current_obj = $newObj;
434 $a_mapping->addMapping(
"Modules/Session",
"sess", $a_rec[
"Id"], $newObj->getId());
435 $a_mapping->addMapping(
'Services/Object',
'objs', $a_rec[
'Id'], $newObj->getId());
436 $a_mapping->addMapping(
'Services/AdvancedMetaData',
'parent', $a_rec[
'Id'], $newObj->getId());
437 $a_mapping->addMapping(
440 $a_rec[
"Id"] .
":0:sess",
441 $newObj->getId() .
":0:sess" 450 if ($obj_id = $a_mapping->getMapping(
'Services/Container',
'objs', $a_rec[
'ItemId'])) {
452 include_once
'./Modules/Session/classes/class.ilEventItems.php';
468 foreach ($a_obj_ids as $obj_id) {
470 foreach ($ref_ids as $ref_id) {
472 $this->data[$counter++][
'Type'] = (int) $tpl_id;
484 $this->logger->debug(
'Apply didactic template');
486 if ((
int) $tpl_id == 0) {
487 $this->logger->debug(
'Default permissions');
493 foreach ($templates as $template) {
494 if ($template->isAutoGenerated()) {
495 $this->logger->debug(
'Apply first auto generated');
static lookupTemplateId($a_ref_id)
Lookup template id ilDB $ilDB.
getSupportedVersions()
Get supported versions.
applyDidacticTemplate(ilObject $rep_object, $tpl_id)
readData($a_entity, $a_version, $a_ids, $a_field="")
Read data.
setTargetId(int $target_id)
getDirectDataFromQuery($a_query, $a_convert_to_leading_upper=true, $a_set=true)
Get data from query.This is a standard procedure, all db field names are directly mapped to abstract ...
static _getAllReferences($a_id)
get all reference ids of object
getDependencies($a_entity, $a_version, $a_rec, $a_ids)
Determine the dependent sets of data.
importRecord($a_entity, $a_types, $a_rec, $a_mapping, $a_schema_version)
Import record.
getTypes($a_entity, $a_version)
Get field types for entity.
applyDidacticTemplate($a_tpl_id)
Apply template.
getXmlNamespace($a_entity, $a_schema_version)
Get xml namespace.
static _lookupObjId($a_id)
static getInstanceByObjectType($a_obj_type)
Get instance by obj type.
__construct(Container $dic, ilPlugin $plugin)
getXmlRecord($a_entity, $a_version, $a_set)
Get xml record (export)
static getInstanceByRefId($a_ref_id, $stop_on_error=true)
get an instance of an Ilias object by reference id
readDidacticTemplateType($a_obj_ids)
addItem($a_item_ref_id)
Add one item.
A dataset contains in data in a common structure that can be shared and transformed for different pur...
class ilSessionAppointment