ILIAS  release_8 Revision v8.24
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)

Reimplemented from ilObject.

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

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)
@inheritDoc

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

+ 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.

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.

Referenced by getLanguages().

+ 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.

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 }
static cut_header(array $content)
remove lang-file haeder information from '$content' 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
string $reason
Error message for last request processed.
Definition: System.php:102
string $key
Consumer key/client ID value.
Definition: System.php:193

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

+ 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.

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 }
array $languages
contians all informations about languages
removeLanguages(array $a_languages)
remove languages which are not installed AND has no lang-file
addNewLanguages(array $a_languages)
add new languages
static _getObjectsByType(string $obj_type="", int $owner=null)
$lang
Definition: xapiexit.php:26

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

+ 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.

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

References $query.

Referenced by getLanguages().

+ 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: