1
|
<?php
|
2
|
/**
|
3
|
*
|
4
|
* @category modules
|
5
|
* @package SecureFormSwitcher
|
6
|
* @author WebsiteBaker Project, D Woellbrink
|
7
|
* @copyright 2009-2011, Website Baker Org. e.V.
|
8
|
* @link http://www.websitebaker2.org/
|
9
|
* @license http://www.gnu.org/licenses/gpl.html
|
10
|
* @platform WebsiteBaker 2.8.2
|
11
|
* @requirements PHP 5.2.2 and higher
|
12
|
* @version $Id: tool.php 1538 2011-12-10 15:06:15Z Luisehahne $
|
13
|
* @filesource $HeadURL: svn://isteam.dynxs.de/wb-archiv/tags/2.8.3/wb/modules/SecureFormSwitcher/tool.php $
|
14
|
* @lastmodified $Date: 2011-12-10 16:06:15 +0100 (Sat, 10 Dec 2011) $
|
15
|
*
|
16
|
*/
|
17
|
|
18
|
// Must include code to stop this file being access directly
|
19
|
if(defined('WB_PATH') == false)
|
20
|
{
|
21
|
die('<head><title>Access denied</title></head><body><h2 style="color:red;margin:3em auto;text-align:center;">Cannot access this file directly</h2></body></html>');
|
22
|
}
|
23
|
|
24
|
// load module language file
|
25
|
$mod_path = (dirname(__FILE__));
|
26
|
require_once( $mod_path.'/language_load.php' );
|
27
|
// callback function for settings name
|
28
|
function converttoupper($val, $key, $vars) {
|
29
|
$vars[0][$key] = strtoupper($key);
|
30
|
$vars[1][$vars[0][$key]] = ($val);
|
31
|
}
|
32
|
|
33
|
// create backlinks
|
34
|
$js_back = ADMIN_URL.'/admintools/tool.php?tool=SecureFormSwitcher';
|
35
|
$backlink = ADMIN_URL.'/admintools/index.php';
|
36
|
$FileNotFound = ' ';
|
37
|
// defaults settings
|
38
|
$default_cfg = array(
|
39
|
'secure_form_module' => '',
|
40
|
'wb_secform_secret' => '5609bnefg93jmgi99igjefg',
|
41
|
'wb_secform_secrettime' => '86400',
|
42
|
'wb_secform_timeout' => '7200',
|
43
|
'wb_secform_tokenname' => 'formtoken',
|
44
|
'wb_secform_usefp' => 'true',
|
45
|
'fingerprint_with_ip_octets' => '2',
|
46
|
);
|
47
|
$setting = $default_cfg;
|
48
|
$MultitabTarget = WB_PATH.'/framework/SecureForm.mtab.php';
|
49
|
// get stored settings to set in mask
|
50
|
$sql = 'SELECT * FROM `'.TABLE_PREFIX.'settings` ';
|
51
|
$sql .= 'WHERE `name` = \'secure_form_module\'';
|
52
|
$sql .= 'OR `name`=\'fingerprint_with_ip_octets\' ';
|
53
|
$sql .= 'OR `name`=\'wb_secform_usefp\' ';
|
54
|
$sql .= 'OR `name`=\'wb_secform_tokenname\' ';
|
55
|
$sql .= 'OR `name`=\'wb_secform_timeout\' ';
|
56
|
$sql .= 'OR `name`=\'wb_secform_secrettime\' ';
|
57
|
$sql .= 'OR `name`=\'wb_secform_secret\' ';
|
58
|
if($res = $database->query($sql) ) {
|
59
|
if($res->numRows() > 0) {
|
60
|
while($rec = $res->fetchRow(MYSQL_ASSOC)) {
|
61
|
$setting[$rec['name']] = $rec['value'];
|
62
|
}
|
63
|
} else {
|
64
|
// add missing values
|
65
|
db_update_key_value('settings', $setting );
|
66
|
}
|
67
|
}
|
68
|
|
69
|
$action = 'show';
|
70
|
$action = isset($_POST['save_settings']) ? 'save_settings' : $action;
|
71
|
$action = isset($_POST['save_settings_default']) ? 'save_settings_default' : $action;
|
72
|
|
73
|
switch ($action) :
|
74
|
case 'save_settings':
|
75
|
$cfg = array(
|
76
|
'secure_form_module' => (isset($_POST['ftan_switch']) ? $_POST['ftan_switch'] : 'mtab'),
|
77
|
'wb_secform_secret' => (isset($_POST['wb_secform_secret']) ? $_POST['wb_secform_secret'] : $setting['wb_secform_secret'] ),
|
78
|
'wb_secform_secrettime' => (isset($_POST['wb_secform_secrettime']) ? $_POST['wb_secform_secrettime'] : $setting['wb_secform_secrettime'] ),
|
79
|
'wb_secform_timeout' => (isset($_POST['wb_secform_timeout']) ? $_POST['wb_secform_timeout'] : $setting['wb_secform_timeout'] ),
|
80
|
'wb_secform_tokenname' => (isset($_POST['wb_secform_tokenname']) ? $_POST['wb_secform_tokenname'] : $setting['wb_secform_tokenname'] ),
|
81
|
'wb_secform_usefp' => (isset($_POST['wb_secform_usefp']) ? $_POST['wb_secform_usefp'] : $setting['wb_secform_usefp'] ),
|
82
|
'fingerprint_with_ip_octets' => (isset($_POST['fingerprint_with_ip_octets']) ? $_POST['fingerprint_with_ip_octets'] : $setting['fingerprint_with_ip_octets'] ),
|
83
|
);
|
84
|
// unset($_POST);
|
85
|
$_SESSION['CFG'] = $cfg;
|
86
|
break;
|
87
|
case 'save_settings_default':
|
88
|
$cfg = $default_cfg;
|
89
|
$cfg['secure_form_module'] = $setting['secure_form_module'];
|
90
|
break;
|
91
|
endswitch;
|
92
|
|
93
|
|
94
|
switch ($action) :
|
95
|
case 'save_settings':
|
96
|
case 'save_settings_default':
|
97
|
if (!$admin->checkFTAN())
|
98
|
{
|
99
|
if(!$admin_header) { $admin->print_header(); }
|
100
|
$admin->print_error($MESSAGE['GENERIC_SECURITY_ACCESS'],$_SERVER['REQUEST_URI']);
|
101
|
}
|
102
|
if(file_exists($MultitabTarget)) {
|
103
|
$val = ( isset($_POST['ftan_switch']) ? ($_POST['ftan_switch']) : 'mtab');
|
104
|
} else {
|
105
|
$cfg['secure_form_module'] = '';
|
106
|
$FileNotFound = $SFS_TEXT['FILE_FORMTAB_NOT_GOUND'];
|
107
|
}
|
108
|
|
109
|
db_update_key_value('settings', $cfg );
|
110
|
// check if there is a database error, otherwise say successful
|
111
|
if(!$admin_header) { $admin->print_header(); }
|
112
|
if($database->is_error()) {
|
113
|
$admin->print_error($database->get_error(), $js_back);
|
114
|
} else {
|
115
|
if(isset($_SESSION['CFG'])) { unset($_SESSION['CFG']);}
|
116
|
$admin->print_success($MESSAGE['PAGES_SAVED'], $js_back);
|
117
|
}
|
118
|
break;
|
119
|
endswitch;
|
120
|
|
121
|
// set template file and assign module and template block
|
122
|
$tpl = new Template(WB_PATH.'/modules/SecureFormSwitcher/htt','keep');
|
123
|
$tpl->set_file('page', 'switchform.htt');
|
124
|
$tpl->debug = false; // false, true
|
125
|
$tpl->set_block('page', 'main_block', 'main');
|
126
|
|
127
|
$checked = ($setting['secure_form_module']!='');
|
128
|
|
129
|
$ftanMode = ($checked ? $SFS_TEXT['SECURE_FORM'] : $SFS_TEXT['SECURE_FORMMTAB']);
|
130
|
$target = ($checked) ? '.'.$setting['secure_form_module'] : '';
|
131
|
$target = WB_PATH.'/framework/SecureForm'.$target.'.php';
|
132
|
|
133
|
$SingleTabStatus = intval($checked==false);
|
134
|
$MultitabStatus = intval($checked==true);
|
135
|
$NotFoundClass = '';
|
136
|
if(!file_exists($MultitabTarget)) {
|
137
|
$SingleTabStatus = true;
|
138
|
$MultitabStatus = false;
|
139
|
$FileNotFound = $SFS_TEXT['FILE_FORMTAB_NOT_GOUND'];
|
140
|
$NotFoundClass = 'class="warning"';
|
141
|
} else {
|
142
|
}
|
143
|
|
144
|
// convert settings name to upper
|
145
|
array_walk($setting,'converttoupper', array(&$search, &$replace ));
|
146
|
|
147
|
$tpl->set_var($replace);
|
148
|
$tpl->set_var(array(
|
149
|
'FTAN' => $admin->getFTAN(),
|
150
|
'SERVER_REQUEST_URI' => $_SERVER['REQUEST_URI'],
|
151
|
'TEXT_CANCEL' => $TEXT['CANCEL'],
|
152
|
'BACKLINK' => (isset($_POST['cancel'])) ? $backlink : '#',
|
153
|
'TEXT_INFO' => $SFS_TEXT['INFO'],
|
154
|
'TEXT_SUBMIT' => $SFS_TEXT['SUBMIT'],
|
155
|
'TEXT_MSUBMIT' => $SFS_TEXT['RESET_SETTINGS'],
|
156
|
'TXT_HEADING' => $SFS_TEXT['SECURE_FORM'.strtoupper($setting['secure_form_module'])],
|
157
|
'SELECTED' => ( ($SingleTabStatus) ? ' checked="checked"' : ''),
|
158
|
'SELECTED_TAB' => ( ($MultitabStatus) ? ' checked="checked"' : ''),
|
159
|
'SUBMIT_TYPE' => ($checked ? 'multitab' : 'singletab'),
|
160
|
'MSELECTED' => '',
|
161
|
'MSELECTED_TAB' => '',
|
162
|
'FTAN_COLOR' => ($checked ? 'grey' : 'norm'),
|
163
|
'TXT_SUBMIT_FORM' => $SFS_TEXT['SUBMIT_FORM'],
|
164
|
'TXT_SUBMIT_FORMTAB' => $SFS_TEXT['SUBMIT_FORMTAB'],
|
165
|
'FILE_FORMTAB_WARNING' => $NotFoundClass,
|
166
|
'FILE_FORMTAB_NOT_GOUND' => $FileNotFound,
|
167
|
)
|
168
|
);
|
169
|
|
170
|
$tpl->set_var(array(
|
171
|
'USEIP_SELECTED' => '',
|
172
|
'TXT_SECFORM_USEIP' => $SFS_TEXT['WB_SECFORM_USEIP'],
|
173
|
'TXT_SECFORM_USEIP_TOOLTIP' => $SFS_TEXT['WB_SECFORM_USEIP_TOOLTIP'], // Tooltip
|
174
|
'TEXT_DEFAULT_SETTINGS' => $HEADING['DEFAULT_SETTINGS'],
|
175
|
'USEIP_DEFAULT' => $default_cfg['fingerprint_with_ip_octets'],
|
176
|
'USEFP_CHECKED_TRUE' => (($setting['wb_secform_usefp']=='true') ? ' checked="checked"' : ''),
|
177
|
'USEFP_CHECKED_FALSE' => (($setting['wb_secform_usefp']=='false') ? ' checked="checked"' : ''),
|
178
|
'TEXT_DEFAULT_SETTINGS' => $HEADING['DEFAULT_SETTINGS'],
|
179
|
)
|
180
|
);
|
181
|
|
182
|
$tpl->set_block('main_block', 'useip_mtab_loop', 'mtab_loop');
|
183
|
for($x=0; $x < 5; $x++) {
|
184
|
// iu value == default set first option with standardtext
|
185
|
if(intval($default_cfg['fingerprint_with_ip_octets'])==$x ) {
|
186
|
$tpl->set_var(array(
|
187
|
'USEIP_VALUE' => $x,
|
188
|
'USEIP_DEFAULT_SELECTED' => ((intval($setting['fingerprint_with_ip_octets'])==$x) ? ' selected="selected"' : ''),
|
189
|
'USEIP_SELECTED' => '',
|
190
|
)
|
191
|
);
|
192
|
} else {
|
193
|
$tpl->set_var(array(
|
194
|
'USEIP_VALUE' => $x,
|
195
|
'USEIP_SELECTED' => ((intval($setting['fingerprint_with_ip_octets'])==$x) && (intval($setting['fingerprint_with_ip_octets'])!=intval($default_cfg['fingerprint_with_ip_octets'])) ? ' selected="selected"' : ''),
|
196
|
)
|
197
|
);
|
198
|
}
|
199
|
$tpl->parse('mtab_loop','useip_mtab_loop', true);
|
200
|
}
|
201
|
|
202
|
$tpl->set_block('main_block', 'show_mtab_block', 'show_mtab');
|
203
|
$tpl->set_block('main_block', 'mtab_block', 'mtab');
|
204
|
if($checked) {
|
205
|
$tpl->set_var(array(
|
206
|
'TEXT_ENABLED' => $SFS_TEXT['ON_OFF'],
|
207
|
'TXT_SECFORM_TOKENNAME' => $SFS_TEXT['WB_SECFORM_TOKENNAME'],
|
208
|
'TXT_SECFORM_TOKENNAME_TOOLTIP' => $SFS_TEXT['WB_SECFORM_TOKENNAME_TOOLTIP'],
|
209
|
'TXT_SECFORM_TIMEOUT' => $SFS_TEXT['WB_SECFORM_TIMEOUT'],
|
210
|
'TXT_SECFORM_TIMEOUT_TOOLTIP' => $SFS_TEXT['WB_SECFORM_TIMEOUT_TOOLTIP'],
|
211
|
'TXT_SECFORM_SECRETTIME' => $SFS_TEXT['WB_SECFORM_SECRETTIME'],
|
212
|
'TXT_SECFORM_SECRETTIME_TOOLTIP' => $SFS_TEXT['WB_SECFORM_SECRETTIME_TOOLTIP'],
|
213
|
'TXT_SECFORM_SECRET' => $SFS_TEXT['WB_SECFORM_SECRET'],
|
214
|
'TXT_SECFORM_SECRET_TOOLTIP' => $SFS_TEXT['WB_SECFORM_SECRET_TOOLTIP'],
|
215
|
'TXT_SECFORM_USEFP' => $SFS_TEXT['WB_SECFORM_USEFP'],
|
216
|
'SECFORM_USEFP' => 'true',
|
217
|
'TXT_SECFORM_USEFP_TOOLTIP' => $SFS_TEXT['WB_SECFORM_USEFP_TOOLTIP'],
|
218
|
)
|
219
|
);
|
220
|
$tpl->parse('mtab','mtab_block', true);
|
221
|
$tpl->parse('show_mtab','show_mtab_block', true);
|
222
|
} else {
|
223
|
$tpl->parse('mtab', '');
|
224
|
$tpl->parse('show_mtab', '');
|
225
|
}
|
226
|
|
227
|
// Parse template object
|
228
|
$tpl->parse('main', 'main_block', false);
|
229
|
$output = $tpl->finish($tpl->parse('output', 'page'));
|
230
|
unset($tpl);
|
231
|
print $output;
|
232
|
|