aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private/Files/Cache/MoveFromCacheTrait.php
blob: db35c6bb7f80d2fdb5d5f2911e4e57376c54b0cc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<?php

/**
 * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
 * SPDX-License-Identifier: AGPL-3.0-only
 */
namespace OC\Files\Cache;

use OCP\Files\Cache\ICache;
use OCP\Files\Cache\ICacheEntry;

/**
 * Fallback implementation for moveFromCache
 */
trait MoveFromCacheTrait {
	/**
	 * store meta data for a file or folder
	 *
	 * @param string $file
	 * @param array $data
	 *
	 * @return int file id
	 * @throws \RuntimeException
	 */
	abstract public function put($file, array $data);

	abstract public function copyFromCache(ICache $sourceCache, ICacheEntry $sourceEntry, string $targetPath): int;

	/**
	 * Move a file or folder in the cache
	 *
	 * @param \OCP\Files\Cache\ICache $sourceCache
	 * @param string $sourcePath
	 * @param string $targetPath
	 */
	public function moveFromCache(ICache $sourceCache, $sourcePath, $targetPath) {
		$sourceEntry = $sourceCache->get($sourcePath);

		$this->copyFromCache($sourceCache, $sourceEntry, $targetPath);

		$sourceCache->remove($sourcePath);
	}
}
ass="nt">center; margin-top: 10px; margin-bottom: 10px; background-repeat: no-repeat; } .actions__item__description { text-align: center; flex-grow: 1; display: flex; flex-direction: column; align-items: center; } .actions__item_options { width: 100%; margin-top: 10px; padding-inline-start: 60px; } h3, small { padding: 6px; display: block; } h3 { margin: 0; padding: 0; font-weight: 600; } small { font-size: 10pt; flex-grow: 1; } .colored:not(.more) { background-color: var(--color-primary-element); h3, small { color: var(--color-primary-element-text) } } .actions__item:not(.colored) { flex-direction: row; .actions__item__description { padding-top: 5px; text-align: start; width: calc(100% - 105px); small { padding: 0; } } .icon { width: 50px; margin: 0; margin-inline-end: 10px; &:not(.icon-invert) { filter: var(--background-invert-if-bright); } } } .colored .icon-invert { filter: var(--background-invert-if-bright); }