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
|
<?php
class Dnbd3 {
const PROP_ENABLED = 'dnbd3.enabled';
const PROP_NFS_FALLBACK = 'dnbd3.nfs-fallback';
const PROP_PREFER_LOCAL = 'dnbd3.prefer-local';
public static function isEnabled(): bool
{
return (bool)Property::get(self::PROP_ENABLED, 0);
}
public static function setEnabled($bool)
{
Property::set(self::PROP_ENABLED, $bool ? 1 : 0);
Trigger::mount(false, true);
}
public static function hasNfsFallback(): bool
{
return (bool)Property::get(self::PROP_NFS_FALLBACK, 0);
}
public static function setNfsFallback($bool)
{
Property::set(self::PROP_NFS_FALLBACK, $bool ? 1 : 0);
}
public static function preferLocal(): bool
{
return (bool)Property::get(self::PROP_PREFER_LOCAL, 0);
}
public static function setPreferLocal($bool)
{
Property::set(self::PROP_PREFER_LOCAL, $bool ? 1 : 0);
}
public static function getActiveServers(): array
{
$res = Database::simpleQuery('SELECT s.serverid, m.clientip, s.fixedip
FROM dnbd3_server s
LEFT JOIN machine m ON (s.machineuuid = m.machineuuid)
WHERE s.lastseen > :cutoff', ['cutoff' => CONFIG_DEBUG ? 0 : time() - 310]);
$lookup = [];
foreach ($res as $row) {
$lookup[$row['fixedip'] ?? $row['clientip'] ?? ''] = $row['serverid'];
}
return $lookup;
}
public static function getServer(string $serverId)
{
return Database::queryFirst('SELECT s.serverid, IFNULL(s.fixedip, m.clientip) AS clientip
FROM dnbd3_server s
LEFT JOIN machine m ON (s.machineuuid = m.machineuuid)
WHERE s.serverid = :id', ['id' => $serverId]);
}
}
|