mirror of
https://github.com/moodle/moodle.git
synced 2025-08-06 09:26:35 +02:00
Merge branch 'MDL-59700-master' of git://github.com/cameron1729/moodle
This commit is contained in:
commit
286a38eeaa
8 changed files with 78 additions and 19 deletions
|
@ -1318,7 +1318,7 @@ class file_storage {
|
|||
$newrecord->status = empty($filerecord->status) ? 0 : $filerecord->status;
|
||||
$newrecord->sortorder = $filerecord->sortorder;
|
||||
|
||||
list($newrecord->contenthash, $newrecord->filesize, $newfile) = $this->add_file_to_pool($pathname);
|
||||
list($newrecord->contenthash, $newrecord->filesize, $newfile) = $this->add_file_to_pool($pathname, null, $newrecord);
|
||||
|
||||
$newrecord->pathnamehash = $this->get_pathname_hash($newrecord->contextid, $newrecord->component, $newrecord->filearea, $newrecord->itemid, $newrecord->filepath, $newrecord->filename);
|
||||
|
||||
|
@ -1432,7 +1432,7 @@ class file_storage {
|
|||
$newrecord->status = empty($filerecord->status) ? 0 : $filerecord->status;
|
||||
$newrecord->sortorder = $filerecord->sortorder;
|
||||
|
||||
list($newrecord->contenthash, $newrecord->filesize, $newfile) = $this->add_string_to_pool($content);
|
||||
list($newrecord->contenthash, $newrecord->filesize, $newfile) = $this->add_string_to_pool($content, $newrecord);
|
||||
if (empty($filerecord->mimetype)) {
|
||||
$newrecord->mimetype = $this->filesystem->mimetype_from_hash($newrecord->contenthash, $newrecord->filename);
|
||||
} else {
|
||||
|
@ -1456,6 +1456,30 @@ class file_storage {
|
|||
return $this->get_file_instance($newrecord);
|
||||
}
|
||||
|
||||
/**
|
||||
* Synchronise stored file from file.
|
||||
*
|
||||
* @param stored_file $file Stored file to synchronise.
|
||||
* @param string $path Path to the file to synchronise from.
|
||||
* @param stdClass $filerecord The file record from the database.
|
||||
*/
|
||||
public function synchronise_stored_file_from_file(stored_file $file, $path, $filerecord) {
|
||||
list($contenthash, $filesize) = $this->add_file_to_pool($path, null, $filerecord);
|
||||
$file->set_synchronized($contenthash, $filesize);
|
||||
}
|
||||
|
||||
/**
|
||||
* Synchronise stored file from string.
|
||||
*
|
||||
* @param stored_file $file Stored file to synchronise.
|
||||
* @param string $content File content.
|
||||
* @param stdClass $filerecord The file record from the database.
|
||||
*/
|
||||
public function synchronise_stored_file_from_string(stored_file $file, $content, $filerecord) {
|
||||
list($contenthash, $filesize) = $this->add_string_to_pool($content, $filerecord);
|
||||
$file->set_synchronized($contenthash, $filesize);
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a new alias/shortcut file from file reference information
|
||||
*
|
||||
|
@ -1570,7 +1594,7 @@ class file_storage {
|
|||
} else {
|
||||
// External file doesn't have content in moodle.
|
||||
// So we create an empty file for it.
|
||||
list($filerecord->contenthash, $filerecord->filesize, $newfile) = $this->add_string_to_pool(null);
|
||||
list($filerecord->contenthash, $filerecord->filesize, $newfile) = $this->add_string_to_pool(null, $filerecord);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1759,10 +1783,12 @@ class file_storage {
|
|||
* Add file content to sha1 pool.
|
||||
*
|
||||
* @param string $pathname path to file
|
||||
* @param string $contenthash sha1 hash of content if known (performance only)
|
||||
* @param string|null $contenthash sha1 hash of content if known (performance only)
|
||||
* @param stdClass|null $newrecord New file record
|
||||
* @return array (contenthash, filesize, newfile)
|
||||
*/
|
||||
public function add_file_to_pool($pathname, $contenthash = NULL) {
|
||||
public function add_file_to_pool($pathname, $contenthash = null, $newrecord = null) {
|
||||
$this->call_before_file_created_plugin_functions($newrecord, $pathname);
|
||||
return $this->filesystem->add_file_from_path($pathname, $contenthash);
|
||||
}
|
||||
|
||||
|
@ -1772,10 +1798,27 @@ class file_storage {
|
|||
* @param string $content file content - binary string
|
||||
* @return array (contenthash, filesize, newfile)
|
||||
*/
|
||||
public function add_string_to_pool($content) {
|
||||
public function add_string_to_pool($content, $newrecord = null) {
|
||||
$this->call_before_file_created_plugin_functions($newrecord, null, $content);
|
||||
return $this->filesystem->add_file_from_string($content);
|
||||
}
|
||||
|
||||
/**
|
||||
* before_file_created hook.
|
||||
*
|
||||
* @param stdClass|null $newrecord New file record.
|
||||
* @param string|null $pathname Path to file.
|
||||
* @param string|null $content File content.
|
||||
*/
|
||||
protected function call_before_file_created_plugin_functions($newrecord, $pathname = null, $content = null) {
|
||||
$pluginsfunction = get_plugins_with_function('before_file_created');
|
||||
foreach ($pluginsfunction as $plugintype => $plugins) {
|
||||
foreach ($plugins as $pluginfunction) {
|
||||
$pluginfunction($newrecord, ['pathname' => $pathname, 'content' => $content]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Serve file content using X-Sendfile header.
|
||||
* Please make sure that all headers are already sent
|
||||
|
|
|
@ -588,6 +588,24 @@ class stored_file {
|
|||
return $this->fs->create_directory($this->file_record->contextid, $this->file_record->component, $this->file_record->filearea, $this->file_record->itemid, $filepath);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set synchronised content from file.
|
||||
*
|
||||
* @param string $path Path to the file.
|
||||
*/
|
||||
public function set_synchronised_content_from_file($path) {
|
||||
$this->fs->synchronise_stored_file_from_file($this, $path, $this->file_record);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set synchronised content from content.
|
||||
*
|
||||
* @param string $content File content.
|
||||
*/
|
||||
public function set_synchronised_content_from_string($content) {
|
||||
$this->fs->synchronise_stored_file_from_string($this, $content, $this->file_record);
|
||||
}
|
||||
|
||||
/**
|
||||
* Synchronize file if it is a reference and needs synchronizing
|
||||
*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue