Skip to content
Snippets Groups Projects
Commit 3b2f3356 authored by Morris Jobke's avatar Morris Jobke
Browse files

Merge pull request #13278 from owncloud/repair-step-missing-etags

Adding repair step to fix missing etags - fixes #12172
parents c4aeb0b5 7966eee0
No related branches found
No related tags found
No related merge requests found
......@@ -12,6 +12,7 @@ use OC\Hooks\BasicEmitter;
use OC\Hooks\Emitter;
use OC\Repair\AssetCache;
use OC\Repair\Collation;
use OC\Repair\FillETags;
use OC\Repair\InnoDB;
use OC\Repair\RepairConfig;
use OC\Repair\RepairLegacyStorages;
......@@ -79,7 +80,8 @@ class Repair extends BasicEmitter {
new RepairMimeTypes(),
new RepairLegacyStorages(\OC::$server->getConfig(), \OC_DB::getConnection()),
new RepairConfig(),
new AssetCache()
new AssetCache(),
new FillETags(\OC_DB::getConnection())
);
}
......
<?php
/**
* Copyright (c) 2015 Thomas Müller <deepdiver@owncloud.com>
* This file is licensed under the Affero General Public License version 3 or
* later.
* See the COPYING-README file.
*/
namespace OC\Repair;
use Doctrine\DBAL\Query\QueryBuilder;
use OC\Hooks\BasicEmitter;
class FillETags extends BasicEmitter implements \OC\RepairStep {
/** @var \OC\DB\Connection */
protected $connection;
/**
* @param \OC\DB\Connection $connection
*/
public function __construct($connection) {
$this->connection = $connection;
}
public function getName() {
return 'Generate ETags for file where no ETag is present.';
}
public function run() {
$qb = $this->connection->createQueryBuilder();
$qb->update('`*PREFIX*filecache`')
->set('`etag`', $qb->expr()->literal('xxx'))
->where($qb->expr()->eq('`etag`', $qb->expr()->literal('')))
->orWhere($qb->expr()->isNull('`etag`'));
$result = $qb->execute();
$this->emit('\OC\Repair', 'info', array("ETags have been fixed for $result files/folders."));
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment