ILIAS  Release_3_10_x_branch Revision 61812
 All Data Structures Namespaces Files Functions Variables Groups Pages
ilObjLanguageExt Class Reference

Class ilObjLanguageExt. More...

+ Inheritance diagram for ilObjLanguageExt:
+ Collaboration diagram for ilObjLanguageExt:

Public Member Functions

 ilObjLanguageExt ($a_id=0, $a_call_by_reference=false)
 Constructor.
 getGlobalLanguageFile ()
 Read and get the global language file as an object.
 setLocal ($a_local=true)
 Set the local status of the language.
 getLongDescription ()
 Get the full language description.
 getLangPath ()
 Get the language files path.
 getCustLangPath ()
 Get the customized language files path.
 getAllValues ($a_modules=array(), $a_pattern= '')
 Get all values from the database.
 getChangedValues ($a_modules=array(), $a_pattern= '')
 Get only the changed values from the database which differ from the original language file.
 getUnchangedValues ($a_modules=array(), $a_pattern= '')
 Get only the unchanged values from the database which are equal to the original language file.
 getCommentedValues ($a_modules=array(), $a_pattern= '')
 Get all values from the database for wich the global language file has a comment.
 importLanguageFile ($a_file, $a_mode_existing= 'keepnew')
 Import a language file into the ilias database.
- Public Member Functions inherited from ilObjLanguage
 ilObjLanguage ($a_id=0, $a_call_by_reference=false)
 Constructor.
 getKey ()
 get language key
 getStatus ()
 get language status
 isSystemLanguage ()
 check if language is system language
 isUserLanguage ()
 check if language is system language
 isInstalled ()
 Check language object status, and return true if language is installed.
 isLocal ()
 Check language object status, and return true if a local language file is installed.
 install ($scope= '')
 install current language
 uninstall ()
 uninstall current language
 flush ($a_mode= 'all')
 remove language data from database
 getLocalChanges ($a_min_date="", $a_max_date="")
 get locally changed language entries
 insert ($scope= '')
 insert language data from file into database
 resetUserLanguage ($lang_key)
 search ILIAS for users which have selected '$lang_key' as their prefered language and reset them to default language (english).
 cut_header ($content)
 remove lang-file haeder information from '$content' This function seeks for a special keyword where the language information starts.
 optimizeData ()
 optimizes the db-table langdata
 check ($scope= '')
 Validate the logical structure of a lang file.
- Public Member Functions inherited from ilObject
 ilObject ($a_id=0, $a_reference=true)
 Constructor public.
 withReferences ()
 determines wehter objects are referenced or not (got ref ids or not)
 read ($a_force_db=false)
 read object data from db into object
 getId ()
 get object id public
 setId ($a_id)
 set object id public
 setRefId ($a_id)
 set reference id public
 getRefId ()
 get reference id public
 getType ()
 get object type public
 setType ($a_type)
 set object type public
 getPresentationTitle ()
 get presentation title Normally same as title Overwritten for sessions
 getTitle ()
 get object title public
 getUntranslatedTitle ()
 get untranslated object title public
 setTitle ($a_title)
 set object title
 getDescription ()
 get object description
 setDescription ($a_desc)
 set object description
 getImportId ()
 get import id
 setImportId ($a_import_id)
 set import id
 _lookupObjIdByImportId ($a_import_id)
 getOwner ()
 get object owner
 getOwnerName ()
 _lookupOwnerName ($a_owner_id)
 lookup owner name for owner id
 setOwner ($a_owner)
 set object owner
 getCreateDate ()
 get create date public
 getLastUpdateDate ()
 get last update date public
 setObjDataRecord ($a_record)
 set object_data record (note: this method should only be called from the ilObjectFactory class)
 create ()
 create
 update ()
 update object in db
 MDUpdateListener ($a_element)
 Meta data update listener.
 createMetaData ()
 create meta data entry
 updateMetaData ()
 update meta data entry
 deleteMetaData ()
 delete meta data entry
 updateOwner ()
 update owner of object in db
 _getIdForImportId ($a_import_id)
 get current object id for import id (static)
 _getAllReferences ($a_id)
 get all reference ids of object
 _lookupTitle ($a_id)
 lookup object title
 _lookupDescription ($a_id)
 lookup object description
 _lookupLastUpdate ($a_id, $a_as_string=false)
 lookup last update
 _getLastUpdateOfObjects ($a_objs)
 Get last update for a set of media objects.
 _lookupObjId ($a_id)
 _setDeletedDate ($a_ref_id)
 only called in ilTree::saveSubTree
 _resetDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes
 _writeTitle ($a_obj_id, $a_title)
 write title to db (static)
 _writeDescription ($a_obj_id, $a_desc)
 write description to db (static)
 _writeImportId ($a_obj_id, $a_import_id)
 write import id to db (static)
 _lookupType ($a_id, $a_reference=false)
 lookup object type
 _isInTrash ($a_ref_id)
 checks wether object is in trash
 _hasUntrashedReference ($a_obj_id)
 checks wether an object has at least one reference that is not in trash
 _lookupObjectId ($a_ref_id)
 lookup object id
 _getObjectsDataForType ($a_type, $a_omit_trash=false)
 get all objects of a certain type
 putInTree ($a_parent_ref)
 maybe this method should be in tree object!?
 setPermissions ($a_parent_ref)
 set permissions of object
 createReference ()
 creates reference for object
 countReferences ()
 count references of object
 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!!
 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 If you want to setup default local roles you MUST overwrite this method in derived object classes (see ilObjForum for an example) public
 createRoleFolder ()
 creates a local role folder
 notify ($a_event, $a_ref_id, $a_parent_non_rbac_id, $a_node_id, $a_params=0)
 notifys an object about an event occured Based on the event passed, each object may decide how it reacts.
 setRegisterMode ($a_bool)
 isUserRegistered ($a_user_id=0)
 requireRegistration ()
 getXMLZip ()
 getHTMLDirectory ()
 cloneObject ($a_target_id, $a_copy_id=0)
 Clone object permissions, put in tree ...
 appendCopyInfo ($a_target_id, $a_copy_id)
 Prepend Copy info if object with same name exists in that container.
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies.
 cloneMetaData ($target_obj)
 Copy meta data.

Static Public Member Functions

static _getModules ($a_lang_key)
 Get all modules of a language.
static _getValues ($a_lang_key, $a_modules=array(), $a_topics=array(), $a_pattern= '', $a_state= '')
 Get the translations of specified topics.
static _saveValues ($a_lang_key, $a_values=array())
 Save a set of translation in the database.
- Static Public Member Functions inherited from ilObjLanguage
static replaceLangModule ($a_key, $a_module, $a_array)
 Replace language module array.
- Static Public Member Functions inherited from ilObject
static _getIdsForTitle ($title, $type= '')
 _exists ($a_id, $a_reference=false)
 checks if an object exists in object_data
static _getObjectsByType ($a_obj_type="")
 Get objects by type.
static _prepareCloneSelection ($a_ref_ids, $new_type)
 Prepare copy wizard object selection.
static _getIcon ($a_obj_id="", $a_size="big", $a_type="", $a_offline=false)

Additional Inherited Members

- Data Fields inherited from ilObjLanguage
 $separator
 $comment_separator
 $lang_default
 $lang_user
 $lang_path
 $key
 $status

Detailed Description

Member Function Documentation

static ilObjLanguageExt::_getModules (   $a_lang_key)
static

Get all modules of a language.

static

Parameters
stringlanguage key
Returns
array list of modules

Definition at line 241 of file class.ilObjLanguageExt.php.

References DB_FETCHMODE_ASSOC.

Referenced by ilObjLanguageExtGUI\statisticsObject(), and ilObjLanguageExtGUI\viewObject().

{
global $ilDB;
$q = "SELECT DISTINCT module FROM lng_data WHERE ".
" lang_key = ".$ilDB->quote($a_lang_key).
" order by module";
$set = $ilDB->query($q);
while ($rec = $set->fetchRow(DB_FETCHMODE_ASSOC))
{
$modules[] = $rec["module"];
}
return $modules;
}

+ Here is the caller graph for this function:

static ilObjLanguageExt::_getValues (   $a_lang_key,
  $a_modules = array(),
  $a_topics = array(),
  $a_pattern = '',
  $a_state = '' 
)
static

Get the translations of specified topics.

static

Parameters
stringlanguage key
arraylist of modules
arraylist of topics
arraysearch pattern
stringlocal change state ('changed', 'unchanged', '')
Returns
array module.separator.topic => value

Definition at line 268 of file class.ilObjLanguageExt.php.

References ilObject\$lng, and DB_FETCHMODE_ASSOC.

Referenced by getAllValues(), getChangedValues(), getCommentedValues(), getUnchangedValues(), and ilObjLanguageExtGUI\viewObject().

{
global $ilDB, $lng;
if (is_array($a_modules))
{
for ($i = 0; $i < count($a_modules); $i++)
{
$a_modules[$i] = $ilDB->quote($a_modules[$i]);
}
$modules_list = implode(',', $a_modules);
}
if (is_array($a_topics))
{
for ($i = 0; $i < count($a_topics); $i++)
{
$a_topics[$i] = $ilDB->quote($a_topics[$i]);
}
$topics_list = implode(',', $a_topics);
}
$q = "SELECT * FROM lng_data WHERE".
" lang_key =".$ilDB->quote($a_lang_key);
if ($modules_list)
{
$q .= " AND module in (". $modules_list. ")";
}
if ($topics_list)
{
$q .= " AND identifier in (". $topics_list. ")";
}
if ($a_pattern)
{
$q .= " AND value like ". $ilDB->quote("%".$a_pattern."%");
}
if ($a_state == "changed")
{
$q .= " AND local_change <> '0000-00-00 00:00:00'";
}
if ($a_state == "unchanged")
{
$q .= " AND local_change = '0000-00-00 00:00:00'";
}
$q .= " ORDER BY module, identifier";
$set = $ilDB->query($q);
$values = array();
while ($rec = $set->fetchRow(DB_FETCHMODE_ASSOC))
{
$values[$rec["module"].$lng->separator.$rec["identifier"]] = $rec["value"];
}
return $values;
}

+ Here is the caller graph for this function:

static ilObjLanguageExt::_saveValues (   $a_lang_key,
  $a_values = array() 
)
static

Save a set of translation in the database.

static

Parameters
stringlanguage key
arraymodule.separator.topic => value

Definition at line 331 of file class.ilObjLanguageExt.php.

References ilObjLanguage\$key, ilObject\$lng, ilLanguageFile\_getGlobalLanguageFile(), and DB_FETCHMODE_ASSOC.

Referenced by importLanguageFile(), and ilObjLanguageExtGUI\saveObject().

{
global $ilDB, $lng;
if (!is_array($a_values))
{
return;
}
$save_array = array();
$save_date = date("Y-m-d H:i:s", time());
// read and get the global values
require_once "./Services/Language/classes/class.ilLanguageFile.php";
$global_file_obj = ilLanguageFile::_getGlobalLanguageFile($a_lang_key);
$global_values = $global_file_obj->getAllValues();
// save the single translations in lng_data
foreach ($a_values as $key => $value)
{
$keys = explode($lng->separator, $key);
if (count($keys) == 2)
{
$module = $keys[0];
$topic = $keys[1];
$save_array[$module][$topic] = $value;
$local_change = $global_values[$key] == $value ?
"0000-00-00 00:00:00" : $save_date;
$q = "REPLACE INTO lng_data(lang_key, module, identifier, value, local_change)"
. " VALUES("
. $ilDB->quote($a_lang_key). ","
. $ilDB->quote($module). ","
. $ilDB->quote($topic). ","
. $ilDB->quote($value). ","
. $ilDB->quote($local_change). ")";
$ilDB->query($q);
}
}
// save the serialized module entries in lng_modules
foreach ($save_array as $module => $entries)
{
$q = "SELECT * FROM lng_modules WHERE ".
" lang_key = ".$ilDB->quote($a_lang_key).
" AND module = ".$ilDB->quote($module);
$set = $ilDB->query($q);
$row = $set->fetchRow(DB_FETCHMODE_ASSOC);
$arr = unserialize($row["lang_array"]);
if (is_array($arr))
{
$entries = array_merge($arr, $entries);
}
$q = "REPLACE INTO lng_modules (lang_key, module, lang_array) VALUES ".
"(".$ilDB->quote($a_lang_key).", " .
" ".$ilDB->quote($module).", " .
" ".$ilDB->quote(serialize($entries)).") ";
$ilDB->query($q);
}
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjLanguageExt::getAllValues (   $a_modules = array(),
  $a_pattern = '' 
)

Get all values from the database.

Parameters
arraylist of modules
stringsearch pattern
Returns
array module.separator.topic => value

Definition at line 114 of file class.ilObjLanguageExt.php.

References _getValues().

Referenced by importLanguageFile().

{
return self::_getValues($this->key, $a_modules, NULL, $a_pattern);
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjLanguageExt::getChangedValues (   $a_modules = array(),
  $a_pattern = '' 
)

Get only the changed values from the database which differ from the original language file.

Parameters
arraylist of modules
stringsearch pattern
Returns
array module.separator.topic => value

Definition at line 128 of file class.ilObjLanguageExt.php.

References _getValues().

Referenced by importLanguageFile().

{
return self::_getValues($this->key, $a_modules, NULL, $a_pattern, 'changed');
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjLanguageExt::getCommentedValues (   $a_modules = array(),
  $a_pattern = '' 
)

Get all values from the database for wich the global language file has a comment.

Parameters
arraylist of modules
arraysearch pattern
Returns
array module.separator.topic => value

Definition at line 156 of file class.ilObjLanguageExt.php.

References ilObjLanguage\$key, _getValues(), and getGlobalLanguageFile().

{
$global_file_obj = $this->getGlobalLanguageFile();
$global_values = $global_file_obj->getAllValues();
$local_values = self::_getValues($this->key, $a_modules, NULL, $a_pattern);
$commented = array();
foreach ($local_values as $key => $value)
{
if ($global_comments[$key] != "")
{
$commented[$key] = $value;
}
}
return $commented;
}

+ Here is the call graph for this function:

ilObjLanguageExt::getCustLangPath ( )

Get the customized language files path.

Returns
string path of customized language files folder

Definition at line 102 of file class.ilObjLanguageExt.php.

{
return $this->cust_lang_path;
}
ilObjLanguageExt::getGlobalLanguageFile ( )

Read and get the global language file as an object.

Returns
object global language file

Definition at line 49 of file class.ilObjLanguageExt.php.

References ilLanguageFile\_getGlobalLanguageFile().

Referenced by getCommentedValues().

{
require_once "./Services/Language/classes/class.ilLanguageFile.php";
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjLanguageExt::getLangPath ( )

Get the language files path.

Returns
string path of language files folder

Definition at line 92 of file class.ilObjLanguageExt.php.

References ilObjLanguage\$lang_path.

{
}
ilObjLanguageExt::getLongDescription ( )

Get the full language description.

Returns
string description

Reimplemented from ilObject.

Definition at line 82 of file class.ilObjLanguageExt.php.

{
return $this->lng->txt($this->desc);
}
ilObjLanguageExt::getUnchangedValues (   $a_modules = array(),
  $a_pattern = '' 
)

Get only the unchanged values from the database which are equal to the original language file.

Parameters
arraylist of modules
arraysearch pattern
Returns
array module.separator.topic => value

Definition at line 142 of file class.ilObjLanguageExt.php.

References _getValues().

{
return self::_getValues($this->key, $a_modules, NULL, $a_pattern, 'unchanged');
}

+ Here is the call graph for this function:

ilObjLanguageExt::ilObjLanguageExt (   $a_id = 0,
  $a_call_by_reference = false 
)

Constructor.

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

References ilObjLanguage\ilObjLanguage().

{
$this->ilObjLanguage($a_id, $a_call_by_reference);
}

+ Here is the call graph for this function:

ilObjLanguageExt::importLanguageFile (   $a_file,
  $a_mode_existing = 'keepnew' 
)

Import a language file into the ilias database.

Parameters
stringhandling of existing values ('keepall','keeknew','replace','delete')

Definition at line 180 of file class.ilObjLanguageExt.php.

References $ilErr, ilObjLanguage\$key, _saveValues(), getAllValues(), and getChangedValues().

{
global $ilDB, $ilErr;
// read the new language file
require_once "./Services/Language/classes/class.ilLanguageFile.php";
$import_file_obj = new ilLanguageFile($a_file);
if (!$import_file_obj->read())
{
$ilErr->raiseError($import_file_obj->getErrorMessage(),$ilErr->MESSAGE);
}
switch($a_mode_existing)
{
// keep all existing entries
case 'keepall':
$to_keep = $this->getAllValues();
break;
// keep existing online changes
case 'keepnew':
$to_keep = $this->getChangedValues();
break;
// replace all existing definitions
case 'replace':
$to_keep = array();
break;
// delete all existing entries
case 'delete':
$query = "DELETE FROM lng_data WHERE lang_key='".$this->key."'";
$ilDB->query($query);
$query = "DELETE FROM lng_modules WHERE lang_key='".$this->key."'";
$ilDB->query($query);
$to_keep = array();
break;
default:
return;
}
// process the values of the import file
$to_save = array();
foreach ($import_file_obj->getAllValues() as $key => $value)
{
if (!isset($to_keep[$key]))
{
$to_save[$key] = $value;
}
}
self::_saveValues($this->key, $to_save);
}

+ Here is the call graph for this function:

ilObjLanguageExt::setLocal (   $a_local = true)

Set the local status of the language.

Parameters
booleanlocal status (true/false)

Definition at line 60 of file class.ilObjLanguageExt.php.

References ilObjLanguage\isInstalled(), ilObject\setDescription(), and ilObject\update().

{
if ($this->isInstalled())
{
if ($a_local == true)
{
$this->setDescription("installed_local");
}
else
{
$this->setDescription("installed");
}
$this->update();
}
}

+ Here is the call graph for this function:


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