4 include_once(
"./Services/DataSet/classes/class.ilDataSet.php");
27 return array(
"4.3.0",
"4.5.0",
"5.1.0",
"5.2.0",
"5.3.0");
38 return "http://www.ilias.de/xml/Services/User/" . $a_entity;
47 protected function getTypes($a_entity, $a_version)
50 if ($a_entity ==
"usr_profile") {
60 "Firstname" =>
"text",
65 "Institution" =>
"text",
66 "Department" =>
"text",
71 "SelCountry" =>
"text",
72 "PhoneOffice" =>
"text",
73 "PhoneHome" =>
"text",
74 "PhoneMobile" =>
"text",
77 "SecondEmail" =>
"text",
79 "ReferralComment" =>
"text",
80 "Matriculation" =>
"text",
82 "Longitude" =>
"text",
84 "Picture" =>
"directory" 89 if ($a_entity ==
"usr_setting") {
97 "UserId" =>
"integer",
104 if ($a_entity ==
"personal_data") {
105 switch ($a_version) {
117 if ($a_entity ==
"usr_multi") {
118 switch ($a_version) {
124 "UserId" =>
"integer",
143 if ($a_entity ==
"usr_profile") {
146 include_once(
"./Services/User/classes/class.ilObjUser.php");
148 $im = ilObjUser::_getPersonalPicturePath(
159 $this->temp_picture_dirs[$a_set[
"Id"]] = $tmp_dir;
161 $a_set[
"Picture"] = $tmp_dir;
175 if ($a_entity ==
"usr_profile") {
177 $tmp_dir = $this->temp_picture_dirs[$a_set[
"Id"]];
178 if ($tmp_dir !=
"" && is_dir($tmp_dir)) {
190 public function readData($a_entity, $a_version, $a_ids, $a_field =
"")
194 if (!is_array($a_ids)) {
195 $a_ids =
array($a_ids);
198 if ($a_entity ==
"personal_data") {
199 switch ($a_version) {
206 foreach ($a_ids as
$id) {
213 if ($a_entity ==
"usr_profile") {
214 switch ($a_version) {
219 " title, birthday, gender, institution, department, street, city, zipcode, country, sel_country, " .
220 " phone_office, phone_home, phone_mobile, fax, email, hobby, referral_comment, matriculation, " .
221 " delicious, latitude, longitude, loc_zoom" .
222 " FROM usr_data u " .
224 $ilDB->in(
"u.usr_id", $a_ids,
false,
"integer"));
229 " title, birthday, gender, institution, department, street, city, zipcode, country, sel_country, " .
230 " phone_office, phone_home, phone_mobile, fax, email, hobby, referral_comment, matriculation, " .
231 " latitude, longitude, loc_zoom" .
232 " FROM usr_data u " .
234 $ilDB->in(
"u.usr_id", $a_ids,
false,
"integer"));
238 " title, birthday, gender, institution, department, street, city, zipcode, country, sel_country, " .
239 " phone_office, phone_home, phone_mobile, fax, email, second_email, hobby, referral_comment, matriculation, " .
240 " latitude, longitude, loc_zoom" .
241 " FROM usr_data u " .
243 $ilDB->in(
"u.usr_id", $a_ids,
false,
"integer"));
248 if ($a_entity ==
"usr_setting") {
249 switch ($a_version) {
256 $prefs =
array(
"date_format",
"day_end",
"day_start",
"bs_allow_to_contact_me",
"chat_osc_accept_msg",
"hide_own_online_status",
"hits_per_page",
"language",
257 "public_birthday",
"puplic_city",
"public_country",
"public_delicious",
"public_department",
"public_email",
"public_second_email",
258 "public_fax",
"public_gender",
"public_hobby",
"public_im_aim",
"public_im_icq",
"public_im_jabber",
259 "public_im_msn",
"public_im_skype",
"public_im_voip",
"public_im_yahoo",
"public_institution",
"public_location",
260 "public_matriculation",
"public_phone_home",
"public_phone_mobile",
"public_phone_office",
261 "public_profile",
"public_sel_country",
"public_street",
"public_title",
"public_upload",
"public_zipcode",
262 "screen_reader_optimization",
"show_users_online",
263 "store_last_visited",
"time_format",
"user_tz",
"weekstart",
264 "session_reminder_enabled",
"session_reminder_lead_time",
"usr_starting_point",
265 "char_selector_availability",
"char_selector_definition");
267 if (version_compare($a_version,
'5.2.0',
'>=')) {
269 $prefs[
'public_im_aim'], $prefs[
'public_im_icq'], $prefs[
'public_im_jabber'],
270 $prefs[
'public_im_msn'], $prefs[
'public_im_skype'], $prefs[
'public_im_voip'],
271 $prefs[
'public_im_yahoo'], $prefs[
'public_delicious']
276 $set = $ilDB->query(
"SELECT * FROM usr_pref " .
277 " WHERE " . $ilDB->in(
"keyword", $prefs,
false,
"text") .
278 " AND " . $ilDB->in(
"usr_id", $a_ids,
false,
"integer"));
279 while ($rec = $ilDB->fetchAssoc($set)) {
280 $this->
data[] =
array(
"UserId" => $rec[
"usr_id"],
"Keyword" => $rec[
"keyword"],
"Value" => $rec[
"value"]);
286 if ($a_entity ==
"usr_multi") {
287 switch ($a_version) {
293 $set = $ilDB->query(
"SELECT * FROM usr_data_multi" .
294 " WHERE " . $ilDB->in(
"usr_id", $a_ids,
false,
"integer"));
295 while ($rec = $ilDB->fetchAssoc($set)) {
296 $this->
data[] =
array(
"UserId" => $rec[
"usr_id"],
"FieldId" => $rec[
"field_id"],
"Value" => $rec[
"value"]);
310 case "personal_data":
312 "usr_profile" =>
array(
"ids" => $a_rec[
"Id"]),
313 "usr_setting" =>
array(
"ids" => $a_rec[
"Id"]),
314 "usr_multi" =>
array(
"ids" => $a_rec[
"Id"])
327 public function importRecord($a_entity, $a_types, $a_rec, $a_mapping, $a_schema_version)
334 case "personal_data":
337 $a_mapping->addMapping(
"Services/User",
"usr", $a_rec[
"Id"], $ilUser->getId());
341 $usr_id = $a_mapping->getMapping(
"Services/User",
"usr", $a_rec[
"Id"]);
343 if (!isset($this->users[$usr_id])) {
344 $this->users[$usr_id] =
new ilObjUser($usr_id);
346 $user = $this->users[$usr_id];
347 include_once(
"./Services/User/classes/class.ilUserProfile.php");
349 $prof->skipField(
"username");
350 $prof->skipField(
"password");
351 $prof->skipField(
"roles");
352 $prof->skipGroup(
"settings");
353 $fields = $prof->getStandardFields();
354 foreach ($fields as $k => $f) {
358 !$ilSetting->get(
"usr_settings_disable_" . $k) &&
359 $f[
"method"] !=
"" && isset($a_rec[$up_k])) {
360 $set_method =
"set" . substr($f[
"method"], 3);
365 $user->setLatitude($a_rec[
"Latitude"]);
366 $user->setLongitude($a_rec[
"Longitude"]);
367 $user->setLocationZoom($a_rec[
"LocZoom"]);
372 $pic_dir = $this->
getImportDirectory() .
"/" . str_replace(
"..",
"", $a_rec[
"Picture"]);
373 if ($pic_dir !=
"" && is_dir($pic_dir)) {
374 $upload_file = $pic_dir .
"/upload_" . $a_rec[
"Id"] .
"pic";
375 if (is_file($upload_file)) {
383 $usr_id = $a_mapping->getMapping(
"Services/User",
"usr", $a_rec[
"UserId"]);
385 if (!isset($this->users[$usr_id])) {
386 $this->users[$usr_id] =
new ilObjUser($usr_id);
388 $user = $this->users[$usr_id];
394 $usr_id = $a_mapping->getMapping(
"Services/User",
"usr", $a_rec[
"UserId"]);
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 userSettingVisible($a_setting)
Checks whether user setting is visible.
if(!array_key_exists('StateId', $_REQUEST)) $id
importRecord($a_entity, $a_types, $a_rec, $a_mapping, $a_schema_version)
Import record.
getImportDirectory()
Get import directory.
convertToLeadingUpper($a_str)
Make xyz_abc a XyzAbc string.
static copyProfilePicturesToDirectory($a_user_id, $a_dir)
Get profile picture direcotory.
static _uploadPersonalPicture($tmp_file, $obj_id)
Create a personal picture image file from a temporary image file.
Create styles array
The data for the language used.
static _lookupType($a_id, $a_reference=false)
lookup object type
readData($a_entity, $a_version, $a_ids, $a_field="")
Read data.
static makeDir($a_dir)
creates a new directory and inherits all filesystem permissions of the parent directory You may pass ...
getDependencies($a_entity, $a_version, $a_rec, $a_ids)
Determine the dependent sets of data.
static ilTempnam($a_temp_path=null)
Create a temporary file in an ILIAS writable directory.
getXmlNamespace($a_entity, $a_schema_version)
Get xml namespace.
getSupportedVersions()
Get supported versions.
static secureString($a_str, $a_strip_html=true, $a_allow="")
Remove unsecure tags.
getXmlRecord($a_entity, $a_version, $a_set)
Get xml record.
A dataset contains in data in a common structure that can be shared and transformed for different pur...
getTypes($a_entity, $a_version)
Get field types for entity.
static delDir($a_dir, $a_clean_only=false)
removes a dir and all its content (subdirs and files) recursively
afterXmlRecordWriting($a_entity, $a_version, $a_set)
After xml record writing hook record.