blob: 630da398255875286ef57d529f516a17289f7806 (
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
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
118
119
120
121
122
123
124
125
126
127
|
<p>
{{lang_connectionWait}}
</p>
<div id="zeug">
<div data-tm-id="{{taskid}}" data-tm-log="messages" data-tm-callback="portScan">Port Check</div>
</div>
<div id="self-signed" style="display:none" class="alert alert-info">{{lang_selfSignedNote}}</div>
<div id="no-valid-cert" style="display:none" class="alert alert-danger">{{lang_noValidCert}}</div>
<div id="no-open-port" style="display:none" class="alert alert-danger">{{lang_noOpenPort}}</div>
<div id="supplied-cert-invalid" style="display:none" class="alert alert-danger">{{lang_userCertInvalid}}</div>
<div id="trying-fingerprint" style="display:none" class="alert alert-warning">{{lang_tryingFingerprint}}</div>
<br>
<div class="text-left">
<form role="form" method="post" action="?do=SysConfig&action=addmodule&step={{prev}}">
<input type="hidden" name="token" value="{{token}}">
<input type="hidden" name="edit" value="{{edit}}">
<input name="title" value="{{title}}" type="hidden">
<input name="server" value="{{server}}" type="hidden">
<input name="searchbase" value="{{searchbase}}" type="hidden">
<input name="binddn" value="{{binddn}}" type="hidden">
<input name="bindpw" value="{{bindpw}}" type="hidden">
<input name="home" value="{{home}}" type="hidden">
<input name="homeattr" value="{{homeattr}}" type="hidden">
{{#ssl}}
<input name="ssl" value="on" type="hidden">
<input type="hidden" name="certificate" value="{{certificate}}">
{{/ssl}}
{{#mapping}}
<input type="hidden" name="mapping[{{field}}]" value="{{value}}">
{{/mapping}}
<input name="fixnumeric" value="{{fixnumeric}}" type="hidden">
<button type="submit" class="btn btn-primary">« {{lang_back}}</button>
</form>
</div>
<div class="text-right">
<form id="nextform" role="form" method="post" action="?do=SysConfig&action=addmodule&step={{next}}">
<input type="hidden" name="token" value="{{token}}">
<input type="hidden" name="edit" value="{{edit}}">
<input name="title" value="{{title}}" type="hidden">
<input name="server" value="{{server}}" type="hidden">
<input id="port" name="port" value="" type="hidden">
<input name="searchbase" value="{{searchbase}}" type="hidden">
<input name="binddn" value="{{binddn}}" type="hidden">
<input name="bindpw" value="{{bindpw}}" type="hidden">
<input name="home" value="{{home}}" type="hidden">
<input name="homeattr" value="{{homeattr}}" type="hidden">
{{#ssl}}
<input id="ssl" name="ssl" value="on" type="hidden">
<input id="fingerprint" name="fingerprint" value="" type="hidden">
<input id="certificate" type="hidden" name="certificate" value="{{certificate}}">
{{/ssl}}
{{#mapping}}
<input type="hidden" name="mapping[{{field}}]" value="{{value}}">
{{/mapping}}
<input name="fixnumeric" value="{{fixnumeric}}" type="hidden">
<input name="originalbinddn" value="{{binddn}}" type="hidden">
<button id="nextbutton" type="submit" class="btn btn-primary" style="display:none">{{lang_next}} »</button>
</form>
</div>
<div id="bla"></div>
<script type="text/javascript">
function isSelfSigned(code)
{
return code == 19;
}
function isIncomplete(code)
{
return code == 18 || code == 20 || code == 21;
}
function isValid(code)
{
return code == 0;
}
function portScan(task)
{
if (!task || !task.statusCode)
return;
if (task.statusCode === 'TASK_FINISHED' && task.data && task.data.ports) {
var ssl = $('#ssl').length > 0;
var ports = task.data.ports;
var verRes = -1;
var userCert = ssl && $('#certificate').val().length > 10;
var openPort = false;
for (var i = 0; i < ports.length; ++i) {
if (!ports[i].open || !ports[i].port) continue;
if ($.isNumeric($('#port').val()) && $('#port').val() < ports[i].port) continue; // Prefer the global LDAP ports over the specific AD ports
openPort = true;
if (ssl) {
if (verRes === -1) verRes = ports[i].verifyResult;
if (typeof ports[i].certFingerprint !== 'string' || typeof ports[i].certificateChain !== 'string') continue;
if (ports[i].certFingerprint.length < 10 || ports[i].certificateChain.length < 10) continue;
if (!isValid(ports[i].verifyResult) && userCert) continue;
if (!isValid(ports[i].verifyResult) && !isSelfSigned(ports[i].verifyResult) && !isIncomplete(ports[i].verifyResult)) continue;
verRes = ports[i].verifyResult;
$('#fingerprint').val(ports[i].certFingerprint);
if (!userCert && isSelfSigned(verRes)) {
$('#certificate').val(ports[i].certificateChain);
} else if (!userCert && isValid(verRes)) {
$('#certificate').val('default');
} else if (!userCert) {
$('#certificate').val('');
}
}
$('#port').val(ports[i].port);
}
if (openPort && ssl && !isValid(verRes)) {
if (userCert) {
$('#supplied-cert-invalid').show();
} else if (isSelfSigned(verRes)) {
$('#self-signed').show();
} else if (isIncomplete(verRes)) {
$('#trying-fingerprint').show();
} else {
$('#no-valid-cert').show();
}
}
if (openPort) {
$('#nextbutton').show();
if (!ssl || isValid(verRes)) $('#nextform').submit();
} else {
$('#no-open-port').css('display', '');
}
}
}
</script>
|