Files
moodle/files/classes/hook/before_file_created.php
Andrew Nicols b9a5ed7737 MDL-83245 core_files: Update file redaction API
This change:
- Moves the API to use the `before_file_created` hook
- Remove the newly created `$notify` param for `after_file_created` hook
- Stop persisting redactable content
- Update manager to not deal with `stored_file` instances
- Correct namespace from `\core\filereact` to `\core_files\redactor`
- Add `redactor` as a valid L2 namespace within the `core_files` API
- Correct config setting names
- Adds missing unit tests
- Disables the service for PHPUnit tests

AMOS BEGIN
  MOV [fileredact,core_files],[redactor,core_files]
  MOV [fileredact,core_files],[redactor:exifremover,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:emptyremovetags,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:enabled,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:enabled_desc,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:failedprocessexiftool,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:failedprocessgd,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:heading,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:mimetype,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:mimetype_desc,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:removetags,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:removetags_desc,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:tag:all,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:tag:gps,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:tooldoesnotexist,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:toolpath,core_files]
  MOV [fileredact,core_files],[redactor:exifremover:toolpath_desc,core_files]
AMOS END
2024-09-26 11:24:17 +08:00

161 lines
4.7 KiB
PHP

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
namespace core_files\hook;
use core\exception\coding_exception;
use core\attribute;
/**
* A hook which is fired before a file is created in the file storage API.
*
* @package core_files
* @copyright 2024 Andrew Lyons <andrew@nicols.co.uk>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
#[attribute\label('Allows subscribers to modify file content before it is stored in the file pool')]
#[attribute\tags('file')]
#[attribute\hook\replaces_callbacks('before_file_created')]
final class before_file_created {
use \core\hook\stoppable_trait;
/** @var bool Whether the content has been updated at all */
public bool $contentupdated = false;
/**
* Constructor.
*
* @param \stdClass|null $filerecord
* @param string|null $filepath The path to the file on disk
* @param string|null $filecontent The content of the file
*/
public function __construct(
/** @var \stdClass The file record */
protected ?\stdClass $filerecord = null,
/** @var string|null $filepath The source file on disk */
protected ?string $filepath = null,
/** @var string|null $filecontent The content of the file if it is not stored on disk */
protected ?string $filecontent = null,
) {
if ($filepath === null && $filecontent === null) {
throw new \InvalidArgumentException('Either $filepath or $filecontent must be set');
}
if ($filepath !== null && $filecontent !== null) {
throw new \InvalidArgumentException('Only one of $filepath or $filecontent can be set');
}
}
/**
* Whether the file path was specified.
*
* @return bool
*/
public function has_filepath(): bool {
return $this->filepath !== null;
}
/**
* Whether the file content was specified.
*
* @return bool
*/
public function has_filecontent(): bool {
return $this->filecontent !== null;
}
/**
* Get the file path to the file that will be stored.
*
* @return string
*/
public function get_filepath(): ?string {
return $this->filepath;
}
/**
* Get the file content that will be stored.
*
* @return string
*/
public function get_filecontent(): ?string {
return $this->filecontent;
}
/**
* Get the file record.
*
* @return \stdClass|null
*/
public function get_filerecord(): ?\stdClass {
return $this->filerecord;
}
/**
* Update the file path to a new value.
*
* @param string $filepath
*/
public function update_filepath(string $filepath): void {
if ($this->filepath === null) {
throw new coding_exception('Cannot update file path when the file path is not set');
}
if ($filepath !== $this->filepath) {
$this->contentupdated = true;
$this->filepath = $filepath;
}
}
/**
* Update the file content to a new value.
*
* @param string $filecontent
*/
public function update_filecontent(string $filecontent): void {
if ($this->filecontent === null) {
throw new coding_exception('Cannot update file content when the file content is not set');
}
if ($filecontent !== $this->filecontent) {
$this->contentupdated = true;
$this->filecontent = $filecontent;
}
}
/**
* Whether the file path or file content has been changed.
*
* @return bool
*/
public function has_changed(): bool {
return $this->contentupdated;
}
/**
* Process legacy callbacks.
*/
public function process_legacy_callbacks(): void {
if ($pluginsfunction = get_plugins_with_function(function: 'before_file_created', migratedtohook: true)) {
foreach ($pluginsfunction as $plugintype => $plugins) {
foreach ($plugins as $pluginfunction) {
$pluginfunction($this->filerecord);
}
}
}
}
}