RenameTable::run()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
nc 1
nop 1
dl 0
loc 4
rs 10
c 0
b 0
f 0
1
<?php
2
/**
3
 * Nextcloud - namespace OCA\Nextnote
4
 *
5
 * @copyright Copyright (c) 2016, Sander Brand ([email protected])
6
 * @copyright Copyright (c) 2016, Marcos Zuriaga Miguel ([email protected])
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
24
namespace OCA\NextNote\Migration;
25
26
27
use OCP\IDBConnection;
28
use OCP\ILogger;
29
use OCP\Migration\IOutput;
30
use OCP\Migration\IRepairStep;
31
32
33
class RenameTable implements IRepairStep {
34
35
36
	/** @var IDBConnection */
37
	private $db;
38
39
	/** @var string */
40
	private $installedVersion;
41
42
	/** @var ILogger */
43
	private $logger;
44
45
46
	public function __construct(IDBConnection $db, ILogger $logger) {
47
		$this->db = $db;
48
		$this->logger = $logger;
49
	}
50
51
	public function getName() {
52
		return 'Copying notes from ownnotes';
53
	}
54
55
	public function run(IOutput $output) {
56
		$output->info('Copying notes from ownnotes');
57
		$this->copyOwnNotes();
58
	}
59
60
	private function copyOwnNotes() {
61
		try {
62
			$this->db->executeQuery('INSERT INTO `*PREFIX*nextnote` SELECT * FROM *PREFIX*ownnote');
63
			$this->db->executeQuery('DROP TABLE *PREFIX*ownnote');
64
		} catch (\Exception $exception) {
65
			$this->logger->warning($exception->getMessage());
66
		}
67
		try {
68
			$this->db->executeQuery('INSERT INTO `*PREFIX*nextnote_parts` SELECT * FROM *PREFIX*ownnote_parts');
69
			$this->db->executeQuery('DROP TABLE *PREFIX*ownnote_parts');
70
		} catch (\Exception $exception) {
71
			$this->logger->warning($exception->getMessage());
72
		}
73
	}
74
75
}
76