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
|
<?php
ConfigModule::registerModule(
'LdapAuth', // ID
Dictionary::translate('config-module', 'ldapAuth_title'), // Title
Dictionary::translate('config-module', 'ldapAuth_description'), // Description
Dictionary::translate('config-module', 'group_authentication'), // Group
true // Only one per config?
);
class ConfigModule_LdapAuth extends ConfigModule
{
const VERSION = 1;
private static $REQUIRED_FIELDS = array('server', 'searchbase');
private static $OPTIONAL_FIELDS = array('binddn', 'bindpw', 'home', 'ssl', 'fingerprint', 'certificate');
protected function generateInternal($tgz, $parent)
{
Trigger::ldadp($this->id(), $parent);
$config = $this->moduleData;
if (isset($config['certificate']) && !is_string($config['certificate'])) {
unset($config['certificate']);
}
if (preg_match('/^([^\:]+)\:(\d+)$/', $config['server'], $out)) {
$config['server'] = $out[1];
$config['adport'] = $out[2]; // sic!
} else {
if (isset($config['certificate'])) {
$config['adport'] = 636;
} else {
$config['adport'] = 389;
}
}
$config['parentTask'] = $parent;
$config['failOnParentFail'] = false;
$config['proxyip'] = Property::getServerIp();
$config['proxyport'] = 3100 + $this->id();
$config['filename'] = $tgz;
$config['moduleid'] = $this->id();
$config['plainldap'] = true;
return Taskmanager::submit('CreateLdapConfig', $config);
}
protected function moduleVersion()
{
return self::VERSION;
}
protected function validateConfig()
{
// Check if required fields are filled
return Util::hasAllKeys($this->moduleData, self::$REQUIRED_FIELDS);
}
public function setData($key, $value)
{
if (!in_array($key, self::$REQUIRED_FIELDS) && !in_array($key, self::$OPTIONAL_FIELDS))
return false;
$this->moduleData[$key] = $value;
return true;
}
// ############## Callbacks #############################
/**
* Server IP changed - rebuild all LDAP modules.
*/
public function event_serverIpChanged()
{
error_log('Calling generate on ' . $this->title());
$this->generate(false);
}
}
|