ILIAS  release_5-4 Revision v5.4.26-12-gabc799a52e6
ilObjFolder Class Reference

Class ilObjFolder. More...

+ Inheritance diagram for ilObjFolder:
+ Collaboration diagram for ilObjFolder:

Public Member Functions

 __construct ($a_id=0, $a_call_by_reference=true)
 Constructor public. More...
 
 setFolderTree ($a_tree)
 
 cloneObject ($a_target_id, $a_copy_id=0, $a_omit_tree=false)
 Clone folder. More...
 
 putInTree ($a_parent)
 insert folder into grp_tree More...
 
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies (crs items, preconditions) More...
 
 downloadFolder ()
 
 getViewMode ()
 Get container view mode. More...
 
 addAdditionalSubItemInformation (&$a_item_data)
 Add additional information to sub item, e.g. More...
 
 read ()
 Overwritten read method. More...
 
- Public Member Functions inherited from ilObject
 __construct ($a_id=0, $a_reference=true)
 Constructor public. More...
 
 withReferences ()
 determines wehter objects are referenced or not (got ref ids or not) More...
 
 read ()
 read object data from db into object More...
 
 getId ()
 get object id public More...
 
 setId ($a_id)
 set object id public More...
 
 setRefId ($a_id)
 set reference id public More...
 
 getRefId ()
 get reference id public More...
 
 getType ()
 get object type public More...
 
 setType ($a_type)
 set object type public More...
 
 getPresentationTitle ()
 get presentation title Normally same as title Overwritten for sessions More...
 
 getTitle ()
 get object title public More...
 
 getUntranslatedTitle ()
 get untranslated object title public More...
 
 setTitle ($a_title)
 set object title More...
 
 getDescription ()
 get object description More...
 
 setDescription ($a_desc)
 set object description More...
 
 getLongDescription ()
 get object long description (stored in object_description) More...
 
 getImportId ()
 get import id More...
 
 setImportId ($a_import_id)
 set import id More...
 
 setOfflineStatus ($a_status)
 Set offline status. More...
 
 getOfflineStatus ()
 Get offline status. More...
 
 supportsOfflineHandling ()
 Check whether object supports offline handling. More...
 
 getOwner ()
 get object owner More...
 
 getOwnerName ()
 
 setOwner ($a_owner)
 set object owner More...
 
 getCreateDate ()
 get create date public More...
 
 getLastUpdateDate ()
 get last update date public More...
 
 getDiskUsage ()
 Gets the disk usage of the object in bytes. More...
 
 create ()
 create More...
 
 update ()
 update object in db More...
 
 MDUpdateListener ($a_element)
 Meta data update listener. More...
 
 createMetaData ()
 create meta data entry More...
 
 updateMetaData ()
 update meta data entry More...
 
 deleteMetaData ()
 delete meta data entry More...
 
 updateOwner ()
 update owner of object in db More...
 
 putInTree ($a_parent_ref)
 maybe this method should be in tree object!? More...
 
 setPermissions ($a_parent_ref)
 set permissions of object More...
 
 setParentRolePermissions ($a_parent_ref)
 Initialize the permissions of parent roles (local roles of categories, global roles...) This method is overwritten in e.g courses, groups for building permission intersections with non_member templates. More...
 
 createReference ()
 creates reference for object More...
 
 countReferences ()
 count references of object 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 If you want to setup default local roles you MUST overwrite this method in derived object classes (see ilObjForum for an example) public More...
 
 applyDidacticTemplate ($a_tpl_id)
 Apply template. More...
 
 setRegisterMode ($a_bool)
 
 isUserRegistered ($a_user_id=0)
 
 requireRegistration ()
 
 getXMLZip ()
 
 getHTMLDirectory ()
 
 appendCopyInfo ($a_target_id, $a_copy_id)
 Prepend Copy info if object with same name exists in that container. More...
 
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies. More...
 
 cloneMetaData ($target_obj)
 Copy meta data. More...
 
 getPossibleSubObjects ($a_filter=true)
 get all possible subobjects of this type the object can decide which types of subobjects are possible jut in time overwrite if the decision distinguish from standard model More...
 
- Public Member Functions inherited from ilContainer
 __construct ($a_id=0, $a_reference=true)
 
 getObjectTranslation ()
 Get object translation. More...
 
 setObjectTranslation (ilObjectTranslation $obj_trans)
 Get object translation. More...
 
 createContainerDirectory ()
 Create directory for the container. More...
 
 getContainerDirectory ()
 Get the container directory. More...
 
 setHiddenFilesFound ($a_hiddenfilesfound)
 Set Found hidden files (set by getSubItems). More...
 
 getHiddenFilesFound ()
 Get Found hidden files (set by getSubItems). More...
 
 getStyleSheetId ()
 get ID of assigned style sheet object More...
 
 setStyleSheetId ($a_style_id)
 set ID of assigned style sheet object More...
 
 setNewsTimeline ($a_val)
 Set news timeline. More...
 
 getNewsTimeline ()
 Get news timeline. More...
 
 setNewsTimelineAutoEntries ($a_val)
 Set news timeline auto entries. More...
 
 getNewsTimelineAutoEntries ()
 Get news timeline auto entries. More...
 
 setNewsTimelineLandingPage ($a_val)
 Set news timline is landing page. More...
 
 getNewsTimelineLandingPage ()
 Get news timline is landing page. More...
 
 isNewsTimelineEffective ()
 Is news timeline effective? More...
 
 isNewsTimelineLandingPageEffective ()
 Is news timeline landing page effective? More...
 
 setNewsBlockActivated ($a_val)
 Set news block activated. More...
 
 getNewsBlockActivated ()
 Get news block activated. More...
 
 setUseNews ($a_val)
 Set use news. More...
 
 getUseNews ()
 Get use news. More...
 
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies (container sorting) More...
 
 cloneAllObject ($session_id, $client_id, $new_type, $ref_id, $clone_source, $options, $soap_call=false, $a_submode=1)
 clone all objects according to this container More...
 
 delete ()
 delete category and all related data More...
 
 getViewMode ()
 Get container view mode. More...
 
 getOrderType ()
 Get order type default implementation. More...
 
 setOrderType ($a_value)
 
 getSubItems ($a_admin_panel_enabled=false, $a_include_side_block=false, $a_get_single=0)
 Get subitems of container. More...
 
 gotItems ()
 Check whether we got any items. More...
 
 addAdditionalSubItemInformation (&$object)
 Add additional information to sub item, e.g. More...
 
 getGroupedObjTypes ()
 Get grouped repository object types. More...
 
 enablePageEditing ()
 Check whether page editing is allowed for container. More...
 
 create ()
 Create. More...
 
 putInTree ($a_parent_ref)
 
 update ()
 Update. More...
 
 read ()
 read More...
 
 readContainerSettings ()
 Read container settings. More...
 
 removeTranslations ()
 Remove all translations of container. More...
 
 deleteTranslation ($a_lang)
 Delete translation. More...
 
 addTranslation ($a_title, $a_desc, $a_lang, $a_lang_default)
 Add translation. More...
 

Data Fields

 $folder_tree
 
- Data Fields inherited from ilObject
const TITLE_LENGTH = 255
 max length of object title More...
 
const DESC_LENGTH = 128
 
 $lng
 
 $id
 
 $ref_id
 
 $type
 
 $title
 
 $untranslatedTitle
 
 $desc
 
 $long_desc
 
 $owner
 
 $create_date
 
 $last_update
 
 $import_id
 
 $register = false
 
 $referenced
 
 $objectList
 
 $max_title
 
 $max_desc
 
 $add_dots
 
- Data Fields inherited from ilContainer
const VIEW_SESSIONS = 0
 
const VIEW_OBJECTIVE = 1
 
const VIEW_TIMING = 2
 
const VIEW_ARCHIVE = 3
 
const VIEW_SIMPLE = 4
 
const VIEW_BY_TYPE = 5
 
const VIEW_INHERIT = 6
 
const VIEW_DEFAULT = self::VIEW_BY_TYPE
 
const SORT_TITLE = 0
 
const SORT_MANUAL = 1
 
const SORT_ACTIVATION = 2
 
const SORT_INHERIT = 3
 
const SORT_CREATION = 4
 
const SORT_DIRECTION_ASC = 0
 
const SORT_DIRECTION_DESC = 1
 
const SORT_NEW_ITEMS_POSITION_TOP = 0
 
const SORT_NEW_ITEMS_POSITION_BOTTOM = 1
 
const SORT_NEW_ITEMS_ORDER_TITLE = 0
 
const SORT_NEW_ITEMS_ORDER_CREATION = 1
 
const SORT_NEW_ITEMS_ORDER_ACTIVATION = 2
 

Static Private Member Functions

static recurseFolder ($ref_id, $title, $tmpdir)
 private functions which iterates through all folders and files and create an according file structure in a temporary directory. More...
 
static renameDuplicateFile ($duplicate_filename)
 bugfix mantis 24309: add "_copy_" followed by a number to the filename (in front of the file-type-extension) if there are identically named files in the same folder to prevent an exception being thrown More...
 

Static Private Attributes

static $duplicate_files = array()
 

Additional Inherited Members

- Static Public Member Functions inherited from ilObject
static _lookupObjIdByImportId ($a_import_id)
 
static _lookupImportId ($a_obj_id)
 
static _lookupOwnerName ($a_owner_id)
 lookup owner name for owner id More...
 
static _getIdForImportId ($a_import_id)
 get current object id for import id (static) More...
 
static _getAllReferences ($a_id)
 get all reference ids of object More...
 
static _lookupTitle ($a_id)
 lookup object title More...
 
static lookupOfflineStatus ($a_obj_id)
 Lookup offline status using objectDataCache. More...
 
static _lookupOwner ($a_id)
 lookup object owner More...
 
static _getIdsForTitle ($title, $type='', $partialmatch=false)
 
static _lookupDescription ($a_id)
 lookup object description More...
 
static _lookupLastUpdate ($a_id, $a_as_string=false)
 lookup last update More...
 
static _getLastUpdateOfObjects ($a_objs)
 Get last update for a set of media objects. More...
 
static _lookupObjId ($a_id)
 
static _setDeletedDate ($a_ref_id)
 only called in ilTree::saveSubTree More...
 
static setDeletedDates ($a_ref_ids)
 Set deleted date. More...
 
static _resetDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes More...
 
static _lookupDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes More...
 
static _writeTitle ($a_obj_id, $a_title)
 write title to db (static) More...
 
static _writeDescription ($a_obj_id, $a_desc)
 write description to db (static) More...
 
static _writeImportId ($a_obj_id, $a_import_id)
 write import id to db (static) More...
 
static _lookupType ($a_id, $a_reference=false)
 lookup object type More...
 
static _isInTrash ($a_ref_id)
 checks wether object is in trash More...
 
static _hasUntrashedReference ($a_obj_id)
 checks wether an object has at least one reference that is not in trash More...
 
static _lookupObjectId ($a_ref_id)
 lookup object id More...
 
static _getObjectsDataForType ($a_type, $a_omit_trash=false)
 get all objects of a certain type More...
 
static _exists ($a_id, $a_reference=false, $a_type=null)
 checks if an object exists in object_data More...
 
static _getObjectsByType ($a_obj_type="", $a_owner="")
 Get objects by type. More...
 
static _prepareCloneSelection ($a_ref_ids, $new_type, $show_path=true)
 Prepare copy wizard object selection. More...
 
static collectDeletionDependencies (&$deps, $a_ref_id, $a_obj_id, $a_type, $a_depth=0)
 Collect deletion dependencies. More...
 
static getDeletionDependencies ($a_obj_id)
 Get deletion dependencies. More...
 
static getLongDescriptions (array $a_obj_ids)
 Get long description data. More...
 
static getAllOwnedRepositoryObjects ($a_user_id)
 Get all ids of objects user owns. More...
 
static fixMissingTitles ($a_type, array &$a_obj_title_map)
 Try to fix missing object titles. More...
 
static _lookupCreationDate ($a_id)
 Lookup creation date. More...
 
static hasAutoRating ($a_type, $a_ref_id)
 Check if auto rating is active for parent group/course. More...
 
- Static Public Member Functions inherited from ilContainer
static _getContainerDirectory ($a_id)
 Get the container directory. More...
 
static _lookupContainerSetting ($a_id, $a_keyword, $a_default_value=null)
 Lookup a container setting. More...
 
static _writeContainerSetting ($a_id, $a_keyword, $a_value)
 
static _getContainerSettings ($a_id)
 
static _deleteContainerSettings ($a_id, $a_keyword=null, $a_keyword_like=false)
 
static _exportContainerSettings (ilXmlWriter $a_xml, $a_obj_id)
 
static getCompleteDescriptions (array $objects)
 overwrites description fields to long or short description in an assoc array keys needed (obj_id and description) More...
 
- Static Public Attributes inherited from ilContainer
static $data_preloaded = false
 
- Protected Attributes inherited from ilObject
 $objDefinition
 
 $db
 
 $log
 
 $error
 
 $tree
 
 $app_event_handler
 
 $rbacadmin
 
 $rbacreview
 
- Protected Attributes inherited from ilContainer
 $db
 
 $log
 
 $access
 
 $error
 
 $rbacsystem
 
 $tree
 
 $user
 
 $obj_definition
 
 $order_type = 0
 
 $hiddenfilesfound = false
 
 $news_timeline = false
 
 $news_timeline_auto_entries = false
 
 $setting
 
 $obj_trans = null
 

Detailed Description

Class ilObjFolder.

Author
Wolfgang Merkens wmerk.nosp@m.ens@.nosp@m.datab.nosp@m.ay.d.nosp@m.e
Version
Id
class.ilObjFolder.php 40448 2013-03-08 10:02:02Z jluetzen

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

Constructor & Destructor Documentation

◆ __construct()

ilObjFolder::__construct (   $a_id = 0,
  $a_call_by_reference = true 
)

Constructor public.

Parameters
integerreference_id or object_id
booleantreat the id as reference_id (true) or object_id (false)

Definition at line 50 of file class.ilObjFolder.php.

References $DIC.

51  {
52  global $DIC;
53 
54  $this->tree = $DIC->repositoryTree();
55  $this->lng = $DIC->language();
56  $this->rbacsystem = $DIC->rbac()->system();
57  $this->access = $DIC->access();
58  $this->type = "fold";
59  parent::__construct($a_id, $a_call_by_reference);
60  $this->lng->loadLanguageModule('fold');
61  }
global $DIC
Definition: saml.php:7

Member Function Documentation

◆ addAdditionalSubItemInformation()

ilObjFolder::addAdditionalSubItemInformation ( $a_item_data)

Add additional information to sub item, e.g.

used in courses for timings information etc.

Definition at line 294 of file class.ilObjFolder.php.

References ilObjectActivation\addAdditionalSubItemInformation().

295  {
296  include_once './Services/Object/classes/class.ilObjectActivation.php';
298  }
static addAdditionalSubItemInformation(array &$a_item)
Parse item data for list entries.
+ Here is the call graph for this function:

◆ cloneDependencies()

ilObjFolder::cloneDependencies (   $a_target_id,
  $a_copy_id 
)

Clone object dependencies (crs items, preconditions)

public

Parameters
inttarget ref id of new course
intcopy id

Definition at line 118 of file class.ilObjFolder.php.

References ilObjectActivation\cloneDependencies(), and ilObject\getRefId().

119  {
120  parent::cloneDependencies($a_target_id, $a_copy_id);
121 
122  include_once('Services/Object/classes/class.ilObjectActivation.php');
123  ilObjectActivation::cloneDependencies($this->getRefId(), $a_target_id, $a_copy_id);
124 
125  return true;
126  }
static cloneDependencies($a_ref_id, $a_target_id, $a_copy_id)
Clone dependencies.
getRefId()
get reference id public
+ Here is the call graph for this function:

◆ cloneObject()

ilObjFolder::cloneObject (   $a_target_id,
  $a_copy_id = 0,
  $a_omit_tree = false 
)

Clone folder.

public

Parameters
inttarget id
intcopy id

Definition at line 76 of file class.ilObjFolder.php.

References ilObject\getId().

77  {
78  $new_obj = parent::cloneObject($a_target_id, $a_copy_id, $a_omit_tree);
79 
80  // Copy learning progress settings
81  include_once('Services/Tracking/classes/class.ilLPObjSettings.php');
82  $obj_settings = new ilLPObjSettings($this->getId());
83  $obj_settings->cloneSettings($new_obj->getId());
84  unset($obj_settings);
85 
86  return $new_obj;
87  }
getId()
get object id public
+ Here is the call graph for this function:

◆ downloadFolder()

ilObjFolder::downloadFolder ( )

Definition at line 233 of file class.ilObjFolder.php.

References ilContainer\$access, ilObject\_isInTrash(), ilUtil\delDir(), ilUtil\deliverFile(), ilObject\getRefId(), ilObject\getTitle(), ilUtil\ilTempnam(), ilUtil\makeDir(), recurseFolder(), ilUtil\sendInfo(), and ilUtil\zip().

234  {
235  $ilAccess = $this->access;
236 
237  if (!$ilAccess->checkAccess("read", "", $this->getRefId())) {
238  $this->ilErr->raiseError(get_class($this) . "::downloadFolder(): missing read permission!", $this->ilErr->WARNING);
239  }
240  if (ilObject::_isInTrash($this->getRefId())) {
241  $this->ilErr->raiseError(get_class($this) . "::downloadFolder(): object is trashed!", $this->ilErr->WARNING);
242  }
243 
244  $tmpdir = ilUtil::ilTempnam();
245  ilUtil::makeDir($tmpdir);
246  $basename = ilUtil::getAsciiFilename($this->getTitle());
247  $deliverFilename = $basename . ".zip";
248  $zipbasedir = $tmpdir . DIRECTORY_SEPARATOR . $basename;
249  $tmpzipfile = $tmpdir . DIRECTORY_SEPARATOR . $deliverFilename;
250 
251  try {
252  ilObjFolder::recurseFolder($this->getRefId(), $this->getTitle(), LegacyPathHelper::createRelativePath($tmpdir));
253  ilUtil::zip($zipbasedir, $tmpzipfile);
254  rename($tmpzipfile, $zipfile = ilUtil::ilTempnam());
255  ilUtil::delDir($tmpdir);
256  ilUtil::deliverFile($zipfile, $deliverFilename, '', false, true);
257  } catch (ilFileException $e) {
258  ilUtil::sendInfo($e->getMessage(), true);
259  }
260  }
static _isInTrash($a_ref_id)
checks wether object is in trash
static recurseFolder($ref_id, $title, $tmpdir)
private functions which iterates through all folders and files and create an according file structure...
static sendInfo($a_info="", $a_keep=false)
Send Info Message to Screen.
getTitle()
get object title public
Class to report exception.
static zip($a_dir, $a_file, $compress_content=false)
zips given directory/file into given zip.file
static makeDir($a_dir)
creates a new directory and inherits all filesystem permissions of the parent directory You may pass ...
static ilTempnam($a_temp_path=null)
Returns a unique and non existing Path for e temporary file or directory.
getRefId()
get reference id public
static delDir($a_dir, $a_clean_only=false)
removes a dir and all its content (subdirs and files) recursively
static deliverFile( $a_file, $a_filename, $a_mime='', $isInline=false, $removeAfterDelivery=false, $a_exit_after=true)
deliver file for download via browser.
+ Here is the call graph for this function:

◆ getViewMode()

ilObjFolder::getViewMode ( )

Get container view mode.

Definition at line 265 of file class.ilObjFolder.php.

References ilContainer\$tree, ilObject\_lookupObjId(), ilObjCourseAccess\_lookupViewMode(), ilContainer\VIEW_BY_TYPE, ilContainer\VIEW_SESSIONS, and ilContainer\VIEW_SIMPLE.

266  {
267  $tree = $this->tree;
268 
269  // default: by type
271 
272  // always inherit from
273  $container_ref_id = $tree->checkForParentType($this->ref_id, 'grp');
274  if (!$container_ref_id) {
275  $container_ref_id = $tree->checkForParentType($this->ref_id, 'crs');
276  }
277  if ($container_ref_id) {
278  include_once("./Modules/Course/classes/class.ilObjCourseAccess.php");
279  $view_mode = ilObjCourseAccess::_lookupViewMode(ilObject::_lookupObjId($container_ref_id));
280  if ($view_mode == ilContainer::VIEW_SESSIONS ||
281  $view_mode == ilContainer::VIEW_BY_TYPE ||
282  $view_mode == ilContainer::VIEW_SIMPLE) {
283  $view = $view_mode;
284  }
285  }
286 
287  return $view;
288  }
static _lookupObjId($a_id)
static _lookupViewMode($a_id)
Lookup view mode.
+ Here is the call graph for this function:

◆ putInTree()

ilObjFolder::putInTree (   $a_parent)

insert folder into grp_tree

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

References ilContainer\$tree, ilObject\getId(), ilObject\getRefId(), and ilObject\withReferences().

94  {
96 
97  if (!is_object($this->folder_tree)) {
98  $this->folder_tree = &$tree;
99  }
100 
101  if ($this->withReferences()) {
102  // put reference id into tree
103  $this->folder_tree->insertNode($this->getRefId(), $a_parent);
104  } else {
105  // put object id into tree
106  $this->folder_tree->insertNode($this->getId(), $a_parent);
107  }
108  }
withReferences()
determines wehter objects are referenced or not (got ref ids or not)
getId()
get object id public
getRefId()
get reference id public
+ Here is the call graph for this function:

◆ read()

ilObjFolder::read ( )

Overwritten read method.

public

Parameters

Definition at line 307 of file class.ilObjFolder.php.

References ilContainer\$tree, ilContainerSortingSettings\_lookupSortMode(), ilObject\getId(), and ilContainer\setOrderType().

308  {
309  $tree = $this->tree;
310 
311  parent::read();
312 
313  // Inherit order type from parent course (if exists)
314  include_once('./Services/Container/classes/class.ilContainerSortingSettings.php');
316  }
getId()
get object id public
setOrderType($a_value)
static _lookupSortMode($a_obj_id)
lookup sort mode
+ Here is the call graph for this function:

◆ recurseFolder()

static ilObjFolder::recurseFolder (   $ref_id,
  $title,
  $tmpdir 
)
staticprivate

private functions which iterates through all folders and files and create an according file structure in a temporary directory.

This function works recursive.

Parameters
int$ref_idReference-ID of Folder
string$titleof Folder
string$tmpdir(MUST be already relative due to filesystem-service)
Returns
string returns first created directory
Exceptions

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

References $DIC, ilObject\$ref_id, $s, $sanitizer, ilObject\$title, ilContainer\$tree, ilObject\_isInTrash(), ilObjFile\_lookupAbsolutePath(), and ilUtil\getASCIIFilename().

Referenced by downloadFolder().

144  {
145  global $DIC;
146 
147  $tree = $DIC->repositoryTree();
148  $ilAccess = $DIC->access();
149 
150  $tmpdir .= DIRECTORY_SEPARATOR . ilUtil::getASCIIFilename($title);
151 
152  $temp_fs = $DIC->filesystem()->temp();
153  $temp_fs->createDir($tmpdir);
154 
155  $subtree = $tree->getChildsByTypeFilter($ref_id, array('fold', 'file'));
156 
157  $storage_fs = $DIC->filesystem()->storage();
158 
159  foreach ($subtree as $child) {
160  if (!$ilAccess->checkAccess('read', '', $child['ref_id'])) {
161  continue;
162  }
163  if (ilObject::_isInTrash($child['ref_id'])) {
164  continue;
165  }
166  if ($child['type'] === 'fold') {
167  ilObjFolder::recurseFolder($child["ref_id"], $child["title"], $tmpdir);
168  } else {
169  // enhance new_filename to full relative path to enable checking for identically named files
170  $new_filename = $tmpdir . DIRECTORY_SEPARATOR . ilUtil::getASCIIFilename($child["title"]);
172  $new_filename = $sanitizer->sanitize($new_filename);
173  if ($temp_fs->has($new_filename)) {
174  $new_filename = self::renameDuplicateFile($new_filename);
175  }
176 
177  // copy to temporal directory
178  $relative_path_of_file = LegacyPathHelper::createRelativePath(ilObjFile::_lookupAbsolutePath($child["obj_id"]));
179  if ($storage_fs->has($relative_path_of_file)) {
180  $s = $storage_fs->readStream($relative_path_of_file);
181  } else {
182  throw new ilFileException('Could not copy ' . $relative_path_of_file . ' to ' . $new_filename);
183  }
184  $temp_fs->writeStream($new_filename, $s);
185  }
186  }
187  }
global $DIC
Definition: saml.php:7
static _isInTrash($a_ref_id)
checks wether object is in trash
$s
Definition: pwgen.php:45
static getASCIIFilename($a_filename)
convert utf8 to ascii filename
static recurseFolder($ref_id, $title, $tmpdir)
private functions which iterates through all folders and files and create an according file structure...
if(empty( $files_to_scan)) $sanitizer
Definition: svg-scanner.php:90
Class to report exception.
static _lookupAbsolutePath($obj_id, $a_version=null)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ renameDuplicateFile()

static ilObjFolder::renameDuplicateFile (   $duplicate_filename)
staticprivate

bugfix mantis 24309: add "_copy_" followed by a number to the filename (in front of the file-type-extension) if there are identically named files in the same folder to prevent an exception being thrown

Parameters
$duplicate_filenamestring filename including path and extension
Returns
string

Definition at line 199 of file class.ilObjFolder.php.

References $filename, and $path.

200  {
201  // determine the copy_number that will be added to the filename either by obtaining it from
202  // the entry of the current file in the duplicate_files-array or use 1 if there is no entry yet
203  $copy_number = 1;
204  $duplicate_has_array_entry = false;
205  foreach (self::$duplicate_files as &$duplicate_file) {
206  if ($duplicate_file['file_name'] == $duplicate_filename) {
207  $duplicate_has_array_entry = true;
208  $copy_number = $duplicate_file['copy_number'];
209  // increment the copy_number for correctly renaming the next duplicate of this file
210  $duplicate_file['copy_number']++;
211  }
212  }
213 
214  // create an array entry for the duplicate file if there isn't one to ensure that the
215  // copy_number can be determined correctly for other duplicates of this file
216  if (!$duplicate_has_array_entry) {
217  self::$duplicate_files[] = [
218  'file_name' => $duplicate_filename,
219  'copy_number' => 2 // set as 2 because 1 is already used for this duplicate
220  ];
221  }
222 
223  // rename the file
224  $path = pathinfo($duplicate_filename, PATHINFO_DIRNAME);
225  $filename = pathinfo($duplicate_filename, PATHINFO_FILENAME);
226  $extension = pathinfo($duplicate_filename, PATHINFO_EXTENSION);
227  $new_filename = $path . "/" . $filename . " (" . $copy_number . ")." . $extension;
228 
229  return $new_filename;
230  }
$path
Definition: aliased.php:25
$filename
Definition: buildRTE.php:89

◆ setFolderTree()

ilObjFolder::setFolderTree (   $a_tree)

Definition at line 63 of file class.ilObjFolder.php.

64  {
65  $this->folder_tree = &$a_tree;
66  }

Field Documentation

◆ $duplicate_files

ilObjFolder::$duplicate_files = array()
staticprivate

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

◆ $folder_tree

ilObjFolder::$folder_tree

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


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