123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 |
- <?php
- namespace OCA\Files_Sharing;
- use OC\Files\Cache\FailedCache;
- use OC\Files\Cache\Wrapper\CacheJail;
- use OC\Files\Storage\Wrapper\Jail;
- use OCP\Files\Cache\ICacheEntry;
- use OCP\Files\StorageNotAvailableException;
- class Cache extends CacheJail {
-
- private $storage;
-
- private $sourceRootInfo;
- private $rootUnchanged = true;
- private $ownerDisplayName;
- private $numericId;
-
- public function __construct($storage, ICacheEntry $sourceRootInfo) {
- $this->storage = $storage;
- $this->sourceRootInfo = $sourceRootInfo;
- $this->numericId = $sourceRootInfo->getStorageId();
- parent::__construct(
- null,
- ''
- );
- }
- protected function getRoot() {
- if ($this->root === '') {
- $absoluteRoot = $this->sourceRootInfo->getPath();
-
-
-
- $currentStorage = $this->storage->getSourceStorage();
- if ($currentStorage->instanceOfStorage(Jail::class)) {
-
- $absoluteRoot = $currentStorage->getJailedPath($absoluteRoot);
- }
- $this->root = $absoluteRoot;
- }
- return $this->root;
- }
- protected function getGetUnjailedRoot() {
- return $this->sourceRootInfo->getPath();
- }
- public function getCache() {
- if (is_null($this->cache)) {
- $sourceStorage = $this->storage->getSourceStorage();
- if ($sourceStorage) {
- $this->cache = $sourceStorage->getCache();
- } else {
-
- return new FailedCache();
- }
- }
- return $this->cache;
- }
- public function getNumericStorageId() {
- if (isset($this->numericId)) {
- return $this->numericId;
- } else {
- return false;
- }
- }
- public function get($file) {
- if ($this->rootUnchanged && ($file === '' || $file === $this->sourceRootInfo->getId())) {
- return $this->formatCacheEntry(clone $this->sourceRootInfo, '');
- }
- return parent::get($file);
- }
- public function update($id, array $data) {
- $this->rootUnchanged = false;
- parent::update($id, $data);
- }
- public function insert($file, array $data) {
- $this->rootUnchanged = false;
- return parent::insert($file, $data);
- }
- public function remove($file) {
- $this->rootUnchanged = false;
- parent::remove($file);
- }
- public function moveFromCache(\OCP\Files\Cache\ICache $sourceCache, $sourcePath, $targetPath) {
- $this->rootUnchanged = false;
- return parent::moveFromCache($sourceCache, $sourcePath, $targetPath);
- }
- protected function formatCacheEntry($entry, $path = null) {
- if (is_null($path)) {
- $path = $entry['path'] ?? '';
- $entry['path'] = $this->getJailedPath($path);
- } else {
- $entry['path'] = $path;
- }
- try {
- if (isset($entry['permissions'])) {
- $entry['permissions'] &= $this->storage->getShare()->getPermissions();
- } else {
- $entry['permissions'] = $this->storage->getPermissions($entry['path']);
- }
- } catch (StorageNotAvailableException $e) {
-
-
- $sharePermissions = 0;
- }
- $entry['uid_owner'] = $this->storage->getOwner('');
- $entry['displayname_owner'] = $this->getOwnerDisplayName();
- if ($path === '') {
- $entry['is_share_mount_point'] = true;
- }
- return $entry;
- }
- private function getOwnerDisplayName() {
- if (!$this->ownerDisplayName) {
- $this->ownerDisplayName = \OC_User::getDisplayName($this->storage->getOwner(''));
- }
- return $this->ownerDisplayName;
- }
-
- public function clear() {
-
- }
- public function search($pattern) {
-
- if ($this->storage->getItemType() !== 'file') {
- return parent::search($pattern);
- }
- $regex = '/' . str_replace('%', '.*', $pattern) . '/i';
- $data = $this->get('');
- if (preg_match($regex, $data->getName()) === 1) {
- return [$data];
- }
- return [];
- }
- }
|