| @@ -36,216 +36,216 @@ | ||
| 36 | 36 | * | 
| 37 | 37 | */ | 
| 38 | 38 |  class Updater implements IUpdater { | 
| 39 | - /** | |
| 40 | - * @var bool | |
| 41 | - */ | |
| 42 | - protected $enabled = true; | |
| 43 | - | |
| 44 | - /** | |
| 45 | - * @var \OC\Files\Storage\Storage | |
| 46 | - */ | |
| 47 | - protected $storage; | |
| 48 | - | |
| 49 | - /** | |
| 50 | - * @var \OC\Files\Cache\Propagator | |
| 51 | - */ | |
| 52 | - protected $propagator; | |
| 53 | - | |
| 54 | - /** | |
| 55 | - * @var Scanner | |
| 56 | - */ | |
| 57 | - protected $scanner; | |
| 58 | - | |
| 59 | - /** | |
| 60 | - * @var Cache | |
| 61 | - */ | |
| 62 | - protected $cache; | |
| 63 | - | |
| 64 | - /** | |
| 65 | - * @param \OC\Files\Storage\Storage $storage | |
| 66 | - */ | |
| 67 | -	public function __construct(\OC\Files\Storage\Storage $storage) { | |
| 68 | - $this->storage = $storage; | |
| 69 | - $this->propagator = $storage->getPropagator(); | |
| 70 | - $this->scanner = $storage->getScanner(); | |
| 71 | - $this->cache = $storage->getCache(); | |
| 72 | - } | |
| 73 | - | |
| 74 | - /** | |
| 75 | - * Disable updating the cache trough this updater | |
| 76 | - */ | |
| 77 | -	public function disable() { | |
| 78 | - $this->enabled = false; | |
| 79 | - } | |
| 80 | - | |
| 81 | - /** | |
| 82 | - * Re-enable the updating of the cache trough this updater | |
| 83 | - */ | |
| 84 | -	public function enable() { | |
| 85 | - $this->enabled = true; | |
| 86 | - } | |
| 87 | - | |
| 88 | - /** | |
| 89 | - * Get the propagator for etags and mtime for the view the updater works on | |
| 90 | - * | |
| 91 | - * @return Propagator | |
| 92 | - */ | |
| 93 | -	public function getPropagator() { | |
| 94 | - return $this->propagator; | |
| 95 | - } | |
| 96 | - | |
| 97 | - /** | |
| 98 | - * Propagate etag and mtime changes for the parent folders of $path up to the root of the filesystem | |
| 99 | - * | |
| 100 | - * @param string $path the path of the file to propagate the changes for | |
| 101 | - * @param int|null $time the timestamp to set as mtime for the parent folders, if left out the current time is used | |
| 102 | - */ | |
| 103 | -	public function propagate($path, $time = null) { | |
| 104 | -		if (Scanner::isPartialFile($path)) { | |
| 105 | - return; | |
| 106 | - } | |
| 107 | - $this->propagator->propagateChange($path, $time); | |
| 108 | - } | |
| 109 | - | |
| 110 | - /** | |
| 111 | - * Update the cache for $path and update the size, etag and mtime of the parent folders | |
| 112 | - * | |
| 113 | - * @param string $path | |
| 114 | - * @param int $time | |
| 115 | - */ | |
| 116 | -	public function update($path, $time = null) { | |
| 117 | -		if (!$this->enabled or Scanner::isPartialFile($path)) { | |
| 118 | - return; | |
| 119 | - } | |
| 120 | -		if (is_null($time)) { | |
| 121 | - $time = time(); | |
| 122 | - } | |
| 123 | - | |
| 124 | - $data = $this->scanner->scan($path, Scanner::SCAN_SHALLOW, -1, false); | |
| 125 | - if ( | |
| 126 | - isset($data['oldSize']) && isset($data['size']) && | |
| 127 | - !$data['encrypted'] // encryption is a pita and touches the cache itself | |
| 128 | -		) { | |
| 129 | - $sizeDifference = $data['size'] - $data['oldSize']; | |
| 130 | -		} else { | |
| 131 | - // scanner didn't provide size info, fallback to full size calculation | |
| 132 | - $sizeDifference = 0; | |
| 133 | -			if ($this->cache instanceof Cache) { | |
| 134 | - $this->cache->correctFolderSize($path, $data); | |
| 135 | - } | |
| 136 | - } | |
| 137 | - $this->correctParentStorageMtime($path); | |
| 138 | - $this->propagator->propagateChange($path, $time, $sizeDifference); | |
| 139 | - } | |
| 140 | - | |
| 141 | - /** | |
| 142 | - * Remove $path from the cache and update the size, etag and mtime of the parent folders | |
| 143 | - * | |
| 144 | - * @param string $path | |
| 145 | - */ | |
| 146 | -	public function remove($path) { | |
| 147 | -		if (!$this->enabled or Scanner::isPartialFile($path)) { | |
| 148 | - return; | |
| 149 | - } | |
| 150 | - | |
| 151 | - $parent = dirname($path); | |
| 152 | -		if ($parent === '.') { | |
| 153 | - $parent = ''; | |
| 154 | - } | |
| 155 | - | |
| 156 | - $entry = $this->cache->get($path); | |
| 157 | - | |
| 158 | - $this->cache->remove($path); | |
| 159 | - | |
| 160 | - $this->correctParentStorageMtime($path); | |
| 161 | -		if ($entry instanceof ICacheEntry) { | |
| 162 | - $this->propagator->propagateChange($path, time(), -$entry->getSize()); | |
| 163 | -		} else { | |
| 164 | - $this->propagator->propagateChange($path, time()); | |
| 165 | -			if ($this->cache instanceof Cache) { | |
| 166 | - $this->cache->correctFolderSize($parent); | |
| 167 | - } | |
| 168 | - } | |
| 169 | - | |
| 170 | - } | |
| 171 | - | |
| 172 | - /** | |
| 173 | - * Rename a file or folder in the cache and update the size, etag and mtime of the parent folders | |
| 174 | - * | |
| 175 | - * @param IStorage $sourceStorage | |
| 176 | - * @param string $source | |
| 177 | - * @param string $target | |
| 178 | - */ | |
| 179 | -	public function renameFromStorage(IStorage $sourceStorage, $source, $target) { | |
| 180 | -		if (!$this->enabled or Scanner::isPartialFile($source) or Scanner::isPartialFile($target)) { | |
| 181 | - return; | |
| 182 | - } | |
| 183 | - | |
| 184 | - $time = time(); | |
| 185 | - | |
| 186 | - $sourceCache = $sourceStorage->getCache(); | |
| 187 | - $sourceUpdater = $sourceStorage->getUpdater(); | |
| 188 | - $sourcePropagator = $sourceStorage->getPropagator(); | |
| 189 | - | |
| 190 | -		if ($sourceCache->inCache($source)) { | |
| 191 | -			if ($this->cache->inCache($target)) { | |
| 192 | - $this->cache->remove($target); | |
| 193 | - } | |
| 194 | - | |
| 195 | -			if ($sourceStorage === $this->storage) { | |
| 196 | - $this->cache->move($source, $target); | |
| 197 | -			} else { | |
| 198 | - $this->cache->moveFromCache($sourceCache, $source, $target); | |
| 199 | - } | |
| 200 | - } | |
| 201 | - | |
| 202 | -		if (pathinfo($source, PATHINFO_EXTENSION) !== pathinfo($target, PATHINFO_EXTENSION)) { | |
| 203 | - // handle mime type change | |
| 204 | - $mimeType = $this->storage->getMimeType($target); | |
| 205 | - $fileId = $this->cache->getId($target); | |
| 206 | - $this->cache->update($fileId, ['mimetype' => $mimeType]); | |
| 207 | - } | |
| 208 | - | |
| 209 | -		if ($sourceCache instanceof Cache) { | |
| 210 | - $sourceCache->correctFolderSize($source); | |
| 211 | - } | |
| 212 | -		if ($this->cache instanceof Cache) { | |
| 213 | - $this->cache->correctFolderSize($target); | |
| 214 | - } | |
| 215 | -		if ($sourceUpdater instanceof Updater) { | |
| 216 | - $sourceUpdater->correctParentStorageMtime($source); | |
| 217 | - } | |
| 218 | - $this->correctParentStorageMtime($target); | |
| 219 | - $this->updateStorageMTimeOnly($target); | |
| 220 | - $sourcePropagator->propagateChange($source, $time); | |
| 221 | - $this->propagator->propagateChange($target, $time); | |
| 222 | - } | |
| 223 | - | |
| 224 | -	private function updateStorageMTimeOnly($internalPath) { | |
| 225 | - $fileId = $this->cache->getId($internalPath); | |
| 226 | -		if ($fileId !== -1) { | |
| 227 | - $this->cache->update( | |
| 228 | - $fileId, [ | |
| 229 | - 'mtime' => null, // this magic tells it to not overwrite mtime | |
| 230 | - 'storage_mtime' => $this->storage->filemtime($internalPath) | |
| 231 | - ] | |
| 232 | - ); | |
| 233 | - } | |
| 234 | - } | |
| 235 | - | |
| 236 | - /** | |
| 237 | - * update the storage_mtime of the direct parent in the cache to the mtime from the storage | |
| 238 | - * | |
| 239 | - * @param string $internalPath | |
| 240 | - */ | |
| 241 | -	private function correctParentStorageMtime($internalPath) { | |
| 242 | - $parentId = $this->cache->getParentId($internalPath); | |
| 243 | - $parent = dirname($internalPath); | |
| 244 | -		if ($parentId != -1) { | |
| 245 | - $mtime = $this->storage->filemtime($parent); | |
| 246 | -			if ($mtime !== false) { | |
| 247 | -				$this->cache->update($parentId, array('storage_mtime' => $mtime)); | |
| 248 | - } | |
| 249 | - } | |
| 250 | - } | |
| 39 | + /** | |
| 40 | + * @var bool | |
| 41 | + */ | |
| 42 | + protected $enabled = true; | |
| 43 | + | |
| 44 | + /** | |
| 45 | + * @var \OC\Files\Storage\Storage | |
| 46 | + */ | |
| 47 | + protected $storage; | |
| 48 | + | |
| 49 | + /** | |
| 50 | + * @var \OC\Files\Cache\Propagator | |
| 51 | + */ | |
| 52 | + protected $propagator; | |
| 53 | + | |
| 54 | + /** | |
| 55 | + * @var Scanner | |
| 56 | + */ | |
| 57 | + protected $scanner; | |
| 58 | + | |
| 59 | + /** | |
| 60 | + * @var Cache | |
| 61 | + */ | |
| 62 | + protected $cache; | |
| 63 | + | |
| 64 | + /** | |
| 65 | + * @param \OC\Files\Storage\Storage $storage | |
| 66 | + */ | |
| 67 | +    public function __construct(\OC\Files\Storage\Storage $storage) { | |
| 68 | + $this->storage = $storage; | |
| 69 | + $this->propagator = $storage->getPropagator(); | |
| 70 | + $this->scanner = $storage->getScanner(); | |
| 71 | + $this->cache = $storage->getCache(); | |
| 72 | + } | |
| 73 | + | |
| 74 | + /** | |
| 75 | + * Disable updating the cache trough this updater | |
| 76 | + */ | |
| 77 | +    public function disable() { | |
| 78 | + $this->enabled = false; | |
| 79 | + } | |
| 80 | + | |
| 81 | + /** | |
| 82 | + * Re-enable the updating of the cache trough this updater | |
| 83 | + */ | |
| 84 | +    public function enable() { | |
| 85 | + $this->enabled = true; | |
| 86 | + } | |
| 87 | + | |
| 88 | + /** | |
| 89 | + * Get the propagator for etags and mtime for the view the updater works on | |
| 90 | + * | |
| 91 | + * @return Propagator | |
| 92 | + */ | |
| 93 | +    public function getPropagator() { | |
| 94 | + return $this->propagator; | |
| 95 | + } | |
| 96 | + | |
| 97 | + /** | |
| 98 | + * Propagate etag and mtime changes for the parent folders of $path up to the root of the filesystem | |
| 99 | + * | |
| 100 | + * @param string $path the path of the file to propagate the changes for | |
| 101 | + * @param int|null $time the timestamp to set as mtime for the parent folders, if left out the current time is used | |
| 102 | + */ | |
| 103 | +    public function propagate($path, $time = null) { | |
| 104 | +        if (Scanner::isPartialFile($path)) { | |
| 105 | + return; | |
| 106 | + } | |
| 107 | + $this->propagator->propagateChange($path, $time); | |
| 108 | + } | |
| 109 | + | |
| 110 | + /** | |
| 111 | + * Update the cache for $path and update the size, etag and mtime of the parent folders | |
| 112 | + * | |
| 113 | + * @param string $path | |
| 114 | + * @param int $time | |
| 115 | + */ | |
| 116 | +    public function update($path, $time = null) { | |
| 117 | +        if (!$this->enabled or Scanner::isPartialFile($path)) { | |
| 118 | + return; | |
| 119 | + } | |
| 120 | +        if (is_null($time)) { | |
| 121 | + $time = time(); | |
| 122 | + } | |
| 123 | + | |
| 124 | + $data = $this->scanner->scan($path, Scanner::SCAN_SHALLOW, -1, false); | |
| 125 | + if ( | |
| 126 | + isset($data['oldSize']) && isset($data['size']) && | |
| 127 | + !$data['encrypted'] // encryption is a pita and touches the cache itself | |
| 128 | +        ) { | |
| 129 | + $sizeDifference = $data['size'] - $data['oldSize']; | |
| 130 | +        } else { | |
| 131 | + // scanner didn't provide size info, fallback to full size calculation | |
| 132 | + $sizeDifference = 0; | |
| 133 | +            if ($this->cache instanceof Cache) { | |
| 134 | + $this->cache->correctFolderSize($path, $data); | |
| 135 | + } | |
| 136 | + } | |
| 137 | + $this->correctParentStorageMtime($path); | |
| 138 | + $this->propagator->propagateChange($path, $time, $sizeDifference); | |
| 139 | + } | |
| 140 | + | |
| 141 | + /** | |
| 142 | + * Remove $path from the cache and update the size, etag and mtime of the parent folders | |
| 143 | + * | |
| 144 | + * @param string $path | |
| 145 | + */ | |
| 146 | +    public function remove($path) { | |
| 147 | +        if (!$this->enabled or Scanner::isPartialFile($path)) { | |
| 148 | + return; | |
| 149 | + } | |
| 150 | + | |
| 151 | + $parent = dirname($path); | |
| 152 | +        if ($parent === '.') { | |
| 153 | + $parent = ''; | |
| 154 | + } | |
| 155 | + | |
| 156 | + $entry = $this->cache->get($path); | |
| 157 | + | |
| 158 | + $this->cache->remove($path); | |
| 159 | + | |
| 160 | + $this->correctParentStorageMtime($path); | |
| 161 | +        if ($entry instanceof ICacheEntry) { | |
| 162 | + $this->propagator->propagateChange($path, time(), -$entry->getSize()); | |
| 163 | +        } else { | |
| 164 | + $this->propagator->propagateChange($path, time()); | |
| 165 | +            if ($this->cache instanceof Cache) { | |
| 166 | + $this->cache->correctFolderSize($parent); | |
| 167 | + } | |
| 168 | + } | |
| 169 | + | |
| 170 | + } | |
| 171 | + | |
| 172 | + /** | |
| 173 | + * Rename a file or folder in the cache and update the size, etag and mtime of the parent folders | |
| 174 | + * | |
| 175 | + * @param IStorage $sourceStorage | |
| 176 | + * @param string $source | |
| 177 | + * @param string $target | |
| 178 | + */ | |
| 179 | +    public function renameFromStorage(IStorage $sourceStorage, $source, $target) { | |
| 180 | +        if (!$this->enabled or Scanner::isPartialFile($source) or Scanner::isPartialFile($target)) { | |
| 181 | + return; | |
| 182 | + } | |
| 183 | + | |
| 184 | + $time = time(); | |
| 185 | + | |
| 186 | + $sourceCache = $sourceStorage->getCache(); | |
| 187 | + $sourceUpdater = $sourceStorage->getUpdater(); | |
| 188 | + $sourcePropagator = $sourceStorage->getPropagator(); | |
| 189 | + | |
| 190 | +        if ($sourceCache->inCache($source)) { | |
| 191 | +            if ($this->cache->inCache($target)) { | |
| 192 | + $this->cache->remove($target); | |
| 193 | + } | |
| 194 | + | |
| 195 | +            if ($sourceStorage === $this->storage) { | |
| 196 | + $this->cache->move($source, $target); | |
| 197 | +            } else { | |
| 198 | + $this->cache->moveFromCache($sourceCache, $source, $target); | |
| 199 | + } | |
| 200 | + } | |
| 201 | + | |
| 202 | +        if (pathinfo($source, PATHINFO_EXTENSION) !== pathinfo($target, PATHINFO_EXTENSION)) { | |
| 203 | + // handle mime type change | |
| 204 | + $mimeType = $this->storage->getMimeType($target); | |
| 205 | + $fileId = $this->cache->getId($target); | |
| 206 | + $this->cache->update($fileId, ['mimetype' => $mimeType]); | |
| 207 | + } | |
| 208 | + | |
| 209 | +        if ($sourceCache instanceof Cache) { | |
| 210 | + $sourceCache->correctFolderSize($source); | |
| 211 | + } | |
| 212 | +        if ($this->cache instanceof Cache) { | |
| 213 | + $this->cache->correctFolderSize($target); | |
| 214 | + } | |
| 215 | +        if ($sourceUpdater instanceof Updater) { | |
| 216 | + $sourceUpdater->correctParentStorageMtime($source); | |
| 217 | + } | |
| 218 | + $this->correctParentStorageMtime($target); | |
| 219 | + $this->updateStorageMTimeOnly($target); | |
| 220 | + $sourcePropagator->propagateChange($source, $time); | |
| 221 | + $this->propagator->propagateChange($target, $time); | |
| 222 | + } | |
| 223 | + | |
| 224 | +    private function updateStorageMTimeOnly($internalPath) { | |
| 225 | + $fileId = $this->cache->getId($internalPath); | |
| 226 | +        if ($fileId !== -1) { | |
| 227 | + $this->cache->update( | |
| 228 | + $fileId, [ | |
| 229 | + 'mtime' => null, // this magic tells it to not overwrite mtime | |
| 230 | + 'storage_mtime' => $this->storage->filemtime($internalPath) | |
| 231 | + ] | |
| 232 | + ); | |
| 233 | + } | |
| 234 | + } | |
| 235 | + | |
| 236 | + /** | |
| 237 | + * update the storage_mtime of the direct parent in the cache to the mtime from the storage | |
| 238 | + * | |
| 239 | + * @param string $internalPath | |
| 240 | + */ | |
| 241 | +    private function correctParentStorageMtime($internalPath) { | |
| 242 | + $parentId = $this->cache->getParentId($internalPath); | |
| 243 | + $parent = dirname($internalPath); | |
| 244 | +        if ($parentId != -1) { | |
| 245 | + $mtime = $this->storage->filemtime($parent); | |
| 246 | +            if ($mtime !== false) { | |
| 247 | +                $this->cache->update($parentId, array('storage_mtime' => $mtime)); | |
| 248 | + } | |
| 249 | + } | |
| 250 | + } | |
| 251 | 251 | } | 
| @@ -28,88 +28,88 @@ | ||
| 28 | 28 | * meta data for a file or folder | 
| 29 | 29 | */ | 
| 30 | 30 |  class CacheEntry implements ICacheEntry, \ArrayAccess { | 
| 31 | - /** | |
| 32 | - * @var array | |
| 33 | - */ | |
| 34 | - private $data; | |
| 31 | + /** | |
| 32 | + * @var array | |
| 33 | + */ | |
| 34 | + private $data; | |
| 35 | 35 | |
| 36 | -	public function __construct(array $data) { | |
| 37 | - $this->data = $data; | |
| 38 | - } | |
| 36 | +    public function __construct(array $data) { | |
| 37 | + $this->data = $data; | |
| 38 | + } | |
| 39 | 39 | |
| 40 | -	public function offsetSet($offset, $value) { | |
| 41 | - $this->data[$offset] = $value; | |
| 42 | - } | |
| 40 | +    public function offsetSet($offset, $value) { | |
| 41 | + $this->data[$offset] = $value; | |
| 42 | + } | |
| 43 | 43 | |
| 44 | -	public function offsetExists($offset) { | |
| 45 | - return isset($this->data[$offset]); | |
| 46 | - } | |
| 44 | +    public function offsetExists($offset) { | |
| 45 | + return isset($this->data[$offset]); | |
| 46 | + } | |
| 47 | 47 | |
| 48 | -	public function offsetUnset($offset) { | |
| 49 | - unset($this->data[$offset]); | |
| 50 | - } | |
| 48 | +    public function offsetUnset($offset) { | |
| 49 | + unset($this->data[$offset]); | |
| 50 | + } | |
| 51 | 51 | |
| 52 | -	public function offsetGet($offset) { | |
| 53 | -		if (isset($this->data[$offset])) { | |
| 54 | - return $this->data[$offset]; | |
| 55 | -		} else { | |
| 56 | - return null; | |
| 57 | - } | |
| 58 | - } | |
| 52 | +    public function offsetGet($offset) { | |
| 53 | +        if (isset($this->data[$offset])) { | |
| 54 | + return $this->data[$offset]; | |
| 55 | +        } else { | |
| 56 | + return null; | |
| 57 | + } | |
| 58 | + } | |
| 59 | 59 | |
| 60 | -	public function getId() { | |
| 61 | - return (int)$this->data['fileid']; | |
| 62 | - } | |
| 60 | +    public function getId() { | |
| 61 | + return (int)$this->data['fileid']; | |
| 62 | + } | |
| 63 | 63 | |
| 64 | -	public function getStorageId() { | |
| 65 | - return $this->data['storage']; | |
| 66 | - } | |
| 64 | +    public function getStorageId() { | |
| 65 | + return $this->data['storage']; | |
| 66 | + } | |
| 67 | 67 | |
| 68 | 68 | |
| 69 | -	public function getPath() { | |
| 70 | - return $this->data['path']; | |
| 71 | - } | |
| 69 | +    public function getPath() { | |
| 70 | + return $this->data['path']; | |
| 71 | + } | |
| 72 | 72 | |
| 73 | 73 | |
| 74 | -	public function getName() { | |
| 75 | - return $this->data['name']; | |
| 76 | - } | |
| 74 | +    public function getName() { | |
| 75 | + return $this->data['name']; | |
| 76 | + } | |
| 77 | 77 | |
| 78 | 78 | |
| 79 | -	public function getMimeType() { | |
| 80 | - return $this->data['mimetype']; | |
| 81 | - } | |
| 79 | +    public function getMimeType() { | |
| 80 | + return $this->data['mimetype']; | |
| 81 | + } | |
| 82 | 82 | |
| 83 | 83 | |
| 84 | -	public function getMimePart() { | |
| 85 | - return $this->data['mimepart']; | |
| 86 | - } | |
| 84 | +    public function getMimePart() { | |
| 85 | + return $this->data['mimepart']; | |
| 86 | + } | |
| 87 | 87 | |
| 88 | -	public function getSize() { | |
| 89 | - return $this->data['size']; | |
| 90 | - } | |
| 88 | +    public function getSize() { | |
| 89 | + return $this->data['size']; | |
| 90 | + } | |
| 91 | 91 | |
| 92 | -	public function getMTime() { | |
| 93 | - return $this->data['mtime']; | |
| 94 | - } | |
| 92 | +    public function getMTime() { | |
| 93 | + return $this->data['mtime']; | |
| 94 | + } | |
| 95 | 95 | |
| 96 | -	public function getStorageMTime() { | |
| 97 | - return $this->data['storage_mtime']; | |
| 98 | - } | |
| 96 | +    public function getStorageMTime() { | |
| 97 | + return $this->data['storage_mtime']; | |
| 98 | + } | |
| 99 | 99 | |
| 100 | -	public function getEtag() { | |
| 101 | - return $this->data['etag']; | |
| 102 | - } | |
| 100 | +    public function getEtag() { | |
| 101 | + return $this->data['etag']; | |
| 102 | + } | |
| 103 | 103 | |
| 104 | -	public function getPermissions() { | |
| 105 | - return $this->data['permissions']; | |
| 106 | - } | |
| 104 | +    public function getPermissions() { | |
| 105 | + return $this->data['permissions']; | |
| 106 | + } | |
| 107 | 107 | |
| 108 | -	public function isEncrypted() { | |
| 109 | - return isset($this->data['encrypted']) && $this->data['encrypted']; | |
| 110 | - } | |
| 108 | +    public function isEncrypted() { | |
| 109 | + return isset($this->data['encrypted']) && $this->data['encrypted']; | |
| 110 | + } | |
| 111 | 111 | |
| 112 | -	public function getData() { | |
| 113 | - return $this->data; | |
| 114 | - } | |
| 112 | +    public function getData() { | |
| 113 | + return $this->data; | |
| 114 | + } | |
| 115 | 115 | } | 
| @@ -58,7 +58,7 @@ | ||
| 58 | 58 | } | 
| 59 | 59 | |
| 60 | 60 |  	public function getId() { | 
| 61 | - return (int)$this->data['fileid']; | |
| 61 | + return (int) $this->data['fileid']; | |
| 62 | 62 | } | 
| 63 | 63 | |
| 64 | 64 |  	public function getStorageId() { | 
| @@ -30,58 +30,58 @@ | ||
| 30 | 30 | use OCP\Files\Cache\ICacheEntry; | 
| 31 | 31 | |
| 32 | 32 |  class HomeCache extends Cache { | 
| 33 | - /** | |
| 34 | - * get the size of a folder and set it in the cache | |
| 35 | - * | |
| 36 | - * @param string $path | |
| 37 | - * @param array $entry (optional) meta data of the folder | |
| 38 | - * @return int | |
| 39 | - */ | |
| 40 | -	public function calculateFolderSize($path, $entry = null) { | |
| 41 | -		if ($path !== '/' and $path !== '' and $path !== 'files' and $path !== 'files_trashbin' and $path !== 'files_versions') { | |
| 42 | - return parent::calculateFolderSize($path, $entry); | |
| 43 | -		} elseif ($path === '' or $path === '/') { | |
| 44 | - // since the size of / isn't used (the size of /files is used instead) there is no use in calculating it | |
| 45 | - return 0; | |
| 46 | - } | |
| 33 | + /** | |
| 34 | + * get the size of a folder and set it in the cache | |
| 35 | + * | |
| 36 | + * @param string $path | |
| 37 | + * @param array $entry (optional) meta data of the folder | |
| 38 | + * @return int | |
| 39 | + */ | |
| 40 | +    public function calculateFolderSize($path, $entry = null) { | |
| 41 | +        if ($path !== '/' and $path !== '' and $path !== 'files' and $path !== 'files_trashbin' and $path !== 'files_versions') { | |
| 42 | + return parent::calculateFolderSize($path, $entry); | |
| 43 | +        } elseif ($path === '' or $path === '/') { | |
| 44 | + // since the size of / isn't used (the size of /files is used instead) there is no use in calculating it | |
| 45 | + return 0; | |
| 46 | + } | |
| 47 | 47 | |
| 48 | - $totalSize = 0; | |
| 49 | -		if (is_null($entry)) { | |
| 50 | - $entry = $this->get($path); | |
| 51 | - } | |
| 52 | -		if ($entry && $entry['mimetype'] === 'httpd/unix-directory') { | |
| 53 | - $id = $entry['fileid']; | |
| 54 | - $sql = 'SELECT SUM(`size`) AS f1 ' . | |
| 55 | - 'FROM `*PREFIX*filecache` ' . | |
| 56 | - 'WHERE `parent` = ? AND `storage` = ? AND `size` >= 0'; | |
| 57 | - $result = \OC_DB::executeAudited($sql, array($id, $this->getNumericStorageId())); | |
| 58 | -			if ($row = $result->fetchRow()) { | |
| 59 | - $result->closeCursor(); | |
| 60 | - list($sum) = array_values($row); | |
| 61 | - $totalSize = 0 + $sum; | |
| 62 | - $entry['size'] += 0; | |
| 63 | -				if ($entry['size'] !== $totalSize) { | |
| 64 | -					$this->update($id, array('size' => $totalSize)); | |
| 65 | - } | |
| 66 | - } | |
| 67 | - } | |
| 68 | - return $totalSize; | |
| 69 | - } | |
| 48 | + $totalSize = 0; | |
| 49 | +        if (is_null($entry)) { | |
| 50 | + $entry = $this->get($path); | |
| 51 | + } | |
| 52 | +        if ($entry && $entry['mimetype'] === 'httpd/unix-directory') { | |
| 53 | + $id = $entry['fileid']; | |
| 54 | + $sql = 'SELECT SUM(`size`) AS f1 ' . | |
| 55 | + 'FROM `*PREFIX*filecache` ' . | |
| 56 | + 'WHERE `parent` = ? AND `storage` = ? AND `size` >= 0'; | |
| 57 | + $result = \OC_DB::executeAudited($sql, array($id, $this->getNumericStorageId())); | |
| 58 | +            if ($row = $result->fetchRow()) { | |
| 59 | + $result->closeCursor(); | |
| 60 | + list($sum) = array_values($row); | |
| 61 | + $totalSize = 0 + $sum; | |
| 62 | + $entry['size'] += 0; | |
| 63 | +                if ($entry['size'] !== $totalSize) { | |
| 64 | +                    $this->update($id, array('size' => $totalSize)); | |
| 65 | + } | |
| 66 | + } | |
| 67 | + } | |
| 68 | + return $totalSize; | |
| 69 | + } | |
| 70 | 70 | |
| 71 | - /** | |
| 72 | - * @param string $path | |
| 73 | - * @return ICacheEntry | |
| 74 | - */ | |
| 75 | -	public function get($path) { | |
| 76 | - $data = parent::get($path); | |
| 77 | -		if ($path === '' or $path === '/') { | |
| 78 | - // only the size of the "files" dir counts | |
| 79 | -			$filesData = parent::get('files'); | |
| 71 | + /** | |
| 72 | + * @param string $path | |
| 73 | + * @return ICacheEntry | |
| 74 | + */ | |
| 75 | +    public function get($path) { | |
| 76 | + $data = parent::get($path); | |
| 77 | +        if ($path === '' or $path === '/') { | |
| 78 | + // only the size of the "files" dir counts | |
| 79 | +            $filesData = parent::get('files'); | |
| 80 | 80 | |
| 81 | -			if (isset($filesData['size'])) { | |
| 82 | - $data['size'] = $filesData['size']; | |
| 83 | - } | |
| 84 | - } | |
| 85 | - return $data; | |
| 86 | - } | |
| 81 | +            if (isset($filesData['size'])) { | |
| 82 | + $data['size'] = $filesData['size']; | |
| 83 | + } | |
| 84 | + } | |
| 85 | + return $data; | |
| 86 | + } | |
| 87 | 87 | } | 
| @@ -51,8 +51,8 @@ | ||
| 51 | 51 | } | 
| 52 | 52 |  		if ($entry && $entry['mimetype'] === 'httpd/unix-directory') { | 
| 53 | 53 | $id = $entry['fileid']; | 
| 54 | - $sql = 'SELECT SUM(`size`) AS f1 ' . | |
| 55 | - 'FROM `*PREFIX*filecache` ' . | |
| 54 | + $sql = 'SELECT SUM(`size`) AS f1 '. | |
| 55 | + 'FROM `*PREFIX*filecache` '. | |
| 56 | 56 | 'WHERE `parent` = ? AND `storage` = ? AND `size` >= 0'; | 
| 57 | 57 | $result = \OC_DB::executeAudited($sql, array($id, $this->getNumericStorageId())); | 
| 58 | 58 |  			if ($row = $result->fetchRow()) { | 
| @@ -36,43 +36,43 @@ | ||
| 36 | 36 | * @package OC\Files\Cache | 
| 37 | 37 | */ | 
| 38 | 38 |  class StorageGlobal { | 
| 39 | - /** @var IDBConnection */ | |
| 40 | - private $connection; | |
| 39 | + /** @var IDBConnection */ | |
| 40 | + private $connection; | |
| 41 | 41 | |
| 42 | - /** @var array[] */ | |
| 43 | - private $cache = []; | |
| 42 | + /** @var array[] */ | |
| 43 | + private $cache = []; | |
| 44 | 44 | |
| 45 | -	public function __construct(IDBConnection $connection) { | |
| 46 | - $this->connection = $connection; | |
| 47 | - } | |
| 45 | +    public function __construct(IDBConnection $connection) { | |
| 46 | + $this->connection = $connection; | |
| 47 | + } | |
| 48 | 48 | |
| 49 | - /** | |
| 50 | - * @param string[] $storageIds | |
| 51 | - */ | |
| 52 | -	public function loadForStorageIds(array $storageIds) { | |
| 53 | - $builder = $this->connection->getQueryBuilder(); | |
| 54 | - $query = $builder->select(['id', 'numeric_id', 'available', 'last_checked']) | |
| 55 | -			->from('storages') | |
| 56 | -			->where($builder->expr()->in('id', $builder->createNamedParameter(array_values($storageIds), IQueryBuilder::PARAM_STR_ARRAY))); | |
| 49 | + /** | |
| 50 | + * @param string[] $storageIds | |
| 51 | + */ | |
| 52 | +    public function loadForStorageIds(array $storageIds) { | |
| 53 | + $builder = $this->connection->getQueryBuilder(); | |
| 54 | + $query = $builder->select(['id', 'numeric_id', 'available', 'last_checked']) | |
| 55 | +            ->from('storages') | |
| 56 | +            ->where($builder->expr()->in('id', $builder->createNamedParameter(array_values($storageIds), IQueryBuilder::PARAM_STR_ARRAY))); | |
| 57 | 57 | |
| 58 | - $result = $query->execute(); | |
| 59 | -		while ($row = $result->fetch()) { | |
| 60 | - $this->cache[$row['id']] = $row; | |
| 61 | - } | |
| 62 | - } | |
| 58 | + $result = $query->execute(); | |
| 59 | +        while ($row = $result->fetch()) { | |
| 60 | + $this->cache[$row['id']] = $row; | |
| 61 | + } | |
| 62 | + } | |
| 63 | 63 | |
| 64 | - /** | |
| 65 | - * @param string $storageId | |
| 66 | - * @return array|null | |
| 67 | - */ | |
| 68 | -	public function getStorageInfo($storageId) { | |
| 69 | -		if (!isset($this->cache[$storageId])) { | |
| 70 | - $this->loadForStorageIds([$storageId]); | |
| 71 | - } | |
| 72 | - return isset($this->cache[$storageId]) ? $this->cache[$storageId] : null; | |
| 73 | - } | |
| 64 | + /** | |
| 65 | + * @param string $storageId | |
| 66 | + * @return array|null | |
| 67 | + */ | |
| 68 | +    public function getStorageInfo($storageId) { | |
| 69 | +        if (!isset($this->cache[$storageId])) { | |
| 70 | + $this->loadForStorageIds([$storageId]); | |
| 71 | + } | |
| 72 | + return isset($this->cache[$storageId]) ? $this->cache[$storageId] : null; | |
| 73 | + } | |
| 74 | 74 | |
| 75 | -	public function clearCache() { | |
| 76 | - $this->cache = []; | |
| 77 | - } | |
| 75 | +    public function clearCache() { | |
| 76 | + $this->cache = []; | |
| 77 | + } | |
| 78 | 78 | } | 
| @@ -29,60 +29,60 @@ | ||
| 29 | 29 | * Fallback implementation for moveFromCache | 
| 30 | 30 | */ | 
| 31 | 31 |  trait MoveFromCacheTrait { | 
| 32 | - /** | |
| 33 | - * store meta data for a file or folder | |
| 34 | - * | |
| 35 | - * @param string $file | |
| 36 | - * @param array $data | |
| 37 | - * | |
| 38 | - * @return int file id | |
| 39 | - * @throws \RuntimeException | |
| 40 | - */ | |
| 41 | - abstract public function put($file, array $data); | |
| 32 | + /** | |
| 33 | + * store meta data for a file or folder | |
| 34 | + * | |
| 35 | + * @param string $file | |
| 36 | + * @param array $data | |
| 37 | + * | |
| 38 | + * @return int file id | |
| 39 | + * @throws \RuntimeException | |
| 40 | + */ | |
| 41 | + abstract public function put($file, array $data); | |
| 42 | 42 | |
| 43 | - /** | |
| 44 | - * Move a file or folder in the cache | |
| 45 | - * | |
| 46 | - * @param \OCP\Files\Cache\ICache $sourceCache | |
| 47 | - * @param string $sourcePath | |
| 48 | - * @param string $targetPath | |
| 49 | - */ | |
| 50 | -	public function moveFromCache(ICache $sourceCache, $sourcePath, $targetPath) { | |
| 51 | - $sourceEntry = $sourceCache->get($sourcePath); | |
| 43 | + /** | |
| 44 | + * Move a file or folder in the cache | |
| 45 | + * | |
| 46 | + * @param \OCP\Files\Cache\ICache $sourceCache | |
| 47 | + * @param string $sourcePath | |
| 48 | + * @param string $targetPath | |
| 49 | + */ | |
| 50 | +    public function moveFromCache(ICache $sourceCache, $sourcePath, $targetPath) { | |
| 51 | + $sourceEntry = $sourceCache->get($sourcePath); | |
| 52 | 52 | |
| 53 | - $this->copyFromCache($sourceCache, $sourceEntry, $targetPath); | |
| 53 | + $this->copyFromCache($sourceCache, $sourceEntry, $targetPath); | |
| 54 | 54 | |
| 55 | - $sourceCache->remove($sourcePath); | |
| 56 | - } | |
| 55 | + $sourceCache->remove($sourcePath); | |
| 56 | + } | |
| 57 | 57 | |
| 58 | - /** | |
| 59 | - * Copy a file or folder in the cache | |
| 60 | - * | |
| 61 | - * @param \OCP\Files\Cache\ICache $sourceCache | |
| 62 | - * @param ICacheEntry $sourceEntry | |
| 63 | - * @param string $targetPath | |
| 64 | - */ | |
| 65 | -	public function copyFromCache(ICache $sourceCache, ICacheEntry $sourceEntry, $targetPath) { | |
| 66 | - $this->put($targetPath, $this->cacheEntryToArray($sourceEntry)); | |
| 67 | -		if ($sourceEntry->getMimeType() === ICacheEntry::DIRECTORY_MIMETYPE) { | |
| 68 | - $folderContent = $sourceCache->getFolderContentsById($sourceEntry->getId()); | |
| 69 | -			foreach ($folderContent as $subEntry) { | |
| 70 | - $subTargetPath = $targetPath . '/' . $subEntry->getName(); | |
| 71 | - $this->copyFromCache($sourceCache, $subEntry, $subTargetPath); | |
| 72 | - } | |
| 73 | - } | |
| 74 | - } | |
| 58 | + /** | |
| 59 | + * Copy a file or folder in the cache | |
| 60 | + * | |
| 61 | + * @param \OCP\Files\Cache\ICache $sourceCache | |
| 62 | + * @param ICacheEntry $sourceEntry | |
| 63 | + * @param string $targetPath | |
| 64 | + */ | |
| 65 | +    public function copyFromCache(ICache $sourceCache, ICacheEntry $sourceEntry, $targetPath) { | |
| 66 | + $this->put($targetPath, $this->cacheEntryToArray($sourceEntry)); | |
| 67 | +        if ($sourceEntry->getMimeType() === ICacheEntry::DIRECTORY_MIMETYPE) { | |
| 68 | + $folderContent = $sourceCache->getFolderContentsById($sourceEntry->getId()); | |
| 69 | +            foreach ($folderContent as $subEntry) { | |
| 70 | + $subTargetPath = $targetPath . '/' . $subEntry->getName(); | |
| 71 | + $this->copyFromCache($sourceCache, $subEntry, $subTargetPath); | |
| 72 | + } | |
| 73 | + } | |
| 74 | + } | |
| 75 | 75 | |
| 76 | -	private function cacheEntryToArray(ICacheEntry $entry) { | |
| 77 | - return [ | |
| 78 | - 'size' => $entry->getSize(), | |
| 79 | - 'mtime' => $entry->getMTime(), | |
| 80 | - 'storage_mtime' => $entry->getStorageMTime(), | |
| 81 | - 'mimetype' => $entry->getMimeType(), | |
| 82 | - 'mimepart' => $entry->getMimePart(), | |
| 83 | - 'etag' => $entry->getEtag(), | |
| 84 | - 'permissions' => $entry->getPermissions(), | |
| 85 | - 'encrypted' => $entry->isEncrypted() | |
| 86 | - ]; | |
| 87 | - } | |
| 76 | +    private function cacheEntryToArray(ICacheEntry $entry) { | |
| 77 | + return [ | |
| 78 | + 'size' => $entry->getSize(), | |
| 79 | + 'mtime' => $entry->getMTime(), | |
| 80 | + 'storage_mtime' => $entry->getStorageMTime(), | |
| 81 | + 'mimetype' => $entry->getMimeType(), | |
| 82 | + 'mimepart' => $entry->getMimePart(), | |
| 83 | + 'etag' => $entry->getEtag(), | |
| 84 | + 'permissions' => $entry->getPermissions(), | |
| 85 | + 'encrypted' => $entry->isEncrypted() | |
| 86 | + ]; | |
| 87 | + } | |
| 88 | 88 | } | 
| @@ -67,7 +67,7 @@ | ||
| 67 | 67 |  		if ($sourceEntry->getMimeType() === ICacheEntry::DIRECTORY_MIMETYPE) { | 
| 68 | 68 | $folderContent = $sourceCache->getFolderContentsById($sourceEntry->getId()); | 
| 69 | 69 |  			foreach ($folderContent as $subEntry) { | 
| 70 | - $subTargetPath = $targetPath . '/' . $subEntry->getName(); | |
| 70 | + $subTargetPath = $targetPath.'/'.$subEntry->getName(); | |
| 71 | 71 | $this->copyFromCache($sourceCache, $subEntry, $subTargetPath); | 
| 72 | 72 | } | 
| 73 | 73 | } | 
| @@ -32,113 +32,113 @@ | ||
| 32 | 32 | */ | 
| 33 | 33 |  class Watcher implements IWatcher { | 
| 34 | 34 | |
| 35 | - protected $watchPolicy = self::CHECK_ONCE; | |
| 35 | + protected $watchPolicy = self::CHECK_ONCE; | |
| 36 | 36 | |
| 37 | - protected $checkedPaths = array(); | |
| 37 | + protected $checkedPaths = array(); | |
| 38 | 38 | |
| 39 | - /** | |
| 40 | - * @var \OC\Files\Storage\Storage $storage | |
| 41 | - */ | |
| 42 | - protected $storage; | |
| 39 | + /** | |
| 40 | + * @var \OC\Files\Storage\Storage $storage | |
| 41 | + */ | |
| 42 | + protected $storage; | |
| 43 | 43 | |
| 44 | - /** | |
| 45 | - * @var Cache $cache | |
| 46 | - */ | |
| 47 | - protected $cache; | |
| 44 | + /** | |
| 45 | + * @var Cache $cache | |
| 46 | + */ | |
| 47 | + protected $cache; | |
| 48 | 48 | |
| 49 | - /** | |
| 50 | - * @var Scanner $scanner ; | |
| 51 | - */ | |
| 52 | - protected $scanner; | |
| 49 | + /** | |
| 50 | + * @var Scanner $scanner ; | |
| 51 | + */ | |
| 52 | + protected $scanner; | |
| 53 | 53 | |
| 54 | - /** | |
| 55 | - * @param \OC\Files\Storage\Storage $storage | |
| 56 | - */ | |
| 57 | -	public function __construct(\OC\Files\Storage\Storage $storage) { | |
| 58 | - $this->storage = $storage; | |
| 59 | - $this->cache = $storage->getCache(); | |
| 60 | - $this->scanner = $storage->getScanner(); | |
| 61 | - } | |
| 54 | + /** | |
| 55 | + * @param \OC\Files\Storage\Storage $storage | |
| 56 | + */ | |
| 57 | +    public function __construct(\OC\Files\Storage\Storage $storage) { | |
| 58 | + $this->storage = $storage; | |
| 59 | + $this->cache = $storage->getCache(); | |
| 60 | + $this->scanner = $storage->getScanner(); | |
| 61 | + } | |
| 62 | 62 | |
| 63 | - /** | |
| 64 | - * @param int $policy either \OC\Files\Cache\Watcher::CHECK_NEVER, \OC\Files\Cache\Watcher::CHECK_ONCE, \OC\Files\Cache\Watcher::CHECK_ALWAYS | |
| 65 | - */ | |
| 66 | -	public function setPolicy($policy) { | |
| 67 | - $this->watchPolicy = $policy; | |
| 68 | - } | |
| 63 | + /** | |
| 64 | + * @param int $policy either \OC\Files\Cache\Watcher::CHECK_NEVER, \OC\Files\Cache\Watcher::CHECK_ONCE, \OC\Files\Cache\Watcher::CHECK_ALWAYS | |
| 65 | + */ | |
| 66 | +    public function setPolicy($policy) { | |
| 67 | + $this->watchPolicy = $policy; | |
| 68 | + } | |
| 69 | 69 | |
| 70 | - /** | |
| 71 | - * @return int either \OC\Files\Cache\Watcher::CHECK_NEVER, \OC\Files\Cache\Watcher::CHECK_ONCE, \OC\Files\Cache\Watcher::CHECK_ALWAYS | |
| 72 | - */ | |
| 73 | -	public function getPolicy() { | |
| 74 | - return $this->watchPolicy; | |
| 75 | - } | |
| 70 | + /** | |
| 71 | + * @return int either \OC\Files\Cache\Watcher::CHECK_NEVER, \OC\Files\Cache\Watcher::CHECK_ONCE, \OC\Files\Cache\Watcher::CHECK_ALWAYS | |
| 72 | + */ | |
| 73 | +    public function getPolicy() { | |
| 74 | + return $this->watchPolicy; | |
| 75 | + } | |
| 76 | 76 | |
| 77 | - /** | |
| 78 | - * check $path for updates and update if needed | |
| 79 | - * | |
| 80 | - * @param string $path | |
| 81 | - * @param ICacheEntry|null $cachedEntry | |
| 82 | - * @return boolean true if path was updated | |
| 83 | - */ | |
| 84 | -	public function checkUpdate($path, $cachedEntry = null) { | |
| 85 | -		if (is_null($cachedEntry)) { | |
| 86 | - $cachedEntry = $this->cache->get($path); | |
| 87 | - } | |
| 88 | -		if ($this->needsUpdate($path, $cachedEntry)) { | |
| 89 | - $this->update($path, $cachedEntry); | |
| 90 | - return true; | |
| 91 | -		} else { | |
| 92 | - return false; | |
| 93 | - } | |
| 94 | - } | |
| 77 | + /** | |
| 78 | + * check $path for updates and update if needed | |
| 79 | + * | |
| 80 | + * @param string $path | |
| 81 | + * @param ICacheEntry|null $cachedEntry | |
| 82 | + * @return boolean true if path was updated | |
| 83 | + */ | |
| 84 | +    public function checkUpdate($path, $cachedEntry = null) { | |
| 85 | +        if (is_null($cachedEntry)) { | |
| 86 | + $cachedEntry = $this->cache->get($path); | |
| 87 | + } | |
| 88 | +        if ($this->needsUpdate($path, $cachedEntry)) { | |
| 89 | + $this->update($path, $cachedEntry); | |
| 90 | + return true; | |
| 91 | +        } else { | |
| 92 | + return false; | |
| 93 | + } | |
| 94 | + } | |
| 95 | 95 | |
| 96 | - /** | |
| 97 | - * Update the cache for changes to $path | |
| 98 | - * | |
| 99 | - * @param string $path | |
| 100 | - * @param ICacheEntry $cachedData | |
| 101 | - */ | |
| 102 | -	public function update($path, $cachedData) { | |
| 103 | -		if ($this->storage->is_dir($path)) { | |
| 104 | - $this->scanner->scan($path, Scanner::SCAN_SHALLOW); | |
| 105 | -		} else { | |
| 106 | - $this->scanner->scanFile($path); | |
| 107 | - } | |
| 108 | -		if ($cachedData['mimetype'] === 'httpd/unix-directory') { | |
| 109 | - $this->cleanFolder($path); | |
| 110 | - } | |
| 111 | -		if ($this->cache instanceof Cache) { | |
| 112 | - $this->cache->correctFolderSize($path); | |
| 113 | - } | |
| 114 | - } | |
| 96 | + /** | |
| 97 | + * Update the cache for changes to $path | |
| 98 | + * | |
| 99 | + * @param string $path | |
| 100 | + * @param ICacheEntry $cachedData | |
| 101 | + */ | |
| 102 | +    public function update($path, $cachedData) { | |
| 103 | +        if ($this->storage->is_dir($path)) { | |
| 104 | + $this->scanner->scan($path, Scanner::SCAN_SHALLOW); | |
| 105 | +        } else { | |
| 106 | + $this->scanner->scanFile($path); | |
| 107 | + } | |
| 108 | +        if ($cachedData['mimetype'] === 'httpd/unix-directory') { | |
| 109 | + $this->cleanFolder($path); | |
| 110 | + } | |
| 111 | +        if ($this->cache instanceof Cache) { | |
| 112 | + $this->cache->correctFolderSize($path); | |
| 113 | + } | |
| 114 | + } | |
| 115 | 115 | |
| 116 | - /** | |
| 117 | - * Check if the cache for $path needs to be updated | |
| 118 | - * | |
| 119 | - * @param string $path | |
| 120 | - * @param ICacheEntry $cachedData | |
| 121 | - * @return bool | |
| 122 | - */ | |
| 123 | -	public function needsUpdate($path, $cachedData) { | |
| 124 | -		if ($this->watchPolicy === self::CHECK_ALWAYS or ($this->watchPolicy === self::CHECK_ONCE and array_search($path, $this->checkedPaths) === false)) { | |
| 125 | - $this->checkedPaths[] = $path; | |
| 126 | - return $this->storage->hasUpdated($path, $cachedData['storage_mtime']); | |
| 127 | - } | |
| 128 | - return false; | |
| 129 | - } | |
| 116 | + /** | |
| 117 | + * Check if the cache for $path needs to be updated | |
| 118 | + * | |
| 119 | + * @param string $path | |
| 120 | + * @param ICacheEntry $cachedData | |
| 121 | + * @return bool | |
| 122 | + */ | |
| 123 | +    public function needsUpdate($path, $cachedData) { | |
| 124 | +        if ($this->watchPolicy === self::CHECK_ALWAYS or ($this->watchPolicy === self::CHECK_ONCE and array_search($path, $this->checkedPaths) === false)) { | |
| 125 | + $this->checkedPaths[] = $path; | |
| 126 | + return $this->storage->hasUpdated($path, $cachedData['storage_mtime']); | |
| 127 | + } | |
| 128 | + return false; | |
| 129 | + } | |
| 130 | 130 | |
| 131 | - /** | |
| 132 | - * remove deleted files in $path from the cache | |
| 133 | - * | |
| 134 | - * @param string $path | |
| 135 | - */ | |
| 136 | -	public function cleanFolder($path) { | |
| 137 | - $cachedContent = $this->cache->getFolderContents($path); | |
| 138 | -		foreach ($cachedContent as $entry) { | |
| 139 | -			if (!$this->storage->file_exists($entry['path'])) { | |
| 140 | - $this->cache->remove($entry['path']); | |
| 141 | - } | |
| 142 | - } | |
| 143 | - } | |
| 131 | + /** | |
| 132 | + * remove deleted files in $path from the cache | |
| 133 | + * | |
| 134 | + * @param string $path | |
| 135 | + */ | |
| 136 | +    public function cleanFolder($path) { | |
| 137 | + $cachedContent = $this->cache->getFolderContents($path); | |
| 138 | +        foreach ($cachedContent as $entry) { | |
| 139 | +            if (!$this->storage->file_exists($entry['path'])) { | |
| 140 | + $this->cache->remove($entry['path']); | |
| 141 | + } | |
| 142 | + } | |
| 143 | + } | |
| 144 | 144 | } | 
| @@ -51,19 +51,19 @@ | ||
| 51 | 51 | continue; | 
| 52 | 52 | } | 
| 53 | 53 | // create audio result | 
| 54 | -			if($fileData['mimepart'] === 'audio'){ | |
| 54 | +			if ($fileData['mimepart'] === 'audio') { | |
| 55 | 55 | $result = new \OC\Search\Result\Audio($fileData); | 
| 56 | 56 | } | 
| 57 | 57 | // create image result | 
| 58 | -			elseif($fileData['mimepart'] === 'image'){ | |
| 58 | +			elseif ($fileData['mimepart'] === 'image') { | |
| 59 | 59 | $result = new \OC\Search\Result\Image($fileData); | 
| 60 | 60 | } | 
| 61 | 61 | // create folder result | 
| 62 | -			elseif($fileData['mimetype'] === 'httpd/unix-directory'){ | |
| 62 | +			elseif ($fileData['mimetype'] === 'httpd/unix-directory') { | |
| 63 | 63 | $result = new \OC\Search\Result\Folder($fileData); | 
| 64 | 64 | } | 
| 65 | 65 | // or create file result | 
| 66 | -			else{ | |
| 66 | +			else { | |
| 67 | 67 | $result = new \OC\Search\Result\File($fileData); | 
| 68 | 68 | } | 
| 69 | 69 | // add to results | 
| @@ -32,45 +32,45 @@ | ||
| 32 | 32 | */ | 
| 33 | 33 |  class File extends \OCP\Search\Provider { | 
| 34 | 34 | |
| 35 | - /** | |
| 36 | - * Search for files and folders matching the given query | |
| 37 | - * @param string $query | |
| 38 | - * @return \OCP\Search\Result | |
| 39 | - */ | |
| 40 | -	public function search($query) { | |
| 41 | - $files = Filesystem::search($query); | |
| 42 | - $results = array(); | |
| 43 | - // edit results | |
| 44 | -		foreach ($files as $fileData) { | |
| 45 | - // skip versions | |
| 46 | -			if (strpos($fileData['path'], '_versions') === 0) { | |
| 47 | - continue; | |
| 48 | - } | |
| 49 | - // skip top-level folder | |
| 50 | -			if ($fileData['name'] === 'files' && $fileData['parent'] === -1) { | |
| 51 | - continue; | |
| 52 | - } | |
| 53 | - // create audio result | |
| 54 | -			if($fileData['mimepart'] === 'audio'){ | |
| 55 | - $result = new \OC\Search\Result\Audio($fileData); | |
| 56 | - } | |
| 57 | - // create image result | |
| 58 | -			elseif($fileData['mimepart'] === 'image'){ | |
| 59 | - $result = new \OC\Search\Result\Image($fileData); | |
| 60 | - } | |
| 61 | - // create folder result | |
| 62 | -			elseif($fileData['mimetype'] === 'httpd/unix-directory'){ | |
| 63 | - $result = new \OC\Search\Result\Folder($fileData); | |
| 64 | - } | |
| 65 | - // or create file result | |
| 66 | -			else{ | |
| 67 | - $result = new \OC\Search\Result\File($fileData); | |
| 68 | - } | |
| 69 | - // add to results | |
| 70 | - $results[] = $result; | |
| 71 | - } | |
| 72 | - // return | |
| 73 | - return $results; | |
| 74 | - } | |
| 35 | + /** | |
| 36 | + * Search for files and folders matching the given query | |
| 37 | + * @param string $query | |
| 38 | + * @return \OCP\Search\Result | |
| 39 | + */ | |
| 40 | +    public function search($query) { | |
| 41 | + $files = Filesystem::search($query); | |
| 42 | + $results = array(); | |
| 43 | + // edit results | |
| 44 | +        foreach ($files as $fileData) { | |
| 45 | + // skip versions | |
| 46 | +            if (strpos($fileData['path'], '_versions') === 0) { | |
| 47 | + continue; | |
| 48 | + } | |
| 49 | + // skip top-level folder | |
| 50 | +            if ($fileData['name'] === 'files' && $fileData['parent'] === -1) { | |
| 51 | + continue; | |
| 52 | + } | |
| 53 | + // create audio result | |
| 54 | +            if($fileData['mimepart'] === 'audio'){ | |
| 55 | + $result = new \OC\Search\Result\Audio($fileData); | |
| 56 | + } | |
| 57 | + // create image result | |
| 58 | +            elseif($fileData['mimepart'] === 'image'){ | |
| 59 | + $result = new \OC\Search\Result\Image($fileData); | |
| 60 | + } | |
| 61 | + // create folder result | |
| 62 | +            elseif($fileData['mimetype'] === 'httpd/unix-directory'){ | |
| 63 | + $result = new \OC\Search\Result\Folder($fileData); | |
| 64 | + } | |
| 65 | + // or create file result | |
| 66 | +            else{ | |
| 67 | + $result = new \OC\Search\Result\File($fileData); | |
| 68 | + } | |
| 69 | + // add to results | |
| 70 | + $results[] = $result; | |
| 71 | + } | |
| 72 | + // return | |
| 73 | + return $results; | |
| 74 | + } | |
| 75 | 75 | |
| 76 | 76 | } | 
| @@ -29,13 +29,13 @@ | ||
| 29 | 29 | */ | 
| 30 | 30 |  class Image extends File { | 
| 31 | 31 | |
| 32 | - /** | |
| 33 | - * Type name; translated in templates | |
| 34 | - * @var string | |
| 35 | - */ | |
| 36 | - public $type = 'image'; | |
| 32 | + /** | |
| 33 | + * Type name; translated in templates | |
| 34 | + * @var string | |
| 35 | + */ | |
| 36 | + public $type = 'image'; | |
| 37 | 37 | |
| 38 | - /** | |
| 39 | - * @TODO add EXIF information | |
| 40 | - */ | |
| 38 | + /** | |
| 39 | + * @TODO add EXIF information | |
| 40 | + */ | |
| 41 | 41 | } | 
| @@ -105,7 +105,7 @@ | ||
| 105 | 105 | * @param string $path | 
| 106 | 106 | * @return string relative path | 
| 107 | 107 | */ | 
| 108 | -	protected function getRelativePath ($path) { | |
| 108 | +	protected function getRelativePath($path) { | |
| 109 | 109 |  		if (!isset(self::$userFolderCache)) { | 
| 110 | 110 | $user = \OC::$server->getUserSession()->getUser()->getUID(); | 
| 111 | 111 | self::$userFolderCache = \OC::$server->getUserFolder($user); | 
| @@ -32,85 +32,85 @@ | ||
| 32 | 32 | */ | 
| 33 | 33 |  class File extends \OCP\Search\Result { | 
| 34 | 34 | |
| 35 | - /** | |
| 36 | - * Type name; translated in templates | |
| 37 | - * @var string | |
| 38 | - */ | |
| 39 | - public $type = 'file'; | |
| 35 | + /** | |
| 36 | + * Type name; translated in templates | |
| 37 | + * @var string | |
| 38 | + */ | |
| 39 | + public $type = 'file'; | |
| 40 | 40 | |
| 41 | - /** | |
| 42 | - * Path to file | |
| 43 | - * @var string | |
| 44 | - */ | |
| 45 | - public $path; | |
| 41 | + /** | |
| 42 | + * Path to file | |
| 43 | + * @var string | |
| 44 | + */ | |
| 45 | + public $path; | |
| 46 | 46 | |
| 47 | - /** | |
| 48 | - * Size, in bytes | |
| 49 | - * @var int | |
| 50 | - */ | |
| 51 | - public $size; | |
| 47 | + /** | |
| 48 | + * Size, in bytes | |
| 49 | + * @var int | |
| 50 | + */ | |
| 51 | + public $size; | |
| 52 | 52 | |
| 53 | - /** | |
| 54 | - * Date modified, in human readable form | |
| 55 | - * @var string | |
| 56 | - */ | |
| 57 | - public $modified; | |
| 53 | + /** | |
| 54 | + * Date modified, in human readable form | |
| 55 | + * @var string | |
| 56 | + */ | |
| 57 | + public $modified; | |
| 58 | 58 | |
| 59 | - /** | |
| 60 | - * File mime type | |
| 61 | - * @var string | |
| 62 | - */ | |
| 63 | - public $mime_type; | |
| 59 | + /** | |
| 60 | + * File mime type | |
| 61 | + * @var string | |
| 62 | + */ | |
| 63 | + public $mime_type; | |
| 64 | 64 | |
| 65 | - /** | |
| 66 | - * File permissions: | |
| 67 | - * | |
| 68 | - * @var string | |
| 69 | - */ | |
| 70 | - public $permissions; | |
| 65 | + /** | |
| 66 | + * File permissions: | |
| 67 | + * | |
| 68 | + * @var string | |
| 69 | + */ | |
| 70 | + public $permissions; | |
| 71 | 71 | |
| 72 | - /** | |
| 73 | - * Create a new file search result | |
| 74 | - * @param FileInfo $data file data given by provider | |
| 75 | - */ | |
| 76 | -	public function __construct(FileInfo $data) { | |
| 72 | + /** | |
| 73 | + * Create a new file search result | |
| 74 | + * @param FileInfo $data file data given by provider | |
| 75 | + */ | |
| 76 | +    public function __construct(FileInfo $data) { | |
| 77 | 77 | |
| 78 | - $path = $this->getRelativePath($data->getPath()); | |
| 78 | + $path = $this->getRelativePath($data->getPath()); | |
| 79 | 79 | |
| 80 | - $info = pathinfo($path); | |
| 81 | - $this->id = $data->getId(); | |
| 82 | - $this->name = $info['basename']; | |
| 83 | - $this->link = \OC::$server->getURLGenerator()->linkToRoute( | |
| 84 | - 'files.view.index', | |
| 85 | - [ | |
| 86 | - 'dir' => $info['dirname'], | |
| 87 | - 'scrollto' => $info['basename'], | |
| 88 | - ] | |
| 89 | - ); | |
| 90 | - $this->permissions = $data->getPermissions(); | |
| 91 | - $this->path = $path; | |
| 92 | - $this->size = $data->getSize(); | |
| 93 | - $this->modified = $data->getMtime(); | |
| 94 | - $this->mime_type = $data->getMimetype(); | |
| 95 | - } | |
| 80 | + $info = pathinfo($path); | |
| 81 | + $this->id = $data->getId(); | |
| 82 | + $this->name = $info['basename']; | |
| 83 | + $this->link = \OC::$server->getURLGenerator()->linkToRoute( | |
| 84 | + 'files.view.index', | |
| 85 | + [ | |
| 86 | + 'dir' => $info['dirname'], | |
| 87 | + 'scrollto' => $info['basename'], | |
| 88 | + ] | |
| 89 | + ); | |
| 90 | + $this->permissions = $data->getPermissions(); | |
| 91 | + $this->path = $path; | |
| 92 | + $this->size = $data->getSize(); | |
| 93 | + $this->modified = $data->getMtime(); | |
| 94 | + $this->mime_type = $data->getMimetype(); | |
| 95 | + } | |
| 96 | 96 | |
| 97 | - /** | |
| 98 | - * @var Folder $userFolderCache | |
| 99 | - */ | |
| 100 | - static protected $userFolderCache = null; | |
| 97 | + /** | |
| 98 | + * @var Folder $userFolderCache | |
| 99 | + */ | |
| 100 | + static protected $userFolderCache = null; | |
| 101 | 101 | |
| 102 | - /** | |
| 103 | - * converts a path relative to the users files folder | |
| 104 | - * eg /user/files/foo.txt -> /foo.txt | |
| 105 | - * @param string $path | |
| 106 | - * @return string relative path | |
| 107 | - */ | |
| 108 | -	protected function getRelativePath ($path) { | |
| 109 | -		if (!isset(self::$userFolderCache)) { | |
| 110 | - $user = \OC::$server->getUserSession()->getUser()->getUID(); | |
| 111 | - self::$userFolderCache = \OC::$server->getUserFolder($user); | |
| 112 | - } | |
| 113 | - return self::$userFolderCache->getRelativePath($path); | |
| 114 | - } | |
| 102 | + /** | |
| 103 | + * converts a path relative to the users files folder | |
| 104 | + * eg /user/files/foo.txt -> /foo.txt | |
| 105 | + * @param string $path | |
| 106 | + * @return string relative path | |
| 107 | + */ | |
| 108 | +    protected function getRelativePath ($path) { | |
| 109 | +        if (!isset(self::$userFolderCache)) { | |
| 110 | + $user = \OC::$server->getUserSession()->getUser()->getUID(); | |
| 111 | + self::$userFolderCache = \OC::$server->getUserFolder($user); | |
| 112 | + } | |
| 113 | + return self::$userFolderCache->getRelativePath($path); | |
| 114 | + } | |
| 115 | 115 | |
| 116 | 116 | } |