Completed
Push — master ( ae6394...970eb8 )
by John
31:32 queued 02:08
created
core/templates/loginflowv2/grant.php 2 patches
Indentation   +6 added lines, -6 removed lines patch added patch discarded remove patch
@@ -31,15 +31,15 @@
 block discarded – undo
31 31
 	<h2><?php p($l->t('Account access')) ?></h2>
32 32
 	<p class="info">
33 33
 		<?php p($l->t('Currently logged in as %1$s (%2$s).', [
34
-			$_['userDisplayName'],
35
-			$_['userId'],
36
-		])) ?>
34
+            $_['userDisplayName'],
35
+            $_['userId'],
36
+        ])) ?>
37 37
 	</p>
38 38
 	<p class="info">
39 39
 		<?php print_unescaped($l->t('You are about to grant %1$s access to your %2$s account.', [
40
-			'<strong>' . \OCP\Util::sanitizeHTML($_['client']) . '</strong>',
41
-			\OCP\Util::sanitizeHTML($_['instanceName'])
42
-		])) ?>
40
+            '<strong>' . \OCP\Util::sanitizeHTML($_['client']) . '</strong>',
41
+            \OCP\Util::sanitizeHTML($_['instanceName'])
42
+        ])) ?>
43 43
 	</p>
44 44
 
45 45
 	<br/>
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -37,7 +37,7 @@
 block discarded – undo
37 37
 	</p>
38 38
 	<p class="info">
39 39
 		<?php print_unescaped($l->t('You are about to grant %1$s access to your %2$s account.', [
40
-			'<strong>' . \OCP\Util::sanitizeHTML($_['client']) . '</strong>',
40
+			'<strong>'.\OCP\Util::sanitizeHTML($_['client']).'</strong>',
41 41
 			\OCP\Util::sanitizeHTML($_['instanceName'])
42 42
 		])) ?>
43 43
 	</p>
Please login to merge, or discard this patch.
apps/federatedfilesharing/lib/BackgroundJob/RetryJob.php 2 patches
Spacing   +3 added lines, -3 removed lines patch added patch discarded remove patch
@@ -75,7 +75,7 @@  discard block
 block discarded – undo
75 75
 		$token = $argument['token'];
76 76
 		$action = $argument['action'];
77 77
 		$data = json_decode($argument['data'], true);
78
-		$try = (int)$argument['try'] + 1;
78
+		$try = (int) $argument['try'] + 1;
79 79
 
80 80
 		$result = $this->notifications->sendUpdateToRemote($remote, $remoteId, $token, $action, $data, $try);
81 81
 
@@ -95,7 +95,7 @@  discard block
 block discarded – undo
95 95
 				'token' => $argument['token'],
96 96
 				'data' => $argument['data'],
97 97
 				'action' => $argument['action'],
98
-				'try' => (int)$argument['try'] + 1,
98
+				'try' => (int) $argument['try'] + 1,
99 99
 				'lastRun' => $this->time->getTime()
100 100
 			]
101 101
 		);
@@ -105,7 +105,7 @@  discard block
 block discarded – undo
105 105
 	 * Test if it is time for the next run
106 106
 	 */
107 107
 	protected function shouldRun(array $argument): bool {
108
-		$lastRun = (int)$argument['lastRun'];
108
+		$lastRun = (int) $argument['lastRun'];
109 109
 		return (($this->time->getTime() - $lastRun) > $this->interval);
110 110
 	}
111 111
 }
Please login to merge, or discard this patch.
Indentation   +58 added lines, -58 removed lines patch added patch discarded remove patch
@@ -21,71 +21,71 @@
 block discarded – undo
21 21
  * @package OCA\FederatedFileSharing\BackgroundJob
22 22
  */
23 23
 class RetryJob extends Job {
24
-	private bool $retainJob = true;
24
+    private bool $retainJob = true;
25 25
 
26
-	/** @var int max number of attempts to send the request */
27
-	private int $maxTry = 20;
26
+    /** @var int max number of attempts to send the request */
27
+    private int $maxTry = 20;
28 28
 
29
-	/** @var int how much time should be between two tries (10 minutes) */
30
-	private int $interval = 600;
29
+    /** @var int how much time should be between two tries (10 minutes) */
30
+    private int $interval = 600;
31 31
 
32
-	public function __construct(
33
-		private Notifications $notifications,
34
-		ITimeFactory $time,
35
-	) {
36
-		parent::__construct($time);
37
-	}
32
+    public function __construct(
33
+        private Notifications $notifications,
34
+        ITimeFactory $time,
35
+    ) {
36
+        parent::__construct($time);
37
+    }
38 38
 
39
-	/**
40
-	 * Run the job, then remove it from the jobList
41
-	 */
42
-	public function start(IJobList $jobList): void {
43
-		if ($this->shouldRun($this->argument)) {
44
-			parent::start($jobList);
45
-			$jobList->remove($this, $this->argument);
46
-			if ($this->retainJob) {
47
-				$this->reAddJob($jobList, $this->argument);
48
-			}
49
-		}
50
-	}
39
+    /**
40
+     * Run the job, then remove it from the jobList
41
+     */
42
+    public function start(IJobList $jobList): void {
43
+        if ($this->shouldRun($this->argument)) {
44
+            parent::start($jobList);
45
+            $jobList->remove($this, $this->argument);
46
+            if ($this->retainJob) {
47
+                $this->reAddJob($jobList, $this->argument);
48
+            }
49
+        }
50
+    }
51 51
 
52
-	protected function run($argument) {
53
-		$remote = $argument['remote'];
54
-		$remoteId = $argument['remoteId'];
55
-		$token = $argument['token'];
56
-		$action = $argument['action'];
57
-		$data = json_decode($argument['data'], true);
58
-		$try = (int)$argument['try'] + 1;
52
+    protected function run($argument) {
53
+        $remote = $argument['remote'];
54
+        $remoteId = $argument['remoteId'];
55
+        $token = $argument['token'];
56
+        $action = $argument['action'];
57
+        $data = json_decode($argument['data'], true);
58
+        $try = (int)$argument['try'] + 1;
59 59
 
60
-		$result = $this->notifications->sendUpdateToRemote($remote, $remoteId, $token, $action, $data, $try);
60
+        $result = $this->notifications->sendUpdateToRemote($remote, $remoteId, $token, $action, $data, $try);
61 61
 
62
-		if ($result === true || $try > $this->maxTry) {
63
-			$this->retainJob = false;
64
-		}
65
-	}
62
+        if ($result === true || $try > $this->maxTry) {
63
+            $this->retainJob = false;
64
+        }
65
+    }
66 66
 
67
-	/**
68
-	 * Re-add background job with new arguments
69
-	 */
70
-	protected function reAddJob(IJobList $jobList, array $argument): void {
71
-		$jobList->add(RetryJob::class,
72
-			[
73
-				'remote' => $argument['remote'],
74
-				'remoteId' => $argument['remoteId'],
75
-				'token' => $argument['token'],
76
-				'data' => $argument['data'],
77
-				'action' => $argument['action'],
78
-				'try' => (int)$argument['try'] + 1,
79
-				'lastRun' => $this->time->getTime()
80
-			]
81
-		);
82
-	}
67
+    /**
68
+     * Re-add background job with new arguments
69
+     */
70
+    protected function reAddJob(IJobList $jobList, array $argument): void {
71
+        $jobList->add(RetryJob::class,
72
+            [
73
+                'remote' => $argument['remote'],
74
+                'remoteId' => $argument['remoteId'],
75
+                'token' => $argument['token'],
76
+                'data' => $argument['data'],
77
+                'action' => $argument['action'],
78
+                'try' => (int)$argument['try'] + 1,
79
+                'lastRun' => $this->time->getTime()
80
+            ]
81
+        );
82
+    }
83 83
 
84
-	/**
85
-	 * Test if it is time for the next run
86
-	 */
87
-	protected function shouldRun(array $argument): bool {
88
-		$lastRun = (int)$argument['lastRun'];
89
-		return (($this->time->getTime() - $lastRun) > $this->interval);
90
-	}
84
+    /**
85
+     * Test if it is time for the next run
86
+     */
87
+    protected function shouldRun(array $argument): bool {
88
+        $lastRun = (int)$argument['lastRun'];
89
+        return (($this->time->getTime() - $lastRun) > $this->interval);
90
+    }
91 91
 }
Please login to merge, or discard this patch.
lib/public/IBinaryFinder.php 2 patches
Indentation   +7 added lines, -7 removed lines patch added patch discarded remove patch
@@ -31,11 +31,11 @@
 block discarded – undo
31 31
  * @since 25.0.0
32 32
  */
33 33
 interface IBinaryFinder {
34
-	/**
35
-	 * Try to find a program
36
-	 *
37
-	 * @return false|string
38
-	 * @since 25.0.0
39
-	 */
40
-	public function findBinaryPath(string $program);
34
+    /**
35
+     * Try to find a program
36
+     *
37
+     * @return false|string
38
+     * @since 25.0.0
39
+     */
40
+    public function findBinaryPath(string $program);
41 41
 }
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -1,6 +1,6 @@
 block discarded – undo
1 1
 <?php
2 2
 
3
-declare(strict_types = 1);
3
+declare(strict_types=1);
4 4
 /**
5 5
  * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors
6 6
  * SPDX-License-Identifier: AGPL-3.0-or-later
Please login to merge, or discard this patch.
lib/private/PreviewManager.php 2 patches
Spacing   +3 added lines, -3 removed lines patch added patch discarded remove patch
@@ -326,7 +326,7 @@  discard block
 block discarded – undo
326 326
 	 */
327 327
 	protected function registerCoreProvider($class, $mimeType, $options = []) {
328 328
 		if (in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
329
-			$this->registerProvider($mimeType, function () use ($class, $options) {
329
+			$this->registerProvider($mimeType, function() use ($class, $options) {
330 330
 				return new $class($options);
331 331
 			});
332 332
 		}
@@ -425,14 +425,14 @@  discard block
 block discarded – undo
425 425
 
426 426
 		$providers = $context->getPreviewProviders();
427 427
 		foreach ($providers as $provider) {
428
-			$key = $provider->getMimeTypeRegex() . '-' . $provider->getService();
428
+			$key = $provider->getMimeTypeRegex().'-'.$provider->getService();
429 429
 			if (array_key_exists($key, $this->loadedBootstrapProviders)) {
430 430
 				// Do not load the provider more than once
431 431
 				continue;
432 432
 			}
433 433
 			$this->loadedBootstrapProviders[$key] = null;
434 434
 
435
-			$this->registerProvider($provider->getMimeTypeRegex(), function () use ($provider) {
435
+			$this->registerProvider($provider->getMimeTypeRegex(), function() use ($provider) {
436 436
 				try {
437 437
 					return $this->container->get($provider->getService());
438 438
 				} catch (QueryException $e) {
Please login to merge, or discard this patch.
Indentation   +432 added lines, -432 removed lines patch added patch discarded remove patch
@@ -28,436 +28,436 @@
 block discarded – undo
28 28
 use function array_key_exists;
29 29
 
30 30
 class PreviewManager implements IPreview {
31
-	protected IConfig $config;
32
-	protected IRootFolder $rootFolder;
33
-	protected IAppData $appData;
34
-	protected IEventDispatcher $eventDispatcher;
35
-	private ?Generator $generator = null;
36
-	private GeneratorHelper $helper;
37
-	protected bool $providerListDirty = false;
38
-	protected bool $registeredCoreProviders = false;
39
-	protected array $providers = [];
40
-
41
-	/** @var array mime type => support status */
42
-	protected array $mimeTypeSupportMap = [];
43
-	protected ?array $defaultProviders = null;
44
-	protected ?string $userId;
45
-	private Coordinator $bootstrapCoordinator;
46
-
47
-	/**
48
-	 * Hash map (without value) of loaded bootstrap providers
49
-	 * @psalm-var array<string, null>
50
-	 */
51
-	private array $loadedBootstrapProviders = [];
52
-	private ContainerInterface $container;
53
-	private IBinaryFinder $binaryFinder;
54
-	private IMagickSupport $imagickSupport;
55
-	private bool $enablePreviews;
56
-
57
-	public function __construct(
58
-		IConfig $config,
59
-		IRootFolder $rootFolder,
60
-		IAppData $appData,
61
-		IEventDispatcher $eventDispatcher,
62
-		GeneratorHelper $helper,
63
-		?string $userId,
64
-		Coordinator $bootstrapCoordinator,
65
-		ContainerInterface $container,
66
-		IBinaryFinder $binaryFinder,
67
-		IMagickSupport $imagickSupport,
68
-	) {
69
-		$this->config = $config;
70
-		$this->rootFolder = $rootFolder;
71
-		$this->appData = $appData;
72
-		$this->eventDispatcher = $eventDispatcher;
73
-		$this->helper = $helper;
74
-		$this->userId = $userId;
75
-		$this->bootstrapCoordinator = $bootstrapCoordinator;
76
-		$this->container = $container;
77
-		$this->binaryFinder = $binaryFinder;
78
-		$this->imagickSupport = $imagickSupport;
79
-		$this->enablePreviews = $config->getSystemValueBool('enable_previews', true);
80
-	}
81
-
82
-	/**
83
-	 * In order to improve lazy loading a closure can be registered which will be
84
-	 * called in case preview providers are actually requested
85
-	 *
86
-	 * $callable has to return an instance of \OCP\Preview\IProvider or \OCP\Preview\IProviderV2
87
-	 *
88
-	 * @param string $mimeTypeRegex Regex with the mime types that are supported by this provider
89
-	 * @param \Closure $callable
90
-	 * @return void
91
-	 */
92
-	public function registerProvider($mimeTypeRegex, \Closure $callable): void {
93
-		if (!$this->enablePreviews) {
94
-			return;
95
-		}
96
-
97
-		if (!isset($this->providers[$mimeTypeRegex])) {
98
-			$this->providers[$mimeTypeRegex] = [];
99
-		}
100
-		$this->providers[$mimeTypeRegex][] = $callable;
101
-		$this->providerListDirty = true;
102
-	}
103
-
104
-	/**
105
-	 * Get all providers
106
-	 */
107
-	public function getProviders(): array {
108
-		if (!$this->enablePreviews) {
109
-			return [];
110
-		}
111
-
112
-		$this->registerCoreProviders();
113
-		$this->registerBootstrapProviders();
114
-		if ($this->providerListDirty) {
115
-			$keys = array_map('strlen', array_keys($this->providers));
116
-			array_multisort($keys, SORT_DESC, $this->providers);
117
-			$this->providerListDirty = false;
118
-		}
119
-
120
-		return $this->providers;
121
-	}
122
-
123
-	/**
124
-	 * Does the manager have any providers
125
-	 */
126
-	public function hasProviders(): bool {
127
-		$this->registerCoreProviders();
128
-		return !empty($this->providers);
129
-	}
130
-
131
-	private function getGenerator(): Generator {
132
-		if ($this->generator === null) {
133
-			$this->generator = new Generator(
134
-				$this->config,
135
-				$this,
136
-				$this->appData,
137
-				new GeneratorHelper(
138
-					$this->rootFolder,
139
-					$this->config
140
-				),
141
-				$this->eventDispatcher,
142
-				$this->container->get(LoggerInterface::class),
143
-			);
144
-		}
145
-		return $this->generator;
146
-	}
147
-
148
-	public function getPreview(
149
-		File $file,
150
-		$width = -1,
151
-		$height = -1,
152
-		$crop = false,
153
-		$mode = IPreview::MODE_FILL,
154
-		$mimeType = null,
155
-		bool $cacheResult = true,
156
-	): ISimpleFile {
157
-		$this->throwIfPreviewsDisabled();
158
-		$previewConcurrency = $this->getGenerator()->getNumConcurrentPreviews('preview_concurrency_all');
159
-		$sem = Generator::guardWithSemaphore(Generator::SEMAPHORE_ID_ALL, $previewConcurrency);
160
-		try {
161
-			$preview = $this->getGenerator()->getPreview($file, $width, $height, $crop, $mode, $mimeType, $cacheResult);
162
-		} finally {
163
-			Generator::unguardWithSemaphore($sem);
164
-		}
165
-
166
-		return $preview;
167
-	}
168
-
169
-	/**
170
-	 * Generates previews of a file
171
-	 *
172
-	 * @param File $file
173
-	 * @param array $specifications
174
-	 * @param string $mimeType
175
-	 * @return ISimpleFile the last preview that was generated
176
-	 * @throws NotFoundException
177
-	 * @throws \InvalidArgumentException if the preview would be invalid (in case the original image is invalid)
178
-	 * @since 19.0.0
179
-	 */
180
-	public function generatePreviews(File $file, array $specifications, $mimeType = null) {
181
-		$this->throwIfPreviewsDisabled();
182
-		return $this->getGenerator()->generatePreviews($file, $specifications, $mimeType);
183
-	}
184
-
185
-	/**
186
-	 * returns true if the passed mime type is supported
187
-	 *
188
-	 * @param string $mimeType
189
-	 * @return boolean
190
-	 */
191
-	public function isMimeSupported($mimeType = '*') {
192
-		if (!$this->enablePreviews) {
193
-			return false;
194
-		}
195
-
196
-		if (isset($this->mimeTypeSupportMap[$mimeType])) {
197
-			return $this->mimeTypeSupportMap[$mimeType];
198
-		}
199
-
200
-		$this->registerCoreProviders();
201
-		$this->registerBootstrapProviders();
202
-		$providerMimeTypes = array_keys($this->providers);
203
-		foreach ($providerMimeTypes as $supportedMimeType) {
204
-			if (preg_match($supportedMimeType, $mimeType)) {
205
-				$this->mimeTypeSupportMap[$mimeType] = true;
206
-				return true;
207
-			}
208
-		}
209
-		$this->mimeTypeSupportMap[$mimeType] = false;
210
-		return false;
211
-	}
212
-
213
-	/**
214
-	 * Check if a preview can be generated for a file
215
-	 */
216
-	public function isAvailable(\OCP\Files\FileInfo $file): bool {
217
-		if (!$this->enablePreviews) {
218
-			return false;
219
-		}
220
-
221
-		$this->registerCoreProviders();
222
-		if (!$this->isMimeSupported($file->getMimetype())) {
223
-			return false;
224
-		}
225
-
226
-		$mount = $file->getMountPoint();
227
-		if ($mount and !$mount->getOption('previews', true)) {
228
-			return false;
229
-		}
230
-
231
-		foreach ($this->providers as $supportedMimeType => $providers) {
232
-			if (preg_match($supportedMimeType, $file->getMimetype())) {
233
-				foreach ($providers as $providerClosure) {
234
-					$provider = $this->helper->getProvider($providerClosure);
235
-					if (!($provider instanceof IProviderV2)) {
236
-						continue;
237
-					}
238
-
239
-					if ($provider->isAvailable($file)) {
240
-						return true;
241
-					}
242
-				}
243
-			}
244
-		}
245
-		return false;
246
-	}
247
-
248
-	/**
249
-	 * List of enabled default providers
250
-	 *
251
-	 * The following providers are enabled by default:
252
-	 *  - OC\Preview\PNG
253
-	 *  - OC\Preview\JPEG
254
-	 *  - OC\Preview\GIF
255
-	 *  - OC\Preview\BMP
256
-	 *  - OC\Preview\XBitmap
257
-	 *  - OC\Preview\MarkDown
258
-	 *  - OC\Preview\MP3
259
-	 *  - OC\Preview\TXT
260
-	 *
261
-	 * The following providers are disabled by default due to performance or privacy concerns:
262
-	 *  - OC\Preview\Font
263
-	 *  - OC\Preview\HEIC
264
-	 *  - OC\Preview\Illustrator
265
-	 *  - OC\Preview\Movie
266
-	 *  - OC\Preview\MSOfficeDoc
267
-	 *  - OC\Preview\MSOffice2003
268
-	 *  - OC\Preview\MSOffice2007
269
-	 *  - OC\Preview\OpenDocument
270
-	 *  - OC\Preview\PDF
271
-	 *  - OC\Preview\Photoshop
272
-	 *  - OC\Preview\Postscript
273
-	 *  - OC\Preview\StarOffice
274
-	 *  - OC\Preview\SVG
275
-	 *  - OC\Preview\TIFF
276
-	 *
277
-	 * @return array
278
-	 */
279
-	protected function getEnabledDefaultProvider() {
280
-		if ($this->defaultProviders !== null) {
281
-			return $this->defaultProviders;
282
-		}
283
-
284
-		$imageProviders = [
285
-			Preview\PNG::class,
286
-			Preview\JPEG::class,
287
-			Preview\GIF::class,
288
-			Preview\BMP::class,
289
-			Preview\XBitmap::class,
290
-			Preview\Krita::class,
291
-			Preview\WebP::class,
292
-		];
293
-
294
-		$this->defaultProviders = $this->config->getSystemValue('enabledPreviewProviders', array_merge([
295
-			Preview\MarkDown::class,
296
-			Preview\MP3::class,
297
-			Preview\TXT::class,
298
-			Preview\OpenDocument::class,
299
-		], $imageProviders));
300
-
301
-		if (in_array(Preview\Image::class, $this->defaultProviders)) {
302
-			$this->defaultProviders = array_merge($this->defaultProviders, $imageProviders);
303
-		}
304
-		$this->defaultProviders = array_unique($this->defaultProviders);
305
-		return $this->defaultProviders;
306
-	}
307
-
308
-	/**
309
-	 * Register the default providers (if enabled)
310
-	 *
311
-	 * @param string $class
312
-	 * @param string $mimeType
313
-	 */
314
-	protected function registerCoreProvider($class, $mimeType, $options = []) {
315
-		if (in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
316
-			$this->registerProvider($mimeType, function () use ($class, $options) {
317
-				return new $class($options);
318
-			});
319
-		}
320
-	}
321
-
322
-	/**
323
-	 * Register the default providers (if enabled)
324
-	 */
325
-	protected function registerCoreProviders() {
326
-		if ($this->registeredCoreProviders) {
327
-			return;
328
-		}
329
-		$this->registeredCoreProviders = true;
330
-
331
-		$this->registerCoreProvider(Preview\TXT::class, '/text\/plain/');
332
-		$this->registerCoreProvider(Preview\MarkDown::class, '/text\/(x-)?markdown/');
333
-		$this->registerCoreProvider(Preview\PNG::class, '/image\/png/');
334
-		$this->registerCoreProvider(Preview\JPEG::class, '/image\/jpeg/');
335
-		$this->registerCoreProvider(Preview\GIF::class, '/image\/gif/');
336
-		$this->registerCoreProvider(Preview\BMP::class, '/image\/bmp/');
337
-		$this->registerCoreProvider(Preview\XBitmap::class, '/image\/x-xbitmap/');
338
-		$this->registerCoreProvider(Preview\WebP::class, '/image\/webp/');
339
-		$this->registerCoreProvider(Preview\Krita::class, '/application\/x-krita/');
340
-		$this->registerCoreProvider(Preview\MP3::class, '/audio\/mpeg$/');
341
-		$this->registerCoreProvider(Preview\OpenDocument::class, '/application\/vnd.oasis.opendocument.*/');
342
-		$this->registerCoreProvider(Preview\Imaginary::class, Preview\Imaginary::supportedMimeTypes());
343
-		$this->registerCoreProvider(Preview\ImaginaryPDF::class, Preview\ImaginaryPDF::supportedMimeTypes());
344
-
345
-		// SVG and Bitmap require imagick
346
-		if ($this->imagickSupport->hasExtension()) {
347
-			$imagickProviders = [
348
-				'SVG' => ['mimetype' => '/image\/svg\+xml/', 'class' => Preview\SVG::class],
349
-				'TIFF' => ['mimetype' => '/image\/tiff/', 'class' => Preview\TIFF::class],
350
-				'PDF' => ['mimetype' => '/application\/pdf/', 'class' => Preview\PDF::class],
351
-				'AI' => ['mimetype' => '/application\/illustrator/', 'class' => Preview\Illustrator::class],
352
-				'PSD' => ['mimetype' => '/application\/x-photoshop/', 'class' => Preview\Photoshop::class],
353
-				'EPS' => ['mimetype' => '/application\/postscript/', 'class' => Preview\Postscript::class],
354
-				'TTF' => ['mimetype' => '/application\/(?:font-sfnt|x-font$)/', 'class' => Preview\Font::class],
355
-				'HEIC' => ['mimetype' => '/image\/(x-)?hei(f|c)/', 'class' => Preview\HEIC::class],
356
-				'TGA' => ['mimetype' => '/image\/(x-)?t(ar)?ga/', 'class' => Preview\TGA::class],
357
-				'SGI' => ['mimetype' => '/image\/(x-)?sgi/', 'class' => Preview\SGI::class],
358
-			];
359
-
360
-			foreach ($imagickProviders as $queryFormat => $provider) {
361
-				$class = $provider['class'];
362
-				if (!in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
363
-					continue;
364
-				}
365
-
366
-				if ($this->imagickSupport->supportsFormat($queryFormat)) {
367
-					$this->registerCoreProvider($class, $provider['mimetype']);
368
-				}
369
-			}
370
-		}
371
-
372
-		$this->registerCoreProvidersOffice();
373
-
374
-		// Video requires avconv or ffmpeg
375
-		if (in_array(Preview\Movie::class, $this->getEnabledDefaultProvider())) {
376
-			$movieBinary = $this->config->getSystemValue('preview_ffmpeg_path', null);
377
-			if (!is_string($movieBinary)) {
378
-				$movieBinary = $this->binaryFinder->findBinaryPath('avconv');
379
-				if (!is_string($movieBinary)) {
380
-					$movieBinary = $this->binaryFinder->findBinaryPath('ffmpeg');
381
-				}
382
-			}
383
-
384
-
385
-			if (is_string($movieBinary)) {
386
-				$this->registerCoreProvider(Preview\Movie::class, '/video\/.*/', ['movieBinary' => $movieBinary]);
387
-			}
388
-		}
389
-	}
390
-
391
-	private function registerCoreProvidersOffice(): void {
392
-		$officeProviders = [
393
-			['mimetype' => '/application\/msword/', 'class' => Preview\MSOfficeDoc::class],
394
-			['mimetype' => '/application\/vnd.ms-.*/', 'class' => Preview\MSOffice2003::class],
395
-			['mimetype' => '/application\/vnd.openxmlformats-officedocument.*/', 'class' => Preview\MSOffice2007::class],
396
-			['mimetype' => '/application\/vnd.oasis.opendocument.*/', 'class' => Preview\OpenDocument::class],
397
-			['mimetype' => '/application\/vnd.sun.xml.*/', 'class' => Preview\StarOffice::class],
398
-			['mimetype' => '/image\/emf/', 'class' => Preview\EMF::class],
399
-		];
400
-
401
-		$findBinary = true;
402
-		$officeBinary = false;
403
-
404
-		foreach ($officeProviders as $provider) {
405
-			$class = $provider['class'];
406
-			if (!in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
407
-				continue;
408
-			}
409
-
410
-			if ($findBinary) {
411
-				// Office requires openoffice or libreoffice
412
-				$officeBinary = $this->config->getSystemValue('preview_libreoffice_path', false);
413
-				if ($officeBinary === false) {
414
-					$officeBinary = $this->binaryFinder->findBinaryPath('libreoffice');
415
-				}
416
-				if ($officeBinary === false) {
417
-					$officeBinary = $this->binaryFinder->findBinaryPath('openoffice');
418
-				}
419
-				$findBinary = false;
420
-			}
421
-
422
-			if ($officeBinary) {
423
-				$this->registerCoreProvider($class, $provider['mimetype'], ['officeBinary' => $officeBinary]);
424
-			}
425
-		}
426
-	}
427
-
428
-	private function registerBootstrapProviders(): void {
429
-		$context = $this->bootstrapCoordinator->getRegistrationContext();
430
-
431
-		if ($context === null) {
432
-			// Just ignore for now
433
-			return;
434
-		}
435
-
436
-		$providers = $context->getPreviewProviders();
437
-		foreach ($providers as $provider) {
438
-			$key = $provider->getMimeTypeRegex() . '-' . $provider->getService();
439
-			if (array_key_exists($key, $this->loadedBootstrapProviders)) {
440
-				// Do not load the provider more than once
441
-				continue;
442
-			}
443
-			$this->loadedBootstrapProviders[$key] = null;
444
-
445
-			$this->registerProvider($provider->getMimeTypeRegex(), function () use ($provider) {
446
-				try {
447
-					return $this->container->get($provider->getService());
448
-				} catch (QueryException $e) {
449
-					return null;
450
-				}
451
-			});
452
-		}
453
-	}
454
-
455
-	/**
456
-	 * @throws NotFoundException if preview generation is disabled
457
-	 */
458
-	private function throwIfPreviewsDisabled(): void {
459
-		if (!$this->enablePreviews) {
460
-			throw new NotFoundException('Previews disabled');
461
-		}
462
-	}
31
+    protected IConfig $config;
32
+    protected IRootFolder $rootFolder;
33
+    protected IAppData $appData;
34
+    protected IEventDispatcher $eventDispatcher;
35
+    private ?Generator $generator = null;
36
+    private GeneratorHelper $helper;
37
+    protected bool $providerListDirty = false;
38
+    protected bool $registeredCoreProviders = false;
39
+    protected array $providers = [];
40
+
41
+    /** @var array mime type => support status */
42
+    protected array $mimeTypeSupportMap = [];
43
+    protected ?array $defaultProviders = null;
44
+    protected ?string $userId;
45
+    private Coordinator $bootstrapCoordinator;
46
+
47
+    /**
48
+     * Hash map (without value) of loaded bootstrap providers
49
+     * @psalm-var array<string, null>
50
+     */
51
+    private array $loadedBootstrapProviders = [];
52
+    private ContainerInterface $container;
53
+    private IBinaryFinder $binaryFinder;
54
+    private IMagickSupport $imagickSupport;
55
+    private bool $enablePreviews;
56
+
57
+    public function __construct(
58
+        IConfig $config,
59
+        IRootFolder $rootFolder,
60
+        IAppData $appData,
61
+        IEventDispatcher $eventDispatcher,
62
+        GeneratorHelper $helper,
63
+        ?string $userId,
64
+        Coordinator $bootstrapCoordinator,
65
+        ContainerInterface $container,
66
+        IBinaryFinder $binaryFinder,
67
+        IMagickSupport $imagickSupport,
68
+    ) {
69
+        $this->config = $config;
70
+        $this->rootFolder = $rootFolder;
71
+        $this->appData = $appData;
72
+        $this->eventDispatcher = $eventDispatcher;
73
+        $this->helper = $helper;
74
+        $this->userId = $userId;
75
+        $this->bootstrapCoordinator = $bootstrapCoordinator;
76
+        $this->container = $container;
77
+        $this->binaryFinder = $binaryFinder;
78
+        $this->imagickSupport = $imagickSupport;
79
+        $this->enablePreviews = $config->getSystemValueBool('enable_previews', true);
80
+    }
81
+
82
+    /**
83
+     * In order to improve lazy loading a closure can be registered which will be
84
+     * called in case preview providers are actually requested
85
+     *
86
+     * $callable has to return an instance of \OCP\Preview\IProvider or \OCP\Preview\IProviderV2
87
+     *
88
+     * @param string $mimeTypeRegex Regex with the mime types that are supported by this provider
89
+     * @param \Closure $callable
90
+     * @return void
91
+     */
92
+    public function registerProvider($mimeTypeRegex, \Closure $callable): void {
93
+        if (!$this->enablePreviews) {
94
+            return;
95
+        }
96
+
97
+        if (!isset($this->providers[$mimeTypeRegex])) {
98
+            $this->providers[$mimeTypeRegex] = [];
99
+        }
100
+        $this->providers[$mimeTypeRegex][] = $callable;
101
+        $this->providerListDirty = true;
102
+    }
103
+
104
+    /**
105
+     * Get all providers
106
+     */
107
+    public function getProviders(): array {
108
+        if (!$this->enablePreviews) {
109
+            return [];
110
+        }
111
+
112
+        $this->registerCoreProviders();
113
+        $this->registerBootstrapProviders();
114
+        if ($this->providerListDirty) {
115
+            $keys = array_map('strlen', array_keys($this->providers));
116
+            array_multisort($keys, SORT_DESC, $this->providers);
117
+            $this->providerListDirty = false;
118
+        }
119
+
120
+        return $this->providers;
121
+    }
122
+
123
+    /**
124
+     * Does the manager have any providers
125
+     */
126
+    public function hasProviders(): bool {
127
+        $this->registerCoreProviders();
128
+        return !empty($this->providers);
129
+    }
130
+
131
+    private function getGenerator(): Generator {
132
+        if ($this->generator === null) {
133
+            $this->generator = new Generator(
134
+                $this->config,
135
+                $this,
136
+                $this->appData,
137
+                new GeneratorHelper(
138
+                    $this->rootFolder,
139
+                    $this->config
140
+                ),
141
+                $this->eventDispatcher,
142
+                $this->container->get(LoggerInterface::class),
143
+            );
144
+        }
145
+        return $this->generator;
146
+    }
147
+
148
+    public function getPreview(
149
+        File $file,
150
+        $width = -1,
151
+        $height = -1,
152
+        $crop = false,
153
+        $mode = IPreview::MODE_FILL,
154
+        $mimeType = null,
155
+        bool $cacheResult = true,
156
+    ): ISimpleFile {
157
+        $this->throwIfPreviewsDisabled();
158
+        $previewConcurrency = $this->getGenerator()->getNumConcurrentPreviews('preview_concurrency_all');
159
+        $sem = Generator::guardWithSemaphore(Generator::SEMAPHORE_ID_ALL, $previewConcurrency);
160
+        try {
161
+            $preview = $this->getGenerator()->getPreview($file, $width, $height, $crop, $mode, $mimeType, $cacheResult);
162
+        } finally {
163
+            Generator::unguardWithSemaphore($sem);
164
+        }
165
+
166
+        return $preview;
167
+    }
168
+
169
+    /**
170
+     * Generates previews of a file
171
+     *
172
+     * @param File $file
173
+     * @param array $specifications
174
+     * @param string $mimeType
175
+     * @return ISimpleFile the last preview that was generated
176
+     * @throws NotFoundException
177
+     * @throws \InvalidArgumentException if the preview would be invalid (in case the original image is invalid)
178
+     * @since 19.0.0
179
+     */
180
+    public function generatePreviews(File $file, array $specifications, $mimeType = null) {
181
+        $this->throwIfPreviewsDisabled();
182
+        return $this->getGenerator()->generatePreviews($file, $specifications, $mimeType);
183
+    }
184
+
185
+    /**
186
+     * returns true if the passed mime type is supported
187
+     *
188
+     * @param string $mimeType
189
+     * @return boolean
190
+     */
191
+    public function isMimeSupported($mimeType = '*') {
192
+        if (!$this->enablePreviews) {
193
+            return false;
194
+        }
195
+
196
+        if (isset($this->mimeTypeSupportMap[$mimeType])) {
197
+            return $this->mimeTypeSupportMap[$mimeType];
198
+        }
199
+
200
+        $this->registerCoreProviders();
201
+        $this->registerBootstrapProviders();
202
+        $providerMimeTypes = array_keys($this->providers);
203
+        foreach ($providerMimeTypes as $supportedMimeType) {
204
+            if (preg_match($supportedMimeType, $mimeType)) {
205
+                $this->mimeTypeSupportMap[$mimeType] = true;
206
+                return true;
207
+            }
208
+        }
209
+        $this->mimeTypeSupportMap[$mimeType] = false;
210
+        return false;
211
+    }
212
+
213
+    /**
214
+     * Check if a preview can be generated for a file
215
+     */
216
+    public function isAvailable(\OCP\Files\FileInfo $file): bool {
217
+        if (!$this->enablePreviews) {
218
+            return false;
219
+        }
220
+
221
+        $this->registerCoreProviders();
222
+        if (!$this->isMimeSupported($file->getMimetype())) {
223
+            return false;
224
+        }
225
+
226
+        $mount = $file->getMountPoint();
227
+        if ($mount and !$mount->getOption('previews', true)) {
228
+            return false;
229
+        }
230
+
231
+        foreach ($this->providers as $supportedMimeType => $providers) {
232
+            if (preg_match($supportedMimeType, $file->getMimetype())) {
233
+                foreach ($providers as $providerClosure) {
234
+                    $provider = $this->helper->getProvider($providerClosure);
235
+                    if (!($provider instanceof IProviderV2)) {
236
+                        continue;
237
+                    }
238
+
239
+                    if ($provider->isAvailable($file)) {
240
+                        return true;
241
+                    }
242
+                }
243
+            }
244
+        }
245
+        return false;
246
+    }
247
+
248
+    /**
249
+     * List of enabled default providers
250
+     *
251
+     * The following providers are enabled by default:
252
+     *  - OC\Preview\PNG
253
+     *  - OC\Preview\JPEG
254
+     *  - OC\Preview\GIF
255
+     *  - OC\Preview\BMP
256
+     *  - OC\Preview\XBitmap
257
+     *  - OC\Preview\MarkDown
258
+     *  - OC\Preview\MP3
259
+     *  - OC\Preview\TXT
260
+     *
261
+     * The following providers are disabled by default due to performance or privacy concerns:
262
+     *  - OC\Preview\Font
263
+     *  - OC\Preview\HEIC
264
+     *  - OC\Preview\Illustrator
265
+     *  - OC\Preview\Movie
266
+     *  - OC\Preview\MSOfficeDoc
267
+     *  - OC\Preview\MSOffice2003
268
+     *  - OC\Preview\MSOffice2007
269
+     *  - OC\Preview\OpenDocument
270
+     *  - OC\Preview\PDF
271
+     *  - OC\Preview\Photoshop
272
+     *  - OC\Preview\Postscript
273
+     *  - OC\Preview\StarOffice
274
+     *  - OC\Preview\SVG
275
+     *  - OC\Preview\TIFF
276
+     *
277
+     * @return array
278
+     */
279
+    protected function getEnabledDefaultProvider() {
280
+        if ($this->defaultProviders !== null) {
281
+            return $this->defaultProviders;
282
+        }
283
+
284
+        $imageProviders = [
285
+            Preview\PNG::class,
286
+            Preview\JPEG::class,
287
+            Preview\GIF::class,
288
+            Preview\BMP::class,
289
+            Preview\XBitmap::class,
290
+            Preview\Krita::class,
291
+            Preview\WebP::class,
292
+        ];
293
+
294
+        $this->defaultProviders = $this->config->getSystemValue('enabledPreviewProviders', array_merge([
295
+            Preview\MarkDown::class,
296
+            Preview\MP3::class,
297
+            Preview\TXT::class,
298
+            Preview\OpenDocument::class,
299
+        ], $imageProviders));
300
+
301
+        if (in_array(Preview\Image::class, $this->defaultProviders)) {
302
+            $this->defaultProviders = array_merge($this->defaultProviders, $imageProviders);
303
+        }
304
+        $this->defaultProviders = array_unique($this->defaultProviders);
305
+        return $this->defaultProviders;
306
+    }
307
+
308
+    /**
309
+     * Register the default providers (if enabled)
310
+     *
311
+     * @param string $class
312
+     * @param string $mimeType
313
+     */
314
+    protected function registerCoreProvider($class, $mimeType, $options = []) {
315
+        if (in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
316
+            $this->registerProvider($mimeType, function () use ($class, $options) {
317
+                return new $class($options);
318
+            });
319
+        }
320
+    }
321
+
322
+    /**
323
+     * Register the default providers (if enabled)
324
+     */
325
+    protected function registerCoreProviders() {
326
+        if ($this->registeredCoreProviders) {
327
+            return;
328
+        }
329
+        $this->registeredCoreProviders = true;
330
+
331
+        $this->registerCoreProvider(Preview\TXT::class, '/text\/plain/');
332
+        $this->registerCoreProvider(Preview\MarkDown::class, '/text\/(x-)?markdown/');
333
+        $this->registerCoreProvider(Preview\PNG::class, '/image\/png/');
334
+        $this->registerCoreProvider(Preview\JPEG::class, '/image\/jpeg/');
335
+        $this->registerCoreProvider(Preview\GIF::class, '/image\/gif/');
336
+        $this->registerCoreProvider(Preview\BMP::class, '/image\/bmp/');
337
+        $this->registerCoreProvider(Preview\XBitmap::class, '/image\/x-xbitmap/');
338
+        $this->registerCoreProvider(Preview\WebP::class, '/image\/webp/');
339
+        $this->registerCoreProvider(Preview\Krita::class, '/application\/x-krita/');
340
+        $this->registerCoreProvider(Preview\MP3::class, '/audio\/mpeg$/');
341
+        $this->registerCoreProvider(Preview\OpenDocument::class, '/application\/vnd.oasis.opendocument.*/');
342
+        $this->registerCoreProvider(Preview\Imaginary::class, Preview\Imaginary::supportedMimeTypes());
343
+        $this->registerCoreProvider(Preview\ImaginaryPDF::class, Preview\ImaginaryPDF::supportedMimeTypes());
344
+
345
+        // SVG and Bitmap require imagick
346
+        if ($this->imagickSupport->hasExtension()) {
347
+            $imagickProviders = [
348
+                'SVG' => ['mimetype' => '/image\/svg\+xml/', 'class' => Preview\SVG::class],
349
+                'TIFF' => ['mimetype' => '/image\/tiff/', 'class' => Preview\TIFF::class],
350
+                'PDF' => ['mimetype' => '/application\/pdf/', 'class' => Preview\PDF::class],
351
+                'AI' => ['mimetype' => '/application\/illustrator/', 'class' => Preview\Illustrator::class],
352
+                'PSD' => ['mimetype' => '/application\/x-photoshop/', 'class' => Preview\Photoshop::class],
353
+                'EPS' => ['mimetype' => '/application\/postscript/', 'class' => Preview\Postscript::class],
354
+                'TTF' => ['mimetype' => '/application\/(?:font-sfnt|x-font$)/', 'class' => Preview\Font::class],
355
+                'HEIC' => ['mimetype' => '/image\/(x-)?hei(f|c)/', 'class' => Preview\HEIC::class],
356
+                'TGA' => ['mimetype' => '/image\/(x-)?t(ar)?ga/', 'class' => Preview\TGA::class],
357
+                'SGI' => ['mimetype' => '/image\/(x-)?sgi/', 'class' => Preview\SGI::class],
358
+            ];
359
+
360
+            foreach ($imagickProviders as $queryFormat => $provider) {
361
+                $class = $provider['class'];
362
+                if (!in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
363
+                    continue;
364
+                }
365
+
366
+                if ($this->imagickSupport->supportsFormat($queryFormat)) {
367
+                    $this->registerCoreProvider($class, $provider['mimetype']);
368
+                }
369
+            }
370
+        }
371
+
372
+        $this->registerCoreProvidersOffice();
373
+
374
+        // Video requires avconv or ffmpeg
375
+        if (in_array(Preview\Movie::class, $this->getEnabledDefaultProvider())) {
376
+            $movieBinary = $this->config->getSystemValue('preview_ffmpeg_path', null);
377
+            if (!is_string($movieBinary)) {
378
+                $movieBinary = $this->binaryFinder->findBinaryPath('avconv');
379
+                if (!is_string($movieBinary)) {
380
+                    $movieBinary = $this->binaryFinder->findBinaryPath('ffmpeg');
381
+                }
382
+            }
383
+
384
+
385
+            if (is_string($movieBinary)) {
386
+                $this->registerCoreProvider(Preview\Movie::class, '/video\/.*/', ['movieBinary' => $movieBinary]);
387
+            }
388
+        }
389
+    }
390
+
391
+    private function registerCoreProvidersOffice(): void {
392
+        $officeProviders = [
393
+            ['mimetype' => '/application\/msword/', 'class' => Preview\MSOfficeDoc::class],
394
+            ['mimetype' => '/application\/vnd.ms-.*/', 'class' => Preview\MSOffice2003::class],
395
+            ['mimetype' => '/application\/vnd.openxmlformats-officedocument.*/', 'class' => Preview\MSOffice2007::class],
396
+            ['mimetype' => '/application\/vnd.oasis.opendocument.*/', 'class' => Preview\OpenDocument::class],
397
+            ['mimetype' => '/application\/vnd.sun.xml.*/', 'class' => Preview\StarOffice::class],
398
+            ['mimetype' => '/image\/emf/', 'class' => Preview\EMF::class],
399
+        ];
400
+
401
+        $findBinary = true;
402
+        $officeBinary = false;
403
+
404
+        foreach ($officeProviders as $provider) {
405
+            $class = $provider['class'];
406
+            if (!in_array(trim($class, '\\'), $this->getEnabledDefaultProvider())) {
407
+                continue;
408
+            }
409
+
410
+            if ($findBinary) {
411
+                // Office requires openoffice or libreoffice
412
+                $officeBinary = $this->config->getSystemValue('preview_libreoffice_path', false);
413
+                if ($officeBinary === false) {
414
+                    $officeBinary = $this->binaryFinder->findBinaryPath('libreoffice');
415
+                }
416
+                if ($officeBinary === false) {
417
+                    $officeBinary = $this->binaryFinder->findBinaryPath('openoffice');
418
+                }
419
+                $findBinary = false;
420
+            }
421
+
422
+            if ($officeBinary) {
423
+                $this->registerCoreProvider($class, $provider['mimetype'], ['officeBinary' => $officeBinary]);
424
+            }
425
+        }
426
+    }
427
+
428
+    private function registerBootstrapProviders(): void {
429
+        $context = $this->bootstrapCoordinator->getRegistrationContext();
430
+
431
+        if ($context === null) {
432
+            // Just ignore for now
433
+            return;
434
+        }
435
+
436
+        $providers = $context->getPreviewProviders();
437
+        foreach ($providers as $provider) {
438
+            $key = $provider->getMimeTypeRegex() . '-' . $provider->getService();
439
+            if (array_key_exists($key, $this->loadedBootstrapProviders)) {
440
+                // Do not load the provider more than once
441
+                continue;
442
+            }
443
+            $this->loadedBootstrapProviders[$key] = null;
444
+
445
+            $this->registerProvider($provider->getMimeTypeRegex(), function () use ($provider) {
446
+                try {
447
+                    return $this->container->get($provider->getService());
448
+                } catch (QueryException $e) {
449
+                    return null;
450
+                }
451
+            });
452
+        }
453
+    }
454
+
455
+    /**
456
+     * @throws NotFoundException if preview generation is disabled
457
+     */
458
+    private function throwIfPreviewsDisabled(): void {
459
+        if (!$this->enablePreviews) {
460
+            throw new NotFoundException('Previews disabled');
461
+        }
462
+    }
463 463
 }
Please login to merge, or discard this patch.
apps/settings/lib/Controller/HelpController.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -79,7 +79,7 @@
 block discarded – undo
79 79
 		}
80 80
 
81 81
 		$documentationUrl = $this->urlGenerator->getAbsoluteURL(
82
-			$this->urlGenerator->linkTo('', 'core/doc/' . $mode . '/index.html')
82
+			$this->urlGenerator->linkTo('', 'core/doc/'.$mode.'/index.html')
83 83
 		);
84 84
 
85 85
 		$urlUserDocs = $this->urlGenerator->linkToRoute('settings.Help.help', ['mode' => 'user']);
Please login to merge, or discard this patch.
Indentation   +57 added lines, -57 removed lines patch added patch discarded remove patch
@@ -25,67 +25,67 @@
 block discarded – undo
25 25
 #[OpenAPI(scope: OpenAPI::SCOPE_IGNORE)]
26 26
 class HelpController extends Controller {
27 27
 
28
-	public function __construct(
29
-		string $appName,
30
-		IRequest $request,
31
-		private INavigationManager $navigationManager,
32
-		private IURLGenerator $urlGenerator,
33
-		/** @var string */
34
-		private ?string $userId,
35
-		private IGroupManager $groupManager,
36
-		private IL10N $l10n,
37
-		private IConfig $config,
38
-		private IAppConfig $appConfig,
39
-	) {
40
-		parent::__construct($appName, $request);
41
-	}
28
+    public function __construct(
29
+        string $appName,
30
+        IRequest $request,
31
+        private INavigationManager $navigationManager,
32
+        private IURLGenerator $urlGenerator,
33
+        /** @var string */
34
+        private ?string $userId,
35
+        private IGroupManager $groupManager,
36
+        private IL10N $l10n,
37
+        private IConfig $config,
38
+        private IAppConfig $appConfig,
39
+    ) {
40
+        parent::__construct($appName, $request);
41
+    }
42 42
 
43
-	/**
44
-	 * @return TemplateResponse
45
-	 *
46
-	 * @NoSubAdminRequired
47
-	 */
48
-	#[NoCSRFRequired]
49
-	#[NoAdminRequired]
50
-	public function help(string $mode = 'user'): TemplateResponse {
51
-		$this->navigationManager->setActiveEntry('help');
52
-		$pageTitle = $this->l10n->t('Administrator documentation');
53
-		if ($mode !== 'admin') {
54
-			$pageTitle = $this->l10n->t('User documentation');
55
-			$mode = 'user';
56
-		}
43
+    /**
44
+     * @return TemplateResponse
45
+     *
46
+     * @NoSubAdminRequired
47
+     */
48
+    #[NoCSRFRequired]
49
+    #[NoAdminRequired]
50
+    public function help(string $mode = 'user'): TemplateResponse {
51
+        $this->navigationManager->setActiveEntry('help');
52
+        $pageTitle = $this->l10n->t('Administrator documentation');
53
+        if ($mode !== 'admin') {
54
+            $pageTitle = $this->l10n->t('User documentation');
55
+            $mode = 'user';
56
+        }
57 57
 
58
-		$documentationUrl = $this->urlGenerator->getAbsoluteURL(
59
-			$this->urlGenerator->linkTo('', 'core/doc/' . $mode . '/index.html')
60
-		);
58
+        $documentationUrl = $this->urlGenerator->getAbsoluteURL(
59
+            $this->urlGenerator->linkTo('', 'core/doc/' . $mode . '/index.html')
60
+        );
61 61
 
62
-		$urlUserDocs = $this->urlGenerator->linkToRoute('settings.Help.help', ['mode' => 'user']);
63
-		$urlAdminDocs = $this->urlGenerator->linkToRoute('settings.Help.help', ['mode' => 'admin']);
62
+        $urlUserDocs = $this->urlGenerator->linkToRoute('settings.Help.help', ['mode' => 'user']);
63
+        $urlAdminDocs = $this->urlGenerator->linkToRoute('settings.Help.help', ['mode' => 'admin']);
64 64
 
65
-		$knowledgebaseEmbedded = $this->config->getSystemValueBool('knowledgebase.embedded', false);
66
-		if (!$knowledgebaseEmbedded) {
67
-			$pageTitle = $this->l10n->t('Nextcloud help overview');
68
-			$urlUserDocs = $this->urlGenerator->linkToDocs('user');
69
-			$urlAdminDocs = $this->urlGenerator->linkToDocs('admin');
70
-		}
65
+        $knowledgebaseEmbedded = $this->config->getSystemValueBool('knowledgebase.embedded', false);
66
+        if (!$knowledgebaseEmbedded) {
67
+            $pageTitle = $this->l10n->t('Nextcloud help overview');
68
+            $urlUserDocs = $this->urlGenerator->linkToDocs('user');
69
+            $urlAdminDocs = $this->urlGenerator->linkToDocs('admin');
70
+        }
71 71
 
72
-		$legalNoticeUrl = $this->appConfig->getValueString('theming', 'imprintUrl');
73
-		$privacyUrl = $this->appConfig->getValueString('theming', 'privacyUrl');
72
+        $legalNoticeUrl = $this->appConfig->getValueString('theming', 'imprintUrl');
73
+        $privacyUrl = $this->appConfig->getValueString('theming', 'privacyUrl');
74 74
 
75
-		$response = new TemplateResponse('settings', 'help', [
76
-			'admin' => $this->groupManager->isAdmin($this->userId),
77
-			'url' => $documentationUrl,
78
-			'urlUserDocs' => $urlUserDocs,
79
-			'urlAdminDocs' => $urlAdminDocs,
80
-			'mode' => $mode,
81
-			'pageTitle' => $pageTitle,
82
-			'knowledgebaseEmbedded' => $knowledgebaseEmbedded,
83
-			'legalNoticeUrl' => $legalNoticeUrl,
84
-			'privacyUrl' => $privacyUrl,
85
-		]);
86
-		$policy = new ContentSecurityPolicy();
87
-		$policy->addAllowedFrameDomain('\'self\'');
88
-		$response->setContentSecurityPolicy($policy);
89
-		return $response;
90
-	}
75
+        $response = new TemplateResponse('settings', 'help', [
76
+            'admin' => $this->groupManager->isAdmin($this->userId),
77
+            'url' => $documentationUrl,
78
+            'urlUserDocs' => $urlUserDocs,
79
+            'urlAdminDocs' => $urlAdminDocs,
80
+            'mode' => $mode,
81
+            'pageTitle' => $pageTitle,
82
+            'knowledgebaseEmbedded' => $knowledgebaseEmbedded,
83
+            'legalNoticeUrl' => $legalNoticeUrl,
84
+            'privacyUrl' => $privacyUrl,
85
+        ]);
86
+        $policy = new ContentSecurityPolicy();
87
+        $policy->addAllowedFrameDomain('\'self\'');
88
+        $response->setContentSecurityPolicy($policy);
89
+        return $response;
90
+    }
91 91
 }
Please login to merge, or discard this patch.
lib/private/Authentication/Token/TokenCleanupJob.php 1 patch
Indentation   +11 added lines, -11 removed lines patch added patch discarded remove patch
@@ -25,17 +25,17 @@
 block discarded – undo
25 25
 use OCP\BackgroundJob\TimedJob;
26 26
 
27 27
 class TokenCleanupJob extends TimedJob {
28
-	private IProvider $provider;
28
+    private IProvider $provider;
29 29
 
30
-	public function __construct(ITimeFactory $time, IProvider $provider) {
31
-		parent::__construct($time);
32
-		$this->provider = $provider;
33
-		// Run once a day at off-peak time
34
-		$this->setInterval(24 * 60 * 60);
35
-		$this->setTimeSensitivity(self::TIME_INSENSITIVE);
36
-	}
30
+    public function __construct(ITimeFactory $time, IProvider $provider) {
31
+        parent::__construct($time);
32
+        $this->provider = $provider;
33
+        // Run once a day at off-peak time
34
+        $this->setInterval(24 * 60 * 60);
35
+        $this->setTimeSensitivity(self::TIME_INSENSITIVE);
36
+    }
37 37
 
38
-	protected function run($argument) {
39
-		$this->provider->invalidateOldTokens();
40
-	}
38
+    protected function run($argument) {
39
+        $this->provider->invalidateOldTokens();
40
+    }
41 41
 }
Please login to merge, or discard this patch.
lib/private/Repair/NC24/AddTokenCleanupJob.php 1 patch
Indentation   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -31,17 +31,17 @@
 block discarded – undo
31 31
 use OCP\Migration\IRepairStep;
32 32
 
33 33
 class AddTokenCleanupJob implements IRepairStep {
34
-	private IJobList $jobList;
34
+    private IJobList $jobList;
35 35
 
36
-	public function __construct(IJobList $jobList) {
37
-		$this->jobList = $jobList;
38
-	}
36
+    public function __construct(IJobList $jobList) {
37
+        $this->jobList = $jobList;
38
+    }
39 39
 
40
-	public function getName(): string {
41
-		return 'Add token cleanup job';
42
-	}
40
+    public function getName(): string {
41
+        return 'Add token cleanup job';
42
+    }
43 43
 
44
-	public function run(IOutput $output) {
45
-		$this->jobList->add(TokenCleanupJob::class);
46
-	}
44
+    public function run(IOutput $output) {
45
+        $this->jobList->add(TokenCleanupJob::class);
46
+    }
47 47
 }
Please login to merge, or discard this patch.
lib/public/Files/DavUtil.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -47,7 +47,7 @@
 block discarded – undo
47 47
 	public static function getDavFileId(int $id): string {
48 48
 		$instanceId = \OC_Util::getInstanceId();
49 49
 		$id = sprintf('%08d', $id);
50
-		return $id . $instanceId;
50
+		return $id.$instanceId;
51 51
 	}
52 52
 
53 53
 	/**
Please login to merge, or discard this patch.
Indentation   +57 added lines, -57 removed lines patch added patch discarded remove patch
@@ -15,64 +15,64 @@
 block discarded – undo
15 15
  * @since 25.0.0
16 16
  */
17 17
 class DavUtil {
18
-	/**
19
-	 * Compute the fileId to use for dav responses
20
-	 *
21
-	 * @param int $id Id of the file returned by FileInfo::getId
22
-	 * @since 25.0.0
23
-	 */
24
-	public static function getDavFileId(int $id): string {
25
-		$instanceId = \OC_Util::getInstanceId();
26
-		$id = sprintf('%08d', $id);
27
-		return $id . $instanceId;
28
-	}
18
+    /**
19
+     * Compute the fileId to use for dav responses
20
+     *
21
+     * @param int $id Id of the file returned by FileInfo::getId
22
+     * @since 25.0.0
23
+     */
24
+    public static function getDavFileId(int $id): string {
25
+        $instanceId = \OC_Util::getInstanceId();
26
+        $id = sprintf('%08d', $id);
27
+        return $id . $instanceId;
28
+    }
29 29
 
30
-	/**
31
-	 * Compute the format needed for returning permissions for dav
32
-	 *
33
-	 * @since 25.0.0
34
-	 */
35
-	public static function getDavPermissions(FileInfo $info): string {
36
-		$permissions = $info->getPermissions();
37
-		$p = '';
38
-		if ($info->isShared()) {
39
-			$p .= 'S';
40
-		}
41
-		if ($permissions & Constants::PERMISSION_SHARE) {
42
-			$p .= 'R';
43
-		}
44
-		if ($info->isMounted()) {
45
-			$p .= 'M';
46
-		}
47
-		if ($permissions & Constants::PERMISSION_READ) {
48
-			$p .= 'G';
49
-		}
50
-		if ($permissions & Constants::PERMISSION_DELETE) {
51
-			$p .= 'D';
52
-		}
53
-		if ($permissions & Constants::PERMISSION_UPDATE) {
54
-			$p .= 'NV'; // Renameable, Movable
55
-		}
30
+    /**
31
+     * Compute the format needed for returning permissions for dav
32
+     *
33
+     * @since 25.0.0
34
+     */
35
+    public static function getDavPermissions(FileInfo $info): string {
36
+        $permissions = $info->getPermissions();
37
+        $p = '';
38
+        if ($info->isShared()) {
39
+            $p .= 'S';
40
+        }
41
+        if ($permissions & Constants::PERMISSION_SHARE) {
42
+            $p .= 'R';
43
+        }
44
+        if ($info->isMounted()) {
45
+            $p .= 'M';
46
+        }
47
+        if ($permissions & Constants::PERMISSION_READ) {
48
+            $p .= 'G';
49
+        }
50
+        if ($permissions & Constants::PERMISSION_DELETE) {
51
+            $p .= 'D';
52
+        }
53
+        if ($permissions & Constants::PERMISSION_UPDATE) {
54
+            $p .= 'NV'; // Renameable, Movable
55
+        }
56 56
 
57
-		// since we always add update permissions for the root of movable mounts
58
-		// we need to check the shared cache item directly to determine if it's writable
59
-		$storage = $info->getStorage();
60
-		if ($info->getInternalPath() === '' && $info->getMountPoint() instanceof IMovableMount) {
61
-			$rootEntry = $storage->getCache()->get('');
62
-			$isWritable = $rootEntry->getPermissions() & Constants::PERMISSION_UPDATE;
63
-		} else {
64
-			$isWritable = $permissions & Constants::PERMISSION_UPDATE;
65
-		}
57
+        // since we always add update permissions for the root of movable mounts
58
+        // we need to check the shared cache item directly to determine if it's writable
59
+        $storage = $info->getStorage();
60
+        if ($info->getInternalPath() === '' && $info->getMountPoint() instanceof IMovableMount) {
61
+            $rootEntry = $storage->getCache()->get('');
62
+            $isWritable = $rootEntry->getPermissions() & Constants::PERMISSION_UPDATE;
63
+        } else {
64
+            $isWritable = $permissions & Constants::PERMISSION_UPDATE;
65
+        }
66 66
 
67
-		if ($info->getType() === FileInfo::TYPE_FILE) {
68
-			if ($isWritable) {
69
-				$p .= 'W';
70
-			}
71
-		} else {
72
-			if ($permissions & Constants::PERMISSION_CREATE) {
73
-				$p .= 'CK';
74
-			}
75
-		}
76
-		return $p;
77
-	}
67
+        if ($info->getType() === FileInfo::TYPE_FILE) {
68
+            if ($isWritable) {
69
+                $p .= 'W';
70
+            }
71
+        } else {
72
+            if ($permissions & Constants::PERMISSION_CREATE) {
73
+                $p .= 'CK';
74
+            }
75
+        }
76
+        return $p;
77
+    }
78 78
 }
Please login to merge, or discard this patch.
lib/public/Collaboration/Reference/IReferenceProvider.php 1 patch
Indentation   +29 added lines, -29 removed lines patch added patch discarded remove patch
@@ -28,36 +28,36 @@
 block discarded – undo
28 28
  * @since 25.0.0
29 29
  */
30 30
 interface IReferenceProvider {
31
-	/**
32
-	 * Validate that a given reference identifier matches the current provider
33
-	 *
34
-	 * @since 25.0.0
35
-	 */
36
-	public function matchReference(string $referenceText): bool;
31
+    /**
32
+     * Validate that a given reference identifier matches the current provider
33
+     *
34
+     * @since 25.0.0
35
+     */
36
+    public function matchReference(string $referenceText): bool;
37 37
 
38
-	/**
39
-	 * Return a reference with its metadata for a given reference identifier
40
-	 *
41
-	 * @since 25.0.0
42
-	 */
43
-	public function resolveReference(string $referenceText): ?IReference;
38
+    /**
39
+     * Return a reference with its metadata for a given reference identifier
40
+     *
41
+     * @since 25.0.0
42
+     */
43
+    public function resolveReference(string $referenceText): ?IReference;
44 44
 
45
-	/**
46
-	 * Return true if the reference metadata can be globally cached
47
-	 *
48
-	 * @since 25.0.0
49
-	 */
50
-	public function getCachePrefix(string $referenceId): string;
45
+    /**
46
+     * Return true if the reference metadata can be globally cached
47
+     *
48
+     * @since 25.0.0
49
+     */
50
+    public function getCachePrefix(string $referenceId): string;
51 51
 
52
-	/**
53
-	 * Return a custom cache key to be used for caching the metadata
54
-	 * This could be for example the current user id if the reference
55
-	 * access permissions are different for each user
56
-	 *
57
-	 * Should return null, if the cache is only related to the
58
-	 * reference id and has no further dependency
59
-	 *
60
-	 * @since 25.0.0
61
-	 */
62
-	public function getCacheKey(string $referenceId): ?string;
52
+    /**
53
+     * Return a custom cache key to be used for caching the metadata
54
+     * This could be for example the current user id if the reference
55
+     * access permissions are different for each user
56
+     *
57
+     * Should return null, if the cache is only related to the
58
+     * reference id and has no further dependency
59
+     *
60
+     * @since 25.0.0
61
+     */
62
+    public function getCacheKey(string $referenceId): ?string;
63 63
 }
Please login to merge, or discard this patch.