19 declare(strict_types=1);
49 protected \ilDBInterface
$db;
61 return [self::TABLE_NAME];
73 $revision->setVersionNumber($new_version_number);
74 $revision->setStatus($status);
84 bool $keep_original =
false 89 $revision->setVersionNumber($new_version_number);
90 $revision->setStatus($status);
103 $revision->setVersionNumber($new_version_number);
104 $revision->setStatus(RevisionStatus::PUBLISHED);
112 $r = $this->db->queryF(
113 "SELECT " . self::IDENTIFICATION .
" FROM " . self::TABLE_NAME .
" WHERE " . self::IDENTIFICATION .
" = %s AND version_number = %s",
118 if (
$r->numRows() > 0) {
123 'available' => [
'integer',
true],
124 'owner_id' => [
'integer', $revision->
getOwnerId()],
125 'title' => [
'text', $revision->
getTitle()],
126 'status' => [
'text', $revision->
getStatus()->value],
129 self::IDENTIFICATION => [
'text', $rid],
138 self::IDENTIFICATION => [
'text', $rid],
140 'available' => [
'integer',
true],
141 'owner_id' => [
'integer', $revision->
getOwnerId()],
142 'title' => [
'text', $revision->
getTitle()],
143 'status' => [
'text', $revision->
getStatus()->value],
157 $rid = $resource->getIdentification()->serialize();
158 if (isset($this->cache[$rid]) && is_array($this->cache[$rid])) {
159 foreach ($this->cache[$rid] as $rev) {
160 $collection->
add($rev);
164 $r = $this->db->queryF(
165 "SELECT * FROM " . self::TABLE_NAME .
" WHERE " . self::IDENTIFICATION .
" = %s",
169 while (
$d = $this->db->fetchObject(
$r)) {
171 $revision->setVersionNumber((
int)
$d->version_number);
172 $revision->setOwnerId((
int)
$d->owner_id);
173 $revision->setTitle((
string)
$d->title);
175 $collection->add($revision);
176 $this->cache[
$d->rid][(
int)
$d->version_number] = $revision;
187 $rid = $revision->getIdentification()->serialize();
188 $this->db->manipulateF(
189 "DELETE FROM " . self::TABLE_NAME .
" WHERE " . self::IDENTIFICATION .
" = %s AND version_number = %s",
191 [$rid, $revision->getVersionNumber()]
193 unset($this->cache[$rid][$revision->getVersionNumber()]);
196 public function preload(array $identification_strings): void
198 $r = $this->db->query(
199 "SELECT * FROM " . self::TABLE_NAME .
" WHERE " . $this->db->in(
200 self::IDENTIFICATION,
201 $identification_strings,
206 while (
$d = $this->db->fetchAssoc(
$r)) {
214 $revision->setVersionNumber((
int)$data[
'version_number']);
215 $revision->setOwnerId((
int)$data[
'owner_id']);
216 $revision->setTitle((
string)$data[
'revision_title']);
218 $this->cache[$data[
'rid']][(
int)$data[
'version_number']] = $revision;
setStorageID(string $storage_id)
Class RevisionARRepository.
Interface StorageResource.
Class UploadedFileRevision.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
Class UploadedFileRevision.
preload(array $identification_strings)
blankFromStream(InfoResolver $info_resolver, StorableResource $resource, FileStream $stream, RevisionStatus $status, bool $keep_original=false)
store(Revision $revision)
Class RevisionCollection.
blankFromUpload(InfoResolver $info_resolver, StorableResource $resource, UploadResult $result, RevisionStatus $status)
Class ResourceIdentification.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
populateFromArray(array $data)
Class RevisionDBRepository.
__construct(\ilDBInterface $db)
The base interface for all filesystem streams.
blankFromClone(InfoResolver $info_resolver, StorableResource $resource, FileRevision $revision_to_clone)