ILIAS  release_8 Revision v8.19-1-g4e8f2f9140c
All Data Structures Namespaces Files Functions Variables Modules Pages
ilObjLanguageFolder Class Reference

Class ilObjLanguageFolder contains all function to manage language support for ILIAS3 install, uninstall, checkfiles .... More...

+ Inheritance diagram for ilObjLanguageFolder:
+ Collaboration diagram for ilObjLanguageFolder:

Public Member Functions

 __construct (int $a_id, bool $a_call_by_reference=true)
 Constructor $a_id reference_id or object_id $a_call_by_reference treat the id as reference_id (true) or object_id (false) More...
 
 getLanguages ()
 gather all information about available languages More...
 
 addNewLanguages (array $a_languages)
 add new languages More...
 
 removeLanguages (array $a_languages)
 remove languages which are not installed AND has no lang-file More...
 
 checkAllLanguages ()
 validate the logical structure of a lang-file More...
 
- Public Member Functions inherited from ilObject
 __construct (int $id=0, bool $reference=true)
 
 withReferences ()
 determines whether objects are referenced or not (got ref ids or not) More...
 
 processAutoRating ()
 
 read ()
 
 getId ()
 
 setId (int $id)
 
 setRefId (int $ref_id)
 
 getRefId ()
 
 getType ()
 
 setType (string $type)
 
 getPresentationTitle ()
 get presentation title Normally same as title Overwritten for sessions More...
 
 getTitle ()
 
 getUntranslatedTitle ()
 Get untranslated object title WebDAV needs to access the untranslated title of an object. More...
 
 setTitle (string $title)
 
 getDescription ()
 
 setDescription (string $desc)
 
 getLongDescription ()
 get object long description (stored in object_description) More...
 
 getImportId ()
 
 setImportId (string $import_id)
 
 setOfflineStatus (bool $status)
 
 getOfflineStatus ()
 
 supportsOfflineHandling ()
 
 getOwner ()
 
 getOwnerName ()
 get full name of object owner More...
 
 setOwner (int $usr_id)
 
 getCreateDate ()
 Get create date in YYYY-MM-DD HH-MM-SS format. More...
 
 getLastUpdateDate ()
 Get last update date in YYYY-MM-DD HH-MM-SS format. More...
 
 create ()
 note: title, description and type should be set when this function is called More...
 
 update ()
 
 MDUpdateListener (string $element)
 Metadata update listener. More...
 
 createMetaData ()
 
 updateMetaData ()
 
 deleteMetaData ()
 
 updateOwner ()
 update owner of object in db More...
 
 putInTree (int $parent_ref_id)
 maybe this method should be in tree object!? More...
 
 setPermissions (int $parent_ref_id)
 
 setParentRolePermissions (int $parent_ref_id)
 Initialize the permissions of parent roles (local roles of categories, global roles...) This method is overwritten in e.g. More...
 
 createReference ()
 creates reference for object More...
 
 countReferences ()
 
 delete ()
 delete object or referenced object (in the case of a referenced object, object data is only deleted if last reference is deleted) This function removes an object entirely from system!! More...
 
 initDefaultRoles ()
 init default roles settings Purpose of this function is to create a local role folder and local roles, that are needed depending on the object type. More...
 
 applyDidacticTemplate (int $tpl_id)
 
 getXMLZip ()
 
 getHTMLDirectory ()
 
 appendCopyInfo (int $target_id, int $copy_id)
 Prepend Copy info if object with same name exists in that container. More...
 
 cloneDependencies (int $target_id, int $copy_id)
 Clone object dependencies. More...
 
 cloneMetaData (ilObject $target_obj)
 Copy meta data. More...
 
 selfOrParentWithRatingEnabled ()
 
 getPossibleSubObjects (bool $filter=true)
 get all possible sub objects of this type the object can decide which types of sub objects are possible jut in time overwrite if the decision distinguish from standard model More...
 

Data Fields

string $lang_default
 indicator for the system language this language must not be deleted More...
 
string $lang_user
 language that is in use by current user this language must not be deleted More...
 
string $lang_path
 path to language files relative path is taken from ini file and added to absolute path of ilias More...
 
string $separator
 separator value between module,identivier & value More...
 
array $languages
 contians all informations about languages More...
 
- Data Fields inherited from ilObject
const TITLE_LENGTH = 255
 
const DESC_LENGTH = 128
 
const LONG_DESC_LENGTH = 4000
 
const TABLE_OBJECT_DATA = "object_data"
 
array $objectList
 
string $untranslatedTitle
 

Additional Inherited Members

- Static Public Member Functions inherited from ilObject
static _lookupObjIdByImportId (string $import_id)
 Get (latest) object id for an import id. More...
 
static _lookupImportId (int $obj_id)
 
static _lookupOwnerName (int $owner_id)
 Lookup owner name for owner id. More...
 
static _getIdForImportId (string $import_id)
 
static _getAllReferences (int $id)
 get all reference ids for object ID More...
 
static _lookupTitle (int $obj_id)
 
static lookupOfflineStatus (int $obj_id)
 Lookup offline status using objectDataCache. More...
 
static _lookupOwner (int $obj_id)
 Lookup owner user ID for object ID. More...
 
static _getIdsForTitle (string $title, string $type='', bool $partial_match=false)
 
static _lookupDescription (int $obj_id)
 
static _lookupLastUpdate (int $obj_id, bool $formatted=false)
 
static _getLastUpdateOfObjects (array $obj_ids)
 
static _lookupObjId (int $ref_id)
 
static _setDeletedDate (int $ref_id, int $deleted_by)
 
static setDeletedDates (array $ref_ids, int $user_id)
 
static _resetDeletedDate (int $ref_id)
 
static _lookupDeletedDate (int $ref_id)
 
static _writeTitle (int $obj_id, string $title)
 write title to db (static) More...
 
static _writeDescription (int $obj_id, string $desc)
 write description to db (static) More...
 
static _writeImportId (int $obj_id, string $import_id)
 write import id to db (static) More...
 
static _lookupType (int $id, bool $reference=false)
 
static _isInTrash (int $ref_id)
 
static _hasUntrashedReference (int $obj_id)
 checks whether an object has at least one reference that is not in trash More...
 
static _lookupObjectId (int $ref_id)
 
static _getObjectsDataForType (string $type, bool $omit_trash=false)
 get all objects of a certain type More...
 
static _exists (int $id, bool $reference=false, ?string $type=null)
 checks if an object exists in object_data More...
 
static _getObjectsByType (string $obj_type="", int $owner=null)
 
static _prepareCloneSelection (array $ref_ids, string $new_type, bool $show_path=true)
 Prepare copy wizard object selection. More...
 
static _getIcon (int $obj_id=0, string $size="big", string $type="", bool $offline=false)
 Get icon for repository item. More...
 
static collectDeletionDependencies (array &$deps, int $ref_id, int $obj_id, string $type, int $depth=0)
 Collect deletion dependencies. More...
 
static getDeletionDependencies (int $obj_id)
 Get deletion dependencies. More...
 
static getLongDescriptions (array $obj_ids)
 
static getAllOwnedRepositoryObjects (int $user_id)
 
static fixMissingTitles ($type, array &$obj_title_map)
 Try to fix missing object titles. More...
 
static _lookupCreationDate (int $obj_id)
 
static _getObjectTypeIdByTitle (string $type, \ilDBInterface $ilDB=null)
 
- Protected Member Functions inherited from ilObject
 doMDUpdateListener (string $a_element)
 
 beforeMDUpdateListener (string $a_element)
 
 doCreateMetaData ()
 
 beforeCreateMetaData ()
 
 doUpdateMetaData ()
 
 beforeUpdateMetaData ()
 
 doDeleteMetaData ()
 
 beforeDeleteMetaData ()
 
 handleAutoRating ()
 
 hasAutoRating ()
 
- Protected Attributes inherited from ilObject
ilLogger $obj_log
 
ILIAS $ilias
 
ilObjectDefinition $obj_definition
 
ilDBInterface $db
 
ilLogger $log
 
ilErrorHandling $error
 
ilTree $tree
 
ilAppEventHandler $app_event_handler
 
ilRbacAdmin $rbac_admin
 
ilRbacReview $rbac_review
 
ilObjUser $user
 
ilLanguage $lng
 
int $id
 
bool $referenced
 
bool $call_by_reference
 
int $max_title = self::TITLE_LENGTH
 
int $max_desc = self::DESC_LENGTH
 
bool $add_dots = true
 
int $ref_id = null
 
string $type = ""
 
string $title = ""
 
bool $offline = false
 
string $desc = ""
 
string $long_desc = ""
 
int $owner = 0
 
string $create_date = ""
 
string $last_update = ""
 
string $import_id = ""
 
bool $register = false
 

Detailed Description

Class ilObjLanguageFolder contains all function to manage language support for ILIAS3 install, uninstall, checkfiles ....

Author
Sascha Hofmann shofm.nosp@m.ann@.nosp@m.datab.nosp@m.ay.d.nosp@m.e
Version
$Id$

Definition at line 31 of file class.ilObjLanguageFolder.php.

Constructor & Destructor Documentation

◆ __construct()

ilObjLanguageFolder::__construct ( int  $a_id,
bool  $a_call_by_reference = true 
)

Constructor $a_id reference_id or object_id $a_call_by_reference treat the id as reference_id (true) or object_id (false)

Definition at line 68 of file class.ilObjLanguageFolder.php.

References ILIAS\GlobalScreen\Provider\__construct(), and ILIAS\Repository\lng().

69  {
70  $this->type = "lngf";
71  parent::__construct($a_id, $a_call_by_reference);
72 
73  $this->lang_path = $this->lng->lang_path;
74  $this->lang_default = $this->lng->lang_default;
75  $this->lang_user = $this->lng->lang_user;
76  $this->separator = $this->lng->separator;
77  }
__construct(Container $dic, ilPlugin $plugin)
+ Here is the call graph for this function:

Member Function Documentation

◆ addNewLanguages()

ilObjLanguageFolder::addNewLanguages ( array  $a_languages)

add new languages

This functions checks in $languages for languages with the attribute 'new' and insert these languages in db-table 'languages'

Definition at line 176 of file class.ilObjLanguageFolder.php.

Referenced by getLanguages().

176  : array
177  {
178  if (count($a_languages) > 0) {
179  foreach ($a_languages as $lang_key => $lang_data) {
180  if (isset($lang_data["info"]) && $lang_data["info"] === "new_language") {
181  include_once "./Services/Language/classes/class.ilObjLanguage.php";
182  $lngObj = new ilObjLanguage();
183  $lngObj->setTitle($lang_key);
184  $lngObj->setDescription("not_installed");
185  $lngObj->create();
186 
187  // must get OOP through the whole class some time
188  // (no arrays with db fields! this class doesn't know anything about table object!)
189  $a_languages[$lang_key] = array("obj_id" => $lngObj->getId(),
190  "type" => $lngObj->getType(),
191  "description" => $lngObj->getDescription(),
192  "desc" => $lngObj->getDescription(),
193  "owner" => $lngObj->getOwner(),
194  "create_date" => $lngObj->getCreateDate(),
195  "last_update" => $lngObj->getLastUpdateDate());
196 
197  $a_languages[$lang_key]["info"] = "new_language";
198  unset($lngObj); // better: the objects should be resident in an member array of this class
199  }
200  }
201  }
202 
203  return $a_languages;
204  }
Class ilObjLanguage.
+ Here is the caller graph for this function:

◆ checkAllLanguages()

ilObjLanguageFolder::checkAllLanguages ( )

validate the logical structure of a lang-file

This function is similar to function checkLanguage() (see below) but checks for all lang-files and outputs more helpful information.

Return system message

Definition at line 240 of file class.ilObjLanguageFolder.php.

References $d, ILIAS\LTI\ToolProvider\$key, ILIAS\LTI\ToolProvider\$reason, ilObjLanguage\cut_header(), and ILIAS\Repository\lng().

240  : string
241  {
242  // set path to directory where lang-files reside
243  $d = dir($this->lang_path);
244  $tmpPath = getcwd();
245  chdir($this->lang_path);
246 
247  // for giving a message when no lang-file was found
248  $found = false;
249 
250  $output = '';
251  // get available lang-files
252  while ($entry = $d->read()) {
253  if (is_file($entry) && (preg_match("~(^ilias_.{2}\.lang$)~", $entry))) {
254  // textmeldung, wenn langfile gefunden wurde
255  $output .= "<br/><br/>" . $this->lng->txt("langfile_found") . ": " . $entry;
256  $content = file($entry);
257  $lines_full = count($content);
258  $found = true;
259  $error_param = false;
260  $error_double = false;
261  $double_checker = [];
262 
263  if ($content = ilObjLanguage::cut_header($content)) {
264  $lines_cut = count($content);
265  foreach ($content as $key => $val) {
266  $separated = explode($this->separator, trim($val));
267  $num = count($separated);
268  $line = $key + $lines_full - $lines_cut + 1;
269 
270  if ($num !== 3) {
271  $error_param = true;
272 
273  $output .= "<br/><b/>" . $this->lng->txt("err_in_line") . " " . $line . " !</b>&nbsp;&nbsp;";
274 
275  switch ($num) {
276  case 1:
277  if (empty($separated[0])) {
278  $output .= "<br/>" . $this->lng->txt("err_no_param") . " " . $this->lng->txt("check_langfile");
279  } else {
280  $output .= $this->lng->txt("module") . ": " . $separated[0];
281  $output .= "<br/>" . $this->lng->txt("err_1_param") . " " . $this->lng->txt("check_langfile");
282  }
283  break;
284 
285  case 2:
286  $output .= $this->lng->txt("module") . ": " . $separated[0];
287  $output .= ", " . $this->lng->txt("identifier") . ": " . $separated[1];
288  $output .= "<br/>" . $this->lng->txt("err_2_param") . " " . $this->lng->txt("check_langfile");
289  break;
290 
291  default:
292  $output .= $this->lng->txt("module") . ": " . $separated[0];
293  $output .= ", " . $this->lng->txt("identifier") . ": " . $separated[1];
294  $output .= ", " . $this->lng->txt("value") . ": " . $separated[2];
295  $output .= "<br/>" . $this->lng->txt("err_over_3_param") . " " . $this->lng->txt("check_langfile");
296  break;
297  }
298  continue;
299  }
300  if ($double_checker[strtolower($separated[0])][strtolower($separated[1])] ?? false) {
301  $error_double = true;
302 
303  $output .= "<br/><b/>" . $this->lng->txt("err_in_line") . " " . $double_checker[strtolower($separated[0])][strtolower($separated[1])] . " " . $this->lng->txt("and") . " " . $line . " !</b>&nbsp;&nbsp;";
304  $output .= $this->lng->txt("module") . ": " . $separated[0];
305  $output .= ", " . $this->lng->txt("identifier") . ": " . $separated[1];
306  $output .= ", " . $this->lng->txt("value") . ": " . $separated[2];
307  }
308  $double_checker[strtolower($separated[0])][strtolower($separated[1])] = $line;
309  }
310 
311  if ($error_param || $error_double) {
312  $reason = "";
313  if ($error_param) {
314  $reason .= " " . $this->lng->txt("err_count_param");
315  }
316  if ($error_double) {
317  $reason .= " " . $this->lng->txt("err_double_entries");
318  }
319  $output .= "<br/>" . $this->lng->txt("file_not_valid") . $reason;
320  } else {
321  $output .= "<br/>" . $this->lng->txt("file_valid");
322  }
323  } else {
324  $output .= "<br/>" . $this->lng->txt("file_not_valid") . " " . $this->lng->txt("err_wrong_header");
325  }
326  }
327  }
328 
329  $d->close();
330 
331  if (!$found) {
332  $output .= "<br/>" . $this->lng->txt("err_no_langfile_found");
333  }
334 
335  chdir($tmpPath);
336  return $output;
337  }
string $key
Consumer key/client ID value.
Definition: System.php:193
string $reason
Error message for last request processed.
Definition: System.php:102
static cut_header(array $content)
remove lang-file haeder information from &#39;$content&#39; This function seeks for a special keyword where t...
for($i=6; $i< 13; $i++) for($i=1; $i< 13; $i++) $d
Definition: date.php:296
+ Here is the call graph for this function:

◆ getLanguages()

ilObjLanguageFolder::getLanguages ( )

gather all information about available languages

This function builds an array with the following structure: $languages[lang_key][long][installed][update][info]

lang_key: string international language key (2 digits, i.e. de,en,dk...) long: string full language name in the chosen user language installed: boolean is the language installed (true) or not (false)? update: int contains the timestamp of last db-modification info: string optional information. valid is: 'notfound','new'

Returns $languages status information about available languages

Definition at line 93 of file class.ilObjLanguageFolder.php.

References $d, $lang, $languages, ilObject\_getObjectsByType(), addNewLanguages(), ILIAS\Repository\lng(), and removeLanguages().

93  : array
94  {
95  $this->lng->loadLanguageModule("meta");
96 
97  // set path to directory where lang-files reside
98  $d = dir($this->lang_path);
99  $tmpPath = getcwd();
100  chdir($this->lang_path);
101 
102  $languages = [];
103 
104  // get available lang-files
105  while ($entry = $d->read()) {
106  if (is_file($entry) && (preg_match("~(^ilias_.{2}\.lang$)~", $entry))) {
107  $lang_key = substr($entry, 6, 2);
108  $languages[$lang_key] = ""; // long names will be set in class Out
109  }
110  }
111 
112  $language = array();
113  $tmp_array = array_keys($languages);
114  $lang_keys = array();
115 
116  // now get languages from database
117  if ($lang_db = ilObject::_getObjectsByType("lng")) {
118  foreach ($lang_db as $lang) {
119  // set values
120  $lang_key = $lang["title"];
121  $languages[$lang_key] = $lang;
122  $lang_keys[] = $lang_key;
123 
124  $languages[$lang_key]["info"] = "";
125  $languages[$lang_key]["status"] = "";
126 
127  // determine default language and language of current user
128  if ($lang_key === $this->lang_user) {
129  $languages[$lang_key]["status"] = "in_use";
130  }
131 
132  if ($lang_key === $this->lang_default) {
133  $languages[$lang_key]["status"] = "system_language";
134  }
135 
136  // check if files are missing
137  if (count($tmp_array) > 0 && !in_array($lang_key, $tmp_array, true)) {
138  $languages[$lang_key]["info"] = "file_not_found";
139  }
140  }
141  }
142 
143  // compute new languages
144  foreach ($languages as $lang_key => $lang_data) {
145  if (!in_array($lang_key, $lang_keys, true)) {
146  $languages[$lang_key] = array();
147  $languages[$lang_key]["info"] = "new_language";
148  //$languages[$lang_key]["desc"] = "not_installed";
149  }
150  }
151 
152  chdir($tmpPath);
153 
154  // Insert languages with files new found into table language
156 
157  // Remove from array & db languages which are not installed and no lang-files
159 
160  // setting language's full names
161  foreach ($languages as $lang_key => $lang_data) {
162  $languages[$lang_key]["name"] = $this->lng->txt("meta_l_" . $lang_key);
163  }
164 
165  $this->languages = $languages;
166 
167  return $this->languages;
168  }
static _getObjectsByType(string $obj_type="", int $owner=null)
removeLanguages(array $a_languages)
remove languages which are not installed AND has no lang-file
$lang
Definition: xapiexit.php:26
array $languages
contians all informations about languages
for($i=6; $i< 13; $i++) for($i=1; $i< 13; $i++) $d
Definition: date.php:296
addNewLanguages(array $a_languages)
add new languages
+ Here is the call graph for this function:

◆ removeLanguages()

ilObjLanguageFolder::removeLanguages ( array  $a_languages)

remove languages which are not installed AND has no lang-file

This function removes only the entry in db-table 'languages' and in the array $languages. Does not uninstall a language (see: function flushLanguage())

Return $languages updated status information about available languages

Definition at line 214 of file class.ilObjLanguageFolder.php.

References $query.

Referenced by getLanguages().

214  : array
215  {
216  foreach ($a_languages as $lang_key => $lang_data) {
217  if ($lang_data["desc"] === "not_installed" && $lang_data["info"] === "file_not_found") {
218  // update languages array
219  unset($a_languages[$lang_key]);
220 
221  // update object_data table
222  $query = "DELETE FROM object_data " .
223  "WHERE type = " . $this->db->quote("lng", "text") . " " .
224  "AND title = " . $this->db->quote($lang_key, "text");
225  $this->db->manipulate($query);
226  }
227  }
228 
229  return $a_languages;
230  }
$query
+ Here is the caller graph for this function:

Field Documentation

◆ $lang_default

string ilObjLanguageFolder::$lang_default

indicator for the system language this language must not be deleted

Definition at line 37 of file class.ilObjLanguageFolder.php.

◆ $lang_path

string ilObjLanguageFolder::$lang_path

path to language files relative path is taken from ini file and added to absolute path of ilias

Definition at line 51 of file class.ilObjLanguageFolder.php.

◆ $lang_user

string ilObjLanguageFolder::$lang_user

language that is in use by current user this language must not be deleted

Definition at line 44 of file class.ilObjLanguageFolder.php.

◆ $languages

array ilObjLanguageFolder::$languages

contians all informations about languages

Definition at line 61 of file class.ilObjLanguageFolder.php.

Referenced by getLanguages().

◆ $separator

string ilObjLanguageFolder::$separator

separator value between module,identivier & value

Definition at line 56 of file class.ilObjLanguageFolder.php.


The documentation for this class was generated from the following file: