ILIAS  release_8 Revision v8.19
All Data Structures Namespaces Files Functions Variables Modules Pages
ilObjFileBasedLM Class Reference

This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Learning e.V. More...

+ Inheritance diagram for ilObjFileBasedLM:
+ Collaboration diagram for ilObjFileBasedLM:

Public Member Functions

 __construct (int $a_id=0, bool $a_call_by_reference=true)
 
 update (bool $a_skip_meta=false)
 
 read ()
 
 create (bool $a_skip_meta=false)
 
 getDataDirectory (string $mode="filesystem")
 
 createDataDirectory ()
 
 getStartFile ()
 
 setStartFile (string $a_file, bool $a_omit_file_check=false)
 
 delete ()
 
 populateByDirectoy (string $a_dir, string $a_filename="")
 Populate by directory. More...
 
 isInfoEnabled ()
 
- 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...
 

Protected Attributes

string $start_file = null
 
bool $online
 
- 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
 

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)
 
- 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
 
- Protected Member Functions inherited from ilObject
 doMDUpdateListener (string $a_element)
 
 beforeMDUpdateListener (string $a_element)
 
 doCreateMetaData ()
 
 beforeCreateMetaData ()
 
 doUpdateMetaData ()
 
 beforeUpdateMetaData ()
 
 doDeleteMetaData ()
 
 beforeDeleteMetaData ()
 
 handleAutoRating ()
 
 hasAutoRating ()
 

Detailed Description

This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Learning e.V.

ILIAS is licensed with the GPL-3.0, see https://www.gnu.org/licenses/gpl-3.0.en.html You should have received a copy of said license along with the source code, too.

If this is not the case or you just want to try ILIAS, you'll find us at: https://www.ilias.de https://github.com/ILIAS-eLearning File Based Learning Module (HTML) object

Author
Alexander Killing killi.nosp@m.ng@l.nosp@m.eifos.nosp@m..de

Definition at line 23 of file class.ilObjFileBasedLM.php.

Constructor & Destructor Documentation

◆ __construct()

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

Definition at line 28 of file class.ilObjFileBasedLM.php.

References $DIC, ILIAS\GlobalScreen\Provider\__construct(), and ilObject\setOfflineStatus().

31  {
32  global $DIC;
33 
34  // default is offline
35  $this->setOfflineStatus(true);
36 
37  $this->db = $DIC->database();
38  // this also calls read() method! (if $a_id is set)
39  $this->type = "htlm";
40  parent::__construct($a_id, $a_call_by_reference);
41  }
global $DIC
Definition: feed.php:28
setOfflineStatus(bool $status)
__construct(Container $dic, ilPlugin $plugin)
+ Here is the call graph for this function:

Member Function Documentation

◆ create()

ilObjFileBasedLM::create ( bool  $a_skip_meta = false)

Definition at line 70 of file class.ilObjFileBasedLM.php.

References ilObject\$db, ilObject\$id, $ilDB, createDataDirectory(), and ilObject\createMetaData().

70  : int
71  {
72  $ilDB = $this->db;
73 
74  $id = parent::create();
75  $this->createDataDirectory();
76 
77  $ilDB->manipulate("INSERT INTO file_based_lm (id, startfile) VALUES " .
78  " (" . $ilDB->quote($this->getId(), "integer") . "," .
79  $ilDB->quote($this->getStartFile(), "text") . ")");
80  if (!$a_skip_meta) {
81  $this->createMetaData();
82  }
83  return $id;
84  }
ilDBInterface $db
+ Here is the call graph for this function:

◆ createDataDirectory()

ilObjFileBasedLM::createDataDirectory ( )

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

References getDataDirectory(), and ilFileUtils\makeDir().

Referenced by create().

94  : void
95  {
97  }
getDataDirectory(string $mode="filesystem")
static makeDir(string $a_dir)
creates a new directory and inherits all filesystem permissions of the parent directory You may pass ...
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ delete()

ilObjFileBasedLM::delete ( )

Definition at line 115 of file class.ilObjFileBasedLM.php.

References ilObject\$db, $ilDB, ilFileUtils\delDir(), ilObject\deleteMetaData(), and getDataDirectory().

115  : bool
116  {
117  $ilDB = $this->db;
118 
119  // always call parent delete function first!!
120  if (!parent::delete()) {
121  return false;
122  }
123 
124  // Delete meta data
125  $this->deleteMetaData();
126 
127  // delete file_based_lm record
128  $ilDB->manipulate("DELETE FROM file_based_lm WHERE id = " .
129  $ilDB->quote($this->getId(), "integer"));
130 
131  // delete data directory
133 
134  return true;
135  }
getDataDirectory(string $mode="filesystem")
static delDir(string $a_dir, bool $a_clean_only=false)
removes a dir and all its content (subdirs and files) recursively
ilDBInterface $db
+ Here is the call graph for this function:

◆ getDataDirectory()

ilObjFileBasedLM::getDataDirectory ( string  $mode = "filesystem")

Definition at line 86 of file class.ilObjFileBasedLM.php.

References ilObject\getId(), and ilFileUtils\getWebspaceDir().

Referenced by createDataDirectory(), delete(), populateByDirectoy(), and setStartFile().

86  : string
87  {
88  $lm_data_dir = ilFileUtils::getWebspaceDir($mode) . "/lm_data";
89  $lm_dir = $lm_data_dir . "/lm_" . $this->getId();
90 
91  return $lm_dir;
92  }
static getWebspaceDir(string $mode="filesystem")
get webspace directory
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getStartFile()

ilObjFileBasedLM::getStartFile ( )

Definition at line 99 of file class.ilObjFileBasedLM.php.

References $start_file.

Referenced by populateByDirectoy().

99  : ?string
100  {
101  return $this->start_file;
102  }
+ Here is the caller graph for this function:

◆ isInfoEnabled()

ilObjFileBasedLM::isInfoEnabled ( )

Definition at line 179 of file class.ilObjFileBasedLM.php.

References ilObject\getId(), and ilObjContentObjectAccess\isInfoEnabled().

179  : bool
180  {
182  }
+ Here is the call graph for this function:

◆ populateByDirectoy()

ilObjFileBasedLM::populateByDirectoy ( string  $a_dir,
string  $a_filename = "" 
)

Populate by directory.

Add a filename to do a special check for ILIAS HTML export files. If the corresponding directory is found within the passed directory path (i.e. "htlm_<id>") this subdirectory is used instead.

Definition at line 143 of file class.ilObjFileBasedLM.php.

References $target_id, ilCopyWizardOptions\_getInstance(), ilObject\cloneMetaData(), getDataDirectory(), ilObject\getOfflineStatus(), getStartFile(), ilFileUtils\rCopy(), and ilFileUtils\renameExecutables().

146  : void {
147  preg_match("/.*htlm_([0-9]*)\.zip/", $a_filename, $match);
148  if (is_dir($a_dir . "/htlm_" . ($match[1] ?? ""))) {
149  $a_dir .= "/htlm_" . ($match[1] ?? "");
150  }
151  ilFileUtils::rCopy($a_dir, $this->getDataDirectory());
153  }
getDataDirectory(string $mode="filesystem")
static rCopy(string $a_sdir, string $a_tdir, bool $preserveTimeAttributes=false)
Copies content of a directory $a_sdir recursively to a directory $a_tdir.
static renameExecutables(string $a_dir)
+ Here is the call graph for this function:

◆ read()

ilObjFileBasedLM::read ( )

Definition at line 58 of file class.ilObjFileBasedLM.php.

References ilObject\$db, $ilDB, $lm_set, ilObject\getId(), and setStartFile().

58  : void
59  {
60  $ilDB = $this->db;
61 
62  parent::read();
63 
64  $q = "SELECT * FROM file_based_lm WHERE id = " . $ilDB->quote($this->getId(), "integer");
65  $lm_set = $ilDB->query($q);
66  $lm_rec = $ilDB->fetchAssoc($lm_set);
67  $this->setStartFile((string) $lm_rec["startfile"]);
68  }
setStartFile(string $a_file, bool $a_omit_file_check=false)
ilDBInterface $db
$lm_set
+ Here is the call graph for this function:

◆ setStartFile()

ilObjFileBasedLM::setStartFile ( string  $a_file,
bool  $a_omit_file_check = false 
)

Definition at line 104 of file class.ilObjFileBasedLM.php.

References getDataDirectory().

Referenced by read().

107  : void {
108  if ($a_file &&
109  (file_exists($this->getDataDirectory() . "/" . $a_file) || $a_omit_file_check)) {
110  $this->start_file = $a_file;
111  }
112  }
getDataDirectory(string $mode="filesystem")
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ update()

ilObjFileBasedLM::update ( bool  $a_skip_meta = false)

Definition at line 43 of file class.ilObjFileBasedLM.php.

References ilObject\$db, $ilDB, and ilObject\updateMetaData().

43  : bool
44  {
45  $ilDB = $this->db;
46 
47  if (!$a_skip_meta) {
48  $this->updateMetaData();
49  }
50  parent::update();
51 
52  $ilDB->manipulate($q = "UPDATE file_based_lm SET " .
53  " startfile = " . $ilDB->quote($this->getStartFile(), "text") . " " .
54  " WHERE id = " . $ilDB->quote($this->getId(), "integer"));
55  return true;
56  }
ilDBInterface $db
+ Here is the call graph for this function:

Field Documentation

◆ $online

bool ilObjFileBasedLM::$online
protected

Definition at line 26 of file class.ilObjFileBasedLM.php.

◆ $start_file

string ilObjFileBasedLM::$start_file = null
protected

Definition at line 25 of file class.ilObjFileBasedLM.php.

Referenced by getStartFile().


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