‪TYPO3CMS  ‪main
FileCollector.php
Go to the documentation of this file.
1 <?php
2 
3 declare(strict_types=1);
4 
5 /*
6  * This file is part of the TYPO3 CMS project.
7  *
8  * It is free software; you can redistribute it and/or modify it under
9  * the terms of the GNU General Public License, either version 2
10  * of the License, or any later version.
11  *
12  * For the full copyright and license information, please read the
13  * LICENSE.txt file that was distributed with this source code.
14  *
15  * The TYPO3 project - inspiring people to share!
16  */
17 
19 
20 use Psr\Log\LoggerAwareInterface;
21 use Psr\Log\LoggerAwareTrait;
32 
46 class ‪FileCollector implements \Countable, LoggerAwareInterface
47 {
48  use LoggerAwareTrait;
49 
55  protected array ‪$files = [];
56 
57  public function ‪__construct(
58  protected readonly ‪ResourceFactory $resourceFactory,
59  protected readonly ‪FileCollectionRepository $fileCollectionRepository,
60  protected readonly ‪FileRepository $fileRepository,
61  ) {}
62 
66  public function ‪addFiles(array $fileUids = []): void
67  {
68  foreach ($fileUids as $fileUid) {
69  try {
70  $this->‪addFileObject($this->resourceFactory->getFileObject($fileUid));
71  } catch (‪Exception $e) {
72  $this->logger->warning(
73  'The file with uid "' . $fileUid
74  . '" could not be found and won\'t be included in frontend output',
75  ['exception' => $e]
76  );
77  }
78  }
79  }
80 
88  public function ‪addFilesFromRelation(string $relationTable, string $relationField, array $referenceRecord): void
89  {
90  $fileReferences = $this->‪getFileReferences($relationTable, $relationField, $referenceRecord);
91  if (!empty($fileReferences)) {
92  $this->‪addFileObjects($fileReferences);
93  }
94  }
95 
99  public function ‪addFileReferences(array $fileReferenceUids = []): void
100  {
101  foreach ($fileReferenceUids as $fileReferenceUid) {
102  $fileObject = $this->resourceFactory->getFileReferenceObject((int)$fileReferenceUid);
103  if (!$fileObject instanceof ‪FileInterface) {
104  continue;
105  }
106  $this->‪addFileObject($fileObject);
107  }
108  }
109 
113  public function ‪addFilesFromFileCollections(array $fileCollectionUids = []): void
114  {
115  foreach ($fileCollectionUids as $fileCollectionUid) {
116  $this->‪addFilesFromFileCollection((int)$fileCollectionUid);
117  }
118  }
119 
123  public function ‪addFilesFromFileCollection(int $fileCollectionUid): void
124  {
125  if ($fileCollectionUid <= 0) {
126  return;
127  }
128  try {
129  $fileCollection = $this->fileCollectionRepository->findByUid($fileCollectionUid);
130  if ($fileCollection instanceof ‪AbstractFileCollection) {
131  $fileCollection->loadContents();
132  ‪$files = $fileCollection->getItems();
133  $this->‪addFileObjects($files);
134  }
135  } catch (‪Exception $e) {
136  $this->logger->warning(
137  'The file-collection with uid "' . $fileCollectionUid
138  . '" could not be found or contents could not be loaded and won\'t be included in frontend output.',
139  ['exception' => $e]
140  );
141  }
142  }
143 
150  public function ‪addFilesFromFolders(array $folderIdentifiers, bool $recursive = false): void
151  {
152  foreach ($folderIdentifiers as $folderIdentifier) {
153  $this->‪addFilesFromFolder($folderIdentifier, $recursive);
154  }
155  }
156 
163  public function ‪addFilesFromFolder(string $folderIdentifier, bool $recursive = false): void
164  {
165  if ($folderIdentifier) {
166  try {
167  if (str_starts_with($folderIdentifier, 't3://folder')) {
168  // a t3://folder link to a folder in FAL
169  $linkService = GeneralUtility::makeInstance(LinkService::class);
170  $data = $linkService->resolveByStringRepresentation($folderIdentifier);
171  $folder = $data['folder'];
172  } else {
173  $folder = $this->resourceFactory->getFolderObjectFromCombinedIdentifier($folderIdentifier);
174  }
175  if ($folder instanceof ‪Folder) {
176  ‪$files = $folder->getFiles(0, 0, ‪Folder::FILTER_MODE_USE_OWN_AND_STORAGE_FILTERS, $recursive);
177  $this->‪addFileObjects(array_values(‪$files));
178  }
179  } catch (‪Exception $e) {
180  $this->logger->warning('The folder with identifier "{folder}" could not be found and won\'t be included in frontend output', [
181  'folder' => $folderIdentifier,
182  'exception' => $e,
183  ]);
184  }
185  }
186  }
187 
194  public function ‪sort(string $sortingProperty = '', string $sortingOrder = 'ascending'): void
195  {
196  if ($sortingProperty !== '' && ‪count($this->files) > 1) {
197  @usort(
198  $this->files,
199  static function (
200  ‪FileInterface $a,
202  ) use ($sortingProperty) {
203  if ($a->‪hasProperty($sortingProperty) && $b->‪hasProperty($sortingProperty)) {
204  return strnatcasecmp($a->getProperty($sortingProperty), $b->getProperty($sortingProperty));
205  }
206  return 0;
207  }
208  );
209 
210  switch (strtolower($sortingOrder)) {
211  case 'descending':
212  case 'desc':
213  $this->files = array_reverse($this->files);
214  break;
215  case 'random':
216  case 'rand':
217  shuffle($this->files);
218  break;
219  }
220  }
221  }
222 
226  public function ‪addFileObject(‪FileInterface $file): void
227  {
228  $this->files[] = $file;
229  }
230 
236  public function ‪addFileObjects(array ‪$files): void
237  {
238  $this->files = array_merge($this->files, ‪$files);
239  }
240 
244  public function ‪getFiles(): array
245  {
246  return ‪$this->files;
247  }
248 
249  public function ‪count(): int
250  {
251  return ‪count($this->files);
252  }
253 
262  protected function ‪getFileReferences(string $tableName, string $fieldName, array $element): array
263  {
264  $currentId = !empty($element['uid']) ? (int)$element['uid'] : 0;
265 
266  // Fetch the references of the default element
267  try {
268  $references = $this->fileRepository->findByRelation($tableName, $fieldName, $currentId);
269  } catch (‪FileDoesNotExistException $e) {
274  return [];
275  } catch (\InvalidArgumentException $e) {
280  $this->logger->error('{exception_message}: table: {table}, field: {field}, currentId: {current_id}', [
281  'table' => $tableName,
282  'field' => $fieldName,
283  'currentId' => $currentId,
284  'exception' => $e,
285  ]);
286  return [];
287  }
288 
289  $localizedId = $element['_LOCALIZED_UID'] ?? null;
290 
291  $isTableLocalizable = (
292  !empty(‪$GLOBALS['TCA'][$tableName]['ctrl']['languageField'])
293  && !empty(‪$GLOBALS['TCA'][$tableName]['ctrl']['transOrigPointerField'])
294  );
295  if ($isTableLocalizable && $localizedId !== null) {
296  $localizedReferences = $this->fileRepository->findByRelation($tableName, $fieldName, (int)$localizedId);
297  $references = $localizedReferences;
298  }
299 
300  return $references;
301  }
302 }
‪TYPO3\CMS\Frontend\Resource\FileCollector\__construct
‪__construct(protected readonly ResourceFactory $resourceFactory, protected readonly FileCollectionRepository $fileCollectionRepository, protected readonly FileRepository $fileRepository,)
Definition: FileCollector.php:57
‪TYPO3\CMS\Core\Resource\FileCollectionRepository
Definition: FileCollectionRepository.php:30
‪TYPO3\CMS\Frontend\Resource\FileCollector\sort
‪sort(string $sortingProperty='', string $sortingOrder='ascending')
Definition: FileCollector.php:194
‪TYPO3\CMS\Core\Resource\Collection\AbstractFileCollection
Definition: AbstractFileCollection.php:28
‪TYPO3\CMS\Core\Resource\FileInterface
Definition: FileInterface.php:26
‪TYPO3\CMS\Frontend\Resource
Definition: FileCollector.php:18
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFilesFromFolders
‪addFilesFromFolders(array $folderIdentifiers, bool $recursive=false)
Definition: FileCollector.php:150
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFiles
‪addFiles(array $fileUids=[])
Definition: FileCollector.php:66
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFilesFromFileCollection
‪addFilesFromFileCollection(int $fileCollectionUid)
Definition: FileCollector.php:123
‪TYPO3\CMS\Core\Resource\Folder\FILTER_MODE_USE_OWN_AND_STORAGE_FILTERS
‪const FILTER_MODE_USE_OWN_AND_STORAGE_FILTERS
Definition: Folder.php:70
‪TYPO3\CMS\Core\Resource\Exception\FileDoesNotExistException
Definition: FileDoesNotExistException.php:21
‪TYPO3\CMS\Core\Resource\FileInterface\hasProperty
‪hasProperty(string $key)
‪TYPO3\CMS\Frontend\Resource\FileCollector\getFileReferences
‪getFileReferences(string $tableName, string $fieldName, array $element)
Definition: FileCollector.php:262
‪TYPO3\CMS\Frontend\Resource\FileCollector
Definition: FileCollector.php:47
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFileReferences
‪addFileReferences(array $fileReferenceUids=[])
Definition: FileCollector.php:99
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFilesFromFolder
‪addFilesFromFolder(string $folderIdentifier, bool $recursive=false)
Definition: FileCollector.php:163
‪TYPO3\CMS\Core\Resource\FileRepository
Definition: FileRepository.php:38
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFileObject
‪addFileObject(FileInterface $file)
Definition: FileCollector.php:226
‪TYPO3\CMS\Core\Resource\Folder
Definition: Folder.php:38
‪TYPO3\CMS\Core\Resource\ResourceFactory
Definition: ResourceFactory.php:42
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFilesFromRelation
‪addFilesFromRelation(string $relationTable, string $relationField, array $referenceRecord)
Definition: FileCollector.php:88
‪TYPO3\CMS\Frontend\Resource\FileCollector\$files
‪array $files
Definition: FileCollector.php:55
‪TYPO3\CMS\Core\Resource\Exception
Definition: Exception.php:21
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFilesFromFileCollections
‪addFilesFromFileCollections(array $fileCollectionUids=[])
Definition: FileCollector.php:113
‪$GLOBALS
‪$GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['adminpanel']['modules']
Definition: ext_localconf.php:25
‪TYPO3\CMS\Frontend\Resource\FileCollector\getFiles
‪getFiles()
Definition: FileCollector.php:244
‪TYPO3\CMS\Core\Utility\GeneralUtility
Definition: GeneralUtility.php:52
‪TYPO3\CMS\Frontend\Resource\FileCollector\count
‪count()
Definition: FileCollector.php:249
‪TYPO3\CMS\Frontend\Resource\FileCollector\addFileObjects
‪addFileObjects(array $files)
Definition: FileCollector.php:236
‪TYPO3\CMS\Core\Resource\Exception
Definition: AbstractFileOperationException.php:16