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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
<?php
/*
* Wizard for setting up active directory integration for authentication.
*/
AddModule_Base::addModule('active_directory', 'AdModule_Start', 'Active Directory Authentifizierung',
'Mit diesem Modul ist die Anmeldung an den Client PCs mit den Benutzerkonten eines Active Directory'
. ' möglich. Je nach Konfiguration ist auch die Nutzung eines Benutzerverzeichnisses auf dem Client möglich.'
);
class AdModule_Start extends AddModule_Base
{
protected function renderInternal()
{
Session::set('ad_check', false);
Session::save();
Render::addDialog('Active Directory Authentifizierung', false, 'sysconfig/ad-start', array(
'step' => 'AdModule_CheckConnection',
'server' => Request::post('server'),
'searchbase' => Request::post('searchbase'),
'binddn' => Request::post('binddn'),
'bindpw' => Request::post('bindpw'),
'token' => Session::get('token')
));
}
}
class AdModule_CheckConnection extends AddModule_Base
{
private $taskIds;
protected function preprocessInternal()
{
$server = Request::post('server');
$searchbase = Request::post('searchbase');
$binddn = Request::post('binddn');
$bindpw = Request::post('bindpw');
if (empty($server) || empty($searchbase) || empty($binddn)) {
Message::addError('empty-field');
AddModule_Base::setStep('AdModule_Start'); // Continues with AdModule_Start for render()
return;
}
/*
$data = Taskmanager::submit('LdapSearch', array(
'id' => $this->taskId,
'uri' => ''
));
*/
$ldapSearch = Taskmanager::submit('DummyTask', array());
if (isset($ldapSearch['id'])) {
$dummy = Taskmanager::submit('DummyTask', array('parentTask' => $ldapSearch['id']));
}
if (!isset($ldapSearch['id']) || !isset($dummy['id'])) {
AddModule_Base::setStep('AdModule_Start'); // Continues with AdModule_Start for render()
return;
}
$this->taskIds = array(
'tm-search' => $ldapSearch['id'],
'tm-dummy' => $dummy['id']
);
}
protected function renderInternal()
{
Render::addDialog('Active Directory Authentifizierung', false, 'sysconfig/ad-checkconnection',
array_merge($this->taskIds, array(
'server' => Request::post('server'),
'searchbase' => Request::post('searchbase'),
'binddn' => Request::post('binddn'),
'bindpw' => Request::post('bindpw'),
'token' => Session::get('token'),
'step' => 'AdModule_Finish'
))
);
}
}
class AdModule_Finish extends AddModule_Base
{
private $taskIds;
protected function preprocessInternal()
{
$config = ConfigModule::insertAdConfig('AD: ' . Request::post('server'),
Request::post('server'),
Request::post('searchbase'),
Request::post('binddn'),
Request::post('bindpw')
);
$config['proxyip'] = Property::getServerIp();
$tgz = Taskmanager::submit('CreateAdConfig', $config);
if (isset($tgz['id'])) {
$ldadp = Taskmanager::submit('DummyTask', array('parentTask' => $tgz['id']));
}
if (!isset($tgz['id']) || !isset($ldadp['id'])) {
AddModule_Base::setStep('AdModule_Start'); // Continues with AdModule_Start for render()
return;
}
$this->taskIds = array(
'tm-config' => $tgz['id'],
'tm-ldadp' => $ldadp['id']
);
}
protected function renderInternal()
{
Render::addDialog('Active Directory Authentifizierung', false, 'sysconfig/ad-finish',
$this->taskIds
);
}
}
|