Revision 1479
Added by Luisehahne over 13 years ago
branches/2.8.x/CHANGELOG | ||
---|---|---|
11 | 11 |
! = Update/Change |
12 | 12 |
|
13 | 13 |
------------------------------------- 2.8.2 ------------------------------------ |
14 |
22 Jul-2011 Build 1477 Dietmar Woellbrink (Luisehahne) |
|
14 |
25 Jul-2011 Build 1479 Dietmar Woellbrink (Luisehahne) |
|
15 |
! preparing backend for the new installer |
|
16 |
+ add SecureFormSwitcher (Admintool) |
|
17 |
22 Jul-2011 Build 1478 Dietmar Woellbrink (Luisehahne) |
|
15 | 18 |
# fix mssing filename in intro.php |
16 | 19 |
! inactive user in dropwonlist are show with line-through |
17 | 20 |
21 Jul-2011 Build 1477 Dietmar Woellbrink (Luisehahne) |
branches/2.8.x/wb/admin/start/index.php | ||
---|---|---|
19 | 19 |
require('../../config.php'); |
20 | 20 |
require_once(WB_PATH.'/framework/class.admin.php'); |
21 | 21 |
$admin = new admin('Start','start'); |
22 |
|
|
22 |
// --------------------------------------- |
|
23 |
if(defined('FINALIZE_SETUP')) { |
|
24 |
require_once(WB_PATH.'/framework/functions.php'); |
|
25 |
$dirs = array( 'modules' => WB_PATH.'/modules/', |
|
26 |
'templates' => WB_PATH.'/templates/', |
|
27 |
'languages' => WB_PATH.'/languages/' |
|
28 |
); |
|
29 |
foreach($dirs AS $type => $dir) { |
|
30 |
if( ($handle = opendir($dir)) ) { |
|
31 |
while(false !== ($file = readdir($handle))) { |
|
32 |
if($file != '' AND substr($file, 0, 1) != '.' AND $file != 'admin.php' AND $file != 'index.php') { |
|
33 |
// Get addon type |
|
34 |
if($type == 'modules') { |
|
35 |
load_module($dir.'/'.$file, true); |
|
36 |
// Pretty ugly hack to let modules run $admin->set_error |
|
37 |
// See dummy class definition admin_dummy above |
|
38 |
if(isset($admin->error) && $admin->error != '') { |
|
39 |
$admin->print_error($admin->error); |
|
40 |
} |
|
41 |
} elseif($type == 'templates') { |
|
42 |
load_template($dir.'/'.$file); |
|
43 |
} elseif($type == 'languages') { |
|
44 |
load_language($dir.'/'.$file); |
|
45 |
} |
|
46 |
} |
|
47 |
} |
|
48 |
closedir($handle); |
|
49 |
} |
|
50 |
} |
|
51 |
$sql = 'DELETE FROM `'.TABLE_PREFIX.'settings` WHERE `name`=\'FINALIZE_SETUP\''; |
|
52 |
$database->query($sql); |
|
53 |
} |
|
54 |
// --------------------------------------- |
|
23 | 55 |
// Setup template object |
24 | 56 |
$template = new Template(THEME_PATH.'/templates'); |
25 | 57 |
$template->set_file('page', 'start.htt'); |
branches/2.8.x/wb/admin/interface/version.php | ||
---|---|---|
52 | 52 |
|
53 | 53 |
// check if defined to avoid errors during installation (redirect to admin panel fails if PHP error/warnings are enabled) |
54 | 54 |
if(!defined('VERSION')) define('VERSION', '2.8.2.RC7'); |
55 |
if(!defined('REVISION')) define('REVISION', '1478'); |
|
55 |
if(!defined('REVISION')) define('REVISION', '1479'); |
branches/2.8.x/wb/modules/SecureFormSwitcher/htt/switchform.htt | ||
---|---|---|
1 |
<!-- BEGIN main_block --> |
|
2 |
<script language="JavaScript" type="text/javascript"> |
|
3 |
/*<![CDATA[*/ |
|
4 |
if('{BACKLINK}'!=false) { |
|
5 |
redirect_to_page ('{BACKLINK}', 0); |
|
6 |
} |
|
7 |
/*]]>*/ |
|
8 |
</script> |
|
9 |
<table class="switch-ftan-info" summary="" cellpadding="4" cellspacing="0" border="0"> |
|
10 |
<thead> |
|
11 |
<tr> |
|
12 |
<th colspan="3">Status: <span class="{FTAN_COLOR}">{TXT_HEADING}</span></th> |
|
13 |
</tr> |
|
14 |
</thead> |
|
15 |
<tbody> |
|
16 |
<tr> |
|
17 |
<td colspan="2" class="module-info"><p>{TEXT_INFO}</p></td> |
|
18 |
</tr> |
|
19 |
<tr> |
|
20 |
<td colspan="2"><p {FILE_FORMTAB_WARNING}>{FILE_FORMTAB_NOT_GOUND}</p></td> |
|
21 |
</tr> |
|
22 |
</tbody> |
|
23 |
</table> |
|
24 |
|
|
25 |
<form class="secure_switch" name="store_settings" action="{SERVER_REQUEST_URI}" method="post" > |
|
26 |
{FTAN} |
|
27 |
<input type="hidden" name="{SUBMIT_TYPE}" value="true" /> |
|
28 |
<div class="left-content"> |
|
29 |
<table class="switch-ftan-form" summary="" cellpadding="4" cellspacing="0" border="0"> |
|
30 |
<tbody> |
|
31 |
<tr> |
|
32 |
<td width="20"><input type="radio" name="ftan_switch" id="ftan_switch" value=""{SELECTED}/></td> |
|
33 |
<td><label for="ftan_switch">{TXT_SUBMIT_FORM}</label></td> |
|
34 |
</tr> |
|
35 |
<tr> |
|
36 |
<td width="20"><input type="radio" name="ftan_switch" id="ftan_switch_tab" value="mtab"{SELECTED_TAB}/></td> |
|
37 |
<td><label for="ftan_switch_tab">{TXT_SUBMIT_FORMTAB}</label></td> |
|
38 |
</tr> |
|
39 |
<tr> |
|
40 |
<td colspan="2"> </td> |
|
41 |
</tr> |
|
42 |
<!-- BEGIN show_mtab_block --> |
|
43 |
<tr> |
|
44 |
<td colspan="2"> </td> |
|
45 |
</tr> |
|
46 |
<tr> |
|
47 |
<td colspan="2"> </td> |
|
48 |
</tr> |
|
49 |
<tr> |
|
50 |
<td colspan="2"> </td> |
|
51 |
</tr> |
|
52 |
<tr> |
|
53 |
<td colspan="2"> </td> |
|
54 |
</tr> |
|
55 |
<tr> |
|
56 |
<td colspan="2"> </td> |
|
57 |
</tr> |
|
58 |
<!-- END show_mtab_block --> |
|
59 |
<tr> |
|
60 |
<td colspan="2"> |
|
61 |
<input type="submit" name="save_settings" value="{TEXT_SUBMIT}" /> |
|
62 |
<input type="submit" name="cancel" value="{TEXT_CANCEL}" /> |
|
63 |
</td> |
|
64 |
</tr> |
|
65 |
</tbody> |
|
66 |
</table> |
|
67 |
</div> |
|
68 |
<div class="right-content"> |
|
69 |
<table class="switch-ftan-form" summary="" cellpadding="4" cellspacing="0" border="0"> |
|
70 |
<tbody> |
|
71 |
<tr> |
|
72 |
<td colspan="2"> |
|
73 |
<select name="fingerprint_with_ip_octets"> |
|
74 |
<option value="{USEIP_DEFAULT}"{USEIP_DEFAULT_SELECTED}>{TEXT_DEFAULT_SETTINGS}</option> |
|
75 |
<!-- BEGIN useip_mtab_loop --> |
|
76 |
<option value="{USEIP_VALUE}"{USEIP_SELECTED}>{USEIP_VALUE}</option> |
|
77 |
<!-- END useip_mtab_loop --> |
|
78 |
</select> |
|
79 |
</td> |
|
80 |
<td><label for="fingerprint_with_ip_octets">{TXT_SECFORM_USEIP} |
|
81 |
<a class="tooltip" href="#">? {TXT_SECFORM_USEIP_TOOLTIP}</a> |
|
82 |
</label></td> |
|
83 |
</tr> |
|
84 |
<!-- BEGIN mtab_block --> |
|
85 |
<tr> |
|
86 |
<td colspan="2"><input type="text" name="wb_secform_tokenname" id="wb_secform_tokenname" value="{WB_SECFORM_TOKENNAME}"/></td> |
|
87 |
<td><label for="wb_secform_tokenname">{TXT_SECFORM_TOKENNAME} |
|
88 |
<a class="tooltip" href="#">? {TXT_SECFORM_TOKENNAME_TOOLTIP}</a> |
|
89 |
</label></td> |
|
90 |
</tr> |
|
91 |
<tr> |
|
92 |
<td colspan="2"><input type="text" name="wb_secform_secret" id="wb_secform_secret" value="{WB_SECFORM_SECRET}"/></td> |
|
93 |
<td><label for="wb_secform_secret">{TXT_SECFORM_SECRET} |
|
94 |
<a class="tooltip" href="#">? {TXT_SECFORM_SECRET_TOOLTIP}</a> |
|
95 |
</label></td> |
|
96 |
</tr> |
|
97 |
<tr> |
|
98 |
<td colspan="2"><input type="text" name="wb_secform_secrettime" id="wb_secform_secrettime" value="{WB_SECFORM_SECRETTIME}"/></td> |
|
99 |
<td><label for="wb_secform_secrettime">{TXT_SECFORM_SECRETTIME} |
|
100 |
<a class="tooltip" href="#">? {TXT_SECFORM_SECRETTIME_TOOLTIP}</a> |
|
101 |
</label></td> |
|
102 |
</tr> |
|
103 |
<tr> |
|
104 |
<td colspan="2"><input type="text" name="wb_secform_timeout" id="wb_secform_timeout" value="{WB_SECFORM_TIMEOUT}"/></td> |
|
105 |
<td><label for="wb_secform_timeout">{TXT_SECFORM_TIMEOUT} |
|
106 |
<a class="tooltip" href="#">? {TXT_SECFORM_TIMEOUT_TOOLTIP}</a> |
|
107 |
</label></td> |
|
108 |
</tr> |
|
109 |
<tr> |
|
110 |
<td> |
|
111 |
<label for="wb_secform_usefp_true">{TEXT_ENABLED}</label> |
|
112 |
</td> |
|
113 |
<td width="50"> |
|
114 |
<input type="radio" value="true" id="wb_secform_usefp_true" name="wb_secform_usefp"{USEFP_CHECKED_TRUE} /> |
|
115 |
<input type="radio" value="false" id="wb_secform_usefp_false" name="wb_secform_usefp"{USEFP_CHECKED_FALSE} /> |
|
116 |
</td> |
|
117 |
<td><label for="wb_secform_usefp">{TXT_SECFORM_USEFP} |
|
118 |
<a class="tooltip" href="#">? {TXT_SECFORM_USEFP_TOOLTIP}</a> |
|
119 |
</label></td> |
|
120 |
</tr> |
|
121 |
<tr> |
|
122 |
<td> </td> |
|
123 |
<td> </td> |
|
124 |
<td> </td> |
|
125 |
</tr> |
|
126 |
|
|
127 |
<tr> |
|
128 |
<td colspan="4"> </td> |
|
129 |
</tr> |
|
130 |
<tr> |
|
131 |
<td colspan="4"> |
|
132 |
<input type="submit" name="save_settings_default" value="{TEXT_MSUBMIT}" /> |
|
133 |
</td> |
|
134 |
</tr> |
|
135 |
<!-- END mtab_block --> |
|
136 |
</tbody> |
|
137 |
</table> |
|
138 |
</div> |
|
139 |
|
|
140 |
</form> |
|
141 |
<!-- END main_block --> |
branches/2.8.x/wb/modules/SecureFormSwitcher/uninstall.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
// Must include code to stop this file being access directly |
|
20 |
if(defined('WB_PATH') == false) { exit("Cannot access this file directly"); } |
|
21 |
|
|
22 |
require_once(WB_PATH.'/framework/class.database.php'); |
|
23 |
require_once(WB_PATH.'/framework/functions.php'); |
|
24 |
|
|
25 |
$sql = 'DELETE FROM `'.TABLE_PREFIX.'settings` '; |
|
26 |
$sql .= 'WHERE `name`=\'wb_secform_useip\' '; |
|
27 |
$sql .= 'OR `name`=\'wb_secform_usefp\' '; |
|
28 |
$sql .= 'OR `name`=\'wb_secform_tokenname\' '; |
|
29 |
$sql .= 'OR `name`=\'wb_secform_timeout\' '; |
|
30 |
$sql .= 'OR `name`=\'wb_secform_secrettime\' '; |
|
31 |
$sql .= 'OR `name`=\'wb_secform_secret\' '; |
|
32 |
$sql .= 'OR `name`=\'secure_form_module\' '; |
|
33 |
$database->query($sql); |
|
34 |
$dest_to_delete = WB_PATH.'/framework/SecureForm.mtab.php'; |
|
35 |
if(is_writeable(WB_PATH.'/framework') ) { |
|
36 |
@chmod($dest_to_delete, 0666); |
|
37 |
@unlink($dest_to_delete); |
|
38 |
} |
|
39 |
|
|
40 |
|
|
41 |
|
|
0 | 42 |
branches/2.8.x/wb/modules/SecureFormSwitcher/info.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
$module_directory = 'SecureFormSwitcher'; |
|
20 |
$module_name = 'SecureForm Switcher'; |
|
21 |
$module_function = 'tool'; |
|
22 |
$module_version = '0.6.6'; |
|
23 |
$module_platform = '2.8.2'; |
|
24 |
$module_author = 'D. Wöllbrrink (Luisehahne), Florian Meerwinck (instantflorian), Michael Tentschert (testör)'; |
|
25 |
$module_license = 'GNU General Public License'; |
|
26 |
$module_description = 'This module switch between the <strong>SingleTab SecureForm</strong> and <strong>MultiTab SecureForm</strong>.'; |
|
27 |
|
|
0 | 28 |
branches/2.8.x/wb/modules/SecureFormSwitcher/files/SecureForm.mtab.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category framework |
|
5 |
* @package SecureForm.mtab |
|
6 |
* @author WebsiteBaker Community Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* @description |
|
17 |
*/ |
|
18 |
## Heavy patched version, idea for patches based on : |
|
19 |
## http://stackoverflow.com/questions/2695153/php-csrf-how-to-make-it-works-in-all-tabs/2695291#2695291 |
|
20 |
## Whith this patch the token System now allows for multiple browser tabs but |
|
21 |
## denies the use of multiple browsers. |
|
22 |
## You can configure this class by adding several constants to your config.php |
|
23 |
## All Patches are Copyright Norbert Heimsath released under GPLv3 |
|
24 |
## http://www.gnu.org/licenses/gpl.html |
|
25 |
## Take a look at __construkt for configuration options(constants). |
|
26 |
## Patch version 0.3.5 |
|
27 |
|
|
28 |
/** |
|
29 |
* If you want some special configuration put this somewhere in your config.php for |
|
30 |
* example or just uncomment the lines here |
|
31 |
* |
|
32 |
* This parameter now can be set with the admintool SecureForm Switcher coded by Luisehahne, |
|
33 |
* pls ask for it in the forum |
|
34 |
* |
|
35 |
* Secret can contain anything its the base for the secret part for the hash |
|
36 |
* define ('WB_SECFORM_SECRET','whatever you like'); |
|
37 |
* after how many seconds a new secret is generated |
|
38 |
* define ('WB_SECFORM_SECRETTIME',86400); #aprox one day |
|
39 |
* shall we use fingerprinting true/false |
|
40 |
* define ('WB_SECFORM_USEFP', true); |
|
41 |
* Timeout till the form token times out. Integer value between 0-86400 seconds (one day) |
|
42 |
* define ('WB_SECFORM_TIMEOUT', 3600); |
|
43 |
* Name for the token form element only alphanumerical string allowed that starts whith a charakter |
|
44 |
* define ('WB_SECFORM_TOKENNAME','my3form3'); |
|
45 |
* how many blocks of the IP should be used in fingerprint 0=no ipcheck, possible values 0-4 |
|
46 |
* define ('FINGERPRINT_WITH_IP_OCTETS',2); |
|
47 |
*/ |
|
48 |
|
|
49 |
class SecureForm { |
|
50 |
|
|
51 |
const FRONTEND = 0; |
|
52 |
const BACKEND = 1; |
|
53 |
|
|
54 |
## additional private data |
|
55 |
private $_secret = '5609bnefg93jmgi99igjefg'; |
|
56 |
private $_secrettime = 86400; #Approx. one day |
|
57 |
private $_tokenname = 'formtoken'; |
|
58 |
private $_timeout = 7200; |
|
59 |
private $_useipblocks = 2; |
|
60 |
private $_usefingerprint = true; |
|
61 |
### additional private data |
|
62 |
|
|
63 |
private $_FTAN = ''; |
|
64 |
private $_IDKEYs = array('0'=>'0'); |
|
65 |
private $_idkey_name = ''; |
|
66 |
private $_salt = ''; |
|
67 |
private $_fingerprint = ''; |
|
68 |
private $_serverdata = ''; |
|
69 |
|
|
70 |
/* Construtor */ |
|
71 |
protected function __construct($mode = self::FRONTEND){ |
|
72 |
|
|
73 |
## additional constants and stuff for global configuration |
|
74 |
|
|
75 |
# Secret can contain anything its the base for the secret part of the hash |
|
76 |
if (defined ('WB_SECFORM_SECRET')){ |
|
77 |
$this->_secret=WB_SECFORM_SECRET; |
|
78 |
} |
|
79 |
|
|
80 |
# shall we use fingerprinting |
|
81 |
if (defined ('WB_SECFORM_USEFP') AND WB_SECFORM_USEFP===false){ |
|
82 |
$this->_usefingerprint = false; |
|
83 |
} |
|
84 |
|
|
85 |
# Timeout till the form token times out. Integer value between 0-86400 seconds (one day) |
|
86 |
if (defined ('WB_SECFORM_TIMEOUT') AND is_numeric(WB_SECFORM_TIMEOUT) AND intval(WB_SECFORM_TIMEOUT) >=0 AND intval(WB_SECFORM_TIMEOUT) <=86400 ){ |
|
87 |
$this->_timeout=intval(WB_SECFORM_TIMEOUT); |
|
88 |
} |
|
89 |
# Name for the token form element only alphanumerical string allowed that starts whith a charakter |
|
90 |
if (defined ('WB_SECFORM_TOKENNAME') AND !$this->_validate_alalnum(WB_SECFORM_TOKENNAME)){ |
|
91 |
$this->_tokenname=WB_SECFORM_TOKENNAME; |
|
92 |
} |
|
93 |
# how many bloks of the IP should be used 0=no ipcheck |
|
94 |
if (defined ('FINGERPRINT_WITH_IP_OCTETS') AND !$this->_is04(FINGERPRINT_WITH_IP_OCTETS)){ |
|
95 |
$this->_useipblocks=FINGERPRINT_WITH_IP_OCTETS; |
|
96 |
} |
|
97 |
## additional stuff end |
|
98 |
$this->_browser_fingerprint = $this->_browser_fingerprint(true); |
|
99 |
$this->_fingerprint = $this->_generate_fingerprint(); |
|
100 |
$this->_serverdata = $this->_generate_serverdata(); |
|
101 |
$this->_secret = $this->_generate_secret(); |
|
102 |
$this->_salt = $this->_generate_salt(); |
|
103 |
|
|
104 |
$this->_idkey_name = substr($this->_fingerprint, hexdec($this->_fingerprint[strlen($this->_fingerprint)-1]), 16); |
|
105 |
// make sure there is a alpha-letter at first position |
|
106 |
$this->_idkey_name[0] = dechex(10 + (hexdec($this->_idkey_name[0]) % 5)); |
|
107 |
// takeover id_keys from session if available |
|
108 |
if(isset($_SESSION[$this->_idkey_name]) && is_array($_SESSION[$this->_idkey_name])){ |
|
109 |
$this->_IDKEYs = $_SESSION[$this->_idkey_name]; |
|
110 |
}else{ |
|
111 |
$this->_IDKEYs = array('0'=>'0'); |
|
112 |
$_SESSION[$this->_idkey_name] = $this->_IDKEYs; |
|
113 |
} |
|
114 |
} |
|
115 |
|
|
116 |
private function _generate_secret(){ |
|
117 |
|
|
118 |
$secret= $this->_secret; |
|
119 |
$secrettime= $this->_secrettime; |
|
120 |
#create a different secret every day |
|
121 |
$TimeSeed= floor(time()/$secrettime)*$secrettime; #round(floor) time() to whole days |
|
122 |
$DomainSeed = $_SERVER['SERVER_NAME']; # generate a numerical from server name. |
|
123 |
$Seed = $TimeSeed+$DomainSeed; |
|
124 |
$secret .=md5($Seed); # |
|
125 |
|
|
126 |
$secret .= $this->_secret.$this->_serverdata.session_id(); |
|
127 |
if ($this->_usefingerprint){$secret.= $this->_browser_fingerprint;} |
|
128 |
|
|
129 |
return $secret; |
|
130 |
} |
|
131 |
|
|
132 |
|
|
133 |
|
|
134 |
private function _generate_salt() |
|
135 |
{ |
|
136 |
if(function_exists('microtime')) |
|
137 |
{ |
|
138 |
list($usec, $sec) = explode(" ", microtime()); |
|
139 |
$salt = (string)((float)$usec + (float)$sec); |
|
140 |
}else{ |
|
141 |
$salt = (string)time(); |
|
142 |
} |
|
143 |
$salt = (string)rand(10000, 99999) . $salt . (string)rand(10000, 99999); |
|
144 |
return md5($salt); |
|
145 |
} |
|
146 |
|
|
147 |
private function _generate_fingerprint() |
|
148 |
{ |
|
149 |
// server depending values |
|
150 |
$fingerprint = $this->_generate_serverdata(); |
|
151 |
|
|
152 |
// client depending values |
|
153 |
$fingerprint .= ( isset($_SERVER['HTTP_USER_AGENT']) ) ? $_SERVER['HTTP_USER_AGENT'] : '17'; |
|
154 |
$usedOctets = ( defined('FINGERPRINT_WITH_IP_OCTETS') ) ? intval(defined('FINGERPRINT_WITH_IP_OCTETS')) : 0; |
|
155 |
$clientIp = ( isset($_SERVER['REMOTE_ADDR']) ? $_SERVER['REMOTE_ADDR'] : '' ); |
|
156 |
if(($clientIp != '') && ($usedOctets > 0)){ |
|
157 |
$ip = explode('.', $clientIp); |
|
158 |
while(sizeof($ip) > $usedOctets) { array_pop($ip); } |
|
159 |
$clientIp = implode('.', $ip); |
|
160 |
}else { |
|
161 |
$clientIp = 19; |
|
162 |
} |
|
163 |
$fingerprint .= $clientIp; |
|
164 |
return md5($fingerprint); |
|
165 |
} |
|
166 |
|
|
167 |
private function _generate_serverdata(){ |
|
168 |
|
|
169 |
$serverdata = ( isset($_SERVER['SERVER_SIGNATURE']) ) ? $_SERVER['SERVER_SIGNATURE'] : '2'; |
|
170 |
$serverdata .= ( isset($_SERVER['SERVER_SOFTWARE']) ) ? $_SERVER['SERVER_SOFTWARE'] : '3'; |
|
171 |
$serverdata .= ( isset($_SERVER['SERVER_NAME']) ) ? $_SERVER['SERVER_NAME'] : '5'; |
|
172 |
$serverdata .= ( isset($_SERVER['SERVER_ADDR']) ) ? $_SERVER['SERVER_ADDR'] : '7'; |
|
173 |
$serverdata .= ( isset($_SERVER['SERVER_PORT']) ) ? $_SERVER['SERVER_PORT'] : '11'; |
|
174 |
$serverdata .= ( isset($_SERVER['SERVER_ADMIN']) ) ? $_SERVER['SERVER_ADMIN'] : '13'; |
|
175 |
$serverdata .= PHP_VERSION; |
|
176 |
return $serverdata; |
|
177 |
} |
|
178 |
|
|
179 |
// fake funktion , just exits to avoid error message |
|
180 |
final protected function createFTAN(){} |
|
181 |
|
|
182 |
/* |
|
183 |
* creates selfsigning Formular transactionnumbers for unique use |
|
184 |
* @access public |
|
185 |
* @param bool $asTAG: true returns a complete prepared, hidden HTML-Input-Tag (default) |
|
186 |
* false returns an GET argument 'key=value' |
|
187 |
* @return mixed: string |
|
188 |
* |
|
189 |
* requirements: an active session must not be available but it makes no sense whithout :-) |
|
190 |
*/ |
|
191 |
final public function getFTAN( $as_tag = true) |
|
192 |
{ |
|
193 |
$secret= $this->_secret; |
|
194 |
|
|
195 |
$timeout= time()+$this->_timeout; |
|
196 |
|
|
197 |
#mt_srand(hexdec(crc32(microtime())); |
|
198 |
$token= dechex(mt_rand()); |
|
199 |
|
|
200 |
$hash= sha1($secret.'-'.$token.'-'.$timeout); |
|
201 |
$signed= $token.'-'.$timeout.'-'.$hash; |
|
202 |
|
|
203 |
if($as_tag == true) |
|
204 |
{ // by default return a complete, hidden <input>-tag |
|
205 |
return '<input type="hidden" name="'.$this->_tokenname.'" value="'.htmlspecialchars($signed).'" title="" alt="" />'; |
|
206 |
}else{ // return an array with raw tokenname=value |
|
207 |
return $this->_tokenname.'='.$signed; |
|
208 |
} |
|
209 |
} |
|
210 |
|
|
211 |
/* |
|
212 |
* checks received form-transactionnumbers against itself |
|
213 |
* @access public |
|
214 |
* @param string $mode: requestmethode POST(default) or GET |
|
215 |
* @return bool: true if numbers matches against stored ones |
|
216 |
* |
|
217 |
* requirements: no active session must be available but it makes no sense whithout. |
|
218 |
* this check will prevent from multiple sending a form. history.back() also will never work |
|
219 |
*/ |
|
220 |
final public function checkFTAN( $mode = 'POST') |
|
221 |
{ |
|
222 |
$mode = (strtoupper($mode) != 'POST' ? '_GET' : '_POST'); |
|
223 |
|
|
224 |
$isok= false; |
|
225 |
$secret= $this->_secret; |
|
226 |
|
|
227 |
if (isset($GLOBALS[$mode][$this->_tokenname])) {$latoken=$GLOBALS[$mode][$this->_tokenname];} |
|
228 |
else {return $isok;} |
|
229 |
|
|
230 |
$parts= explode('-', $latoken); |
|
231 |
if (count($parts)==3) { |
|
232 |
list($token,$timeout, $hash)= $parts; |
|
233 |
if ($hash==sha1($secret.'-'.$token.'-'.$timeout) AND $timeout > time()) |
|
234 |
{$isok= true;} |
|
235 |
} |
|
236 |
|
|
237 |
return $isok; |
|
238 |
} |
|
239 |
|
|
240 |
/* |
|
241 |
* save values in session and returns a ID-key |
|
242 |
* @access public |
|
243 |
* @param mixed $value: the value for witch a key shall be generated and memorized |
|
244 |
* @return string: a MD5-Key to use instead of the real value |
|
245 |
* |
|
246 |
* @requirements: an active session must be available |
|
247 |
* @description: IDKEY can handle string/numeric/array - vars. Each key is a |
|
248 |
*/ |
|
249 |
final public function getIDKEY($value) |
|
250 |
{ |
|
251 |
if( is_array($value) == true ) |
|
252 |
{ // serialize value, if it's an array |
|
253 |
$value = serialize($value); |
|
254 |
} |
|
255 |
// crypt value with salt into md5-hash |
|
256 |
// and return a 16-digit block from random start position |
|
257 |
$key = substr( md5($this->_salt.(string)$value), rand(0,15), 16); |
|
258 |
do{ // loop while key/value isn't added |
|
259 |
if( !array_key_exists($key, $this->_IDKEYs) ) |
|
260 |
{ // the key is unique, so store it in list |
|
261 |
$this->_IDKEYs[$key] = $value; |
|
262 |
break; |
|
263 |
}else { |
|
264 |
// if key already exist, increment the last five digits until the key is unique |
|
265 |
$key = substr($key, 0, -5).dechex(('0x'.substr($key, -5)) + 1); |
|
266 |
} |
|
267 |
}while(0); |
|
268 |
// store key/value-pairs into session |
|
269 |
$_SESSION[$this->_idkey_name] = $this->_IDKEYs; |
|
270 |
return $key; |
|
271 |
} |
|
272 |
|
|
273 |
/* |
|
274 |
* search for key in session and returns the original value |
|
275 |
* @access public |
|
276 |
* @param string $fieldname: name of the POST/GET-Field containing the key or hex-key itself |
|
277 |
* @param mixed $default: returnvalue if key not exist (default 0) |
|
278 |
* @param string $request: requestmethode can be POST or GET or '' (default POST) |
|
279 |
* @return mixed: the original value (string, numeric, array) or DEFAULT if request fails |
|
280 |
* |
|
281 |
* @requirements: an active session must be available |
|
282 |
* @description: each IDKEY can be checked only once. Unused Keys stay in list until the |
|
283 |
* session is destroyed. |
|
284 |
*/ |
|
285 |
final public function checkIDKEY( $fieldname, $default = 0, $request = 'POST' ) |
|
286 |
{ |
|
287 |
$return_value = $default; // set returnvalue to default |
|
288 |
switch( strtoupper($request) ) |
|
289 |
{ |
|
290 |
case 'POST': |
|
291 |
$key = isset($_POST[$fieldname]) ? $_POST[$fieldname] : $fieldname; |
|
292 |
break; |
|
293 |
case 'GET': |
|
294 |
$key = isset($_GET[$fieldname]) ? $_GET[$fieldname] : $fieldname; |
|
295 |
break; |
|
296 |
default: |
|
297 |
$key = $fieldname; |
|
298 |
} |
|
299 |
if( preg_match('/[0-9a-f]{16}$/', $key) ) |
|
300 |
{ // key must be a 16-digit hexvalue |
|
301 |
if( array_key_exists($key, $this->_IDKEYs)) |
|
302 |
{ // check if key is stored in IDKEYs-list |
|
303 |
$return_value = $this->_IDKEYs[$key]; // get stored value |
|
304 |
unset($this->_IDKEYs[$key]); // remove from list to prevent multiuse |
|
305 |
$_SESSION[$this->_idkey_name] = $this->_IDKEYs; // save modified list into session again |
|
306 |
if( preg_match('/.*(?<!\{).*(\d:\{.*;\}).*(?!\}).*/', $return_value) ) |
|
307 |
{ // if value is a serialized array, then deserialize it |
|
308 |
$return_value = unserialize($return_value); |
|
309 |
} |
|
310 |
} |
|
311 |
} |
|
312 |
return $return_value; |
|
313 |
} |
|
314 |
|
|
315 |
/* @access public |
|
316 |
* @return void |
|
317 |
* |
|
318 |
* @requirements: an active session must be available |
|
319 |
* @description: remove all entries from IDKEY-Array |
|
320 |
* |
|
321 |
*/ |
|
322 |
final public function clearIDKEY() |
|
323 |
{ |
|
324 |
$this->_IDKEYs = array('0'=>'0'); |
|
325 |
} |
|
326 |
|
|
327 |
|
|
328 |
## additional Functions needed cause the original ones lack some functionality |
|
329 |
## all are Copyright Norbert Heimsath, heimsath.org |
|
330 |
## released under GPLv3 http://www.gnu.org/licenses/gpl.html |
|
331 |
|
|
332 |
/* Made because ctype_ gives strange results using mb Strings*/ |
|
333 |
private function _validate_alalnum($input){ |
|
334 |
# alphanumerical string that starts whith a letter charakter |
|
335 |
if (preg_match('/^[a-zA-Z][0-9a-zA-Z]+$/u', $input)) |
|
336 |
{return false;} |
|
337 |
|
|
338 |
return "The given input is not an alphanumeric string."; |
|
339 |
} |
|
340 |
|
|
341 |
private function _is04($input){ |
|
342 |
# integer value between 0-4 |
|
343 |
if (preg_match('/^[0-4]$/', $input)) {return false;} |
|
344 |
|
|
345 |
return "The given input is not an alphanumeric string."; |
|
346 |
} |
|
347 |
|
|
348 |
|
|
349 |
private function _getip($ipblocks=4){ |
|
350 |
/* |
|
351 |
Just a function to get User ip even if hes behind a proxy |
|
352 |
*/ |
|
353 |
$ip = ""; //Ip address result |
|
354 |
$cutip = ""; //Ip address cut to limit |
|
355 |
|
|
356 |
# mabe user is behind a Proxy but we need his real ip address if we got a nice Proxyserver, |
|
357 |
# it sends us the "HTTP_X_FORWARDED_FOR" Header. Sometimes there is more than one Proxy. |
|
358 |
# !!!!!! THIS PART WAS NEVER TESTED BECAUSE I ONLY GOT A DIRECT INTERNET CONNECTION !!!!!! |
|
359 |
# long2ip(ip2long($lastip)) makes sure we got nothing else than an ip into our script ;-) |
|
360 |
# !!!!! WARNING the 'HTTP_X_FORWARDED_FOR' Part is NOT TESTED !!!!! |
|
361 |
if (isset($_SERVER['HTTP_X_FORWARDED_FOR']) AND !empty($_SERVER['HTTP_X_FORWARDED_FOR'])) |
|
362 |
{ |
|
363 |
$iplist= explode(',',$_SERVER['HTTP_X_FORWARDED_FOR']); |
|
364 |
$lastip = array_pop($iplist); |
|
365 |
$ip.= long2ip(ip2long($lastip)); |
|
366 |
} |
|
367 |
|
|
368 |
/* If theres no other supported info we just use REMOTE_ADDR |
|
369 |
If we have a fiendly proxy supporting HTTP_X_FORWARDED_FOR its ok to use the full address. |
|
370 |
But if there is no HTTP_X_FORWARDED_FOR we can not be sure if its a proxy or whatever, so we use the |
|
371 |
blocklimit for IP address. |
|
372 |
*/ |
|
373 |
else |
|
374 |
{ |
|
375 |
$ip = long2ip(ip2long($_SERVER['REMOTE_ADDR'])); |
|
376 |
|
|
377 |
# ipblocks used here defines how many blocks of the ip adress are checked xxx.xxx.xxx.xxx |
|
378 |
$blocks = explode('.', $ip); |
|
379 |
for ($i=0; $i<$ipblocks; $i++){ |
|
380 |
$cutip.= $blocks[$i] . '.'; |
|
381 |
} |
|
382 |
$ip=substr($cutip, 0, -1); |
|
383 |
} |
|
384 |
|
|
385 |
return $ip; |
|
386 |
} |
|
387 |
|
|
388 |
private function _browser_fingerprint($encode=true,$fpsalt="My Fingerprint: "){ |
|
389 |
/* |
|
390 |
Creates a basic Browser Fingerprint for securing the session and forms. |
|
391 |
*/ |
|
392 |
|
|
393 |
$fingerprint=$fpsalt; |
|
394 |
if (isset($_SERVER['HTTP_USER_AGENT'])){ $fingerprint .= $_SERVER['HTTP_USER_AGENT'];} |
|
395 |
if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])){ $fingerprint .= $_SERVER['HTTP_ACCEPT_LANGUAGE'];} |
|
396 |
if (isset($_SERVER['HTTP_ACCEPT_ENCODING'])){ $fingerprint .= $_SERVER['HTTP_ACCEPT_ENCODING'];} |
|
397 |
if (isset($_SERVER['HTTP_ACCEPT_CHARSET'])){ $fingerprint .= $_SERVER['HTTP_ACCEPT_CHARSET'];} |
|
398 |
|
|
399 |
$fingerprint.= $this->_getip($this->_useipblocks); |
|
400 |
|
|
401 |
if ($encode){$fingerprint=md5($fingerprint);} |
|
402 |
|
|
403 |
return $fingerprint; |
|
404 |
} |
|
405 |
## |
|
406 |
## additional Functions END |
|
407 |
## |
|
408 |
} |
|
0 | 409 |
branches/2.8.x/wb/modules/SecureFormSwitcher/tool.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright (C) 2011, D Woellbrink |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
// Must include code to stop this file being access directly |
|
20 |
if(defined('WB_PATH') == false) |
|
21 |
{ |
|
22 |
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>'); |
|
23 |
} |
|
24 |
|
|
25 |
// load module language file |
|
26 |
$mod_path = (dirname(__FILE__)); |
|
27 |
require_once( $mod_path.'/language_load.php' ); |
|
28 |
// callback function for settings name |
|
29 |
function converttoupper($val, $key, $vars) { |
|
30 |
$vars[0][$key] = strtoupper($key); |
|
31 |
$vars[1][$vars[0][$key]] = ($val); |
|
32 |
} |
|
33 |
|
|
34 |
// create backlinks |
|
35 |
$js_back = ADMIN_URL.'/admintools/tool.php?tool=SecureFormSwitcher'; |
|
36 |
$backlink = ADMIN_URL.'/admintools/index.php'; |
|
37 |
$FileNotFound = ' '; |
|
38 |
// defaults settings |
|
39 |
$default_cfg = array( |
|
40 |
'secure_form_module' => '', |
|
41 |
'wb_secform_secret' => '5609bnefg93jmgi99igjefg', |
|
42 |
'wb_secform_secrettime' => '86400', |
|
43 |
'wb_secform_timeout' => '7200', |
|
44 |
'wb_secform_tokenname' => 'formtoken', |
|
45 |
'wb_secform_usefp' => 'true', |
|
46 |
'fingerprint_with_ip_octets' => '2', |
|
47 |
); |
|
48 |
$setting = $default_cfg; |
|
49 |
$MultitabTarget = WB_PATH.'/framework/SecureForm.mtab.php'; |
|
50 |
// get stored settings to set in mask |
|
51 |
$sql = 'SELECT * FROM `'.TABLE_PREFIX.'settings` '; |
|
52 |
$sql .= 'WHERE `name` = \'secure_form_module\''; |
|
53 |
$sql .= 'OR `name`=\'fingerprint_with_ip_octets\' '; |
|
54 |
$sql .= 'OR `name`=\'wb_secform_usefp\' '; |
|
55 |
$sql .= 'OR `name`=\'wb_secform_tokenname\' '; |
|
56 |
$sql .= 'OR `name`=\'wb_secform_timeout\' '; |
|
57 |
$sql .= 'OR `name`=\'wb_secform_secrettime\' '; |
|
58 |
$sql .= 'OR `name`=\'wb_secform_secret\' '; |
|
59 |
if($res = $database->query($sql) ) { |
|
60 |
if($res->numRows() > 0) { |
|
61 |
while($rec = $res->fetchRow(MYSQL_ASSOC)) { |
|
62 |
$setting[$rec['name']] = $rec['value']; |
|
63 |
} |
|
64 |
} else { |
|
65 |
// add missing values |
|
66 |
db_update_key_value('settings', $setting ); |
|
67 |
} |
|
68 |
} |
|
69 |
|
|
70 |
$action = 'show'; |
|
71 |
$action = isset($_POST['save_settings']) ? 'save_settings' : $action; |
|
72 |
$action = isset($_POST['save_settings_default']) ? 'save_settings_default' : $action; |
|
73 |
|
|
74 |
switch ($action) : |
|
75 |
case 'save_settings': |
|
76 |
$cfg = array( |
|
77 |
'secure_form_module' => (isset($_POST['ftan_switch']) ? $_POST['ftan_switch'] : 'mtab'), |
|
78 |
'wb_secform_secret' => (isset($_POST['wb_secform_secret']) ? $_POST['wb_secform_secret'] : $setting['wb_secform_secret'] ), |
|
79 |
'wb_secform_secrettime' => (isset($_POST['wb_secform_secrettime']) ? $_POST['wb_secform_secrettime'] : $setting['wb_secform_secrettime'] ), |
|
80 |
'wb_secform_timeout' => (isset($_POST['wb_secform_timeout']) ? $_POST['wb_secform_timeout'] : $setting['wb_secform_timeout'] ), |
|
81 |
'wb_secform_tokenname' => (isset($_POST['wb_secform_tokenname']) ? $_POST['wb_secform_tokenname'] : $setting['wb_secform_tokenname'] ), |
|
82 |
'wb_secform_usefp' => (isset($_POST['wb_secform_usefp']) ? $_POST['wb_secform_usefp'] : $setting['wb_secform_usefp'] ), |
|
83 |
'fingerprint_with_ip_octets' => (isset($_POST['fingerprint_with_ip_octets']) ? $_POST['fingerprint_with_ip_octets'] : $setting['fingerprint_with_ip_octets'] ), |
|
84 |
); |
|
85 |
// unset($_POST); |
|
86 |
$_SESSION['CFG'] = $cfg; |
|
87 |
break; |
|
88 |
case 'save_settings_default': |
|
89 |
$cfg = $default_cfg; |
|
90 |
$cfg['secure_form_module'] = $setting['secure_form_module']; |
|
91 |
break; |
|
92 |
endswitch; |
|
93 |
|
|
94 |
|
|
95 |
switch ($action) : |
|
96 |
case 'save_settings': |
|
97 |
case 'save_settings_default': |
|
98 |
if (!$admin->checkFTAN()) |
|
99 |
{ |
|
100 |
if(!$admin_header) { $admin->print_header(); } |
|
101 |
$admin->print_error($MESSAGE['GENERIC_SECURITY_ACCESS'],$_SERVER['REQUEST_URI']); |
|
102 |
} |
|
103 |
if(file_exists($MultitabTarget)) { |
|
104 |
$val = ( isset($_POST['ftan_switch']) ? ($_POST['ftan_switch']) : 'mtab'); |
|
105 |
} else { |
|
106 |
$cfg['secure_form_module'] = ''; |
|
107 |
$FileNotFound = $SFS_TEXT['FILE_FORMTAB_NOT_GOUND']; |
|
108 |
} |
|
109 |
|
|
110 |
db_update_key_value('settings', $cfg ); |
|
111 |
// check if there is a database error, otherwise say successful |
|
112 |
if(!$admin_header) { $admin->print_header(); } |
|
113 |
if($database->is_error()) { |
|
114 |
$admin->print_error($database->get_error(), $js_back); |
|
115 |
} else { |
|
116 |
if(isset($_SESSION['CFG'])) { unset($_SESSION['CFG']);} |
|
117 |
$admin->print_success($MESSAGE['PAGES_SAVED'], $js_back); |
|
118 |
} |
|
119 |
break; |
|
120 |
endswitch; |
|
121 |
|
|
122 |
// set template file and assign module and template block |
|
123 |
$tpl = new Template(WB_PATH.'/modules/SecureFormSwitcher/htt','keep'); |
|
124 |
$tpl->set_file('page', 'switchform.htt'); |
|
125 |
$tpl->debug = false; // false, true |
|
126 |
$tpl->set_block('page', 'main_block', 'main'); |
|
127 |
|
|
128 |
$checked = ($setting['secure_form_module']!=''); |
|
129 |
|
|
130 |
$ftanMode = ($checked ? $SFS_TEXT['SECURE_FORM'] : $SFS_TEXT['SECURE_FORMMTAB']); |
|
131 |
$target = ($checked) ? '.'.$setting['secure_form_module'] : ''; |
|
132 |
$target = WB_PATH.'/framework/SecureForm'.$target.'.php'; |
|
133 |
|
|
134 |
$SingleTabStatus = intval($checked==false); |
|
135 |
$MultitabStatus = intval($checked==true); |
|
136 |
$NotFoundClass = ''; |
|
137 |
if(!file_exists($MultitabTarget)) { |
|
138 |
$SingleTabStatus = true; |
|
139 |
$MultitabStatus = false; |
|
140 |
$FileNotFound = $SFS_TEXT['FILE_FORMTAB_NOT_GOUND']; |
|
141 |
$NotFoundClass = 'class="warning"'; |
|
142 |
} else { |
|
143 |
} |
|
144 |
|
|
145 |
// convert settings name to upper |
|
146 |
array_walk($setting,'converttoupper', array(&$search, &$replace )); |
|
147 |
|
|
148 |
$tpl->set_var($replace); |
|
149 |
$tpl->set_var(array( |
|
150 |
'FTAN' => $admin->getFTAN(), |
|
151 |
'SERVER_REQUEST_URI' => $_SERVER['REQUEST_URI'], |
|
152 |
'TEXT_CANCEL' => $TEXT['CANCEL'], |
|
153 |
'BACKLINK' => (isset($_POST['cancel'])) ? $backlink : '#', |
|
154 |
'TEXT_INFO' => $SFS_TEXT['INFO'], |
|
155 |
'TEXT_SUBMIT' => $SFS_TEXT['SUBMIT'], |
|
156 |
'TEXT_MSUBMIT' => $SFS_TEXT['RESET_SETTINGS'], |
|
157 |
'TXT_HEADING' => $SFS_TEXT['SECURE_FORM'.strtoupper($setting['secure_form_module'])], |
|
158 |
'SELECTED' => ( ($SingleTabStatus) ? ' checked="checked"' : ''), |
|
159 |
'SELECTED_TAB' => ( ($MultitabStatus) ? ' checked="checked"' : ''), |
|
160 |
'SUBMIT_TYPE' => ($checked ? 'multitab' : 'singletab'), |
|
161 |
'MSELECTED' => '', |
|
162 |
'MSELECTED_TAB' => '', |
|
163 |
'FTAN_COLOR' => ($checked ? 'grey' : 'norm'), |
|
164 |
'TXT_SUBMIT_FORM' => $SFS_TEXT['SUBMIT_FORM'], |
|
165 |
'TXT_SUBMIT_FORMTAB' => $SFS_TEXT['SUBMIT_FORMTAB'], |
|
166 |
'FILE_FORMTAB_WARNING' => $NotFoundClass, |
|
167 |
'FILE_FORMTAB_NOT_GOUND' => $FileNotFound, |
|
168 |
) |
|
169 |
); |
|
170 |
|
|
171 |
$tpl->set_var(array( |
|
172 |
'USEIP_SELECTED' => '', |
|
173 |
'TXT_SECFORM_USEIP' => $SFS_TEXT['WB_SECFORM_USEIP'], |
|
174 |
'TXT_SECFORM_USEIP_TOOLTIP' => $SFS_TEXT['WB_SECFORM_USEIP_TOOLTIP'], // Tooltip |
|
175 |
'TEXT_DEFAULT_SETTINGS' => $HEADING['DEFAULT_SETTINGS'], |
|
176 |
'USEIP_DEFAULT' => $default_cfg['fingerprint_with_ip_octets'], |
|
177 |
'USEFP_CHECKED_TRUE' => (($setting['wb_secform_usefp']=='true') ? ' checked="checked"' : ''), |
|
178 |
'USEFP_CHECKED_FALSE' => (($setting['wb_secform_usefp']=='false') ? ' checked="checked"' : ''), |
|
179 |
'TEXT_DEFAULT_SETTINGS' => $HEADING['DEFAULT_SETTINGS'], |
|
180 |
) |
|
181 |
); |
|
182 |
|
|
183 |
$tpl->set_block('main_block', 'useip_mtab_loop', 'mtab_loop'); |
|
184 |
for($x=0; $x < 5; $x++) { |
|
185 |
// iu value == default set first option with standardtext |
|
186 |
if(intval($default_cfg['fingerprint_with_ip_octets'])==$x ) { |
|
187 |
$tpl->set_var(array( |
|
188 |
'USEIP_VALUE' => $x, |
|
189 |
'USEIP_DEFAULT_SELECTED' => ((intval($setting['fingerprint_with_ip_octets'])==$x) ? ' selected="selected"' : ''), |
|
190 |
'USEIP_SELECTED' => '', |
|
191 |
) |
|
192 |
); |
|
193 |
} else { |
|
194 |
$tpl->set_var(array( |
|
195 |
'USEIP_VALUE' => $x, |
|
196 |
'USEIP_SELECTED' => ((intval($setting['fingerprint_with_ip_octets'])==$x) && (intval($setting['fingerprint_with_ip_octets'])!=intval($default_cfg['fingerprint_with_ip_octets'])) ? ' selected="selected"' : ''), |
|
197 |
) |
|
198 |
); |
|
199 |
} |
|
200 |
$tpl->parse('mtab_loop','useip_mtab_loop', true); |
|
201 |
} |
|
202 |
|
|
203 |
$tpl->set_block('main_block', 'show_mtab_block', 'show_mtab'); |
|
204 |
$tpl->set_block('main_block', 'mtab_block', 'mtab'); |
|
205 |
if($checked) { |
|
206 |
$tpl->set_var(array( |
|
207 |
'TEXT_ENABLED' => $SFS_TEXT['ON_OFF'], |
|
208 |
'TXT_SECFORM_TOKENNAME' => $SFS_TEXT['WB_SECFORM_TOKENNAME'], |
|
209 |
'TXT_SECFORM_TOKENNAME_TOOLTIP' => $SFS_TEXT['WB_SECFORM_TOKENNAME_TOOLTIP'], |
|
210 |
'TXT_SECFORM_TIMEOUT' => $SFS_TEXT['WB_SECFORM_TIMEOUT'], |
|
211 |
'TXT_SECFORM_TIMEOUT_TOOLTIP' => $SFS_TEXT['WB_SECFORM_TIMEOUT_TOOLTIP'], |
|
212 |
'TXT_SECFORM_SECRETTIME' => $SFS_TEXT['WB_SECFORM_SECRETTIME'], |
|
213 |
'TXT_SECFORM_SECRETTIME_TOOLTIP' => $SFS_TEXT['WB_SECFORM_SECRETTIME_TOOLTIP'], |
|
214 |
'TXT_SECFORM_SECRET' => $SFS_TEXT['WB_SECFORM_SECRET'], |
|
215 |
'TXT_SECFORM_SECRET_TOOLTIP' => $SFS_TEXT['WB_SECFORM_SECRET_TOOLTIP'], |
|
216 |
'TXT_SECFORM_USEFP' => $SFS_TEXT['WB_SECFORM_USEFP'], |
|
217 |
'SECFORM_USEFP' => 'true', |
|
218 |
'TXT_SECFORM_USEFP_TOOLTIP' => $SFS_TEXT['WB_SECFORM_USEFP_TOOLTIP'], |
|
219 |
) |
|
220 |
); |
|
221 |
$tpl->parse('mtab','mtab_block', true); |
|
222 |
$tpl->parse('show_mtab','show_mtab_block', true); |
|
223 |
} else { |
|
224 |
$tpl->parse('mtab', ''); |
|
225 |
$tpl->parse('show_mtab', ''); |
|
226 |
} |
|
227 |
|
|
228 |
// Parse template object |
|
229 |
$tpl->parse('main', 'main_block', false); |
|
230 |
$output = $tpl->finish($tpl->parse('output', 'page')); |
|
231 |
unset($tpl); |
|
232 |
print $output; |
|
233 |
|
|
0 | 234 |
branches/2.8.x/wb/modules/SecureFormSwitcher/languages/EN.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
//Module description |
|
20 |
$module_description = 'This module switch between the <strong>SingleTab SecureForm</strong> and <strong>MultiTab SecureForm</strong>.'; |
|
21 |
|
|
22 |
// Backend variables |
|
23 |
$SFS_TEXT['TEXT_SWITCH'] = 'Change'; |
|
24 |
$SFS_TEXT['TXT_FTAN_SWITCH'] = 'Change to '; |
|
25 |
$SFS_TEXT['SECURE_FORM'] = 'SingleTab SecureForm'; |
|
26 |
$SFS_TEXT['SECURE_FORMMTAB'] = 'Multitab SecureForm'; |
|
27 |
$SFS_TEXT['FILE_FORMTAB_NOT_GOUND'] = '<strong>Multitab not possible!<br />Needed file \'/framework/SecureForm.mtab.php\' not found!</strong><br /> |
|
28 |
<span>You have to upload the file manually via FTP</span>'; |
|
29 |
$SFS_TEXT['SUBMIT_FORM'] = 'Single Tab (recommended)'; |
|
30 |
$SFS_TEXT['SUBMIT_FORMTAB'] = 'Multi Tab'; |
|
31 |
$SFS_TEXT['SUBMIT'] = 'Accept'; |
|
32 |
$SFS_TEXT['INFO'] = 'Please select if you want to use the default security settings or the settings for working with several WebsiteBaker instances in parallel browser tabs.'; |
|
33 |
$SFS_TEXT['RESET_SETTINGS'] = 'Default setting'; |
|
34 |
$SFS_TEXT['ON_OFF'] = 'On/OFF'; |
|
35 |
|
|
36 |
// Variablen fuer AdminTool Optionen |
|
37 |
$SFS_TEXT['WB_SECFORM_USEIP'] = 'IP-Blocks (1-4, 0=no check)'; |
|
38 |
$SFS_TEXT['WB_SECFORM_USEIP_TOOLTIP'] = '<span class="custom help"><em>Help</em> |
|
39 |
These number of segments of an IP address can be used for the fingerprint. "4" means the whole IP address (this makes sense e.g. for servers with a stable IP address). "2" is a good compromise, because at home there\'s often the 24-hour reset and therefore only the first two segments keep constant. |
|
40 |
<ul> |
|
41 |
<li>4= xxx.xxx.xxx.xxx</li> |
|
42 |
<li>3= xxx.xxx.xxx</li> |
|
43 |
<li>2= xxx.xxx</li> |
|
44 |
<li>1= xxx</li> |
|
45 |
<li>0= no usage of the IP</li></ul></span>'; |
|
46 |
$SFS_TEXT['WB_SECFORM_TOKENNAME'] = 'Tokenname'; |
|
47 |
$SFS_TEXT['WB_SECFORM_TOKENNAME_TOOLTIP'] = '<span class="custom help"><em>Help</em>The name of the token. Coll. a token is often called TAN.</span>'; |
|
48 |
$SFS_TEXT['WB_SECFORM_SECRET'] = 'Secret (whatever you like)'; |
|
49 |
$SFS_TEXT['WB_SECFORM_SECRET_TOOLTIP'] = '<span class="custom help"><em>Help</em>A random key, that is being used for creating a TAN. Recommend are at least 20 digits.</span>'; |
|
50 |
$SFS_TEXT['WB_SECFORM_SECRETTIME'] = 'Secrettime'; |
|
51 |
$SFS_TEXT['WB_SECFORM_SECRETTIME_TOOLTIP'] = '<span class="custom help"><em>Help</em>Time (in seconds), until the secret-key will be renewed.</span>'; |
|
52 |
$SFS_TEXT['WB_SECFORM_TIMEOUT'] = 'Timeout'; |
|
53 |
$SFS_TEXT['WB_SECFORM_TIMEOUT_TOOLTIP'] = '<span class="custom help"><em>Help</em>Time (in seconds), until the form-token is void.</span>'; |
|
54 |
$SFS_TEXT['WB_SECFORM_USEFP'] = 'Fingerprinting'; |
|
55 |
$SFS_TEXT['WB_SECFORM_USEFP_TOOLTIP'] = '<span class="custom help"><em>Help</em>Require OS and browser for every TAN-validation additionally to the IP-address.</span>'; |
|
0 | 56 |
branches/2.8.x/wb/modules/SecureFormSwitcher/languages/DE.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
//Module description |
|
20 |
$module_description = 'Dieses Modul wechselt zwischen <strong>SingleTab SecureForm</strong> und <strong>MultiTab SecureForm</strong>.'; |
|
21 |
|
|
22 |
// Backend variables |
|
23 |
$SFS_TEXT['TEXT_SWITCH'] = 'Wechseln'; |
|
24 |
$SFS_TEXT['TXT_FTAN_SWITCH'] = 'Wechsel zu '; |
|
25 |
$SFS_TEXT['SECURE_FORM'] = 'SingleTab SecureForm'; |
|
26 |
$SFS_TEXT['SECURE_FORMMTAB'] = 'Multitab SecureForm'; |
|
27 |
$SFS_TEXT['FILE_FORMTAB_NOT_GOUND'] = '<strong>Multitab nicht ausführbar!<br />Benötigte Datei \'/framework/SecureForm.mtab.php\' nicht gefunden!</strong><br /> |
|
28 |
<span>Sie müssen die Datei manuell über FTP hochspielen</span>'; |
|
29 |
$SFS_TEXT['SUBMIT_FORM'] = 'SingleTab (empfohlen)'; |
|
30 |
$SFS_TEXT['SUBMIT_FORMTAB'] = 'Multi Tab'; |
|
31 |
$SFS_TEXT['SUBMIT'] = 'Übernehmen'; |
|
32 |
$SFS_TEXT['INFO'] = 'Hier können Sie auswählen, ob die Standard-Sicherheitseinstellung oder die Sicherheitseinstellung zur Verwendung von mehreren WebsiteBaker-Instanzen in parallelen Browser-Tabs aktiviert werden soll.'; |
|
33 |
$SFS_TEXT['RESET_SETTINGS'] = 'Standardeinstellung'; |
|
34 |
$SFS_TEXT['ON_OFF'] = 'Ein/Aus'; |
|
35 |
|
|
36 |
// Variablen fuer AdminTool Optionen |
|
37 |
$SFS_TEXT['WB_SECFORM_USEIP'] = 'IP-Blocks (1-4, 0=kein Check)'; |
|
38 |
$SFS_TEXT['WB_SECFORM_USEIP_TOOLTIP'] = '<span class="custom help"><em>Hilfe</em> |
|
39 |
Diese Anzahl der Segmente einer IP-Adresse werden für den Fingerprint genutzt. "4" heißt die gesamte IP-Adresse (dies macht nur bei festen IPs wie z.B. Servern Sinn). "2" ist ein guter Kompromiss, da im Heimbereich durch 24-Stunden Resets nur die ersten beiden Segmente konstant bleiben. |
|
40 |
<ul> |
|
41 |
<li>4= xxx.xxx.xxx.xxx</li> |
|
42 |
<li>3= xxx.xxx.xxx</li> |
|
43 |
<li>2= xxx.xxx</li> |
|
44 |
<li>1= xxx</li> |
|
45 |
<li>0=keine Nutzung der IP</li></ul></span>'; |
|
46 |
$SFS_TEXT['WB_SECFORM_TOKENNAME'] = 'Tokenname'; |
|
47 |
$SFS_TEXT['WB_SECFORM_TOKENNAME_TOOLTIP'] = '<span class="custom help"><em>Hilfe</em>Der Name des Tokens. Umgangssprachlich wird Token auch TAN genannt.</span>'; |
|
48 |
$SFS_TEXT['WB_SECFORM_SECRET'] = 'Secret (Beliebige Zeichen)'; |
|
49 |
$SFS_TEXT['WB_SECFORM_SECRET_TOOLTIP'] = '<span class="custom help"><em>Hilfe</em>Ein zufälliger Schlüssel, der für die Token-Erstellung verwendet wird. Empfohlen sind mind. 20 Zeichen.</span>'; |
|
50 |
$SFS_TEXT['WB_SECFORM_SECRETTIME'] = 'Secrettime'; |
|
51 |
$SFS_TEXT['WB_SECFORM_SECRETTIME_TOOLTIP'] = '<span class="custom help"><em>Hilfe</em>Zeit (in Sekunden), bis der Secret-Schlüssel sich erneuert.</span>'; |
|
52 |
$SFS_TEXT['WB_SECFORM_TIMEOUT'] = 'Timeout'; |
|
53 |
$SFS_TEXT['WB_SECFORM_TIMEOUT_TOOLTIP'] = '<span class="custom help"><em>Hilfe</em>Zeit (in Sekunden), bis ein Formular-Token nicht mehr gilt.</span>'; |
|
54 |
$SFS_TEXT['WB_SECFORM_USEFP'] = 'Fingerprinting'; |
|
55 |
$SFS_TEXT['WB_SECFORM_USEFP_TOOLTIP'] = '<span class="custom help"><em>Hilfe</em>Zusätzlich zur IP-Adresse wird Betriebssystem und Browser zu jeder TAN-Validierung hinzugezogen.</span>'; |
|
0 | 56 |
branches/2.8.x/wb/modules/SecureFormSwitcher/language_load.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* @description |
|
17 |
* |
|
18 |
*/ |
|
19 |
/* ************************************************************************** */ |
|
20 |
|
|
21 |
if(defined('WB_PATH') == false) |
|
22 |
{ |
|
23 |
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>"); |
|
24 |
} |
|
25 |
|
|
26 |
$mod_path = (dirname(__FILE__)); |
|
27 |
$dlg_lang_dir = $mod_path.'/languages/'; |
|
28 |
if(file_exists($dlg_lang_dir)){ |
|
29 |
$dlg_lang = file_exists($dlg_lang_dir.LANGUAGE.'.php') ? LANGUAGE : 'EN'; |
|
30 |
require_once($dlg_lang_dir.$dlg_lang.'.php'); |
|
31 |
} |
|
32 |
|
|
33 |
// iconv_set_encoding("output_encoding", "ISO-8859-1"); |
|
34 |
if(!function_exists('convert_charset')) |
|
35 |
{ |
|
36 |
function convert_charset(&$val, $key, $vars) { |
|
37 |
$val = iconv($vars['0'], $vars['1'].'//TRANSLIT', ($val)); |
|
38 |
} |
|
39 |
} |
|
40 |
if( strtolower(DEFAULT_CHARSET) != 'utf-8') { |
|
41 |
$in_charset = 'utf-8'; |
|
42 |
$out_charset = DEFAULT_CHARSET; |
|
43 |
array_walk_recursive($SFS_TEXT,'convert_charset',array($in_charset, $out_charset)); |
|
44 |
} |
|
45 |
|
|
0 | 46 |
branches/2.8.x/wb/modules/SecureFormSwitcher/install.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
// Must include code to stop this file being access directly |
|
20 |
if(defined('WB_PATH') == false) { exit("Cannot access this file directly"); } |
|
21 |
|
|
22 |
require_once(WB_PATH.'/framework/class.database.php'); |
|
23 |
require_once(WB_PATH.'/framework/functions.php'); |
|
24 |
|
|
25 |
$mod_path = (dirname(__FILE__)); |
|
26 |
require_once( $mod_path.'/language_load.php' ); |
|
27 |
|
|
28 |
$aDefault = array( |
|
29 |
'secure_form_module' => '', |
|
30 |
'wb_secform_secret' => '5609bnefg93jmgi99igjefg', |
|
31 |
'wb_secform_secrettime' => '86400', |
|
32 |
'wb_secform_timeout' => '7200', |
|
33 |
'wb_secform_tokenname' => 'formtoken', |
|
34 |
'wb_secform_usefp' => 'true', |
|
35 |
'wb_secform_useip' => '2', |
|
36 |
); |
|
37 |
|
|
38 |
db_update_key_value('settings', $aDefault ); |
|
39 |
|
|
40 |
|
|
0 | 41 |
branches/2.8.x/wb/modules/SecureFormSwitcher/upgrade.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.8.2 |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
// Must include code to stop this file being access directly |
|
20 |
if(defined('WB_PATH') == false) { exit("Cannot access this file directly"); } |
|
21 |
global $i; |
|
22 |
// load module language file |
|
23 |
$mod_path = (dirname(__FILE__)); |
|
24 |
require_once( $mod_path.'/language_load.php' ); |
|
25 |
$i = (!isset($i) ? 1 : $i); |
|
26 |
print "<div style=\"margin:1em auto;font-size:1.1em;\">"; |
|
27 |
print "<h4>Step $i: Updating SecureForm Switcher</h4>\n"; |
|
28 |
$i++; |
|
29 |
$OK = "<span class=\"ok\">OK</span>"; |
|
30 |
$FAIL = "<span class=\"error\">FAILED</span>"; |
|
31 |
$target = $mod_path.'/files/SecureForm.mtab.php'; |
|
32 |
$dest = WB_PATH.'/framework/SecureForm.mtab.php'; |
|
33 |
|
|
34 |
if(is_writeable(WB_PATH.'/framework')) { |
|
35 |
if((copy($target,$dest) && change_mode($dest)) || file_exists($target)) { |
|
36 |
print "<br /><strong>Updating secure_form_module</strong> $OK<br />\n"; |
|
37 |
} else { |
|
38 |
print "<br /><strong>Updating secure_form_module</strong> $FAIL<br />\n"; |
|
39 |
} |
|
40 |
} |
|
41 |
print "</div>"; |
|
0 | 42 |
branches/2.8.x/wb/modules/SecureFormSwitcher/index.php | ||
---|---|---|
1 |
<?php |
|
2 |
/** |
|
3 |
* |
|
4 |
* @category modules |
|
5 |
* @package SecureFormSwitcher |
|
6 |
* @author WebsiteBaker Project |
|
7 |
* @copyright 2004-2009, Ryan Djurovich |
|
8 |
* @copyright 2009-2011, Website Baker Org. e.V. |
|
9 |
* @link http://www.websitebaker2.org/ |
|
10 |
* @license http://www.gnu.org/licenses/gpl.html |
|
11 |
* @platform WebsiteBaker 2.9.x |
|
12 |
* @requirements PHP 5.2.2 and higher |
|
13 |
* @version $Id$ |
|
14 |
* @filesource $HeadURL$ |
|
15 |
* @lastmodified $Date$ |
|
16 |
* |
|
17 |
*/ |
|
18 |
|
|
19 |
header('Location: ../index.php'); |
|
20 |
exit(); |
|
0 | 21 |
branches/2.8.x/wb/modules/SecureFormSwitcher/FTAN_SUPPORTED | ||
---|---|---|
1 |
This module supports the FTAN-System |
branches/2.8.x/wb/modules/SecureFormSwitcher/backend.css | ||
---|---|---|
1 |
@charset "UTF-8"; |
|
2 |
|
|
3 |
td.content form.secure_switch .left-content { width :49%; float :left; } |
|
4 |
td.content form.secure_switch .right-content { width :49%; float :right; } |
|
5 |
|
|
6 |
form.secure_switch { border :0px #484 solid; margin :1em 0; width :100%; } |
|
7 |
|
|
8 |
table.switch-ftan-info, |
|
9 |
table.switch-ftan-form { width :100%; background-color :transparent; } |
|
10 |
table.switch-ftan-info tbody, |
|
11 |
table.switch-ftan-form tbody { margin :10px 0; } |
|
12 |
table.switch-ftan-form tbody td label { font-weight :bold; font-size :1.0em; color :#000000; } |
|
13 |
table.switch-ftan-info thead tr th { margin :20px 0; font-weight :bold; font-size :1.4em; background-color :transparent; color :#000000; text-align :left; } |
|
14 |
|
|
15 |
table.switch-ftan-info thead tr th span.norm { color : #003300; } |
|
16 |
table.switch-ftan-info thead tr th span.grey { color : #666666; } |
|
17 |
|
|
18 |
table.switch-ftan-form tbody td { height :30px; vertical-align :middle; } |
|
19 |
table.switch-ftan-form tbody td input[type="submit"] { font-size :1.0em; width : 40%; } |
|
20 |
table.switch-ftan-form tbody td input[type="text"] { font-size :1.0em; width : 100%; } |
|
21 |
table.switch-ftan-form tbody td select { font-size :1.0em; width : 101.5%; } |
|
22 |
|
|
23 |
.ok, .error { font-weight:bold; } |
|
24 |
.ok { color:green; } |
|
25 |
.error { color:red; } |
|
26 |
.check { color:#555; } |
|
27 |
|
|
28 |
.module-info { padding :10px; margin :0px auto; background :transparent; color :#000000; font-size :1.0em; } |
|
29 |
.module-info p { margin :0.2em auto; } |
|
30 |
.warning { border-radius :10px; -khtml-border-radius :10px; -webkit-border-radius :10px; -moz-border-radius :10px; background :#fee; border :0.2em #844 solid; color :#990000; margin :0.2em auto; padding :0.63em; width :60%; text-align :center; } |
|
31 |
.warning strong { font-size :1.2em; } |
|
32 |
.warning span { font-size :1.2em; line-height :1.5em; color :#333333; } |
|
33 |
|
|
34 |
/* Tooltip CSS */ |
|
35 |
.tooltip { |
|
36 |
border-bottom: 1px dotted #000000; |
|
37 |
color: #000000; |
|
38 |
outline: none; |
|
39 |
cursor: help; |
|
40 |
text-decoration: none; |
|
41 |
position: relative; |
|
42 |
} |
|
43 |
.tooltip span { margin-left: -999em; position: absolute; } |
|
44 |
.tooltip:hover em { |
|
45 |
font-family: Candara, Tahoma, Geneva, sans-serif; |
|
46 |
font-size: 1.2em; |
|
47 |
font-weight: bold; |
|
48 |
display: block; |
|
49 |
padding: 0.2em 0 0.6em 0; |
|
50 |
} |
|
51 |
.tooltip:hover span { |
|
52 |
border-radius: 5px 5px; |
|
53 |
box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.1); |
|
54 |
font-family: Calibri, Tahoma, Geneva, sans-serif; |
|
55 |
position: absolute; |
|
56 |
left: -15em; |
|
57 |
top: 2em; |
|
58 |
z-index: 99; |
|
59 |
margin-left: 1em; |
|
60 |
padding: 10px 10px 10px 50px; |
|
61 |
width: 250px; |
Also available in: Unified diff
preparing backend for the new installer
add SecureFormSwitcher (Admintool)