Completed
Pull Request — master (#2673)
by Robin
08:13
created

FixMountStorages::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 1 Features 0
Metric Value
cc 1
eloc 2
c 1
b 1
f 0
nc 1
nop 1
dl 0
loc 3
rs 10
1
<?php
2
/**
3
 * @copyright 2016 Joas Schilling <[email protected]>
4
 *
5
 * @author Joas Schilling <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 * This program is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU Affero General Public License as
11
 * published by the Free Software Foundation, either version 3 of the
12
 * License, or (at your option) any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU Affero General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU Affero General Public License
20
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
namespace OC\Repair\NC11;
24
25
use OCP\DB\QueryBuilder\IQueryBuilder;
26
use OCP\IDBConnection;
27
use OCP\Migration\IOutput;
28
use OCP\Migration\IRepairStep;
29
30
class FixMountStorages implements IRepairStep {
31
32
	/** @var IDBConnection */
33
	private $db;
34
35
	/**
36
	 * @param IDBConnection $db
37
	 */
38
	public function __construct(IDBConnection $db) {
39
		$this->db = $db;
40
	}
41
42
	/**
43
	 * @return string
44
	 */
45
	public function getName() {
46
		return 'Fix potential broken mount points';
47
	}
48
49
	public function run(IOutput $output) {
50
		$query = $this->db->getQueryBuilder();
51
		$query->select('m.id', 'f.storage')
52
			->from('mounts', 'm')
53
			->leftJoin('m', 'filecache', 'f', $query->expr()->eq('m.root_id', 'f.fileid'))
54
			->where($query->expr()->neq('m.storage_id', 'f.storage'));
55
56
		$update = $this->db->getQueryBuilder();
57
		$update->update('mounts')
58
			->set('storage_id', $update->createParameter('storage'))
59
			->where($query->expr()->eq('id', $update->createParameter('mount')));
60
61
		$result = $query->execute();
62
		$entriesUpdated = 0;
63
		while ($row = $result->fetch()) {
64
			$update->setParameter('storage', $row['storage'], IQueryBuilder::PARAM_INT)
65
				->setParameter('mount', $row['id'], IQueryBuilder::PARAM_INT);
66
			$update->execute();
67
			$entriesUpdated++;
68
		}
69
		$result->closeCursor();
70
71
		if ($entriesUpdated > 0) {
72
			$output->info($entriesUpdated . ' mounts updated');
73
			return;
74
		}
75
76
		$output->info('No mounts updated');
77
	}
78
}
79