diff options
Diffstat (limited to 'lib/models/FileRef.php')
| -rw-r--r-- | lib/models/FileRef.php | 41 |
1 files changed, 36 insertions, 5 deletions
diff --git a/lib/models/FileRef.php b/lib/models/FileRef.php index 043aec1..0487121 100644 --- a/lib/models/FileRef.php +++ b/lib/models/FileRef.php @@ -74,6 +74,8 @@ class FileRef extends SimpleORMap implements PrivacyObject, FeedbackRange $config['registered_callbacks']['after_delete'][] = 'cbRemoveFeedbackElements'; $config['registered_callbacks']['before_delete'][] = 'cbLogDeleteFileRef'; $config['registered_callbacks']['before_store'][] = 'cbMakeUniqueFilename'; + $config['registered_callbacks']['after_store'][] = 'cbLogUpdateFileRef'; + $config['registered_callbacks']['after_create'][] = 'cbLogCreateFileRef'; parent::configure($config); } @@ -82,18 +84,47 @@ class FileRef extends SimpleORMap implements PrivacyObject, FeedbackRange protected $download_url; public $path_to_blob; + private function getLogComment(): string + { + $comment = sprintf( + 'Kommentar: %s', + $this->name + ); + + $range_fullname = $this->folder->getRangeFullname(); + + if ($range_fullname) { + $comment .= " - $range_fullname"; + } + return $comment; + } + + public function cbLogUpdateFileRef() + { + StudipLog::log('FILE_UPDATE', + User::findCurrent()->id, + $this->folder->range_id, + $this->getLogComment() + ); + } public function cbLogDeleteFileRef() { StudipLog::log('FILE_DELETE', User::findCurrent()->id, - null, - sprintf( - 'Kommentar: %s', - $this->name - ) + $this->folder->range_id, + $this->getLogComment() + ); + } + public function cbLogCreateFileRef() + { + StudipLog::log('FILE_UPLOAD', + User::findCurrent()->id, + $this->folder->range_id, + $this->getLogComment() ); } + /** * This callback is called after deleting a FileRef. * It removes the File object that is associated with the FileRef, |
