Completed
Push — master ( 721837...277496 )
by Victor
13:18
created

Version20170804201125   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 87
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 2

Importance

Changes 0
Metric Value
dl 0
loc 87
rs 10
c 0
b 0
f 0
wmc 2
lcom 0
cbo 2

1 Method

Rating   Name   Duplication   Size   Complexity  
B changeSchema() 0 85 2
1
<?php
2
3
namespace OCA\Files_Sharing\Migrations;
4
use Doctrine\DBAL\Schema\Schema;
5
use OCP\Migration\ISchemaMigration;
6
7
/** Creates initial schema */
8
class Version20170804201125 implements ISchemaMigration {
9
	public function changeSchema(Schema $schema, array $options) {
10
		$prefix = $options['tablePrefix'];
11
		if (!$schema->hasTable("{$prefix}share_external")) {
12
			$table = $schema->createTable("{$prefix}share_external");
13
			$table->addColumn('id', 'bigint', [
14
				'autoincrement' => true,
15
				'unsigned' => false,
16
				'notnull' => true,
17
				'length' => 11,
18
			]);
19
20
			$table->addColumn('remote', 'string', [
21
				'notnull' => true,
22
				'length' => 512,
23
				'default' => null,
24
				'comment' => 'Url of the remote owncloud instance'
25
			]);
26
27
			$table->addColumn('remote_id', 'bigint', [
28
				'unsigned' => false,
29
				'notnull' => true,
30
				'default' => -1,
31
				'length' => 11,
32
			]);
33
34
			$table->addColumn('share_token', 'string', [
35
				'length' => 64,
36
				'notnull' => true,
37
				'comment' => 'Public share token'
38
			]);
39
40
			$table->addColumn('password', 'string', [
41
				'length' => 64,
42
				'notnull' => false,
43
				'default' => null,
44
				'comment' => 'Optional password for the public share'
45
			]);
46
47
			$table->addColumn('name', 'string', [
48
				'length' => 64,
49
				'notnull' => true,
50
				'comment' => 'Original name on the remote server'
51
			]);
52
53
			$table->addColumn('owner', 'string', [
54
				'length' => 64,
55
				'notnull' => true,
56
				'comment' => 'User that owns the public share on the remote server'
57
			]);
58
59
			$table->addColumn('user', 'string', [
60
				'length' => 64,
61
				'notnull' => true,
62
				'comment' => 'Local user which added the external share'
63
			]);
64
65
			$table->addColumn('mountpoint', 'string', [
66
				'length' => 4000,
67
				'notnull' => true,
68
				'comment' => 'Full path where the share is mounted'
69
			]);
70
71
			$table->addColumn('mountpoint_hash', 'string', [
72
				'length' => 32,
73
				'notnull' => true,
74
				'comment' => 'md5 hash of the mountpoint'
75
			]);
76
77
			$table->addColumn('accepted', 'integer', [
78
				'notnull' => true,
79
				'default' => 0,
80
			]);
81
82
			$table->setPrimaryKey(['id']);
83
84
			$table->addIndex(
85
				['user'],
86
				'sh_external_user'
87
			);
88
			$table->addUniqueIndex(
89
				['user', 'mountpoint_hash'],
90
				'sh_external_mp'
91
			);
92
		}
93
	}
94
}
95