ILIAS  trunk Revision v12.0_alpha-377-g3641b37b9db
ilObjLanguage Class Reference

Class ilObjLanguage. More...

+ Inheritance diagram for ilObjLanguage:
+ Collaboration diagram for ilObjLanguage:

Public Member Functions

 __construct (int $a_id=0, bool $a_call_by_reference=false)
 Constructor. More...
 
 getKey ()
 get language key More...
 
 getStatus ()
 get language status More...
 
 isSystemLanguage ()
 check if language is system language More...
 
 isUserLanguage ()
 check if language is system language More...
 
 isInstalled ()
 Check language object status, and return true if language is installed. More...
 
 isLocal ()
 Check language object status, and return true if a local language file is installed. More...
 
 install (string $scope="")
 install current language More...
 
 uninstall ()
 uninstall current language More...
 
 refresh ()
 refresh current language More...
 
 flush (string $a_mode="all")
 remove language data from database $a_mode "all" or "keep_local" More...
 
 getLocalChanges (string $a_min_date="", string $a_max_date="")
 get locally changed language entries $a_min_date minimum change date "yyyy-mm-dd hh:mm:ss" $a_max_date maximum change date "yyyy-mm-dd hh:mm:ss" Return array [module][identifier] => value More...
 
 insert (string $scope="")
 insert language data from file into database More...
 
 resetUserLanguage (string $lang_key)
 search ILIAS for users which have selected '$lang_key' as their prefered language and reset them to default language (english). More...
 
 optimizeData ()
 optimizes the db-table langdata More...
 
 check (string $scope="")
 Validate the logical structure of a lang file. More...
 
- Public Member Functions inherited from ilObject
 getObjectProperties ()
 
 flushObjectProperties ()
 
 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 $description)
 
 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, int $new_obj_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...
 

Static Public Member Functions

static getInstalledLanguages ()
 Get the language objects of the installed languages. More...
 
static getLangKeysOfInstalledLanguages ()
 Return the language keys of the installed languages. More...
 
static refreshAll ()
 Refresh all installed languages. More...
 
static refreshPlugins (?array $a_lang_keys=null)
 Refresh languages of activated plugins $a_lang_keys keys of languages to be refreshed (not yet supported, all available will be refreshed) More...
 
static _deleteLangData (string $a_lang_key, bool $a_keep_local_change=false)
 Delete languge data $a_lang_key lang key. More...
 
static _getLastLocalChange (string $a_key)
 get the date of the last local change $a_key language key Return change_date "yyyy-mm-dd hh:mm:ss" More...
 
static _getLocalChangesByModule (string $a_key, string $a_module)
 Get the local changes of a language module $a_key Language key $a_module Module key Return array identifier => value. More...
 
static replaceLangModule (string $a_key, string $a_module, array $a_array)
 Replace language module array. More...
 
static replaceLangEntry (string $a_module, string $a_identifier, string $a_lang_key, string $a_value, ?string $a_local_change=null, ?string $a_remarks=null)
 Replace lang entry. More...
 
static updateLangEntry (string $a_module, string $a_identifier, string $a_lang_key, string $a_value, ?string $a_local_change=null, ?string $a_remarks=null)
 Replace lang entry. More...
 
static deleteLangEntry (string $a_module, string $a_identifier, string $a_lang_key)
 Delete lang entry. More...
 
static cut_header (array $content)
 remove lang-file haeder information from '$content' This function seeks for a special keyword where the language information starts. More...
 
static countUsers (string $a_lang)
 Count number of users that use a language. More...
 
- 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 getIconForType (string $type)
 
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)
 

Data Fields

string $separator
 separator of module, comment separator, identifier & values in language files More...
 
string $comment_separator
 
string $lang_default
 
string $lang_user
 
string $lang_path
 
string $key
 
string $status
 
string $cust_lang_path
 
- 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

- 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
 
LOMServices $lom_services
 
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 = ""
 
string $desc = ""
 
string $long_desc = ""
 
int $owner = 0
 
string $create_date = ""
 
string $last_update = ""
 
string $import_id = ""
 
bool $register = false
 

Detailed Description

Class ilObjLanguage.

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

Definition at line 29 of file class.ilObjLanguage.php.

Constructor & Destructor Documentation

◆ __construct()

ilObjLanguage::__construct ( int  $a_id = 0,
bool  $a_call_by_reference = false 
)

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 50 of file class.ilObjLanguage.php.

51 {
52 global $DIC;
53 $lng = $DIC->language();
54
55 $this->type = "lng";
56 parent::__construct($a_id, $a_call_by_reference);
57
58 $this->type = "lng";
59 $this->key = $this->title;
60 $this->status = $this->desc;
61 $this->lang_default = $lng->lang_default;
62 $this->lang_user = $lng->lang_user;
63 $this->lang_path = $lng->lang_path;
64 $this->cust_lang_path = $lng->getCustomLangPath();
65 $this->separator = $lng->separator;
66 $this->comment_separator = $lng->comment_separator;
67 }
string $desc
string $title
ilLanguage $lng
__construct(Container $dic, ilPlugin $plugin)
@inheritDoc
global $DIC
Definition: shib_login.php:26

References ilObject\$desc, $DIC, ilObject\$lng, ilObject\$title, ILIAS\GlobalScreen\Provider\__construct(), and ilLanguage\getCustomLangPath().

+ Here is the call graph for this function:

Member Function Documentation

◆ _deleteLangData()

static ilObjLanguage::_deleteLangData ( string  $a_lang_key,
bool  $a_keep_local_change = false 
)
static

Delete languge data $a_lang_key lang key.

Definition at line 309 of file class.ilObjLanguage.php.

309 : void
310 {
311 global $DIC;
312 $ilDB = $DIC->database();
313
314 if (!$a_keep_local_change) {
315 $ilDB->manipulate("DELETE FROM lng_data WHERE lang_key = " .
316 $ilDB->quote($a_lang_key, "text"));
317 } else {
318 $ilDB->manipulate("DELETE FROM lng_data WHERE lang_key = " .
319 $ilDB->quote($a_lang_key, "text") .
320 " AND local_change IS NULL");
321 }
322 }

References $DIC, and $ilDB.

Referenced by flush().

+ Here is the caller graph for this function:

◆ _getLastLocalChange()

static ilObjLanguage::_getLastLocalChange ( string  $a_key)
static

get the date of the last local change $a_key language key Return change_date "yyyy-mm-dd hh:mm:ss"

Definition at line 382 of file class.ilObjLanguage.php.

382 : string
383 {
384 global $DIC;
385 $ilDB = $DIC->database();
386
387 $q = sprintf(
388 "SELECT MAX(local_change) last_change FROM lng_data " .
389 "WHERE lang_key = %s AND local_change IS NOT NULL",
390 $ilDB->quote($a_key, "text")
391 );
392 $result = $ilDB->query($q);
393
394 if ($row = $result->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) {
395 return (string) $row["last_change"];
396 } else {
397 return "";
398 }
399 }
$q
Definition: shib_logout.php:23

References $DIC, $ilDB, $q, and ilDBConstants\FETCHMODE_ASSOC.

Referenced by ilObjLanguageFolderGUI\buildConfirmModal(), ilObjLanguageFolderGUI\confirmRefreshSelectedObject(), and ilLanguageFolderTable\getRows().

+ Here is the caller graph for this function:

◆ _getLocalChangesByModule()

static ilObjLanguage::_getLocalChangesByModule ( string  $a_key,
string  $a_module 
)
static

Get the local changes of a language module $a_key Language key $a_module Module key Return array identifier => value.

Definition at line 408 of file class.ilObjLanguage.php.

408 : array
409 {
410 global $DIC;
411 $ilDB = $DIC->database();
412
413 $changes = array();
414 $result = $ilDB->queryF(
415 "SELECT * FROM lng_data WHERE lang_key = %s AND module = %s AND local_change IS NOT NULL",
416 array("text", "text"),
417 array($a_key, $a_module)
418 );
419
420 while ($row = $ilDB->fetchAssoc($result)) {
421 $changes[$row["identifier"]] = $row["value"];
422 }
423 return $changes;
424 }

References $DIC, and $ilDB.

Referenced by ilPluginLanguage\updateLanguages().

+ Here is the caller graph for this function:

◆ check()

ilObjLanguage::check ( string  $scope = "")

Validate the logical structure of a lang file.

This function checks if a lang file exists, the file has a header, and each lang-entry consists of exactly three elements (module, identifier, value).

$scope empty (global) or "local" Return system message

Definition at line 688 of file class.ilObjLanguage.php.

688 : bool
689 {
690 global $DIC;
691 $scopeExtension = "";
692 if (!empty($scope)) {
693 if ($scope === "global") {
694 $scope = "";
695 } else {
696 $scopeExtension = "." . $scope;
697 }
698 }
699
701 if ($scope === "local") {
703 }
704
705 $tmpPath = getcwd();
706
707 // dir check
708 if (!is_dir($path)) {
709 $DIC->ui()->mainTemplate()->setOnScreenMessage(
710 'failure',
711 "Directory not found: " . $path,
712 true
713 );
714 $DIC->ctrl()->redirectByClass(ilobjlanguagefoldergui::class, 'view');
715 }
716
717 chdir($path);
718
719 // compute lang-file name format
720 $lang_file = "ilias_" . $this->key . ".lang" . $scopeExtension;
721
722 // file check
723 if (!is_file($lang_file)) {
724 $DIC->ui()->mainTemplate()->setOnScreenMessage(
725 'failure',
726 "File not found: " . $lang_file,
727 true
728 );
729 $DIC->ctrl()->redirectByClass(ilobjlanguagefoldergui::class, 'view');
730 }
731
732 // header check
733 $content = self::cut_header(file($lang_file));
734 if ($content === false) {
735 $DIC->ui()->mainTemplate()->setOnScreenMessage(
736 'failure',
737 "Wrong Header in " . $lang_file,
738 true
739 );
740 $DIC->ctrl()->redirectByClass(ilobjlanguagefoldergui::class, 'view');
741 }
742
743 // check (counting) elements of each lang-entry
744 $line = 0;
745 $n = 0;
746 foreach ($content as $key => $val) {
747 $separated = explode($this->separator, trim($val));
748 $num = count($separated);
749 ++$n;
750 if ($num !== 3) {
751 $line = $n + 36;
752 $DIC->ui()->mainTemplate()->setOnScreenMessage(
753 'failure',
754 "Wrong parameter count in " . $lang_file . " in line $line (Value: $val)! Please check your language file!",
755 true
756 );
757 $DIC->ctrl()->redirectByClass(ilobjlanguagefoldergui::class, 'view');
758 }
759 if (!ilStr::isUtf8($separated[2])) {
760 $DIC->ui()->mainTemplate()->setOnScreenMessage(
761 'failure',
762 "Non UTF8 character found in " . $lang_file . " in line $line (Value: $val)! Please check your language file!",
763 true
764 );
765 $DIC->ctrl()->redirectByClass(ilobjlanguagefoldergui::class, 'view');
766 }
767 }
768
769 chdir($tmpPath);
770
771 // no error occured
772 return true;
773 }
static cut_header(array $content)
remove lang-file haeder information from '$content' This function seeks for a special keyword where t...
static isUtf8(string $a_str)
Check whether string is utf-8.
$scope
Definition: ltiregstart.php:51
$path
Definition: ltiservices.php:30

References $DIC, $path, $scope, and ilStr\isUtf8().

Referenced by install(), and refresh().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ countUsers()

static ilObjLanguage::countUsers ( string  $a_lang)
static

Count number of users that use a language.

Definition at line 778 of file class.ilObjLanguage.php.

778 : int
779 {
780 global $DIC;
781 $ilDB = $DIC->database();
782 $lng = $DIC->language();
783
784 $set = $ilDB->query("SELECT COUNT(*) cnt FROM usr_data ud JOIN usr_pref up" .
785 " ON ud.usr_id = up.usr_id " .
786 " WHERE up.value = " . $ilDB->quote($a_lang, "text") .
787 " AND up.keyword = " . $ilDB->quote("language", "text"));
788 $rec = $ilDB->fetchAssoc($set);
789
790 // add users with no usr_pref set to default language
791 if ($a_lang == $lng->lang_default) {
792 $set2 = $ilDB->query("SELECT COUNT(*) cnt FROM usr_data ud LEFT JOIN usr_pref up" .
793 " ON (ud.usr_id = up.usr_id AND up.keyword = " . $ilDB->quote("language", "text") . ")" .
794 " WHERE up.value IS NULL ");
795 $rec2 = $ilDB->fetchAssoc($set2);
796 }
797
798 return (int) $rec["cnt"] + (int) ($rec2["cnt"] ?? 0);
799 }

References $DIC, $ilDB, $lng, and ILIAS\Repository\int().

Referenced by ilLanguageFolderTable\getRows(), and ILIAS\Dashboard\DataRetrieval\Language\getRows().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ cut_header()

static ilObjLanguage::cut_header ( array  $content)
static

remove lang-file haeder information from '$content' This function seeks for a special keyword where the language information starts.

if found it returns the plain language information, otherwise returns false

$content expecting an ILIAS lang-file Return content without header info OR false if no valid header was found

Returns
bool|array

Definition at line 656 of file class.ilObjLanguage.php.

657 {
658 foreach ($content as $key => $val) {
659 if (trim($val) === "<!-- language file start -->") {
660 return array_slice($content, $key + 1);
661 }
662 }
663
664 return false;
665 }

Referenced by ilObjLanguageFolder\checkAllLanguages().

+ Here is the caller graph for this function:

◆ deleteLangEntry()

static ilObjLanguage::deleteLangEntry ( string  $a_module,
string  $a_identifier,
string  $a_lang_key 
)
staticfinal

Delete lang entry.

Definition at line 612 of file class.ilObjLanguage.php.

612 : bool
613 {
614 global $DIC;
615 $ilDB = $DIC->database();
616
617 $ilDB->manipulate(sprintf(
618 "DELETE FROM lng_data " .
619 "WHERE module = %s AND identifier = %s AND lang_key = %s ",
620 $ilDB->quote($a_module, "text"),
621 $ilDB->quote($a_identifier, "text"),
622 $ilDB->quote($a_lang_key, "text")
623 ));
624
625 return true;
626 }

References $DIC, and $ilDB.

Referenced by ilObjLanguageExt\_deleteValues().

+ Here is the caller graph for this function:

◆ flush()

ilObjLanguage::flush ( string  $a_mode = "all")

remove language data from database $a_mode "all" or "keep_local"

Definition at line 328 of file class.ilObjLanguage.php.

328 : void
329 {
330 global $DIC;
331 $ilDB = $DIC->database();
332
333 self::_deleteLangData($this->key, ($a_mode === "keep_local"));
334
335 if ($a_mode === "all") {
336 $ilDB->manipulate("DELETE FROM lng_modules WHERE lang_key = " .
337 $ilDB->quote($this->key, "text"));
338 }
339 }
static _deleteLangData(string $a_lang_key, bool $a_keep_local_change=false)
Delete languge data $a_lang_key lang key.

References $DIC, $ilDB, and _deleteLangData().

Referenced by install(), refresh(), and uninstall().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getInstalledLanguages()

static ilObjLanguage::getInstalledLanguages ( )
static

Get the language objects of the installed languages.

Definition at line 73 of file class.ilObjLanguage.php.

73 : array
74 {
75 $objects = array();
76 $languages = ilObject::_getObjectsByType("lng");
77 foreach ($languages as $lang) {
78 $langObj = new ilObjLanguage((int) $lang["obj_id"], false);
79 if ($langObj->isInstalled()) {
80 $objects[] = $langObj;
81 } else {
82 unset($langObj);
83 }
84 }
85 return $objects;
86 }
Class ilObjLanguage.
static _getObjectsByType(string $obj_type="", ?int $owner=null)

References ilObject\_getObjectsByType().

+ Here is the call graph for this function:

◆ getKey()

ilObjLanguage::getKey ( )

get language key

Return language key

Definition at line 111 of file class.ilObjLanguage.php.

111 : string
112 {
113 return $this->key;
114 }

References $key.

Referenced by install(), and refresh().

+ Here is the caller graph for this function:

◆ getLangKeysOfInstalledLanguages()

static ilObjLanguage::getLangKeysOfInstalledLanguages ( )
static

Return the language keys of the installed languages.

Returns
array

Definition at line 94 of file class.ilObjLanguage.php.

94 : array
95 {
96 $lang_keys = [];
97 foreach (ilObject::_getObjectsByType("lng") as $lang) {
98 if ($lang['desc'] === 'installed') {
99 $lang_keys[] = $lang['title'];
100 }
101 }
102 return $lang_keys;
103 }

References ilObject\_getObjectsByType().

Referenced by ilPluginLanguage\updateLanguages().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getLocalChanges()

ilObjLanguage::getLocalChanges ( string  $a_min_date = "",
string  $a_max_date = "" 
)

get locally changed language entries $a_min_date minimum change date "yyyy-mm-dd hh:mm:ss" $a_max_date maximum change date "yyyy-mm-dd hh:mm:ss" Return array [module][identifier] => value

Definition at line 348 of file class.ilObjLanguage.php.

348 : array
349 {
350 global $DIC;
351 $ilDB = $DIC->database();
352
353 if ($a_min_date === "") {
354 $a_min_date = "1980-01-01 00:00:00";
355 }
356 if ($a_max_date === "") {
357 $a_max_date = "2200-01-01 00:00:00";
358 }
359
360 $q = sprintf(
361 "SELECT * FROM lng_data WHERE lang_key = %s " .
362 "AND local_change >= %s AND local_change <= %s",
363 $ilDB->quote($this->key, "text"),
364 $ilDB->quote($a_min_date, "timestamp"),
365 $ilDB->quote($a_max_date, "timestamp")
366 );
367 $result = $ilDB->query($q);
368
369 $changes = array();
370 while ($row = $result->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) {
371 $changes[$row["module"]][$row["identifier"]] = $row["value"];
372 }
373 return $changes;
374 }

References $DIC, $ilDB, $q, and ilDBConstants\FETCHMODE_ASSOC.

Referenced by insert().

+ Here is the caller graph for this function:

◆ getStatus()

ilObjLanguage::getStatus ( )

get language status

Return language status

Definition at line 121 of file class.ilObjLanguage.php.

121 : string
122 {
123 return $this->status;
124 }

References $status.

Referenced by isInstalled(), isLocal(), and refresh().

+ Here is the caller graph for this function:

◆ insert()

ilObjLanguage::insert ( string  $scope = "")

insert language data from file into database

$scope empty (global) or "local"

Definition at line 432 of file class.ilObjLanguage.php.

432 : void
433 {
434 global $DIC;
435 $ilDB = $DIC->database();
436 $scopeExtension = "";
437 if (!empty($scope)) {
438 if ($scope === "global") {
439 $scope = "";
440 } else {
441 $scopeExtension = "." . $scope;
442 }
443 }
444
446 if ($scope === "local") {
448 }
449
450 $lang_file = $path . "/ilias_" . $this->key . ".lang" . $scopeExtension;
451
452 if (is_file($lang_file)) {
453 // remove header first
454 if ($content = self::cut_header(file($lang_file))) {
455 $local_changes = null;
456 if (empty($scope)) {
457 // get all local changes for a global file
458 $local_changes = $this->getLocalChanges();
459 } elseif ($scope === "local") {
460 // get the modification date of the local file
461 // get the newer local changes for a local file
462 $min_date = gmdate("Y-m-d H:i:s", filemtime($lang_file));
463 $local_changes = $this->getLocalChanges($min_date);
464 }
465 $dbAccess = new ilObjLanguageDBAccess($ilDB, $this->key, $content, $local_changes, $scope);
466 $lang_array = $dbAccess->insertLangEntries($lang_file);
467 $dbAccess->replaceLangModules($lang_array);
468 }
469 }
470 }
getLocalChanges(string $a_min_date="", string $a_max_date="")
get locally changed language entries $a_min_date minimum change date "yyyy-mm-dd hh:mm:ss" $a_max_dat...

References $cust_lang_path, $DIC, $ilDB, $lang_path, $path, $scope, and getLocalChanges().

Referenced by install(), and refresh().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ install()

ilObjLanguage::install ( string  $scope = "")

install current language

$scope empty (global) or "local" Return installed language key

Definition at line 185 of file class.ilObjLanguage.php.

185 : string
186 {
187 if (!empty($scope)) {
188 if ($scope === "global") {
189 $scope = "";
190 } else {
191 $scopeExtension = "." . $scope;
192 }
193 }
194
195 if (!$this->isInstalled() || (!$this->isLocal() && !empty($scope))) {
196 if ($this->check($scope)) {
197 // lang-file is ok. Flush data in db and...
198 if (empty($scope)) {
199 $this->flush("keep_local");
200 }
201
202 // ...re-insert data from lang-file
203 $this->insert($scope);
204
205 // update information in db-table about available/installed languages
206 $newDesc = '';
207 if (empty($scope)) {
208 $newDesc = "installed";
209 } elseif ($scope === "local") {
210 $newDesc = "installed_local";
211 }
212 $this->setDescription($newDesc);
213 $this->update();
214 return $this->getKey();
215 }
216 }
217 return "";
218 }
flush(string $a_mode="all")
remove language data from database $a_mode "all" or "keep_local"
isInstalled()
Check language object status, and return true if language is installed.
getKey()
get language key
isLocal()
Check language object status, and return true if a local language file is installed.
check(string $scope="")
Validate the logical structure of a lang file.
insert(string $scope="")
insert language data from file into database
setDescription(string $description)

References $scope, check(), flush(), getKey(), insert(), isInstalled(), isLocal(), ilObject\setDescription(), and ilObject\update().

+ Here is the call graph for this function:

◆ isInstalled()

ilObjLanguage::isInstalled ( )

Check language object status, and return true if language is installed.

Return true if installed

Definition at line 155 of file class.ilObjLanguage.php.

155 : bool
156 {
157 if (str_starts_with($this->getStatus(), "installed")) {
158 return true;
159 } else {
160 return false;
161 }
162 }
getStatus()
get language status

References getStatus().

Referenced by install(), refresh(), and ilObjLanguageExt\setLocal().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ isLocal()

ilObjLanguage::isLocal ( )

Check language object status, and return true if a local language file is installed.

Return true if local language is installed

Definition at line 170 of file class.ilObjLanguage.php.

170 : bool
171 {
172 if (substr($this->getStatus(), 10) === "local") {
173 return true;
174 } else {
175 return false;
176 }
177 }

References getStatus().

Referenced by install(), and refresh().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ isSystemLanguage()

ilObjLanguage::isSystemLanguage ( )

check if language is system language

Definition at line 129 of file class.ilObjLanguage.php.

129 : bool
130 {
131 if ($this->key == $this->lang_default) {
132 return true;
133 } else {
134 return false;
135 }
136 }

◆ isUserLanguage()

ilObjLanguage::isUserLanguage ( )

check if language is system language

Definition at line 141 of file class.ilObjLanguage.php.

141 : bool
142 {
143 if ($this->key == $this->lang_user) {
144 return true;
145 } else {
146 return false;
147 }
148 }

◆ optimizeData()

ilObjLanguage::optimizeData ( )

optimizes the db-table langdata

Return true on success

Deprecated:

Definition at line 673 of file class.ilObjLanguage.php.

673 : bool
674 {
675 // Mantis #22313: removed table optimization
676 return true;
677 }

◆ refresh()

ilObjLanguage::refresh ( )

refresh current language

Definition at line 244 of file class.ilObjLanguage.php.

244 : bool
245 {
246 if ($this->isInstalled() && $this->check()) {
247 $this->flush("keep_local");
248 $this->insert();
249 $this->setTitle($this->getKey());
250 $this->setDescription($this->getStatus());
251 $this->update();
252
253 if ($this->isLocal() && $this->check("local")) {
254 $this->insert("local");
255 $this->setTitle($this->getKey());
256 $this->setDescription($this->getStatus());
257 $this->update();
258 }
259
260 return true;
261 }
262
263 return false;
264 }
setTitle(string $title)

References check(), flush(), getKey(), getStatus(), insert(), isInstalled(), isLocal(), ilObject\setDescription(), ilObject\setTitle(), and ilObject\update().

+ Here is the call graph for this function:

◆ refreshAll()

static ilObjLanguage::refreshAll ( )
static

Refresh all installed languages.

Definition at line 269 of file class.ilObjLanguage.php.

269 : void
270 {
271 $languages = ilObject::_getObjectsByType("lng");
272 $refreshed = array();
273
274 foreach ($languages as $lang) {
275 $langObj = new ilObjLanguage($lang["obj_id"], false);
276 if ($langObj->refresh()) {
277 $refreshed[] = $langObj->getKey();
278 }
279 unset($langObj);
280 }
281
282 self::refreshPlugins($refreshed);
283 }
static refreshPlugins(?array $a_lang_keys=null)
Refresh languages of activated plugins $a_lang_keys keys of languages to be refreshed (not yet suppor...

References ilObject\_getObjectsByType(), and refreshPlugins().

Referenced by ilObjLanguageFolderGUI\refreshObject().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ refreshPlugins()

static ilObjLanguage::refreshPlugins ( ?array  $a_lang_keys = null)
static

Refresh languages of activated plugins $a_lang_keys keys of languages to be refreshed (not yet supported, all available will be refreshed)

Definition at line 290 of file class.ilObjLanguage.php.

290 : void
291 {
292 global $DIC;
293
294 $component_repository = $DIC["component.repository"];
295 foreach ($component_repository->getPlugins() as $plugin) {
296 if (!$plugin->isActive()) {
297 continue;
298 }
300 $handler->updateLanguages($a_lang_keys);
301 }
302 }
$handler
Definition: oai.php:29

References $DIC, $handler, and XapiProxy\$plugin.

Referenced by refreshAll(), ilObjLanguageFolderGUI\refreshSelectedObject(), and ilObjLanguageFolderGUI\uninstallChangesObject().

+ Here is the caller graph for this function:

◆ replaceLangEntry()

static ilObjLanguage::replaceLangEntry ( string  $a_module,
string  $a_identifier,
string  $a_lang_key,
string  $a_value,
?string  $a_local_change = null,
?string  $a_remarks = null 
)
staticfinal

Replace lang entry.

Definition at line 523 of file class.ilObjLanguage.php.

530 : bool {
531 global $DIC;
532 $ilDB = $DIC->database();
533
534 // avoid a cache flush here (see mantis #28818)
535 // ilGlobalCache::flushAll();
536
537 if (is_string($a_remarks) && $a_remarks !== '') {
538 $a_remarks = substr($a_remarks, 0, 250);
539 }
540
541 if ($a_remarks === '') {
542 $a_remarks = null;
543 }
544
545 if ($a_value === "") {
546 $a_value = null;
547 } else {
548 $a_value = substr($a_value, 0, 4000);
549 }
550
551 $ilDB->replace(
552 "lng_data",
553 array(
554 "module" => array("text",$a_module),
555 "identifier" => array("text",$a_identifier),
556 "lang_key" => array("text",$a_lang_key)
557 ),
558 array(
559 "value" => array("text",$a_value),
560 "local_change" => array("timestamp",$a_local_change),
561 "remarks" => array("text", $a_remarks)
562 )
563 );
564 return true;
565 }

Referenced by ilObjLanguageExt\_saveValues(), ilObjLanguageExtGUI\saveNewEntryObject(), and ilPluginLanguage\updateLanguages().

+ Here is the caller graph for this function:

◆ replaceLangModule()

static ilObjLanguage::replaceLangModule ( string  $a_key,
string  $a_module,
array  $a_array 
)
staticfinal

Replace language module array.

Definition at line 475 of file class.ilObjLanguage.php.

475 : void
476 {
477 global $DIC;
478 $ilDB = $DIC->database();
479
480 // avoid flushing the whole cache (see mantis #28818)
481 ilCachedLanguage::getInstance($a_key)->deleteInCache();
482
483 $ilDB->manipulate(sprintf(
484 "DELETE FROM lng_modules WHERE lang_key = %s AND module = %s",
485 $ilDB->quote($a_key, "text"),
486 $ilDB->quote($a_module, "text")
487 ));
488
489 /*$ilDB->manipulate(sprintf("INSERT INTO lng_modules (lang_key, module, lang_array) VALUES ".
490 "(%s,%s,%s)", $ilDB->quote($a_key, "text"),
491 $ilDB->quote($a_module, "text"),
492 $ilDB->quote(serialize($a_array), "clob")));*/
493 $ilDB->insert("lng_modules", array(
494 "lang_key" => array("text", $a_key),
495 "module" => array("text", $a_module),
496 "lang_array" => array("clob", serialize($a_array))
497 ));
498
499 // check if the module is correctly saved
500 // see mantis #20046 and #19140
501 $result = $ilDB->queryF(
502 "SELECT lang_array FROM lng_modules WHERE lang_key = %s AND module = %s",
503 array("text","text"),
504 array($a_key, $a_module)
505 );
506 $row = $ilDB->fetchAssoc($result);
507
508 $unserialied = unserialize($row["lang_array"], ["allowed_classes" => false]);
509 if (!is_array($unserialied)) {
510 $DIC->ui()->mainTemplate()->setOnScreenMessage(
511 'failure',
512 "Data for module '" . $a_module . "' of language '" . $a_key . "' is not correctly saved. " .
513 "Please check the collation of your database tables lng_data and lng_modules. It must be utf8_unicode_ci.",
514 true
515 );
516 $DIC->ctrl()->redirectByClass(ilobjlanguagefoldergui::class, 'view');
517 }
518 }

References $DIC, $ilDB, and ilCachedLanguage\getInstance().

Referenced by ilObjLanguageExt\_deleteValues(), ilObjLanguageExt\_saveValues(), ilObjLanguageExtGUI\saveNewEntryObject(), and ilPluginLanguage\updateLanguages().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ resetUserLanguage()

ilObjLanguage::resetUserLanguage ( string  $lang_key)

search ILIAS for users which have selected '$lang_key' as their prefered language and reset them to default language (english).

A message is sent to all affected users

$lang_key international language key (2 digits)

Definition at line 635 of file class.ilObjLanguage.php.

635 : void
636 {
637 global $DIC;
638 $ilDB = $DIC->database();
639
640 $query = "UPDATE usr_pref SET " .
641 "value = " . $ilDB->quote($this->lang_default, "text") . " " .
642 "WHERE keyword = " . $ilDB->quote('language', "text") . " " .
643 "AND value = " . $ilDB->quote($lang_key, "text");
644 $ilDB->manipulate($query);
645 }

References $DIC, and $ilDB.

Referenced by uninstall().

+ Here is the caller graph for this function:

◆ uninstall()

ilObjLanguage::uninstall ( )

uninstall current language

Return uninstalled language key

Definition at line 226 of file class.ilObjLanguage.php.

226 : string
227 {
228 if ((str_starts_with($this->status, "installed")) && ($this->key != $this->lang_default) && ($this->key != $this->lang_user)) {
229 $this->flush();
230 $this->setTitle($this->key);
231 $this->setDescription("not_installed");
232 $this->update();
233 $this->resetUserLanguage($this->key);
234
235 return $this->key;
236 }
237 return "";
238 }
resetUserLanguage(string $lang_key)
search ILIAS for users which have selected '$lang_key' as their prefered language and reset them to d...

References $key, flush(), resetUserLanguage(), ilObject\setDescription(), ilObject\setTitle(), and ilObject\update().

+ Here is the call graph for this function:

◆ updateLangEntry()

static ilObjLanguage::updateLangEntry ( string  $a_module,
string  $a_identifier,
string  $a_lang_key,
string  $a_value,
?string  $a_local_change = null,
?string  $a_remarks = null 
)
staticfinal

Replace lang entry.

Definition at line 570 of file class.ilObjLanguage.php.

577 : void {
578 global $DIC;
579 $ilDB = $DIC->database();
580
581 if (is_string($a_remarks) && $a_remarks !== '') {
582 $a_remarks = substr($a_remarks, 0, 250);
583 }
584
585 if ($a_remarks === '') {
586 $a_remarks = null;
587 }
588
589 if ($a_value === "") {
590 $a_value = null;
591 } else {
592 $a_value = substr($a_value, 0, 4000);
593 }
594
595 $ilDB->manipulate(sprintf(
596 "UPDATE lng_data " .
597 "SET value = %s, local_change = %s, remarks = %s " .
598 "WHERE module = %s AND identifier = %s AND lang_key = %s ",
599 $ilDB->quote($a_value, "text"),
600 $ilDB->quote($a_local_change, "timestamp"),
601 $ilDB->quote($a_remarks, "text"),
602 $ilDB->quote($a_module, "text"),
603 $ilDB->quote($a_identifier, "text"),
604 $ilDB->quote($a_lang_key, "text")
605 ));
606 }

Field Documentation

◆ $comment_separator

string ilObjLanguage::$comment_separator

Definition at line 36 of file class.ilObjLanguage.php.

◆ $cust_lang_path

string ilObjLanguage::$cust_lang_path

Definition at line 42 of file class.ilObjLanguage.php.

Referenced by ilObjLanguageExt\getCustLangPath(), and insert().

◆ $key

string ilObjLanguage::$key

Definition at line 40 of file class.ilObjLanguage.php.

Referenced by getKey(), and uninstall().

◆ $lang_default

string ilObjLanguage::$lang_default

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

◆ $lang_path

string ilObjLanguage::$lang_path

Definition at line 39 of file class.ilObjLanguage.php.

Referenced by ilObjLanguageExt\getLangPath(), and insert().

◆ $lang_user

string ilObjLanguage::$lang_user

Definition at line 38 of file class.ilObjLanguage.php.

◆ $separator

string ilObjLanguage::$separator

separator of module, comment separator, identifier & values in language files

Definition at line 35 of file class.ilObjLanguage.php.

◆ $status

string ilObjLanguage::$status

Definition at line 41 of file class.ilObjLanguage.php.

Referenced by getStatus().


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