summaryrefslogtreecommitdiffstats
path: root/modules-available/remoteaccess/install.inc.php
blob: 2a6fec361b5c9b6e35504711ebbf565e62cf3d00 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php

$dbret = [];

$dbret[] = tableCreate('remoteaccess_group', "
	`groupid` int(11) NOT NULL AUTO_INCREMENT,
	`groupname` varchar(100) NOT NULL,
	`wolcount` smallint(11) NOT NULL,
	`passwd` varchar(100) NOT NULL,
	`active` tinyint(1) UNSIGNED NOT NULL DEFAULT '1',
	`unwoken` int(10) UNSIGNED NOT NULL DEFAULT '0',
	PRIMARY KEY (`groupid`)
");

$dbret[] = tableCreate('remoteaccess_x_location', "
	`groupid` int(11) NOT NULL,
	`locationid` int(11) NOT NULL,
	PRIMARY KEY (`groupid`, `locationid`)
");

$dbret[] = tableCreate('remoteaccess_machine', "
	`machineuuid` char(36) CHARACTER SET ascii NOT NULL,
	`password` char(8) CHARACTER SET ascii NULL DEFAULT NULL,
	`woltime` int(10) UNSIGNED NOT NULL DEFAULT '0',
	`vncport` smallint(5) UNSIGNED NOT NULL DEFAULT '5900',
	PRIMARY KEY (`machineuuid`)
");

$dbret[] = tableAddConstraint('remoteaccess_x_location', 'locationid', 'location', 'locationid',
	'ON UPDATE CASCADE ON DELETE CASCADE');

$dbret[] = tableAddConstraint('remoteaccess_x_location', 'groupid', 'remoteaccess_group', 'groupid',
	'ON UPDATE CASCADE ON DELETE CASCADE');

$dbret[] = tableAddConstraint('remoteaccess_machine', 'machineuuid', 'machine', 'machineuuid',
	'ON UPDATE CASCADE ON DELETE CASCADE');

if (tableExists('remoteaccess_location')
		&& tableExists('remoteaccess_x_location')
		&& tableExists('remoteaccess_group')) {
	// Migrate old version
	$wantedIdleCount = (int)Property::get('remoteaccess.wantedclients', 0);
	$ret = Database::exec("INSERT IGNORE INTO remoteaccess_group (groupid, groupname, wolcount, passwd)
			SELECT l.locationid, l.locationname, $wantedIdleCount AS blu, '' AS bla FROM location l
			    INNER JOIN remoteaccess_location rl USING (locationid)");
	if ($ret === false) {
		finalResponse(UPDATE_FAILED, Database::lastError());
	}
	Property::set('remoteaccess.wantedclients', 0, 1);
	$max = Database::queryFirst("SELECT groupid FROM remoteaccess_group ORDER BY groupid DESC LIMIT 1");
	if ($max !== false) {
		Database::exec("ALTER TABLE remoteaccess_group AUTO_INCREMENT = :next", ['next' => $max['groupid'] + 1]);
	}
	$ret = Database::exec("INSERT IGNORE INTO remoteaccess_x_location (groupid, locationid)
			SELECT locationid, locationid FROM remoteaccess_location");
	if ($ret === false) {
		finalResponse(UPDATE_FAILED, Database::lastError());
	}
	Database::exec("DROP TABLE remoteaccess_location");
}

// 2021-03-05: Add vncport column to machine table
if (!tableHasColumn('remoteaccess_machine', 'vncport')) {
	$ret = Database::exec("ALTER TABLE remoteaccess_machine ADD COLUMN `vncport` smallint(5) UNSIGNED NOT NULL DEFAULT '5900'");
	if ($ret === false) {
		finalResponse(UPDATE_FAILED, Database::lastError());
	}
	$dbret[] = UPDATE_DONE;
}

// 2022-06-01 Unwoken machines: Keeps track of how many machines could not be WOLed
if (!tableHasColumn('remoteaccess_group', 'unwoken')) {
	$ret = Database::exec("ALTER TABLE remoteaccess_group ADD COLUMN `unwoken` int(10) UNSIGNED NOT NULL DEFAULT '0'");
	if ($ret === false) {
		finalResponse(UPDATE_FAILED, Database::lastError());
	}
	$dbret[] = UPDATE_DONE;
}

responseFromArray($dbret);