2015-12-02 08:03:52 -05:00
|
|
|
<?php
|
2024-05-23 03:26:56 -04:00
|
|
|
|
2015-12-02 08:03:52 -05:00
|
|
|
/**
|
2024-05-23 03:26:56 -04:00
|
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
2015-12-02 08:03:52 -05:00
|
|
|
*/
|
|
|
|
|
namespace OCP\Files\Cache;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Propagate etags and mtimes within the storage
|
2015-12-02 09:17:58 -05:00
|
|
|
*
|
|
|
|
|
* @since 9.0.0
|
2015-12-02 08:03:52 -05:00
|
|
|
*/
|
|
|
|
|
interface IPropagator {
|
2016-05-20 09:10:18 -04:00
|
|
|
/**
|
|
|
|
|
* Mark the beginning of a propagation batch
|
|
|
|
|
*
|
|
|
|
|
* Note that not all cache setups support propagation in which case this will be a noop
|
|
|
|
|
*
|
|
|
|
|
* Batching for cache setups that do support it has to be explicit since the cache state is not fully consistent
|
|
|
|
|
* before the batch is committed.
|
|
|
|
|
*
|
|
|
|
|
* @since 9.1.0
|
|
|
|
|
*/
|
|
|
|
|
public function beginBatch();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Commit the active propagation batch
|
|
|
|
|
*
|
|
|
|
|
* @since 9.1.0
|
|
|
|
|
*/
|
|
|
|
|
public function commitBatch();
|
|
|
|
|
|
2015-12-02 08:03:52 -05:00
|
|
|
/**
|
|
|
|
|
* @param string $internalPath
|
|
|
|
|
* @param int $time
|
2021-10-14 11:11:34 -04:00
|
|
|
* @param int $sizeDifference
|
2015-12-02 09:17:58 -05:00
|
|
|
* @since 9.0.0
|
2015-12-02 08:03:52 -05:00
|
|
|
*/
|
2021-10-14 11:11:34 -04:00
|
|
|
public function propagateChange($internalPath, $time, $sizeDifference = 0);
|
2015-12-02 08:03:52 -05:00
|
|
|
}
|