Compare commits
134 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4914fc640a | ||
|
|
f0b073a6f1 | ||
|
|
79f5ff4d35 | ||
|
|
8609b2394b | ||
|
|
5bb3c16312 | ||
|
|
df5d3ef66f | ||
|
|
a207f2f936 | ||
|
|
b0bd0836cd | ||
|
|
475377dd85 | ||
|
|
16776ce750 | ||
|
|
3861917dbc | ||
|
|
65891eff1c | ||
|
|
bf9306c641 | ||
|
|
666d0db550 | ||
|
|
6a41b30e70 | ||
|
|
0808bacb39 | ||
|
|
026f8503ab | ||
|
|
19a7e78ebe | ||
|
|
76fb0d2a20 | ||
|
|
a418e60556 | ||
|
|
8f760e87bc | ||
|
|
0aff176cdc | ||
|
|
cdcab6e1f8 | ||
|
|
37d03bdf6a | ||
|
|
4a40870576 | ||
|
|
35958168a2 | ||
|
|
6badc2ad77 | ||
|
|
5184dc9ce7 | ||
|
|
b446575bf0 | ||
|
|
b7114c670a | ||
|
|
536e66da7c | ||
|
|
9114a98e4c | ||
|
|
9955bed2c1 | ||
|
|
f6af38a2c3 | ||
|
|
76e886e610 | ||
|
|
6daec3c975 | ||
|
|
e9000a7e99 | ||
|
|
44a53492e6 | ||
|
|
7cf0fa7284 | ||
|
|
9aa86e1dee | ||
|
|
961aad43d1 | ||
|
|
6e84ca4ae4 | ||
|
|
f79e351b72 | ||
|
|
a24d809428 | ||
|
|
0fa64ea943 | ||
|
|
fe0b71b628 | ||
|
|
a23260fb7f | ||
|
|
eb984c2f4c | ||
|
|
1836132c28 | ||
|
|
aae635bf5d | ||
|
|
8599ff775b | ||
|
|
8bfdd0bc14 | ||
|
|
30344b0dce | ||
|
|
8019629a28 | ||
|
|
7a28108475 | ||
|
|
cfa94c5837 | ||
|
|
c9c0530461 | ||
|
|
093ebfa457 | ||
|
|
3800f31823 | ||
|
|
cc26584f01 | ||
|
|
8131e9e92c | ||
|
|
38e472a623 | ||
|
|
3e21cb0298 | ||
|
|
b9bb1a1286 | ||
|
|
25609a7068 | ||
|
|
35d8b3f8a1 | ||
|
|
d593a217a4 | ||
|
|
960fa58799 | ||
|
|
76b716d41d | ||
|
|
0b3e788b86 | ||
|
|
b88246b112 | ||
|
|
4d10c72ae9 | ||
|
|
0a21ede3d2 | ||
|
|
3669822064 | ||
|
|
b68f9fe395 | ||
|
|
e101d01e11 | ||
|
|
bdce761af0 | ||
|
|
784d1a62f7 | ||
|
|
c84602d560 | ||
|
|
3bcba9fa40 | ||
|
|
7246dc124e | ||
|
|
fcdcd4d6cb | ||
|
|
07d981ac25 | ||
|
|
1bf764c5c3 | ||
|
|
79b886994c | ||
|
|
62f8c7d1b6 | ||
|
|
6fe0b7f6a4 | ||
|
|
a55df73281 | ||
|
|
ce6176ffe4 | ||
|
|
570ceb8160 | ||
|
|
163228ff75 | ||
|
|
68b9c22938 | ||
|
|
7936f72bc1 | ||
|
|
81df4f5444 | ||
|
|
54093a0a9a | ||
|
|
c5e8786670 | ||
|
|
6ebd6db87f | ||
|
|
68e31962bc | ||
|
|
9d24648607 | ||
|
|
c26223a887 | ||
|
|
444f4b5d1e | ||
|
|
c72b07f690 | ||
|
|
c318d9e9df | ||
|
|
5b6acce822 | ||
|
|
9a4b45838a | ||
|
|
48df1bac4b | ||
|
|
63aed1e8f4 | ||
|
|
426e87a337 | ||
|
|
cd141ce381 | ||
|
|
ece63b8a36 | ||
|
|
af423248da | ||
|
|
5ca7e173b0 | ||
|
|
f845f7771a | ||
|
|
500a829161 | ||
|
|
96c34b9b29 | ||
|
|
ec7c19cceb | ||
|
|
7a4501e581 | ||
|
|
75c5fae6b2 | ||
|
|
7a5bf65184 | ||
|
|
103626e82a | ||
|
|
ca1a77d883 | ||
|
|
ac68a5d35f | ||
|
|
f63f1d947b | ||
|
|
5b6aa1aa8d | ||
|
|
12177fd21d | ||
|
|
aa4254ad47 | ||
|
|
e2076603dd | ||
|
|
2ea90c1b45 | ||
|
|
cf66dcf38d | ||
|
|
51a83d8b09 | ||
|
|
e467409cbb | ||
|
|
05b59621a6 | ||
|
|
e148e7d584 | ||
|
|
3fb6d4eac9 |
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
packages/*
|
||||||
|
temp/*
|
||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Language
|
* @package Language
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id: 220.ftpserver.php 1 2010-04-07 10:00:00Z monotek $
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Settings
|
* @package Settings
|
||||||
* @version $Id: 215.backup.php 1 2010-09-14 08:09:17Z monotek $
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
@@ -36,7 +36,9 @@ return array(
|
|||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
'varname' => 'backup_dir',
|
'varname' => 'backup_dir',
|
||||||
'type' => 'string',
|
'type' => 'string',
|
||||||
'default' => '#froxlor_backup',
|
'string_type' => 'dir',
|
||||||
|
'default' => '/var/customers/backups/',
|
||||||
|
'string_regexp' => '/^/.*/$/',
|
||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField',
|
||||||
),
|
),
|
||||||
'backup_mysqldump_path' => array(
|
'backup_mysqldump_path' => array(
|
||||||
@@ -98,6 +100,15 @@ return array(
|
|||||||
'default' => '',
|
'default' => '',
|
||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField',
|
||||||
),
|
),
|
||||||
|
'backup_passive_mode' => array(
|
||||||
|
'label' => $lng['serversettings']['backup_ftp_passive_mode'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'backup_ftp_passive',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => true,
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'overview_option' => false,
|
||||||
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|||||||
60
actions/admin/settings/220.quota.php
Normal file
60
actions/admin/settings/220.quota.php
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2011 the Froxlor Team (see authors).
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the COPYING
|
||||||
|
* file that was distributed with this source code. You can also view the
|
||||||
|
* COPYING file online at http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
*
|
||||||
|
* @copyright (c) the authors
|
||||||
|
* @author Froxlor team <team@froxlor.org> (2011-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Settings
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'groups' => array(
|
||||||
|
'diskquota' => array(
|
||||||
|
'title' => $lng['diskquota'],
|
||||||
|
'fields' => array(
|
||||||
|
'diskquota_enabled' => array(
|
||||||
|
'label' => $lng['serversettings']['diskquota_enabled'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'diskquota_enabled',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => false,
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'overview_option' => true
|
||||||
|
),
|
||||||
|
'diskquota_repquota_path' => array(
|
||||||
|
'label' => $lng['serversettings']['diskquota_repquota_path']['description'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'diskquota_repquota_path',
|
||||||
|
'type' => 'string',
|
||||||
|
'default' => '/usr/sbin/repquota',
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
),
|
||||||
|
'diskquota_quotatool_path' => array(
|
||||||
|
'label' => $lng['serversettings']['diskquota_quotatool_path']['description'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'diskquota_quotatool_path',
|
||||||
|
'type' => 'string',
|
||||||
|
'default' => '/usr/bin/quotatool',
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
),
|
||||||
|
'diskquota_customer_partition' => array(
|
||||||
|
'label' => $lng['serversettings']['diskquota_customer_partition']['description'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'diskquota_customer_partition',
|
||||||
|
'type' => 'string',
|
||||||
|
'default' => '/dev/root',
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
?>
|
||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id: admin_admins.php 101 2010-12-08 07:03:42Z d00p $
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Required code
|
// Required code
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id: admin_cronjobs.php 105 2010-12-09 08:02:33Z d00p $
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
@@ -42,7 +42,7 @@ if($page == 'customers'
|
|||||||
{
|
{
|
||||||
// clear request data
|
// clear request data
|
||||||
unset($_SESSION['requestData']);
|
unset($_SESSION['requestData']);
|
||||||
|
|
||||||
$log->logAction(ADM_ACTION, LOG_NOTICE, "viewed admin_customers");
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "viewed admin_customers");
|
||||||
$fields = array(
|
$fields = array(
|
||||||
'c.loginname' => $lng['login']['username'],
|
'c.loginname' => $lng['login']['username'],
|
||||||
@@ -83,11 +83,11 @@ if($page == 'customers'
|
|||||||
$fields['c.tickets'] = $lng['customer']['tickets'];
|
$fields['c.tickets'] = $lng['customer']['tickets'];
|
||||||
$fields['c.tickets_used'] = $lng['customer']['tickets'] . ' (' . $lng['panel']['used'] . ')';
|
$fields['c.tickets_used'] = $lng['customer']['tickets'] . ' (' . $lng['panel']['used'] . ')';
|
||||||
}
|
}
|
||||||
|
|
||||||
if($settings['autoresponder']['autoresponder_active'] == 1)
|
if($settings['autoresponder']['autoresponder_active'] == 1)
|
||||||
{
|
{
|
||||||
$fields['c.email_autoresponder'] = $lng['customer']['autoresponder'];
|
$fields['c.email_autoresponder'] = $lng['customer']['autoresponder'];
|
||||||
$fields['c.email_autoresponder_used'] = $lng['customer']['autoresponder'] . ' (' . $lng['panel']['used'] . ')';
|
$fields['c.email_autoresponder_used'] = $lng['customer']['autoresponder'] . ' (' . $lng['panel']['used'] . ')';
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -175,11 +175,11 @@ if($page == 'customers'
|
|||||||
if(isset($_POST['send'])
|
if(isset($_POST['send'])
|
||||||
&& $_POST['send'] == 'send')
|
&& $_POST['send'] == 'send')
|
||||||
{
|
{
|
||||||
$result = $db->query("UPDATE
|
$result = $db->query("UPDATE
|
||||||
`" . TABLE_PANEL_CUSTOMERS . "`
|
`" . TABLE_PANEL_CUSTOMERS . "`
|
||||||
SET
|
SET
|
||||||
`loginfail_count` = '0'
|
`loginfail_count` = '0'
|
||||||
WHERE
|
WHERE
|
||||||
`customerid`= '" . (int)$id . "'"
|
`customerid`= '" . (int)$id . "'"
|
||||||
);
|
);
|
||||||
redirectTo($filename, Array('page' => $page, 's' => $s));
|
redirectTo($filename, Array('page' => $page, 's' => $s));
|
||||||
@@ -259,7 +259,7 @@ if($page == 'customers'
|
|||||||
// remove all package related settings
|
// remove all package related settings
|
||||||
$db->query("DELETE FROM `".TABLE_APS_SETTINGS."` WHERE `InstanceID` = '".(int)$apsrow['ID']."'");
|
$db->query("DELETE FROM `".TABLE_APS_SETTINGS."` WHERE `InstanceID` = '".(int)$apsrow['ID']."'");
|
||||||
// maybe some leftovers in the tasks
|
// maybe some leftovers in the tasks
|
||||||
$db->query("DELETE FROM `".TABLE_APS_TASKS."` WHERE `InstanceID` = '".(int)$apsrow['ID']."'");
|
$db->query("DELETE FROM `".TABLE_APS_TASKS."` WHERE `InstanceID` = '".(int)$apsrow['ID']."'");
|
||||||
}
|
}
|
||||||
// now remove all user instances
|
// now remove all user instances
|
||||||
$db->query("DELETE FROM `".TABLE_APS_INSTANCES."` WHERE `CustomerID`='".(int)$id."'");
|
$db->query("DELETE FROM `".TABLE_APS_INSTANCES."` WHERE `CustomerID`='".(int)$id."'");
|
||||||
@@ -330,13 +330,19 @@ if($page == 'customers'
|
|||||||
$log->logAction(ADM_ACTION, LOG_INFO, "deleted user '" . $result['loginname'] . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "deleted user '" . $result['loginname'] . "'");
|
||||||
inserttask('1');
|
inserttask('1');
|
||||||
inserttask('4');
|
inserttask('4');
|
||||||
|
|
||||||
if(isset($_POST['delete_userfiles'])
|
if(isset($_POST['delete_userfiles'])
|
||||||
&& (int)$_POST['delete_userfiles'] == 1)
|
&& (int)$_POST['delete_userfiles'] == 1)
|
||||||
{
|
{
|
||||||
inserttask('6', $result['loginname']);
|
inserttask('6', $result['loginname']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Using filesystem - quota, insert a task which cleans the filesystem - quota
|
||||||
|
if ($settings['system']['diskquota_enabled'])
|
||||||
|
{
|
||||||
|
inserttask('10');
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* move old tickets to archive
|
* move old tickets to archive
|
||||||
*/
|
*/
|
||||||
@@ -354,8 +360,8 @@ if($page == 'customers'
|
|||||||
$mainticket->Archive();
|
$mainticket->Archive();
|
||||||
$log->logAction(ADM_ACTION, LOG_NOTICE, "archived ticket '" . $mainticket->Get('subject') . "'");
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "archived ticket '" . $mainticket->Get('subject') . "'");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
redirectTo($filename, Array('page' => $page, 's' => $s));
|
redirectTo($filename, Array('page' => $page, 's' => $s));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -384,6 +390,7 @@ if($page == 'customers'
|
|||||||
$customernumber = validate($_POST['customernumber'], 'customer number', '/^[A-Za-z0-9 \-]*$/Di');
|
$customernumber = validate($_POST['customernumber'], 'customer number', '/^[A-Za-z0-9 \-]*$/Di');
|
||||||
$def_language = validate($_POST['def_language'], 'default language');
|
$def_language = validate($_POST['def_language'], 'default language');
|
||||||
$diskspace = intval_ressource($_POST['diskspace']);
|
$diskspace = intval_ressource($_POST['diskspace']);
|
||||||
|
$gender = intval_ressource($_POST['gender']);
|
||||||
|
|
||||||
if(isset($_POST['diskspace_ul']))
|
if(isset($_POST['diskspace_ul']))
|
||||||
{
|
{
|
||||||
@@ -438,7 +445,7 @@ if($page == 'customers'
|
|||||||
{
|
{
|
||||||
$email_quota = - 1;
|
$email_quota = - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($settings['autoresponder']['autoresponder_active'] == '1')
|
if($settings['autoresponder']['autoresponder_active'] == '1')
|
||||||
{
|
{
|
||||||
$email_autoresponder = intval_ressource($_POST['email_autoresponder']);
|
$email_autoresponder = intval_ressource($_POST['email_autoresponder']);
|
||||||
@@ -454,13 +461,13 @@ if($page == 'customers'
|
|||||||
}
|
}
|
||||||
|
|
||||||
$email_imap = 0;
|
$email_imap = 0;
|
||||||
if(isset($_POST['email_imap']))
|
if(isset($_POST['email_imap']))
|
||||||
$email_imap = intval_ressource($_POST['email_imap']);
|
$email_imap = intval_ressource($_POST['email_imap']);
|
||||||
|
|
||||||
$email_pop3 = 0;
|
$email_pop3 = 0;
|
||||||
if(isset($_POST['email_pop3']))
|
if(isset($_POST['email_pop3']))
|
||||||
$email_pop3 = intval_ressource($_POST['email_pop3']);
|
$email_pop3 = intval_ressource($_POST['email_pop3']);
|
||||||
|
|
||||||
$ftps = 0;
|
$ftps = 0;
|
||||||
if(isset($_POST['ftps']))
|
if(isset($_POST['ftps']))
|
||||||
$ftps = intval_ressource($_POST['ftps']);
|
$ftps = intval_ressource($_POST['ftps']);
|
||||||
@@ -498,7 +505,7 @@ if($page == 'customers'
|
|||||||
{
|
{
|
||||||
$number_of_aps_packages = 0;
|
$number_of_aps_packages = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
$createstdsubdomain = 0;
|
$createstdsubdomain = 0;
|
||||||
if(isset($_POST['createstdsubdomain']))
|
if(isset($_POST['createstdsubdomain']))
|
||||||
$createstdsubdomain = intval($_POST['createstdsubdomain']);
|
$createstdsubdomain = intval($_POST['createstdsubdomain']);
|
||||||
@@ -509,32 +516,37 @@ if($page == 'customers'
|
|||||||
{
|
{
|
||||||
$password = validatePassword($password);
|
$password = validatePassword($password);
|
||||||
}
|
}
|
||||||
|
|
||||||
$backup_allowed = 0;
|
$backup_allowed = 0;
|
||||||
if(isset($_POST['backup_allowed']))
|
if(isset($_POST['backup_allowed']))
|
||||||
$backup_allowed = intval($_POST['backup_allowed']);
|
$backup_allowed = intval($_POST['backup_allowed']);
|
||||||
|
|
||||||
if ($backup_allowed != 0)
|
if ($backup_allowed != 0)
|
||||||
{
|
{
|
||||||
$backup_allowed = 1;
|
$backup_allowed = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// gender out of range? [0,2]
|
||||||
|
if ($gender < 0 || $gender > 2) {
|
||||||
|
$gender = 0;
|
||||||
|
}
|
||||||
|
|
||||||
$sendpassword = 0;
|
$sendpassword = 0;
|
||||||
if(isset($_POST['sendpassword']))
|
if(isset($_POST['sendpassword']))
|
||||||
$sendpassword = intval($_POST['sendpassword']);
|
$sendpassword = intval($_POST['sendpassword']);
|
||||||
|
|
||||||
$phpenabled = 0;
|
$phpenabled = 0;
|
||||||
if(isset($_POST['phpenabled']))
|
if(isset($_POST['phpenabled']))
|
||||||
$phpenabled = intval($_POST['phpenabled']);
|
$phpenabled = intval($_POST['phpenabled']);
|
||||||
|
|
||||||
$perlenabled = 0;
|
$perlenabled = 0;
|
||||||
if(isset($_POST['perlenabled']))
|
if(isset($_POST['perlenabled']))
|
||||||
$perlenabled = intval($_POST['perlenabled']);
|
$perlenabled = intval($_POST['perlenabled']);
|
||||||
|
|
||||||
$store_defaultindex = 0;
|
$store_defaultindex = 0;
|
||||||
if(isset($_POST['store_defaultindex']))
|
if(isset($_POST['store_defaultindex']))
|
||||||
$store_defaultindex = intval($_POST['store_defaultindex']);
|
$store_defaultindex = intval($_POST['store_defaultindex']);
|
||||||
|
|
||||||
$diskspace = $diskspace * 1024;
|
$diskspace = $diskspace * 1024;
|
||||||
$traffic = $traffic * 1024 * 1024;
|
$traffic = $traffic * 1024 * 1024;
|
||||||
|
|
||||||
@@ -652,39 +664,40 @@ if($page == 'customers'
|
|||||||
$_theme = $settings['panel']['default_theme'];
|
$_theme = $settings['panel']['default_theme'];
|
||||||
|
|
||||||
$result = $db->query(
|
$result = $db->query(
|
||||||
"INSERT INTO `" . TABLE_PANEL_CUSTOMERS . "` SET
|
"INSERT INTO `" . TABLE_PANEL_CUSTOMERS . "` SET
|
||||||
`adminid` = '" . (int)$userinfo['adminid'] . "',
|
`adminid` = '" . (int)$userinfo['adminid'] . "',
|
||||||
`loginname` = '" . $db->escape($loginname) . "',
|
`loginname` = '" . $db->escape($loginname) . "',
|
||||||
`password` = '" . md5($password) . "',
|
`password` = '" . md5($password) . "',
|
||||||
`name` = '" . $db->escape($name) . "',
|
`name` = '" . $db->escape($name) . "',
|
||||||
`firstname` = '" . $db->escape($firstname) . "',
|
`firstname` = '" . $db->escape($firstname) . "',
|
||||||
`company` = '" . $db->escape($company) . "',
|
`gender` = '" . (int)$gender . "',
|
||||||
`street` = '" . $db->escape($street) . "',
|
`company` = '" . $db->escape($company) . "',
|
||||||
`zipcode` = '" . $db->escape($zipcode) . "',
|
`street` = '" . $db->escape($street) . "',
|
||||||
`city` = '" . $db->escape($city) . "',
|
`zipcode` = '" . $db->escape($zipcode) . "',
|
||||||
`phone` = '" . $db->escape($phone) . "',
|
`city` = '" . $db->escape($city) . "',
|
||||||
`fax` = '" . $db->escape($fax) . "',
|
`phone` = '" . $db->escape($phone) . "',
|
||||||
`email` = '" . $db->escape($email) . "',
|
`fax` = '" . $db->escape($fax) . "',
|
||||||
`customernumber` = '" . $db->escape($customernumber) . "',
|
`email` = '" . $db->escape($email) . "',
|
||||||
`def_language` = '" . $db->escape($def_language) . "',
|
`customernumber` = '" . $db->escape($customernumber) . "',
|
||||||
`documentroot` = '" . $db->escape($documentroot) . "',
|
`def_language` = '" . $db->escape($def_language) . "',
|
||||||
`guid` = '" . $db->escape($guid) . "',
|
`documentroot` = '" . $db->escape($documentroot) . "',
|
||||||
`diskspace` = '" . $db->escape($diskspace) . "',
|
`guid` = '" . $db->escape($guid) . "',
|
||||||
`traffic` = '" . $db->escape($traffic) . "',
|
`diskspace` = '" . $db->escape($diskspace) . "',
|
||||||
`subdomains` = '" . $db->escape($subdomains) . "',
|
`traffic` = '" . $db->escape($traffic) . "',
|
||||||
`emails` = '" . $db->escape($emails) . "',
|
`subdomains` = '" . $db->escape($subdomains) . "',
|
||||||
`email_accounts` = '" . $db->escape($email_accounts) . "',
|
`emails` = '" . $db->escape($emails) . "',
|
||||||
`email_forwarders` = '" . $db->escape($email_forwarders) . "',
|
`email_accounts` = '" . $db->escape($email_accounts) . "',
|
||||||
`email_quota` = '" . $db->escape($email_quota) . "',
|
`email_forwarders` = '" . $db->escape($email_forwarders) . "',
|
||||||
`ftps` = '" . $db->escape($ftps) . "',
|
`email_quota` = '" . $db->escape($email_quota) . "',
|
||||||
`tickets` = '" . $db->escape($tickets) . "',
|
`ftps` = '" . $db->escape($ftps) . "',
|
||||||
`mysqls` = '" . $db->escape($mysqls) . "',
|
`tickets` = '" . $db->escape($tickets) . "',
|
||||||
`standardsubdomain` = '0',
|
`mysqls` = '" . $db->escape($mysqls) . "',
|
||||||
`phpenabled` = '" . $db->escape($phpenabled) . "',
|
`standardsubdomain` = '0',
|
||||||
`imap` = '" . $db->escape($email_imap) . "',
|
`phpenabled` = '" . $db->escape($phpenabled) . "',
|
||||||
`pop3` = '" . $db->escape($email_pop3) . "',
|
`imap` = '" . $db->escape($email_imap) . "',
|
||||||
`aps_packages` = '" . (int)$number_of_aps_packages . "',
|
`pop3` = '" . $db->escape($email_pop3) . "',
|
||||||
`perlenabled` = '" . $db->escape($perlenabled) . "',
|
`aps_packages` = '" . (int)$number_of_aps_packages . "',
|
||||||
|
`perlenabled` = '" . $db->escape($perlenabled) . "',
|
||||||
`email_autoresponder` = '" . $db->escape($email_autoresponder) . "',
|
`email_autoresponder` = '" . $db->escape($email_autoresponder) . "',
|
||||||
`backup_allowed` = '" . $db->escape($backup_allowed) . "',
|
`backup_allowed` = '" . $db->escape($backup_allowed) . "',
|
||||||
`theme` = '" . $db->escape($_theme) . "'"
|
`theme` = '" . $db->escape($_theme) . "'"
|
||||||
@@ -761,6 +774,11 @@ if($page == 'customers'
|
|||||||
$log->logAction(ADM_ACTION, LOG_INFO, "added user '" . $loginname . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "added user '" . $loginname . "'");
|
||||||
inserttask('2', $loginname, $guid, $guid, $store_defaultindex);
|
inserttask('2', $loginname, $guid, $guid, $store_defaultindex);
|
||||||
|
|
||||||
|
# Using filesystem - quota, insert a task which cleans the filesystem - quota
|
||||||
|
if ($settings['system']['diskquota_enabled'])
|
||||||
|
{
|
||||||
|
inserttask('10');
|
||||||
|
}
|
||||||
// Add htpasswd for the webalizer stats
|
// Add htpasswd for the webalizer stats
|
||||||
|
|
||||||
if(CRYPT_STD_DES == 1)
|
if(CRYPT_STD_DES == 1)
|
||||||
@@ -802,16 +820,16 @@ if($page == 'customers'
|
|||||||
$_stdsubdomain = $loginname . '.' . $settings['system']['hostname'];
|
$_stdsubdomain = $loginname . '.' . $settings['system']['hostname'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$db->query("INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET " .
|
$db->query("INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET " .
|
||||||
"`domain` = '". $db->escape($_stdsubdomain) . "', " .
|
"`domain` = '". $db->escape($_stdsubdomain) . "', " .
|
||||||
"`customerid` = '" . (int)$customerid . "', " .
|
"`customerid` = '" . (int)$customerid . "', " .
|
||||||
"`adminid` = '" . (int)$userinfo['adminid'] . "', " .
|
"`adminid` = '" . (int)$userinfo['adminid'] . "', " .
|
||||||
"`parentdomainid` = '-1', " .
|
"`parentdomainid` = '-1', " .
|
||||||
"`ipandport` = '" . $db->escape($settings['system']['defaultip']) . "', " .
|
"`ipandport` = '" . $db->escape($settings['system']['defaultip']) . "', " .
|
||||||
"`documentroot` = '" . $db->escape($documentroot) . "', " .
|
"`documentroot` = '" . $db->escape($documentroot) . "', " .
|
||||||
"`zonefile` = '', " .
|
"`zonefile` = '', " .
|
||||||
"`isemaildomain` = '0', " .
|
"`isemaildomain` = '0', " .
|
||||||
"`caneditdomain` = '0', " .
|
"`caneditdomain` = '0', " .
|
||||||
"`openbasedir` = '1', " .
|
"`openbasedir` = '1', " .
|
||||||
"`safemode` = '1', " .
|
"`safemode` = '1', " .
|
||||||
"`speciallogfile` = '0', " .
|
"`speciallogfile` = '0', " .
|
||||||
@@ -897,7 +915,11 @@ if($page == 'customers'
|
|||||||
#$perlenabled = makeyesno('perlenabled', '1', '0', '0');
|
#$perlenabled = makeyesno('perlenabled', '1', '0', '0');
|
||||||
#$store_defaultindex = makeyesno('store_defaultindex', '1', '0', '1');
|
#$store_defaultindex = makeyesno('store_defaultindex', '1', '0', '1');
|
||||||
$backup_allowed = makeyesno('backup_allowed', '1', '0', '0');
|
$backup_allowed = makeyesno('backup_allowed', '1', '0', '0');
|
||||||
|
|
||||||
|
$gender_options = makeoption($lng['gender']['undef'], 0, true, true, true);
|
||||||
|
$gender_options .= makeoption($lng['gender']['male'], 1, null, true, true);
|
||||||
|
$gender_options .= makeoption($lng['gender']['female'], 2, null, true, true);
|
||||||
|
|
||||||
$customer_add_data = include_once dirname(__FILE__).'/lib/formfields/admin/customer/formfield.customer_add.php';
|
$customer_add_data = include_once dirname(__FILE__).'/lib/formfields/admin/customer/formfield.customer_add.php';
|
||||||
$customer_add_form = htmlform::genHTMLForm($customer_add_data);
|
$customer_add_form = htmlform::genHTMLForm($customer_add_data);
|
||||||
|
|
||||||
@@ -931,6 +953,7 @@ if($page == 'customers'
|
|||||||
$def_language = validate($_POST['def_language'], 'default language');
|
$def_language = validate($_POST['def_language'], 'default language');
|
||||||
$password = validate($_POST['new_customer_password'], 'new password');
|
$password = validate($_POST['new_customer_password'], 'new password');
|
||||||
$diskspace = intval_ressource($_POST['diskspace']);
|
$diskspace = intval_ressource($_POST['diskspace']);
|
||||||
|
$gender = intval_ressource($_POST['gender']);
|
||||||
|
|
||||||
if(isset($_POST['diskspace_ul']))
|
if(isset($_POST['diskspace_ul']))
|
||||||
{
|
{
|
||||||
@@ -998,16 +1021,16 @@ if($page == 'customers'
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
$email_autoresponder = 0;
|
$email_autoresponder = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
$email_imap = 0;
|
$email_imap = 0;
|
||||||
if(isset($_POST['email_imap']))
|
if(isset($_POST['email_imap']))
|
||||||
$email_imap = intval_ressource($_POST['email_imap']);
|
$email_imap = intval_ressource($_POST['email_imap']);
|
||||||
|
|
||||||
$email_pop3 = 0;
|
$email_pop3 = 0;
|
||||||
if(isset($_POST['email_pop3']))
|
if(isset($_POST['email_pop3']))
|
||||||
$email_pop3 = intval_ressource($_POST['email_pop3']);
|
$email_pop3 = intval_ressource($_POST['email_pop3']);
|
||||||
|
|
||||||
$ftps = 0;
|
$ftps = 0;
|
||||||
if(isset($_POST['ftps']))
|
if(isset($_POST['ftps']))
|
||||||
$ftps = intval_ressource($_POST['ftps']);
|
$ftps = intval_ressource($_POST['ftps']);
|
||||||
@@ -1024,15 +1047,20 @@ if($page == 'customers'
|
|||||||
{
|
{
|
||||||
$tickets = - 1;
|
$tickets = - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$backup_allowed = 0;
|
$backup_allowed = 0;
|
||||||
if (isset($_POST['backup_allowed']))
|
if (isset($_POST['backup_allowed']))
|
||||||
$backup_allowed = intval($_POST['backup_allowed']);
|
$backup_allowed = intval($_POST['backup_allowed']);
|
||||||
|
|
||||||
if($backup_allowed != '0'){
|
if($backup_allowed != '0'){
|
||||||
$backup_allowed = 1;
|
$backup_allowed = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// gender out of range? [0,2]
|
||||||
|
if ($gender < 0 || $gender > 2) {
|
||||||
|
$gender = 0;
|
||||||
|
}
|
||||||
|
|
||||||
$mysqls = 0;
|
$mysqls = 0;
|
||||||
if(isset($_POST['mysqls']))
|
if(isset($_POST['mysqls']))
|
||||||
$mysqls = intval_ressource($_POST['mysqls']);
|
$mysqls = intval_ressource($_POST['mysqls']);
|
||||||
@@ -1043,7 +1071,7 @@ if($page == 'customers'
|
|||||||
}
|
}
|
||||||
|
|
||||||
if($settings['aps']['aps_active'] == '1')
|
if($settings['aps']['aps_active'] == '1')
|
||||||
{
|
{
|
||||||
$number_of_aps_packages = intval_ressource($_POST['number_of_aps_packages']);
|
$number_of_aps_packages = intval_ressource($_POST['number_of_aps_packages']);
|
||||||
|
|
||||||
if(isset($_POST['number_of_aps_packages_ul']))
|
if(isset($_POST['number_of_aps_packages_ul']))
|
||||||
@@ -1059,15 +1087,15 @@ if($page == 'customers'
|
|||||||
$createstdsubdomain = 0;
|
$createstdsubdomain = 0;
|
||||||
if(isset($_POST['createstdsubdomain']))
|
if(isset($_POST['createstdsubdomain']))
|
||||||
$createstdsubdomain = intval($_POST['createstdsubdomain']);
|
$createstdsubdomain = intval($_POST['createstdsubdomain']);
|
||||||
|
|
||||||
$deactivated = 0;
|
$deactivated = 0;
|
||||||
if(isset($_POST['deactivated']))
|
if(isset($_POST['deactivated']))
|
||||||
$deactivated = intval($_POST['deactivated']);
|
$deactivated = intval($_POST['deactivated']);
|
||||||
|
|
||||||
$phpenabled = 0;
|
$phpenabled = 0;
|
||||||
if(isset($_POST['phpenabled']))
|
if(isset($_POST['phpenabled']))
|
||||||
$phpenabled = intval($_POST['phpenabled']);
|
$phpenabled = intval($_POST['phpenabled']);
|
||||||
|
|
||||||
$perlenabled = 0;
|
$perlenabled = 0;
|
||||||
if(isset($_POST['perlenabled']))
|
if(isset($_POST['perlenabled']))
|
||||||
$perlenabled = intval($_POST['perlenabled']);
|
$perlenabled = intval($_POST['perlenabled']);
|
||||||
@@ -1193,7 +1221,7 @@ if($page == 'customers'
|
|||||||
$db->query("UPDATE `" . TABLE_MAIL_USERS . "` SET `postfix`='" . (($deactivated) ? 'N' : 'Y') . "', `pop3`='" . (($deactivated) ? '0' : '1') . "', `imap`='" . (($deactivated) ? '0' : '1') . "' WHERE `customerid`='" . (int)$id . "'");
|
$db->query("UPDATE `" . TABLE_MAIL_USERS . "` SET `postfix`='" . (($deactivated) ? 'N' : 'Y') . "', `pop3`='" . (($deactivated) ? '0' : '1') . "', `imap`='" . (($deactivated) ? '0' : '1') . "' WHERE `customerid`='" . (int)$id . "'");
|
||||||
$db->query("UPDATE `" . TABLE_FTP_USERS . "` SET `login_enabled`='" . (($deactivated) ? 'N' : 'Y') . "' WHERE `customerid`='" . (int)$id . "'");
|
$db->query("UPDATE `" . TABLE_FTP_USERS . "` SET `login_enabled`='" . (($deactivated) ? 'N' : 'Y') . "' WHERE `customerid`='" . (int)$id . "'");
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `deactivated`='" . (int)$deactivated . "' WHERE `customerid`='" . (int)$id . "'");
|
$db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `deactivated`='" . (int)$deactivated . "' WHERE `customerid`='" . (int)$id . "'");
|
||||||
|
|
||||||
/* Retrieve customer's databases */
|
/* Retrieve customer's databases */
|
||||||
$databases = $db->query("SELECT * FROM " . TABLE_PANEL_DATABASES . " WHERE customerid='" . (int)$id . "' ORDER BY `dbserver`");
|
$databases = $db->query("SELECT * FROM " . TABLE_PANEL_DATABASES . " WHERE customerid='" . (int)$id . "' ORDER BY `dbserver`");
|
||||||
$db_root = new db($sql_root[0]['host'], $sql_root[0]['user'], $sql_root[0]['password'], '');
|
$db_root = new db($sql_root[0]['host'], $sql_root[0]['user'], $sql_root[0]['password'], '');
|
||||||
@@ -1215,7 +1243,7 @@ if($page == 'customers'
|
|||||||
foreach(array_unique(explode(',', $settings['system']['mysql_access_host'])) as $mysql_access_host)
|
foreach(array_unique(explode(',', $settings['system']['mysql_access_host'])) as $mysql_access_host)
|
||||||
{
|
{
|
||||||
$mysql_access_host = trim($mysql_access_host);
|
$mysql_access_host = trim($mysql_access_host);
|
||||||
|
|
||||||
/* Prevent access, if deactivated */
|
/* Prevent access, if deactivated */
|
||||||
if($deactivated)
|
if($deactivated)
|
||||||
{
|
{
|
||||||
@@ -1223,7 +1251,7 @@ if($page == 'customers'
|
|||||||
$db_root->query('REVOKE ALL PRIVILEGES ON `' . str_replace('_', '\_', $db_root->escape($row_database['databasename'])) . '` . * FROM `' . $db_root->escape($row_database['databasename']) . '`@`' . $db_root->escape($mysql_access_host) . '`');
|
$db_root->query('REVOKE ALL PRIVILEGES ON `' . str_replace('_', '\_', $db_root->escape($row_database['databasename'])) . '` . * FROM `' . $db_root->escape($row_database['databasename']) . '`@`' . $db_root->escape($mysql_access_host) . '`');
|
||||||
}
|
}
|
||||||
else /* Otherwise grant access */
|
else /* Otherwise grant access */
|
||||||
{
|
{
|
||||||
$db_root->query('GRANT ALL PRIVILEGES ON `' . $db_root->escape($row_database['databasename']) .'`.* TO `' . $db_root->escape($row_database['databasename']) . '`@`' . $db_root->escape($mysql_access_host) . '`');
|
$db_root->query('GRANT ALL PRIVILEGES ON `' . $db_root->escape($row_database['databasename']) .'`.* TO `' . $db_root->escape($row_database['databasename']) . '`@`' . $db_root->escape($mysql_access_host) . '`');
|
||||||
$db_root->query('GRANT ALL PRIVILEGES ON `' . str_replace('_', '\_', $db_root->escape($row_database['databasename'])) . '` . * TO `' . $db_root->escape($row_database['databasename']) . '`@`' . $db_root->escape($mysql_access_host) . '`');
|
$db_root->query('GRANT ALL PRIVILEGES ON `' . str_replace('_', '\_', $db_root->escape($row_database['databasename'])) . '` . * TO `' . $db_root->escape($row_database['databasename']) . '`@`' . $db_root->escape($mysql_access_host) . '`');
|
||||||
}
|
}
|
||||||
@@ -1233,7 +1261,7 @@ if($page == 'customers'
|
|||||||
/* At last flush the new privileges */
|
/* At last flush the new privileges */
|
||||||
$db_root->query('FLUSH PRIVILEGES;');
|
$db_root->query('FLUSH PRIVILEGES;');
|
||||||
$db_root->close();
|
$db_root->close();
|
||||||
|
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "deactivated user '" . $result['loginname'] . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "deactivated user '" . $result['loginname'] . "'");
|
||||||
inserttask('1');
|
inserttask('1');
|
||||||
}
|
}
|
||||||
@@ -1253,9 +1281,15 @@ if($page == 'customers'
|
|||||||
}
|
}
|
||||||
|
|
||||||
// $db->query("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `name`='" . $db->escape($name) . "', `firstname`='" . $db->escape($firstname) . "', `company`='" . $db->escape($company) . "', `street`='" . $db->escape($street) . "', `zipcode`='" . $db->escape($zipcode) . "', `city`='" . $db->escape($city) . "', `phone`='" . $db->escape($phone) . "', `fax`='" . $db->escape($fax) . "', `email`='" . $db->escape($email) . "', `customernumber`='" . $db->escape($customernumber) . "', `def_language`='" . $db->escape($def_language) . "', `password` = '" . $password . "', `diskspace`='" . $db->escape($diskspace) . "', `traffic`='" . $db->escape($traffic) . "', `subdomains`='" . $db->escape($subdomains) . "', `emails`='" . $db->escape($emails) . "', `email_accounts` = '" . $db->escape($email_accounts) . "', `email_forwarders`='" . $db->escape($email_forwarders) . "', `ftps`='" . $db->escape($ftps) . "', `tickets`='" . $db->escape($tickets) . "', `mysqls`='" . $db->escape($mysqls) . "', `deactivated`='" . $db->escape($deactivated) . "', `phpenabled`='" . $db->escape($phpenabled) . "', `email_quota`='" . $db->escape($email_quota) . "', `imap`='" . $db->escape($email_imap) . "', `pop3`='" . $db->escape($email_pop3) . "', `aps_packages`='" . (int)$number_of_aps_packages . "', `perlenabled`='" . $db->escape($perlenabled) . "', `email_autoresponder`='" . $db->escape($email_autoresponder) . "' WHERE `customerid`='" . (int)$id . "'");
|
// $db->query("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `name`='" . $db->escape($name) . "', `firstname`='" . $db->escape($firstname) . "', `company`='" . $db->escape($company) . "', `street`='" . $db->escape($street) . "', `zipcode`='" . $db->escape($zipcode) . "', `city`='" . $db->escape($city) . "', `phone`='" . $db->escape($phone) . "', `fax`='" . $db->escape($fax) . "', `email`='" . $db->escape($email) . "', `customernumber`='" . $db->escape($customernumber) . "', `def_language`='" . $db->escape($def_language) . "', `password` = '" . $password . "', `diskspace`='" . $db->escape($diskspace) . "', `traffic`='" . $db->escape($traffic) . "', `subdomains`='" . $db->escape($subdomains) . "', `emails`='" . $db->escape($emails) . "', `email_accounts` = '" . $db->escape($email_accounts) . "', `email_forwarders`='" . $db->escape($email_forwarders) . "', `ftps`='" . $db->escape($ftps) . "', `tickets`='" . $db->escape($tickets) . "', `mysqls`='" . $db->escape($mysqls) . "', `deactivated`='" . $db->escape($deactivated) . "', `phpenabled`='" . $db->escape($phpenabled) . "', `email_quota`='" . $db->escape($email_quota) . "', `imap`='" . $db->escape($email_imap) . "', `pop3`='" . $db->escape($email_pop3) . "', `aps_packages`='" . (int)$number_of_aps_packages . "', `perlenabled`='" . $db->escape($perlenabled) . "', `email_autoresponder`='" . $db->escape($email_autoresponder) . "' WHERE `customerid`='" . (int)$id . "'");
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `name`='" . $db->escape($name) . "', `firstname`='" . $db->escape($firstname) . "', `company`='" . $db->escape($company) . "', `street`='" . $db->escape($street) . "', `zipcode`='" . $db->escape($zipcode) . "', `city`='" . $db->escape($city) . "', `phone`='" . $db->escape($phone) . "', `fax`='" . $db->escape($fax) . "', `email`='" . $db->escape($email) . "', `customernumber`='" . $db->escape($customernumber) . "', `def_language`='" . $db->escape($def_language) . "', `password` = '" . $password . "', `diskspace`='" . $db->escape($diskspace) . "', `traffic`='" . $db->escape($traffic) . "', `subdomains`='" . $db->escape($subdomains) . "', `emails`='" . $db->escape($emails) . "', `email_accounts` = '" . $db->escape($email_accounts) . "', `email_forwarders`='" . $db->escape($email_forwarders) . "', `ftps`='" . $db->escape($ftps) . "', `tickets`='" . $db->escape($tickets) . "', `mysqls`='" . $db->escape($mysqls) . "', `deactivated`='" . $db->escape($deactivated) . "', `phpenabled`='" . $db->escape($phpenabled) . "', `email_quota`='" . $db->escape($email_quota) . "', `imap`='" . $db->escape($email_imap) . "', `pop3`='" . $db->escape($email_pop3) . "', `aps_packages`='" . (int)$number_of_aps_packages . "', `perlenabled`='" . $db->escape($perlenabled) . "', `email_autoresponder`='" . $db->escape($email_autoresponder) . "', `backup_allowed`='" . $db->escape($backup_allowed) . "' WHERE `customerid`='" . (int)$id . "'");
|
$db->query("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `name`='" . $db->escape($name) . "', `firstname`='" . $db->escape($firstname) . "', `gender`='" . $db->escape($gender) . "', `company`='" . $db->escape($company) . "', `street`='" . $db->escape($street) . "', `zipcode`='" . $db->escape($zipcode) . "', `city`='" . $db->escape($city) . "', `phone`='" . $db->escape($phone) . "', `fax`='" . $db->escape($fax) . "', `email`='" . $db->escape($email) . "', `customernumber`='" . $db->escape($customernumber) . "', `def_language`='" . $db->escape($def_language) . "', `password` = '" . $password . "', `diskspace`='" . $db->escape($diskspace) . "', `traffic`='" . $db->escape($traffic) . "', `subdomains`='" . $db->escape($subdomains) . "', `emails`='" . $db->escape($emails) . "', `email_accounts` = '" . $db->escape($email_accounts) . "', `email_forwarders`='" . $db->escape($email_forwarders) . "', `ftps`='" . $db->escape($ftps) . "', `tickets`='" . $db->escape($tickets) . "', `mysqls`='" . $db->escape($mysqls) . "', `deactivated`='" . $db->escape($deactivated) . "', `phpenabled`='" . $db->escape($phpenabled) . "', `email_quota`='" . $db->escape($email_quota) . "', `imap`='" . $db->escape($email_imap) . "', `pop3`='" . $db->escape($email_pop3) . "', `aps_packages`='" . (int)$number_of_aps_packages . "', `perlenabled`='" . $db->escape($perlenabled) . "', `email_autoresponder`='" . $db->escape($email_autoresponder) . "', `backup_allowed`='" . $db->escape($backup_allowed) . "' WHERE `customerid`='" . (int)$id . "'");
|
||||||
$admin_update_query = "UPDATE `" . TABLE_PANEL_ADMINS . "` SET `customers_used` = `customers_used` ";
|
$admin_update_query = "UPDATE `" . TABLE_PANEL_ADMINS . "` SET `customers_used` = `customers_used` ";
|
||||||
|
|
||||||
|
# Using filesystem - quota, insert a task which cleans the filesystem - quota
|
||||||
|
if ($settings['system']['diskquota_enabled'])
|
||||||
|
{
|
||||||
|
inserttask('10');
|
||||||
|
}
|
||||||
|
|
||||||
if($mysqls != '-1'
|
if($mysqls != '-1'
|
||||||
|| $result['mysqls'] != '-1')
|
|| $result['mysqls'] != '-1')
|
||||||
{
|
{
|
||||||
@@ -1548,6 +1582,10 @@ if($page == 'customers'
|
|||||||
$backup_allowed = makeyesno('backup_allowed', '1', '0', $result['backup_allowed']);
|
$backup_allowed = makeyesno('backup_allowed', '1', '0', $result['backup_allowed']);
|
||||||
$result = htmlentities_array($result);
|
$result = htmlentities_array($result);
|
||||||
|
|
||||||
|
$gender_options = makeoption($lng['gender']['undef'], 0, ($result['gender'] == '0' ? true : false), true, true);
|
||||||
|
$gender_options .= makeoption($lng['gender']['male'], 1, ($result['gender'] == '1' ? true : false), true, true);
|
||||||
|
$gender_options .= makeoption($lng['gender']['female'], 2, ($result['gender'] == '2' ? true : false), true, true);
|
||||||
|
|
||||||
$customer_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/customer/formfield.customer_edit.php';
|
$customer_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/customer/formfield.customer_edit.php';
|
||||||
$customer_edit_form = htmlform::genHTMLForm($customer_edit_data);
|
$customer_edit_form = htmlform::genHTMLForm($customer_edit_data);
|
||||||
|
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
@@ -227,23 +227,23 @@ if($page == 'domains'
|
|||||||
|
|
||||||
$domain = $idna_convert->encode(preg_replace(Array('/\:(\d)+$/', '/^https?\:\/\//'), '', validate($_POST['domain'], 'domain')));
|
$domain = $idna_convert->encode(preg_replace(Array('/\:(\d)+$/', '/^https?\:\/\//'), '', validate($_POST['domain'], 'domain')));
|
||||||
$subcanemaildomain = intval($_POST['subcanemaildomain']);
|
$subcanemaildomain = intval($_POST['subcanemaildomain']);
|
||||||
|
|
||||||
$isemaildomain = 0;
|
$isemaildomain = 0;
|
||||||
if(isset($_POST['isemaildomain']))
|
if(isset($_POST['isemaildomain']))
|
||||||
$isemaildomain = intval($_POST['isemaildomain']);
|
$isemaildomain = intval($_POST['isemaildomain']);
|
||||||
|
|
||||||
$email_only = 0;
|
$email_only = 0;
|
||||||
if(isset($_POST['email_only']))
|
if(isset($_POST['email_only']))
|
||||||
$email_only = intval($_POST['email_only']);
|
$email_only = intval($_POST['email_only']);
|
||||||
|
|
||||||
$wwwserveralias = 0;
|
$wwwserveralias = 0;
|
||||||
if(isset($_POST['wwwserveralias']))
|
if(isset($_POST['wwwserveralias']))
|
||||||
$wwwserveralias = intval($_POST['wwwserveralias']);
|
$wwwserveralias = intval($_POST['wwwserveralias']);
|
||||||
|
|
||||||
$speciallogfile = 0;
|
$speciallogfile = 0;
|
||||||
if(isset($_POST['speciallogfile']))
|
if(isset($_POST['speciallogfile']))
|
||||||
$speciallogfile = intval($_POST['speciallogfile']);
|
$speciallogfile = intval($_POST['speciallogfile']);
|
||||||
|
|
||||||
$aliasdomain = intval($_POST['alias']);
|
$aliasdomain = intval($_POST['alias']);
|
||||||
$issubof = intval($_POST['issubof']);
|
$issubof = intval($_POST['issubof']);
|
||||||
$customerid = intval($_POST['customerid']);
|
$customerid = intval($_POST['customerid']);
|
||||||
@@ -273,7 +273,8 @@ if($page == 'domains'
|
|||||||
}
|
}
|
||||||
|
|
||||||
$documentroot = $customer['documentroot'];
|
$documentroot = $customer['documentroot'];
|
||||||
$registration_date = validate($_POST['registration_date'], 'registration_date', '/^(19|20)\d\d[-](0[1-9]|1[012])[-](0[1-9]|[12][0-9]|3[01])$/', '', array('0000-00-00', '0', ''));
|
$registration_date = trim($_POST['registration_date']);
|
||||||
|
$registration_date = validate($registration_date, 'registration_date', '/^(19|20)\d\d[-](0[1-9]|1[012])[-](0[1-9]|[12][0-9]|3[01])$/', '', array('0000-00-00', '0', ''));
|
||||||
|
|
||||||
if($userinfo['change_serversettings'] == '1')
|
if($userinfo['change_serversettings'] == '1')
|
||||||
{
|
{
|
||||||
@@ -375,12 +376,15 @@ if($page == 'domains'
|
|||||||
|
|
||||||
if($settings['system']['use_ssl'] == "1"
|
if($settings['system']['use_ssl'] == "1"
|
||||||
&& isset($_POST['ssl'])
|
&& isset($_POST['ssl'])
|
||||||
&& isset($_POST['ssl_redirect'])
|
/*&& isset($_POST['ssl_redirect'])*/
|
||||||
&& isset($_POST['ssl_ipandport'])
|
&& isset($_POST['ssl_ipandport'])
|
||||||
&& $_POST['ssl'] != '0')
|
&& $_POST['ssl'] != '0')
|
||||||
{
|
{
|
||||||
$ssl = (int)$_POST['ssl'];
|
$ssl = (int)$_POST['ssl'];
|
||||||
$ssl_redirect = (int)$_POST['ssl_redirect'];
|
$ssl_redirect = 0;
|
||||||
|
if (isset($_POST['ssl_redirect'])) {
|
||||||
|
$ssl_redirect = (int)$_POST['ssl_redirect'];
|
||||||
|
}
|
||||||
$ssl_ipandport = (int)$_POST['ssl_ipandport'];
|
$ssl_ipandport = (int)$_POST['ssl_ipandport'];
|
||||||
$ssl_ipandport_check = $db->query_first("SELECT `id`, `ip`, `port` FROM `" . TABLE_PANEL_IPSANDPORTS . "` WHERE `id` = '" . $db->escape($ssl_ipandport) . "' AND `ssl` = '1'" . $additional_ip_condition);
|
$ssl_ipandport_check = $db->query_first("SELECT `id`, `ip`, `port` FROM `" . TABLE_PANEL_IPSANDPORTS . "` WHERE `id` = '" . $db->escape($ssl_ipandport) . "' AND `ssl` = '1'" . $additional_ip_condition);
|
||||||
|
|
||||||
@@ -476,7 +480,7 @@ if($page == 'domains'
|
|||||||
{
|
{
|
||||||
$caneditdomain = '0';
|
$caneditdomain = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
if($issubof <= '0')
|
if($issubof <= '0')
|
||||||
{
|
{
|
||||||
$issubof = '0';
|
$issubof = '0';
|
||||||
@@ -541,7 +545,7 @@ if($page == 'domains'
|
|||||||
);
|
);
|
||||||
|
|
||||||
$security_questions = array(
|
$security_questions = array(
|
||||||
'reallydisablesecuritysetting' => (($openbasedir == '0' || $safemode == '0') && $userinfo['change_serversettings'] == '1'),
|
'reallydisablesecuritysetting' => ($openbasedir == '0' && $userinfo['change_serversettings'] == '1'),
|
||||||
'reallydocrootoutofcustomerroot' => (substr($documentroot, 0, strlen($customer['documentroot'])) != $customer['documentroot'] && !preg_match('/^https?\:\/\//', $documentroot))
|
'reallydocrootoutofcustomerroot' => (substr($documentroot, 0, strlen($customer['documentroot'])) != $customer['documentroot'] && !preg_match('/^https?\:\/\//', $documentroot))
|
||||||
);
|
);
|
||||||
$question_nr = 1;
|
$question_nr = 1;
|
||||||
@@ -652,7 +656,7 @@ if($page == 'domains'
|
|||||||
{
|
{
|
||||||
$domains.= makeoption($idna_convert->decode($row_domain['domain']) . ' (' . $row_domain['loginname'] . ')', $row_domain['id']);
|
$domains.= makeoption($idna_convert->decode($row_domain['domain']) . ' (' . $row_domain['loginname'] . ')', $row_domain['id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$subtodomains = makeoption($lng['domains']['nosubtomaindomain'], 0, NULL, true);
|
$subtodomains = makeoption($lng['domains']['nosubtomaindomain'], 0, NULL, true);
|
||||||
$result_domains = $db->query("SELECT `d`.`id`, `d`.`domain`, `c`.`loginname` FROM `" . TABLE_PANEL_DOMAINS . "` `d`, `" . TABLE_PANEL_CUSTOMERS . "` `c` WHERE `d`.`aliasdomain` IS NULL AND `d`.`parentdomainid`=0 AND `d`.`ismainbutsubto`=0 " . $standardsubdomains . ($userinfo['customers_see_all'] ? '' : " AND `d`.`adminid` = '" . (int)$userinfo['adminid'] . "'") . " AND `d`.`customerid`=`c`.`customerid` ORDER BY `loginname`, `domain` ASC");
|
$result_domains = $db->query("SELECT `d`.`id`, `d`.`domain`, `c`.`loginname` FROM `" . TABLE_PANEL_DOMAINS . "` `d`, `" . TABLE_PANEL_CUSTOMERS . "` `c` WHERE `d`.`aliasdomain` IS NULL AND `d`.`parentdomainid`=0 AND `d`.`ismainbutsubto`=0 " . $standardsubdomains . ($userinfo['customers_see_all'] ? '' : " AND `d`.`adminid` = '" . (int)$userinfo['adminid'] . "'") . " AND `d`.`customerid`=`c`.`customerid` ORDER BY `loginname`, `domain` ASC");
|
||||||
|
|
||||||
@@ -680,7 +684,7 @@ if($page == 'domains'
|
|||||||
#$safemode = makeyesno('safemode', '1', '0', '1');
|
#$safemode = makeyesno('safemode', '1', '0', '1');
|
||||||
#$speciallogfile = makeyesno('speciallogfile', '1', '0', '0');
|
#$speciallogfile = makeyesno('speciallogfile', '1', '0', '0');
|
||||||
#$ssl = makeyesno('ssl', '1', '0', '0');
|
#$ssl = makeyesno('ssl', '1', '0', '0');
|
||||||
#$ssl_redirect = makeyesno('ssl_redirect', '1', '0', '0');
|
#$ssl_redirect = makeyesno('ssl_redirect', '1', '0', '0');
|
||||||
$add_date = date('Y-m-d');
|
$add_date = date('Y-m-d');
|
||||||
|
|
||||||
$domain_add_data = include_once dirname(__FILE__).'/lib/formfields/admin/domains/formfield.domains_add.php';
|
$domain_add_data = include_once dirname(__FILE__).'/lib/formfields/admin/domains/formfield.domains_add.php';
|
||||||
@@ -696,10 +700,10 @@ if($page == 'domains'
|
|||||||
elseif($action == 'edit'
|
elseif($action == 'edit'
|
||||||
&& $id != 0)
|
&& $id != 0)
|
||||||
{
|
{
|
||||||
$result = $db->query_first("SELECT `d`.*, `c`.`customerid` FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
$result = $db->query_first("SELECT `d`.*, `c`.`customerid` FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
||||||
LEFT JOIN `" . TABLE_PANEL_CUSTOMERS . "` `c` USING(`customerid`)
|
LEFT JOIN `" . TABLE_PANEL_CUSTOMERS . "` `c` USING(`customerid`)
|
||||||
WHERE `d`.`parentdomainid`='0'
|
WHERE `d`.`parentdomainid`='0'
|
||||||
AND `d`.`id`='" . (int)$id . "'"
|
AND `d`.`id`='" . (int)$id . "'"
|
||||||
. ($userinfo['customers_see_all'] ? '' : " AND `d`.`adminid` = '" . (int)$userinfo['adminid'] . "' "));
|
. ($userinfo['customers_see_all'] ? '' : " AND `d`.`adminid` = '" . (int)$userinfo['adminid'] . "' "));
|
||||||
|
|
||||||
if($result['domain'] != '')
|
if($result['domain'] != '')
|
||||||
@@ -780,20 +784,21 @@ if($page == 'domains'
|
|||||||
$issubof = intval($_POST['issubof']);
|
$issubof = intval($_POST['issubof']);
|
||||||
$subcanemaildomain = intval($_POST['subcanemaildomain']);
|
$subcanemaildomain = intval($_POST['subcanemaildomain']);
|
||||||
$caneditdomain = intval($_POST['caneditdomain']);
|
$caneditdomain = intval($_POST['caneditdomain']);
|
||||||
$registration_date = validate($_POST['registration_date'], 'registration_date', '/^(19|20)\d\d[-](0[1-9]|1[012])[-](0[1-9]|[12][0-9]|3[01])$/', '', array('0000-00-00', '0', ''));
|
$registration_date = trim($_POST['registration_date']);
|
||||||
|
$registration_date = validate($registration_date, 'registration_date', '/^(19|20)\d\d[-](0[1-9]|1[012])[-](0[1-9]|[12][0-9]|3[01])$/', '', array('0000-00-00', '0', ''));
|
||||||
|
|
||||||
$isemaildomain = 0;
|
$isemaildomain = 0;
|
||||||
if(isset($_POST['isemaildomain']))
|
if(isset($_POST['isemaildomain']))
|
||||||
$isemaildomain = intval($_POST['isemaildomain']);
|
$isemaildomain = intval($_POST['isemaildomain']);
|
||||||
|
|
||||||
$email_only = 0;
|
$email_only = 0;
|
||||||
if(isset($_POST['email_only']))
|
if(isset($_POST['email_only']))
|
||||||
$email_only = intval($_POST['email_only']);
|
$email_only = intval($_POST['email_only']);
|
||||||
|
|
||||||
$wwwserveralias = 0;
|
$wwwserveralias = 0;
|
||||||
if(isset($_POST['wwwserveralias']))
|
if(isset($_POST['wwwserveralias']))
|
||||||
$wwwserveralias = intval($_POST['wwwserveralias']);
|
$wwwserveralias = intval($_POST['wwwserveralias']);
|
||||||
|
|
||||||
if($userinfo['change_serversettings'] == '1')
|
if($userinfo['change_serversettings'] == '1')
|
||||||
{
|
{
|
||||||
$isbinddomain = intval($_POST['isbinddomain']);
|
$isbinddomain = intval($_POST['isbinddomain']);
|
||||||
@@ -890,12 +895,15 @@ if($page == 'domains'
|
|||||||
|
|
||||||
if($settings['system']['use_ssl'] == "1"
|
if($settings['system']['use_ssl'] == "1"
|
||||||
&& isset($_POST['ssl'])
|
&& isset($_POST['ssl'])
|
||||||
&& isset($_POST['ssl_redirect'])
|
/*&& isset($_POST['ssl_redirect'])*/
|
||||||
&& isset($_POST['ssl_ipandport'])
|
&& isset($_POST['ssl_ipandport'])
|
||||||
&& $_POST['ssl'] != '0')
|
&& $_POST['ssl'] != '0')
|
||||||
{
|
{
|
||||||
$ssl = (int)$_POST['ssl'];
|
$ssl = (int)$_POST['ssl'];
|
||||||
$ssl_redirect = (int)$_POST['ssl_redirect'];
|
$ssl_redirect = 0;
|
||||||
|
if (isset($_POST['ssl_redirect'])) {
|
||||||
|
$ssl_redirect = (int)$_POST['ssl_redirect'];
|
||||||
|
}
|
||||||
$ssl_ipandport = (int)$_POST['ssl_ipandport'];
|
$ssl_ipandport = (int)$_POST['ssl_ipandport'];
|
||||||
$ssl_ipandport_check = $db->query_first("SELECT `id`, `ip`, `port` FROM `" . TABLE_PANEL_IPSANDPORTS . "` WHERE `id` = '" . $db->escape($ssl_ipandport) . "' AND `ssl` = '1'" . $additional_ip_condition);
|
$ssl_ipandport_check = $db->query_first("SELECT `id`, `ip`, `port` FROM `" . TABLE_PANEL_IPSANDPORTS . "` WHERE `id` = '" . $db->escape($ssl_ipandport) . "' AND `ssl` = '1'" . $additional_ip_condition);
|
||||||
|
|
||||||
@@ -978,7 +986,7 @@ if($page == 'domains'
|
|||||||
{
|
{
|
||||||
standard_error('domainisaliasorothercustomer');
|
standard_error('domainisaliasorothercustomer');
|
||||||
}
|
}
|
||||||
|
|
||||||
if($issubof <= '0')
|
if($issubof <= '0')
|
||||||
{
|
{
|
||||||
$issubof = '0';
|
$issubof = '0';
|
||||||
@@ -1015,7 +1023,7 @@ if($page == 'domains'
|
|||||||
);
|
);
|
||||||
|
|
||||||
$security_questions = array(
|
$security_questions = array(
|
||||||
'reallydisablesecuritysetting' => (($openbasedir == '0' || $safemode == '0') && $userinfo['change_serversettings'] == '1'),
|
'reallydisablesecuritysetting' => ($openbasedir == '0' && $userinfo['change_serversettings'] == '1'),
|
||||||
'reallydocrootoutofcustomerroot' => (substr($documentroot, 0, strlen($customer['documentroot'])) != $customer['documentroot'] && !preg_match('/^https?\:\/\//', $documentroot))
|
'reallydocrootoutofcustomerroot' => (substr($documentroot, 0, strlen($customer['documentroot'])) != $customer['documentroot'] && !preg_match('/^https?\:\/\//', $documentroot))
|
||||||
);
|
);
|
||||||
foreach($security_questions as $question_name => $question_launch)
|
foreach($security_questions as $question_name => $question_launch)
|
||||||
@@ -1100,14 +1108,14 @@ if($page == 'domains'
|
|||||||
if($ssfs == 1)
|
if($ssfs == 1)
|
||||||
{
|
{
|
||||||
$upd_specialsettings = ", `specialsettings`='" . $db->escape($specialsettings) . "' ";
|
$upd_specialsettings = ", `specialsettings`='" . $db->escape($specialsettings) . "' ";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$upd_specialsettings = '';
|
$upd_specialsettings = '';
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `specialsettings`='' WHERE `parentdomainid`='" . (int)$id . "'");
|
$db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `specialsettings`='' WHERE `parentdomainid`='" . (int)$id . "'");
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "removed specialsettings on all subdomains of domain #" . $id);
|
$log->logAction(ADM_ACTION, LOG_INFO, "removed specialsettings on all subdomains of domain #" . $id);
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = $db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `customerid` = '" . (int)$customerid . "', `adminid` = '" . (int)$adminid . "', `documentroot`='" . $db->escape($documentroot) . "', `ipandport`='" . $db->escape($ipandport) . "', `ssl`='" . (int)$ssl . "', `ssl_redirect`='" . (int)$ssl_redirect . "', `ssl_ipandport`='" . (int)$ssl_ipandport . "', `aliasdomain`=" . (($aliasdomain != 0 && $alias_check == 0) ? '\'' . $db->escape($aliasdomain) . '\'' : 'NULL') . ", `isbinddomain`='" . $db->escape($isbinddomain) . "', `isemaildomain`='" . $db->escape($isemaildomain) . "', `email_only`='" . $db->escape($email_only) . "', `subcanemaildomain`='" . $db->escape($subcanemaildomain) . "', `dkim`='" . $db->escape($dkim) . "', `caneditdomain`='" . $db->escape($caneditdomain) . "', `zonefile`='" . $db->escape($zonefile) . "', `wwwserveralias`='" . $db->escape($wwwserveralias) . "', `openbasedir`='" . $db->escape($openbasedir) . "', `safemode`='" . $db->escape($safemode) . "', `phpsettingid`='" . $db->escape($phpsettingid) . "', `mod_fcgid_starter`='" . $db->escape($mod_fcgid_starter) . "', `mod_fcgid_maxrequests`='" . $db->escape($mod_fcgid_maxrequests) . "', `specialsettings`='" . $db->escape($specialsettings) . "', `registration_date`='" . $db->escape($registration_date) . "', `ismainbutsubto`='" . (int)$issubof . "' WHERE `id`='" . (int)$id . "'");
|
$result = $db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `customerid` = '" . (int)$customerid . "', `adminid` = '" . (int)$adminid . "', `documentroot`='" . $db->escape($documentroot) . "', `ipandport`='" . $db->escape($ipandport) . "', `ssl`='" . (int)$ssl . "', `ssl_redirect`='" . (int)$ssl_redirect . "', `ssl_ipandport`='" . (int)$ssl_ipandport . "', `aliasdomain`=" . (($aliasdomain != 0 && $alias_check == 0) ? '\'' . $db->escape($aliasdomain) . '\'' : 'NULL') . ", `isbinddomain`='" . $db->escape($isbinddomain) . "', `isemaildomain`='" . $db->escape($isemaildomain) . "', `email_only`='" . $db->escape($email_only) . "', `subcanemaildomain`='" . $db->escape($subcanemaildomain) . "', `dkim`='" . $db->escape($dkim) . "', `caneditdomain`='" . $db->escape($caneditdomain) . "', `zonefile`='" . $db->escape($zonefile) . "', `wwwserveralias`='" . $db->escape($wwwserveralias) . "', `openbasedir`='" . $db->escape($openbasedir) . "', `safemode`='" . $db->escape($safemode) . "', `phpsettingid`='" . $db->escape($phpsettingid) . "', `mod_fcgid_starter`='" . $db->escape($mod_fcgid_starter) . "', `mod_fcgid_maxrequests`='" . $db->escape($mod_fcgid_maxrequests) . "', `specialsettings`='" . $db->escape($specialsettings) . "', `registration_date`='" . $db->escape($registration_date) . "', `ismainbutsubto`='" . (int)$issubof . "' WHERE `id`='" . (int)$id . "'");
|
||||||
$result = $db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `customerid` = '" . (int)$customerid . "', `adminid` = '" . (int)$adminid . "', `ipandport`='" . $db->escape($ipandport) . "', `openbasedir`='" . $db->escape($openbasedir) . "', `safemode`='" . $db->escape($safemode) . "', `phpsettingid`='" . $db->escape($phpsettingid) . "', `mod_fcgid_starter`='" . $db->escape($mod_fcgid_starter) . "', `mod_fcgid_maxrequests`='" . $db->escape($mod_fcgid_maxrequests) . "'" . $upd_specialsettings . $updatechildren . " WHERE `parentdomainid`='" . (int)$id . "'");
|
$result = $db->query("UPDATE `" . TABLE_PANEL_DOMAINS . "` SET `customerid` = '" . (int)$customerid . "', `adminid` = '" . (int)$adminid . "', `ipandport`='" . $db->escape($ipandport) . "', `openbasedir`='" . $db->escape($openbasedir) . "', `safemode`='" . $db->escape($safemode) . "', `phpsettingid`='" . $db->escape($phpsettingid) . "', `mod_fcgid_starter`='" . $db->escape($mod_fcgid_starter) . "', `mod_fcgid_maxrequests`='" . $db->escape($mod_fcgid_maxrequests) . "'" . $upd_specialsettings . $updatechildren . " WHERE `parentdomainid`='" . (int)$id . "'");
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "edited domain #" . $id);
|
$log->logAction(ADM_ACTION, LOG_INFO, "edited domain #" . $id);
|
||||||
@@ -1235,7 +1243,7 @@ if($page == 'domains'
|
|||||||
}
|
}
|
||||||
|
|
||||||
#$specialsettingsforsubdomains = makeyesno('specialsettingsforsubdomains', '1', '0', '1');
|
#$specialsettingsforsubdomains = makeyesno('specialsettingsforsubdomains', '1', '0', '1');
|
||||||
|
|
||||||
$result = htmlentities_array($result);
|
$result = htmlentities_array($result);
|
||||||
|
|
||||||
$domain_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/domains/formfield.domains_edit.php';
|
$domain_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/domains/formfield.domains_edit.php';
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
@@ -107,7 +107,7 @@ if($page == 'overview')
|
|||||||
$lookfornewversion_lable = $_version;
|
$lookfornewversion_lable = $_version;
|
||||||
$lookfornewversion_link = $_link;
|
$lookfornewversion_link = $_link;
|
||||||
$lookfornewversion_addinfo = $_message;
|
$lookfornewversion_addinfo = $_message;
|
||||||
|
|
||||||
if (version_compare($version, $_version) == -1) {
|
if (version_compare($version, $_version) == -1) {
|
||||||
$isnewerversion = 1;
|
$isnewerversion = 1;
|
||||||
} else {
|
} else {
|
||||||
@@ -283,7 +283,7 @@ elseif($page == 'change_language')
|
|||||||
$language_options = '';
|
$language_options = '';
|
||||||
|
|
||||||
$default_lang = $settings['panel']['standardlanguage'];
|
$default_lang = $settings['panel']['standardlanguage'];
|
||||||
if($userinfo['def_language'] != '') {
|
if($userinfo['def_language'] != '') {
|
||||||
$default_lang = $userinfo['def_language'];
|
$default_lang = $userinfo['def_language'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
@@ -32,7 +32,7 @@ if(($page == 'settings' || $page == 'overview')
|
|||||||
{
|
{
|
||||||
$settings_data = loadConfigArrayDir('./actions/admin/settings/');
|
$settings_data = loadConfigArrayDir('./actions/admin/settings/');
|
||||||
$settings = loadSettings($settings_data, $db);
|
$settings = loadSettings($settings_data, $db);
|
||||||
|
|
||||||
if(isset($_POST['send'])
|
if(isset($_POST['send'])
|
||||||
&& $_POST['send'] == 'send')
|
&& $_POST['send'] == 'send')
|
||||||
{
|
{
|
||||||
@@ -65,9 +65,14 @@ if(($page == 'settings' || $page == 'overview')
|
|||||||
$only_enabledisable = true;
|
$only_enabledisable = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check if the session timeout is too low #815
|
||||||
|
if (isset($_POST['session_sessiontimeout']) && $_POST['session_sessiontimeout'] <= 60) {
|
||||||
|
standard_error($lng['error']['session_timeout'], $lng['error']['session_timeout_desc']);
|
||||||
|
}
|
||||||
|
|
||||||
if(processFormEx(
|
if(processFormEx(
|
||||||
$settings_data,
|
$settings_data,
|
||||||
$_POST,
|
$_POST,
|
||||||
array('filename' => $filename, 'action' => $action, 'page' => $page),
|
array('filename' => $filename, 'action' => $action, 'page' => $page),
|
||||||
$_part,
|
$_part,
|
||||||
$settings_all,
|
$settings_all,
|
||||||
@@ -86,24 +91,24 @@ if(($page == 'settings' || $page == 'overview')
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
$_part = isset($_GET['part']) ? $_GET['part'] : '';
|
$_part = isset($_GET['part']) ? $_GET['part'] : '';
|
||||||
|
|
||||||
if($_part == '')
|
if($_part == '')
|
||||||
{
|
{
|
||||||
$_part = isset($_POST['part']) ? $_POST['part'] : '';
|
$_part = isset($_POST['part']) ? $_POST['part'] : '';
|
||||||
}
|
}
|
||||||
|
|
||||||
$fields = buildFormEx($settings_data, $_part);
|
$fields = buildFormEx($settings_data, $_part);
|
||||||
|
|
||||||
$settings_page = '';
|
$settings_page = '';
|
||||||
if($_part == '')
|
if($_part == '')
|
||||||
{
|
{
|
||||||
eval("\$settings_page .= \"" . getTemplate("settings/settings_overview") . "\";");
|
eval("\$settings_page .= \"" . getTemplate("settings/settings_overview") . "\";");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
eval("\$settings_page .= \"" . getTemplate("settings/settings") . "\";");
|
eval("\$settings_page .= \"" . getTemplate("settings/settings") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("settings/settings_form_begin") . "\";");
|
eval("echo \"" . getTemplate("settings/settings_form_begin") . "\";");
|
||||||
eval("echo \$settings_page;");
|
eval("echo \$settings_page;");
|
||||||
eval("echo \"" . getTemplate("settings/settings_form_end") . "\";");
|
eval("echo \"" . getTemplate("settings/settings_form_end") . "\";");
|
||||||
@@ -121,6 +126,7 @@ elseif($page == 'rebuildconfigs'
|
|||||||
inserttask('4');
|
inserttask('4');
|
||||||
inserttask('5');
|
inserttask('5');
|
||||||
inserttask('9');
|
inserttask('9');
|
||||||
|
inserttask('10');
|
||||||
standard_success('rebuildingconfigs', '', array('filename' => 'admin_index.php'));
|
standard_success('rebuildingconfigs', '', array('filename' => 'admin_index.php'));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
@@ -41,7 +41,7 @@ if($page == 'tickets'
|
|||||||
|
|
||||||
$countcustomers = $db->query_first("SELECT COUNT(`customerid`) as `countcustomers` FROM `" . TABLE_PANEL_CUSTOMERS . "` " . ($userinfo['customers_see_all'] ? '' : " WHERE `adminid` = '" . (int)$userinfo['adminid'] . "' ") . "");
|
$countcustomers = $db->query_first("SELECT COUNT(`customerid`) as `countcustomers` FROM `" . TABLE_PANEL_CUSTOMERS . "` " . ($userinfo['customers_see_all'] ? '' : " WHERE `adminid` = '" . (int)$userinfo['adminid'] . "' ") . "");
|
||||||
$countcustomers = (int)$countcustomers['countcustomers'];
|
$countcustomers = (int)$countcustomers['countcustomers'];
|
||||||
|
|
||||||
if($action == '')
|
if($action == '')
|
||||||
{
|
{
|
||||||
$log->logAction(ADM_ACTION, LOG_NOTICE, "viewed admin_tickets");
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "viewed admin_tickets");
|
||||||
@@ -104,14 +104,14 @@ if($page == 'tickets'
|
|||||||
$cid = $row['customerid'];
|
$cid = $row['customerid'];
|
||||||
$usr = $db->query_first('SELECT `firstname`, `name`, `company`, `loginname` FROM `' . TABLE_PANEL_CUSTOMERS . '`
|
$usr = $db->query_first('SELECT `firstname`, `name`, `company`, `loginname` FROM `' . TABLE_PANEL_CUSTOMERS . '`
|
||||||
WHERE `customerid` = "' . (int)$cid . '"');
|
WHERE `customerid` = "' . (int)$cid . '"');
|
||||||
|
|
||||||
if(isset($usr['loginname'])) {
|
if(isset($usr['loginname'])) {
|
||||||
$customer = getCorrectFullUserDetails($usr) . ' (' . $usr['loginname'] . ')';
|
$customer = getCorrectFullUserDetails($usr) . ' (' . $usr['loginname'] . ')';
|
||||||
//$customer = $usr['firstname'] . " " . $usr['name'] . " (" . $usr['loginname'] . ")";
|
//$customer = $usr['firstname'] . " " . $usr['name'] . " (" . $usr['loginname'] . ")";
|
||||||
} else {
|
} else {
|
||||||
$customer = $lng['ticket']['nonexistingcustomer'];
|
$customer = $lng['ticket']['nonexistingcustomer'];
|
||||||
}
|
}
|
||||||
eval("\$tickets.=\"" . getTemplate("ticket/tickets_customer") . "\";");
|
eval("\$tickets.=\"" . getTemplate("tickets/tickets_customer") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
$tickets_count++;
|
$tickets_count++;
|
||||||
@@ -146,7 +146,7 @@ if($page == 'tickets'
|
|||||||
$row['subject'] = substr($row['subject'], 0, 17) . '...';
|
$row['subject'] = substr($row['subject'], 0, 17) . '...';
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("\$tickets.=\"" . getTemplate("ticket/tickets_tickets") . "\";");
|
eval("\$tickets.=\"" . getTemplate("tickets/tickets_tickets") . "\";");
|
||||||
$count++;
|
$count++;
|
||||||
$_cid = $row['customerid'];
|
$_cid = $row['customerid'];
|
||||||
}
|
}
|
||||||
@@ -155,7 +155,7 @@ if($page == 'tickets'
|
|||||||
$i++;
|
$i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets") . "\";");
|
||||||
}
|
}
|
||||||
elseif($action == 'new')
|
elseif($action == 'new')
|
||||||
{
|
{
|
||||||
@@ -228,13 +228,13 @@ if($page == 'tickets'
|
|||||||
$priorities.= makeoption($lng['ticket']['unf_normal'], '2', $settings['ticket']['default_priority']);
|
$priorities.= makeoption($lng['ticket']['unf_normal'], '2', $settings['ticket']['default_priority']);
|
||||||
$priorities.= makeoption($lng['ticket']['unf_low'], '3', $settings['ticket']['default_priority']);
|
$priorities.= makeoption($lng['ticket']['unf_low'], '3', $settings['ticket']['default_priority']);
|
||||||
|
|
||||||
$ticket_new_data = include_once dirname(__FILE__).'/lib/formfields/admin/ticket/formfield.ticket_new.php';
|
$ticket_new_data = include_once dirname(__FILE__).'/lib/formfields/admin/tickets/formfield.ticket_new.php';
|
||||||
$ticket_new_form = htmlform::genHTMLForm($ticket_new_data);
|
$ticket_new_form = htmlform::genHTMLForm($ticket_new_data);
|
||||||
|
|
||||||
$title = $ticket_new_data['ticket_new']['title'];
|
$title = $ticket_new_data['ticket_new']['title'];
|
||||||
$image = $ticket_new_data['ticket_new']['image'];
|
$image = $ticket_new_data['ticket_new']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_new") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_new") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -313,7 +313,7 @@ if($page == 'tickets'
|
|||||||
|
|
||||||
$subject = $mainticket->Get('subject');
|
$subject = $mainticket->Get('subject');
|
||||||
$message = $mainticket->Get('message');
|
$message = $mainticket->Get('message');
|
||||||
eval("\$ticket_replies.=\"" . getTemplate("ticket/tickets_tickets_main") . "\";");
|
eval("\$ticket_replies.=\"" . getTemplate("tickets/tickets_tickets_main") . "\";");
|
||||||
$result = $db->query('SELECT `name` FROM `' . TABLE_PANEL_TICKET_CATS . '`
|
$result = $db->query('SELECT `name` FROM `' . TABLE_PANEL_TICKET_CATS . '`
|
||||||
WHERE `id`="' . (int)$mainticket->Get('category') . '"');
|
WHERE `id`="' . (int)$mainticket->Get('category') . '"');
|
||||||
$row = $db->fetch_array($result);
|
$row = $db->fetch_array($result);
|
||||||
@@ -335,7 +335,7 @@ if($page == 'tickets'
|
|||||||
|
|
||||||
$subject = $subticket->Get('subject');
|
$subject = $subticket->Get('subject');
|
||||||
$message = $subticket->Get('message');
|
$message = $subticket->Get('message');
|
||||||
eval("\$ticket_replies.=\"" . getTemplate("ticket/tickets_tickets_list") . "\";");
|
eval("\$ticket_replies.=\"" . getTemplate("tickets/tickets_tickets_list") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
$priorities = makeoption($lng['ticket']['high'], '1', $mainticket->Get('priority'), true, true);
|
$priorities = makeoption($lng['ticket']['high'], '1', $mainticket->Get('priority'), true, true);
|
||||||
@@ -345,13 +345,13 @@ if($page == 'tickets'
|
|||||||
$ticket_replies_count = $db->num_rows($andere) + 1;
|
$ticket_replies_count = $db->num_rows($andere) + 1;
|
||||||
|
|
||||||
// don't forget the main-ticket!
|
// don't forget the main-ticket!
|
||||||
$ticket_reply_data = include_once dirname(__FILE__).'/lib/formfields/admin/ticket/formfield.ticket_reply.php';
|
$ticket_reply_data = include_once dirname(__FILE__).'/lib/formfields/admin/tickets/formfield.ticket_reply.php';
|
||||||
$ticket_reply_form = htmlform::genHTMLForm($ticket_reply_data);
|
$ticket_reply_form = htmlform::genHTMLForm($ticket_reply_data);
|
||||||
|
|
||||||
$title = $ticket_reply_data['ticket_reply']['title'];
|
$title = $ticket_reply_data['ticket_reply']['title'];
|
||||||
$image = $ticket_reply_data['ticket_reply']['image'];
|
$image = $ticket_reply_data['ticket_reply']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_reply") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_reply") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif($action == 'close'
|
elseif($action == 'close'
|
||||||
@@ -466,14 +466,14 @@ elseif($page == 'categories'
|
|||||||
{
|
{
|
||||||
$row = htmlentities_array($row);
|
$row = htmlentities_array($row);
|
||||||
$closedtickets_count = ($row['ticketcount'] - $row['ticketcountnotclosed']);
|
$closedtickets_count = ($row['ticketcount'] - $row['ticketcountnotclosed']);
|
||||||
eval("\$ticketcategories.=\"" . getTemplate("ticket/tickets_categories") . "\";");
|
eval("\$ticketcategories.=\"" . getTemplate("tickets/tickets_categories") . "\";");
|
||||||
$count++;
|
$count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
$i++;
|
$i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/categories") . "\";");
|
eval("echo \"" . getTemplate("tickets/categories") . "\";");
|
||||||
}
|
}
|
||||||
elseif($action == 'addcategory')
|
elseif($action == 'addcategory')
|
||||||
{
|
{
|
||||||
@@ -482,7 +482,7 @@ elseif($page == 'categories'
|
|||||||
{
|
{
|
||||||
$category = validate($_POST['category'], 'category');
|
$category = validate($_POST['category'], 'category');
|
||||||
$order = validate($_POST['logicalorder'], 'logicalorder');
|
$order = validate($_POST['logicalorder'], 'logicalorder');
|
||||||
|
|
||||||
if($order < 1 || $order >= 1000)
|
if($order < 1 || $order >= 1000)
|
||||||
{
|
{
|
||||||
// use the latest available
|
// use the latest available
|
||||||
@@ -504,13 +504,13 @@ elseif($page == 'categories'
|
|||||||
{
|
{
|
||||||
$order = ticket::getHighestOrderNumber($db) + 1;
|
$order = ticket::getHighestOrderNumber($db) + 1;
|
||||||
|
|
||||||
$category_new_data = include_once dirname(__FILE__).'/lib/formfields/admin/ticket/formfield.category_new.php';
|
$category_new_data = include_once dirname(__FILE__).'/lib/formfields/admin/tickets/formfield.category_new.php';
|
||||||
$category_new_form = htmlform::genHTMLForm($category_new_data);
|
$category_new_form = htmlform::genHTMLForm($category_new_data);
|
||||||
|
|
||||||
$title = $category_new_data['category_new']['title'];
|
$title = $category_new_data['category_new']['title'];
|
||||||
$image = $category_new_data['category_new']['image'];
|
$image = $category_new_data['category_new']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_newcategory") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_newcategory") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif($action == 'editcategory'
|
elseif($action == 'editcategory'
|
||||||
@@ -542,13 +542,13 @@ elseif($page == 'categories'
|
|||||||
{
|
{
|
||||||
$row = $db->query_first('SELECT * FROM `' . TABLE_PANEL_TICKET_CATS . '` WHERE `id` = "' . (int)$id . '"');
|
$row = $db->query_first('SELECT * FROM `' . TABLE_PANEL_TICKET_CATS . '` WHERE `id` = "' . (int)$id . '"');
|
||||||
|
|
||||||
$category_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/ticket/formfield.category_edit.php';
|
$category_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/tickets/formfield.category_edit.php';
|
||||||
$category_edit_form = htmlform::genHTMLForm($category_edit_data);
|
$category_edit_form = htmlform::genHTMLForm($category_edit_data);
|
||||||
|
|
||||||
$title = $category_edit_data['category_edit']['title'];
|
$title = $category_edit_data['category_edit']['title'];
|
||||||
$image = $category_edit_data['category_edit']['image'];
|
$image = $category_edit_data['category_edit']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_editcategory") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_editcategory") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif($action == 'deletecategory'
|
elseif($action == 'deletecategory'
|
||||||
@@ -662,14 +662,14 @@ elseif($page == 'archive'
|
|||||||
$cid = $ticket['customerid'];
|
$cid = $ticket['customerid'];
|
||||||
$usr = $db->query_first('SELECT `firstname`, `name`, `company`, `loginname` FROM `' . TABLE_PANEL_CUSTOMERS . '`
|
$usr = $db->query_first('SELECT `firstname`, `name`, `company`, `loginname` FROM `' . TABLE_PANEL_CUSTOMERS . '`
|
||||||
WHERE `customerid` = "' . (int)$cid . '"');
|
WHERE `customerid` = "' . (int)$cid . '"');
|
||||||
|
|
||||||
if(isset($usr['loginname'])) {
|
if(isset($usr['loginname'])) {
|
||||||
$customer = getCorrectFullUserDetails($usr) . ' (' . $usr['loginname'] . ')';
|
$customer = getCorrectFullUserDetails($usr) . ' (' . $usr['loginname'] . ')';
|
||||||
} else {
|
} else {
|
||||||
$customer = $lng['ticket']['nonexistingcustomer'];
|
$customer = $lng['ticket']['nonexistingcustomer'];
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("\$tickets.=\"" . getTemplate("ticket/tickets_customer") . "\";");
|
eval("\$tickets.=\"" . getTemplate("tickets/tickets_customer") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
$tickets_count++;
|
$tickets_count++;
|
||||||
@@ -691,7 +691,7 @@ elseif($page == 'archive'
|
|||||||
|
|
||||||
$ticket = htmlentities_array($ticket);
|
$ticket = htmlentities_array($ticket);
|
||||||
|
|
||||||
eval("\$tickets.=\"" . getTemplate("ticket/archived_tickets") . "\";");
|
eval("\$tickets.=\"" . getTemplate("tickets/archived_tickets") . "\";");
|
||||||
$count++;
|
$count++;
|
||||||
$_cid = $ticket['customerid'];
|
$_cid = $ticket['customerid'];
|
||||||
}
|
}
|
||||||
@@ -700,7 +700,7 @@ elseif($page == 'archive'
|
|||||||
$i++;
|
$i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/archivesearch") . "\";");
|
eval("echo \"" . getTemplate("tickets/archivesearch") . "\";");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -729,7 +729,7 @@ elseif($page == 'archive'
|
|||||||
$ticket['subject'] = substr($ticket['subject'], 0, 17) . '...';
|
$ticket['subject'] = substr($ticket['subject'], 0, 17) . '...';
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("\$tickets.=\"" . getTemplate("ticket/archived_tickets") . "\";");
|
eval("\$tickets.=\"" . getTemplate("tickets/archived_tickets") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -754,7 +754,7 @@ elseif($page == 'archive'
|
|||||||
$customers.= makeoption(getCorrectFullUserDetails($row_customer) . ' (' . $row_customer['loginname'] . ')', $row_customer['customerid']);
|
$customers.= makeoption(getCorrectFullUserDetails($row_customer) . ' (' . $row_customer['loginname'] . ')', $row_customer['customerid']);
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/archive") . "\";");
|
eval("echo \"" . getTemplate("tickets/archive") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif($action == 'view'
|
elseif($action == 'view'
|
||||||
@@ -779,7 +779,7 @@ elseif($page == 'archive'
|
|||||||
|
|
||||||
$subject = htmlentities($mainticket->Get('subject'));
|
$subject = htmlentities($mainticket->Get('subject'));
|
||||||
$message = htmlentities($mainticket->Get('message'));
|
$message = htmlentities($mainticket->Get('message'));
|
||||||
eval("\$ticket_replies.=\"" . getTemplate("ticket/tickets_tickets_main") . "\";");
|
eval("\$ticket_replies.=\"" . getTemplate("tickets/tickets_tickets_main") . "\";");
|
||||||
$result = $db->query('SELECT `name` FROM `' . TABLE_PANEL_TICKET_CATS . '`
|
$result = $db->query('SELECT `name` FROM `' . TABLE_PANEL_TICKET_CATS . '`
|
||||||
WHERE `id`="' . (int)$mainticket->Get('category') . '"');
|
WHERE `id`="' . (int)$mainticket->Get('category') . '"');
|
||||||
$row = $db->fetch_array($result);
|
$row = $db->fetch_array($result);
|
||||||
@@ -801,7 +801,7 @@ elseif($page == 'archive'
|
|||||||
|
|
||||||
$subject = htmlentities($subticket->Get('subject'));
|
$subject = htmlentities($subticket->Get('subject'));
|
||||||
$message = htmlentities($subticket->Get('message'));
|
$message = htmlentities($subticket->Get('message'));
|
||||||
eval("\$ticket_replies.=\"" . getTemplate("ticket/tickets_tickets_list") . "\";");
|
eval("\$ticket_replies.=\"" . getTemplate("tickets/tickets_tickets_list") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
$priorities = makeoption($lng['ticket']['high'], '1', htmlentities($mainticket->Get('priority')), true, true);
|
$priorities = makeoption($lng['ticket']['high'], '1', htmlentities($mainticket->Get('priority')), true, true);
|
||||||
@@ -812,7 +812,7 @@ elseif($page == 'archive'
|
|||||||
|
|
||||||
// don't forget the main-ticket!
|
// don't forget the main-ticket!
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_view") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_view") . "\";");
|
||||||
}
|
}
|
||||||
elseif($action == 'delete'
|
elseif($action == 'delete'
|
||||||
&& $id != 0)
|
&& $id != 0)
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* @author Morton Jonuschat <m.jonuschat@chrome-it.de>
|
* @author Morton Jonuschat <m.jonuschat@chrome-it.de>
|
||||||
* @license GPLv2 http://files.syscp.org/misc/COPYING.txt
|
* @license GPLv2 http://files.syscp.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id: $
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
|
|||||||
1
cache/.gitignore
vendored
Normal file
1
cache/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
*
|
||||||
0
cache/.keep
vendored
Normal file
0
cache/.keep
vendored
Normal file
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Required code
|
// Required code
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Required code
|
// Required code
|
||||||
@@ -32,13 +32,13 @@ if($action == "add")
|
|||||||
$account = trim($_POST['account']);
|
$account = trim($_POST['account']);
|
||||||
$subject = trim($_POST['subject']);
|
$subject = trim($_POST['subject']);
|
||||||
$message = trim($_POST['message']);
|
$message = trim($_POST['message']);
|
||||||
|
|
||||||
$date_from_off = isset($_POST['date_from_off']) ? -1 : 0;
|
$date_from_off = isset($_POST['date_from_off']) ? -1 : 0;
|
||||||
$date_until_off = isset($_POST['date_until_off']) ? -1 : 0;
|
$date_until_off = isset($_POST['date_until_off']) ? -1 : 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @TODO validate date (DD-MM-YYYY)
|
* @TODO validate date (DD-MM-YYYY)
|
||||||
*/
|
*/
|
||||||
$ts_from = -1;
|
$ts_from = -1;
|
||||||
$ts_until = -1;
|
$ts_until = -1;
|
||||||
|
|
||||||
@@ -106,19 +106,19 @@ if($action == "add")
|
|||||||
{
|
{
|
||||||
$accounts.= "<option value=\"" . $row['email'] . "\">" . $row['email'] . "</option>";
|
$accounts.= "<option value=\"" . $row['email'] . "\">" . $row['email'] . "</option>";
|
||||||
}
|
}
|
||||||
|
|
||||||
$date_from_off = makecheckbox('date_from_off', $lng['panel']['not_activated'], '-1', false, '-1', true, true);
|
$date_from_off = makecheckbox('date_from_off', $lng['panel']['not_activated'], '-1', false, '-1', true, true);
|
||||||
$date_until_off = makecheckbox('date_until_off', $lng['panel']['not_activated'], '-1', false, '-1', true, true);
|
$date_until_off = makecheckbox('date_until_off', $lng['panel']['not_activated'], '-1', false, '-1', true, true);
|
||||||
|
|
||||||
#$isactive = makeyesno('active', '1', '0', '1');
|
#$isactive = makeyesno('active', '1', '0', '1');
|
||||||
|
|
||||||
$autoresponder_add_data = include_once dirname(__FILE__).'/lib/formfields/customer/email/formfield.emails_addautoresponder.php';
|
$autoresponder_add_data = include_once dirname(__FILE__).'/lib/formfields/customer/autoresponder/formfield.autoresponder_add.php';
|
||||||
$autoresponder_add_form = htmlform::genHTMLForm($autoresponder_add_data);
|
$autoresponder_add_form = htmlform::genHTMLForm($autoresponder_add_data);
|
||||||
|
|
||||||
$title = $autoresponder_add_data['autoresponder_add']['title'];
|
$title = $autoresponder_add_data['autoresponder_add']['title'];
|
||||||
$image = $autoresponder_add_data['autoresponder_add']['image'];
|
$image = $autoresponder_add_data['autoresponder_add']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("email/autoresponder_add") . "\";");
|
eval("echo \"" . getTemplate("autoresponder/autoresponder_add") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Edit autoresponder
|
// Edit autoresponder
|
||||||
@@ -136,10 +136,10 @@ if($action == "edit")
|
|||||||
|
|
||||||
$date_from_off = isset($_POST['date_from_off']) ? -1 : 0;
|
$date_from_off = isset($_POST['date_from_off']) ? -1 : 0;
|
||||||
$date_until_off = isset($_POST['date_until_off']) ? -1 : 0;
|
$date_until_off = isset($_POST['date_until_off']) ? -1 : 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @TODO validate date (DD-MM-YYYY)
|
* @TODO validate date (DD-MM-YYYY)
|
||||||
*/
|
*/
|
||||||
$ts_from = -1;
|
$ts_from = -1;
|
||||||
$ts_until = -1;
|
$ts_until = -1;
|
||||||
|
|
||||||
@@ -152,7 +152,7 @@ if($action == "edit")
|
|||||||
{
|
{
|
||||||
$date_until = $_POST['date_until'];
|
$date_until = $_POST['date_until'];
|
||||||
$ts_until = mktime(0, 0, 0, substr($date_until, 3, 2), substr($date_until, 0, 2), substr($date_until, 6, 4));
|
$ts_until = mktime(0, 0, 0, substr($date_until, 3, 2), substr($date_until, 0, 2), substr($date_until, 6, 4));
|
||||||
}
|
}
|
||||||
|
|
||||||
if(empty($account)
|
if(empty($account)
|
||||||
|| empty($subject)
|
|| empty($subject)
|
||||||
@@ -191,7 +191,7 @@ if($action == "edit")
|
|||||||
SET `message` = '" . $db->escape($message) . "',
|
SET `message` = '" . $db->escape($message) . "',
|
||||||
`enabled` = '" . (int)$ResponderActive . "',
|
`enabled` = '" . (int)$ResponderActive . "',
|
||||||
`date_from` = '" . (int)$ts_from . "',
|
`date_from` = '" . (int)$ts_from . "',
|
||||||
`date_until` = '" . (int)$ts_until . "',
|
`date_until` = '" . (int)$ts_until . "',
|
||||||
`subject` = '" . $db->escape($subject) . "'
|
`subject` = '" . $db->escape($subject) . "'
|
||||||
WHERE `email` = '" . $db->escape($account) . "'
|
WHERE `email` = '" . $db->escape($account) . "'
|
||||||
AND `customerid` = '" . $db->escape((int)$userinfo['customerid']) . "'
|
AND `customerid` = '" . $db->escape((int)$userinfo['customerid']) . "'
|
||||||
@@ -213,10 +213,10 @@ if($action == "edit")
|
|||||||
$row = $db->fetch_array($result);
|
$row = $db->fetch_array($result);
|
||||||
$subject = htmlspecialchars($row['subject']);
|
$subject = htmlspecialchars($row['subject']);
|
||||||
$message = htmlspecialchars($row['message']);
|
$message = htmlspecialchars($row['message']);
|
||||||
|
|
||||||
$date_from = (int)$row['date_from'];
|
$date_from = (int)$row['date_from'];
|
||||||
$date_until = (int)$row['date_until'];
|
$date_until = (int)$row['date_until'];
|
||||||
|
|
||||||
if($date_from == -1)
|
if($date_from == -1)
|
||||||
{
|
{
|
||||||
$deactivated = '-1';
|
$deactivated = '-1';
|
||||||
@@ -228,7 +228,7 @@ if($action == "edit")
|
|||||||
$date_from = date('d-m-Y', $date_from);
|
$date_from = date('d-m-Y', $date_from);
|
||||||
}
|
}
|
||||||
$date_from_off = makecheckbox('date_from_off', $lng['panel']['not_activated'], '-1', false, $deactivated, true, true);
|
$date_from_off = makecheckbox('date_from_off', $lng['panel']['not_activated'], '-1', false, $deactivated, true, true);
|
||||||
|
|
||||||
if($date_until == -1)
|
if($date_until == -1)
|
||||||
{
|
{
|
||||||
$deactivated = '-1';
|
$deactivated = '-1';
|
||||||
@@ -240,16 +240,16 @@ if($action == "edit")
|
|||||||
$date_until = date('d-m-Y', $date_until);
|
$date_until = date('d-m-Y', $date_until);
|
||||||
}
|
}
|
||||||
$date_until_off = makecheckbox('date_until_off', $lng['panel']['not_activated'], '-1', false, $deactivated, true, true);
|
$date_until_off = makecheckbox('date_until_off', $lng['panel']['not_activated'], '-1', false, $deactivated, true, true);
|
||||||
|
|
||||||
#$isactive = makeyesno('active', '1', '0', $row['enabled']);
|
#$isactive = makeyesno('active', '1', '0', $row['enabled']);
|
||||||
|
|
||||||
$autoresponder_edit_data = include_once dirname(__FILE__).'/lib/formfields/customer/email/formfield.emails_editautoresponder.php';
|
$autoresponder_edit_data = include_once dirname(__FILE__).'/lib/formfields/customer/autoresponder/formfield.autoresponder_edit.php';
|
||||||
$autoresponder_edit_form = htmlform::genHTMLForm($autoresponder_edit_data);
|
$autoresponder_edit_form = htmlform::genHTMLForm($autoresponder_edit_data);
|
||||||
|
|
||||||
$title = $autoresponder_edit_data['autoresponder_edit']['title'];
|
$title = $autoresponder_edit_data['autoresponder_edit']['title'];
|
||||||
$image = $autoresponder_edit_data['autoresponder_edit']['image'];
|
$image = $autoresponder_edit_data['autoresponder_edit']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("email/autoresponder_edit") . "\";");
|
eval("echo \"" . getTemplate("autoresponder/autoresponder_edit") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete autoresponder
|
// Delete autoresponder
|
||||||
@@ -286,7 +286,7 @@ if($action == "delete")
|
|||||||
|
|
||||||
// List existing autoresponders
|
// List existing autoresponders
|
||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$autoresponder = '';
|
$autoresponder = '';
|
||||||
$count = 0;
|
$count = 0;
|
||||||
@@ -305,14 +305,14 @@ else
|
|||||||
elseif($row['date_from'] != -1 && $row['date_until'] == -1)
|
elseif($row['date_from'] != -1 && $row['date_until'] == -1)
|
||||||
{
|
{
|
||||||
$activated_date = $lng['autoresponder']['date_from'].': '.date('d-m-Y', $row['date_from']);
|
$activated_date = $lng['autoresponder']['date_from'].': '.date('d-m-Y', $row['date_from']);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$activated_date = date('d-m-Y', $row['date_from']) . ' - ' . date('d-m-Y', $row['date_until']);
|
$activated_date = date('d-m-Y', $row['date_from']) . ' - ' . date('d-m-Y', $row['date_until']);
|
||||||
}
|
}
|
||||||
eval("\$autoresponder.=\"" . getTemplate("email/autoresponder_autoresponder") . "\";");
|
eval("\$autoresponder.=\"" . getTemplate("autoresponder/autoresponder_autoresponder") . "\";");
|
||||||
$count++;
|
$count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("email/autoresponder") . "\";");
|
eval("echo \"" . getTemplate("autoresponder/autoresponder") . "\";");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
@@ -49,7 +49,7 @@ elseif($page == 'accounts')
|
|||||||
'homedir' => $lng['panel']['path']
|
'homedir' => $lng['panel']['path']
|
||||||
);
|
);
|
||||||
$paging = new paging($userinfo, $db, TABLE_FTP_USERS, $fields, $settings['panel']['paging'], $settings['panel']['natsorting']);
|
$paging = new paging($userinfo, $db, TABLE_FTP_USERS, $fields, $settings['panel']['paging'], $settings['panel']['natsorting']);
|
||||||
$result = $db->query("SELECT `id`, `username`, `homedir` FROM `" . TABLE_FTP_USERS . "` WHERE `customerid`='" . $userinfo['customerid'] . "' " . $paging->getSqlWhere(true) . " " . $paging->getSqlOrderBy() . " " . $paging->getSqlLimit());
|
$result = $db->query("SELECT `id`, `username`, `homedir` FROM `" . TABLE_FTP_USERS . "` WHERE `customerid`='" . $userinfo['customerid'] . "' AND `username` NOT LIKE '%_backup'" . $paging->getSqlWhere(true) . " " . $paging->getSqlOrderBy() . " " . $paging->getSqlLimit());
|
||||||
$paging->setEntries($db->num_rows($result));
|
$paging->setEntries($db->num_rows($result));
|
||||||
$sortcode = $paging->getHtmlSortCode($lng);
|
$sortcode = $paging->getHtmlSortCode($lng);
|
||||||
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
||||||
@@ -312,6 +312,11 @@ elseif($page == 'accounts')
|
|||||||
{
|
{
|
||||||
$log->logAction(USR_ACTION, LOG_INFO, "updated ftp-account password for '" . $result['username'] . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "updated ftp-account password for '" . $result['username'] . "'");
|
||||||
$db->query("UPDATE `" . TABLE_FTP_USERS . "` SET `password`=ENCRYPT('" . $db->escape($password) . "') WHERE `customerid`='" . (int)$userinfo['customerid'] . "' AND `id`='" . (int)$id . "'");
|
$db->query("UPDATE `" . TABLE_FTP_USERS . "` SET `password`=ENCRYPT('" . $db->escape($password) . "') WHERE `customerid`='" . (int)$userinfo['customerid'] . "' AND `id`='" . (int)$id . "'");
|
||||||
|
|
||||||
|
// also update customers backup user password if password of main ftp user is changed
|
||||||
|
if(!preg_match('/' . $settings['customer']['ftpprefix'] . '/', $result['username'])){
|
||||||
|
$db->query("UPDATE `" . TABLE_FTP_USERS . "` SET `password`=ENCRYPT('" . $db->escape($password) . "') WHERE `customerid`='" . (int)$userinfo['customerid'] . "' AND `username`='" . $result['username'] . "_backup'");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
@@ -37,7 +37,7 @@ elseif(isset($_GET['id']))
|
|||||||
if($page == 'overview')
|
if($page == 'overview')
|
||||||
{
|
{
|
||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "viewed customer_tickets");
|
$log->logAction(USR_ACTION, LOG_NOTICE, "viewed customer_tickets");
|
||||||
eval("echo \"" . getTemplate("ticket/ticket") . "\";");
|
eval("echo \"" . getTemplate("tickets/ticket") . "\";");
|
||||||
}
|
}
|
||||||
elseif($page == 'tickets')
|
elseif($page == 'tickets')
|
||||||
{
|
{
|
||||||
@@ -104,7 +104,7 @@ elseif($page == 'tickets')
|
|||||||
$row['subject'] = substr($row['subject'], 0, 17) . '...';
|
$row['subject'] = substr($row['subject'], 0, 17) . '...';
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("\$tickets.=\"" . getTemplate("ticket/tickets_tickets") . "\";");
|
eval("\$tickets.=\"" . getTemplate("tickets/tickets_tickets") . "\";");
|
||||||
$count++;
|
$count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -157,7 +157,7 @@ elseif($page == 'tickets')
|
|||||||
}
|
}
|
||||||
|
|
||||||
$ticketsopen = (int)$opentickets['count'];
|
$ticketsopen = (int)$opentickets['count'];
|
||||||
eval("echo \"" . getTemplate("ticket/tickets") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets") . "\";");
|
||||||
}
|
}
|
||||||
elseif($action == 'new')
|
elseif($action == 'new')
|
||||||
{
|
{
|
||||||
@@ -248,13 +248,13 @@ elseif($page == 'tickets')
|
|||||||
|
|
||||||
$ticketsopen = (int)$opentickets['count'];
|
$ticketsopen = (int)$opentickets['count'];
|
||||||
|
|
||||||
$ticket_add_data = include_once dirname(__FILE__).'/lib/formfields/customer/ticket/formfield.ticket_add.php';
|
$ticket_add_data = include_once dirname(__FILE__).'/lib/formfields/customer/tickets/formfield.ticket_add.php';
|
||||||
$ticket_add_form = htmlform::genHTMLForm($ticket_add_data);
|
$ticket_add_form = htmlform::genHTMLForm($ticket_add_data);
|
||||||
|
|
||||||
$title = $ticket_add_data['ticket_add']['title'];
|
$title = $ticket_add_data['ticket_add']['title'];
|
||||||
$image = $ticket_add_data['ticket_add']['image'];
|
$image = $ticket_add_data['ticket_add']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_new") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_new") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -334,7 +334,7 @@ elseif($page == 'tickets')
|
|||||||
|
|
||||||
$subject = $mainticket->Get('subject');
|
$subject = $mainticket->Get('subject');
|
||||||
$message = $mainticket->Get('message');
|
$message = $mainticket->Get('message');
|
||||||
eval("\$ticket_replies.=\"" . getTemplate("ticket/tickets_tickets_main") . "\";");
|
eval("\$ticket_replies.=\"" . getTemplate("tickets/tickets_tickets_main") . "\";");
|
||||||
$result = $db->query('SELECT `name` FROM `' . TABLE_PANEL_TICKET_CATS . '`
|
$result = $db->query('SELECT `name` FROM `' . TABLE_PANEL_TICKET_CATS . '`
|
||||||
WHERE `id`="' . (int)$mainticket->Get('category') . '"');
|
WHERE `id`="' . (int)$mainticket->Get('category') . '"');
|
||||||
$row = $db->fetch_array($result);
|
$row = $db->fetch_array($result);
|
||||||
@@ -356,7 +356,7 @@ elseif($page == 'tickets')
|
|||||||
|
|
||||||
$subject = $subticket->Get('subject');
|
$subject = $subticket->Get('subject');
|
||||||
$message = $subticket->Get('message');
|
$message = $subticket->Get('message');
|
||||||
eval("\$ticket_replies.=\"" . getTemplate("ticket/tickets_tickets_list") . "\";");
|
eval("\$ticket_replies.=\"" . getTemplate("tickets/tickets_tickets_list") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
$priorities = makeoption($lng['ticket']['high'], '1', $mainticket->Get('priority'), true, true);
|
$priorities = makeoption($lng['ticket']['high'], '1', $mainticket->Get('priority'), true, true);
|
||||||
@@ -367,13 +367,13 @@ elseif($page == 'tickets')
|
|||||||
|
|
||||||
// don't forget the main-ticket!
|
// don't forget the main-ticket!
|
||||||
|
|
||||||
$ticket_reply_data = include_once dirname(__FILE__).'/lib/formfields/customer/ticket/formfield.ticket_reply.php';
|
$ticket_reply_data = include_once dirname(__FILE__).'/lib/formfields/customer/tickets/formfield.ticket_reply.php';
|
||||||
$ticket_reply_form = htmlform::genHTMLForm($ticket_reply_data);
|
$ticket_reply_form = htmlform::genHTMLForm($ticket_reply_data);
|
||||||
|
|
||||||
$title = $ticket_reply_data['ticket_reply']['title'];
|
$title = $ticket_reply_data['ticket_reply']['title'];
|
||||||
$image = $ticket_reply_data['ticket_reply']['image'];
|
$image = $ticket_reply_data['ticket_reply']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("ticket/tickets_reply") . "\";");
|
eval("echo \"" . getTemplate("tickets/tickets_reply") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif($action == 'close'
|
elseif($action == 'close'
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
|
|||||||
BIN
images/Froxlor/icons/file.gif
Normal file
BIN
images/Froxlor/icons/file.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
BIN
images/Froxlor/icons/folder.gif
Normal file
BIN
images/Froxlor/icons/folder.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
BIN
images/Froxlor/icons/link.gif
Normal file
BIN
images/Froxlor/icons/link.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 748 B |
BIN
images/Froxlor/icons/parent.gif
Normal file
BIN
images/Froxlor/icons/parent.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
BIN
images/Froxlor/icons/rename.gif
Normal file
BIN
images/Froxlor/icons/rename.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Panel
|
* @package Panel
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'login');
|
define('AREA', 'login');
|
||||||
|
|||||||
@@ -167,8 +167,6 @@ CREATE TABLE `panel_admins` (
|
|||||||
`email_autoresponder` int(5) NOT NULL default '0',
|
`email_autoresponder` int(5) NOT NULL default '0',
|
||||||
`email_autoresponder_used` int(5) NOT NULL default '0',
|
`email_autoresponder_used` int(5) NOT NULL default '0',
|
||||||
`theme` varchar(255) NOT NULL default 'Froxlor',
|
`theme` varchar(255) NOT NULL default 'Froxlor',
|
||||||
`backup_allowed` TINYINT( 1 ) NOT NULL DEFAULT '1',
|
|
||||||
`backup_enabled` TINYINT( 1 ) NOT NULL DEFAULT '0',
|
|
||||||
PRIMARY KEY (`adminid`),
|
PRIMARY KEY (`adminid`),
|
||||||
UNIQUE KEY `loginname` (`loginname`)
|
UNIQUE KEY `loginname` (`loginname`)
|
||||||
) ENGINE=MyISAM ;
|
) ENGINE=MyISAM ;
|
||||||
@@ -188,6 +186,7 @@ CREATE TABLE `panel_customers` (
|
|||||||
`adminid` int(11) unsigned NOT NULL default '0',
|
`adminid` int(11) unsigned NOT NULL default '0',
|
||||||
`name` varchar(255) NOT NULL default '',
|
`name` varchar(255) NOT NULL default '',
|
||||||
`firstname` varchar(255) NOT NULL default '',
|
`firstname` varchar(255) NOT NULL default '',
|
||||||
|
`gender` int(1) NOT NULL DEFAULT '0',
|
||||||
`company` varchar(255) NOT NULL default '',
|
`company` varchar(255) NOT NULL default '',
|
||||||
`street` varchar(255) NOT NULL default '',
|
`street` varchar(255) NOT NULL default '',
|
||||||
`zipcode` varchar(255) NOT NULL default '',
|
`zipcode` varchar(255) NOT NULL default '',
|
||||||
@@ -236,6 +235,8 @@ CREATE TABLE `panel_customers` (
|
|||||||
`email_autoresponder` int(5) NOT NULL default '0',
|
`email_autoresponder` int(5) NOT NULL default '0',
|
||||||
`email_autoresponder_used` int(5) NOT NULL default '0',
|
`email_autoresponder_used` int(5) NOT NULL default '0',
|
||||||
`theme` varchar(255) NOT NULL default 'Froxlor',
|
`theme` varchar(255) NOT NULL default 'Froxlor',
|
||||||
|
`backup_allowed` TINYINT( 1 ) NOT NULL DEFAULT '1',
|
||||||
|
`backup_enabled` TINYINT( 1 ) NOT NULL DEFAULT '0',
|
||||||
PRIMARY KEY (`customerid`),
|
PRIMARY KEY (`customerid`),
|
||||||
UNIQUE KEY `loginname` (`loginname`)
|
UNIQUE KEY `loginname` (`loginname`)
|
||||||
) ENGINE=MyISAM ;
|
) ENGINE=MyISAM ;
|
||||||
@@ -467,7 +468,7 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('syste
|
|||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'vmail_homedir', '/var/customers/mail/');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'vmail_homedir', '/var/customers/mail/');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'bindconf_directory', '/etc/bind/');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'bindconf_directory', '/etc/bind/');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'bindreload_command', '/etc/init.d/bind9 reload');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'bindreload_command', '/etc/init.d/bind9 reload');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('panel', 'version', '0.9.20.1');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('panel', 'version', '0.9.23');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'hostname', 'SERVERNAME');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'hostname', 'SERVERNAME');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('login', 'maxloginattempts', '3');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('login', 'maxloginattempts', '3');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('login', 'deactivatetime', '900');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('login', 'deactivatetime', '900');
|
||||||
@@ -621,7 +622,7 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('syste
|
|||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('panel', 'default_theme', 'Froxlor');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('panel', 'default_theme', 'Froxlor');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'validate_domain', '1');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'validate_domain', '1');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_enabled', '1');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_enabled', '1');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_dir', '#froxlor_backup');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_dir', '/var/customers/backups/');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_mysqldump_path', '/usr/bin/mysqldump');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_mysqldump_path', '/usr/bin/mysqldump');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_count', '1');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_count', '1');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_bigfile', '1');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_bigfile', '1');
|
||||||
@@ -630,6 +631,12 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('syste
|
|||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_server', '');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_server', '');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_user', '');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_user', '');
|
||||||
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_pass', '');
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_pass', '');
|
||||||
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_passive', '1');
|
||||||
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_enabled', '0');
|
||||||
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_repquota_path', '/usr/sbin/repquota');
|
||||||
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_quotatool_path', '/usr/bin/quotatool');
|
||||||
|
INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_customer_partition', '/dev/root');
|
||||||
|
|
||||||
# --------------------------------------------------------
|
# --------------------------------------------------------
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -1017,7 +1024,7 @@ CREATE TABLE IF NOT EXISTS `aps_temp_settings` (
|
|||||||
DROP TABLE IF EXISTS `cronjobs_run`;
|
DROP TABLE IF EXISTS `cronjobs_run`;
|
||||||
CREATE TABLE IF NOT EXISTS `cronjobs_run` (
|
CREATE TABLE IF NOT EXISTS `cronjobs_run` (
|
||||||
`id` bigint(20) NOT NULL auto_increment,
|
`id` bigint(20) NOT NULL auto_increment,
|
||||||
`module` varchar(250) NOT NULL,
|
`module` varchar(250) NOT NULL,
|
||||||
`cronfile` varchar(250) NOT NULL,
|
`cronfile` varchar(250) NOT NULL,
|
||||||
`lastrun` int(15) NOT NULL DEFAULT '0',
|
`lastrun` int(15) NOT NULL DEFAULT '0',
|
||||||
`interval` varchar(100) NOT NULL DEFAULT '5 MINUTE',
|
`interval` varchar(100) NOT NULL DEFAULT '5 MINUTE',
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Language
|
* @package Language
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
* @author Froxlor Team <team@froxlor.org>
|
* @author Froxlor Team <team@froxlor.org>
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Language
|
* @package Language
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -23,16 +23,16 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
$lng['install']['language'] = 'Langue d\'installation';
|
$lng['install']['language'] = 'Langue d\'installation';
|
||||||
$lng['install']['welcome'] = 'Bienvenue <20> l\'installation de Froxlor';
|
$lng['install']['welcome'] = 'Bienvenue <20> l\'installation de Froxlor';
|
||||||
$lng['install']['welcometext'] = 'Merci beaucoup d\'avoir choisi Froxlor. Pour installer Froxlor remplissez les cases ci-dessous avec les informations demand<6E>es.<br /><b>Attention :</b> Si vous entrez le nom d\'une base de donn<6E>es existante, celle-ci sera effac<61>e !';
|
$lng['install']['welcometext'] = 'Merci beaucoup d\'avoir choisi Froxlor. Pour installer Froxlor remplissez les cases ci-dessous avec les informations demand<6E>es.<br /><b>Attention :</b> Si vous entrez le nom d\'une base de donn<6E>es existante, celle-ci sera effac<61>e !';
|
||||||
$lng['install']['database'] = 'Base de donn<6E>es';
|
$lng['install']['database'] = 'Base de donn<6E>es';
|
||||||
$lng['install']['mysql_hostname'] = 'Nom d\'h<>te du serveur MySQL';
|
$lng['install']['mysql_hostname'] = 'Nom d\'h<>te du serveur MySQL';
|
||||||
$lng['install']['mysql_database'] = 'Base de donn<6E>es MySQL';
|
$lng['install']['mysql_database'] = 'Base de donn<6E>es MySQL';
|
||||||
$lng['install']['mysql_unpriv_user'] = 'Utilisateur pour l\'acc<63>s non privil<69>gi<67> <20> MySQL';
|
$lng['install']['mysql_unpriv_user'] = 'Utilisateur pour l\'acc<63>s non privil<69>gi<67> <20> MySQL';
|
||||||
$lng['install']['mysql_unpriv_pass'] = 'Mot de passe pour l\'acc<63>s non privil<69>gi<67> <20> MySQL';
|
$lng['install']['mysql_unpriv_pass'] = 'Mot de passe pour l\'acc<63>s non privil<69>gi<67> <20> MySQL';
|
||||||
$lng['install']['mysql_root_user'] = 'Utilisateur pour l\'acc<63>s root <20> MySQL';
|
$lng['install']['mysql_root_user'] = 'Utilisateur pour l\'acc<63>s root <20> MySQL';
|
||||||
$lng['install']['mysql_root_pass'] = 'Mot de passe pour l\'acc<63>s root <20> MySQL';
|
$lng['install']['mysql_root_pass'] = 'Mot de passe pour l\'acc<63>s root <20> MySQL';
|
||||||
$lng['install']['admin_account'] = 'Acc<63>s administratif';
|
$lng['install']['admin_account'] = 'Acc<63>s administratif';
|
||||||
$lng['install']['admin_user'] = 'Login de l\'administrateur';
|
$lng['install']['admin_user'] = 'Login de l\'administrateur';
|
||||||
$lng['install']['admin_pass'] = 'Mot de passe de l\'administrateur';
|
$lng['install']['admin_pass'] = 'Mot de passe de l\'administrateur';
|
||||||
$lng['install']['admin_pass_confirm'] = 'Mot de passe de l\'administrateur (confirmation)';
|
$lng['install']['admin_pass_confirm'] = 'Mot de passe de l\'administrateur (confirmation)';
|
||||||
@@ -47,19 +47,19 @@ $lng['install']['installdata'] = 'Installation - Data';
|
|||||||
* Progress
|
* Progress
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$lng['install']['testing_mysql'] = 'V<>rification du login root de MySQL ...';
|
$lng['install']['testing_mysql'] = 'V<>rification du login root de MySQL ...';
|
||||||
$lng['install']['erasing_old_db'] = 'Effacement de l\'ancienne base de donn<6E>es ...';
|
$lng['install']['erasing_old_db'] = 'Effacement de l\'ancienne base de donn<6E>es ...';
|
||||||
$lng['install']['create_mysqluser_and_db'] = 'Cr<43>ation de la base de donn<6E>es puis des utilisateurs ...';
|
$lng['install']['create_mysqluser_and_db'] = 'Cr<43>ation de la base de donn<6E>es puis des utilisateurs ...';
|
||||||
$lng['install']['testing_new_db'] = 'V<>rification de la base de donn<6E>es et des utilisateurs ...';
|
$lng['install']['testing_new_db'] = 'V<>rification de la base de donn<6E>es et des utilisateurs ...';
|
||||||
$lng['install']['importing_data'] = 'Importation des informations dans la base de donn<6E>es ...';
|
$lng['install']['importing_data'] = 'Importation des informations dans la base de donn<6E>es ...';
|
||||||
$lng['install']['changing_data'] = 'Modification des donn<6E>es import<72>s ...';
|
$lng['install']['changing_data'] = 'Modification des donn<6E>es import<72>s ...';
|
||||||
$lng['install']['adding_admin_user'] = 'Ajout de l\'utilisateur administrateur ...';
|
$lng['install']['adding_admin_user'] = 'Ajout de l\'utilisateur administrateur ...';
|
||||||
$lng['install']['creating_configfile'] = 'Cr<43>ation du fichier de configuration ...';
|
$lng['install']['creating_configfile'] = 'Cr<43>ation du fichier de configuration ...';
|
||||||
$lng['install']['creating_configfile_succ'] = 'OK, userdata.inc.php a <20>t<EFBFBD> sauvegard<72> dans le dossier lib/ de Froxlor.';
|
$lng['install']['creating_configfile_succ'] = 'OK, userdata.inc.php a <20>t<EFBFBD> sauvegard<72> dans le dossier lib/ de Froxlor.';
|
||||||
$lng['install']['creating_configfile_temp'] = 'Le fichier a <20>t<EFBFBD> sauvegard<72> dans /tmp/userdata.inc.php, veuillez le d<>placer / copier dans le dossier lib/ de Froxlor.';
|
$lng['install']['creating_configfile_temp'] = 'Le fichier a <20>t<EFBFBD> sauvegard<72> dans /tmp/userdata.inc.php, veuillez le d<>placer / copier dans le dossier lib/ de Froxlor.';
|
||||||
$lng['install']['creating_configfile_failed'] = 'Erreur en cr<63>ant le fichier lib/userdata.inc.php, veuillez le cr<63>er avec le contenu ci-dessous :';
|
$lng['install']['creating_configfile_failed'] = 'Erreur en cr<63>ant le fichier lib/userdata.inc.php, veuillez le cr<63>er avec le contenu ci-dessous :';
|
||||||
$lng['install']['froxlor_succ_installed'] = 'Froxlor a <20>t<EFBFBD> install<6C> correctement.';
|
$lng['install']['froxlor_succ_installed'] = 'Froxlor a <20>t<EFBFBD> install<6C> correctement.';
|
||||||
$lng['install']['click_here_to_login'] = 'Cliquez ici pour vous rendre <20> l\'invite de connexion.';
|
$lng['install']['click_here_to_login'] = 'Cliquez ici pour vous rendre <20> l\'invite de connexion.';
|
||||||
$lng['install']['httpuser'] = 'Nom du utilisateur du HTTP';
|
$lng['install']['httpuser'] = 'Nom du utilisateur du HTTP';
|
||||||
$lng['install']['httpgroup'] = 'Nom du la group du HTTP';
|
$lng['install']['httpgroup'] = 'Nom du la group du HTTP';
|
||||||
|
|
||||||
@@ -69,5 +69,5 @@ $lng['install']['httpgroup'] = 'Nom du la group du HTTP';
|
|||||||
|
|
||||||
$lng['install']['webserver'] = 'Version du serveur';
|
$lng['install']['webserver'] = 'Version du serveur';
|
||||||
|
|
||||||
$lng['install']['phpxml'] = 'Tester si PHP XML-extension est install<6C>e...';
|
$lng['install']['phpxml'] = 'Tester si PHP XML-extension est install<6C>e...';
|
||||||
?>
|
?>
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor Team <team@froxlor.org> (2010-)
|
* @author Froxlor Team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Language
|
* @package Language
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Michael Duergner <michael@duergner.com>
|
* @author Michael Duergner <michael@duergner.com>
|
||||||
* @license GPLv2 http://files.syscp.org/misc/COPYING.txt
|
* @license GPLv2 http://files.syscp.org/misc/COPYING.txt
|
||||||
* @package System
|
* @package System
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if(@php_sapi_name() != 'cli'
|
if(@php_sapi_name() != 'cli'
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Martin Burchert <eremit@syscp.org>
|
* @author Martin Burchert <eremit@syscp.org>
|
||||||
* @license GPLv2 http://files.syscp.org/misc/COPYING.txt
|
* @license GPLv2 http://files.syscp.org/misc/COPYING.txt
|
||||||
* @package System
|
* @package System
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// some configs
|
// some configs
|
||||||
|
|||||||
124
install/tsmarty2c.php
Executable file
124
install/tsmarty2c.php
Executable file
@@ -0,0 +1,124 @@
|
|||||||
|
#!/usr/bin/php
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* tsmarty2c.php - rips gettext strings from smarty template
|
||||||
|
*
|
||||||
|
* ------------------------------------------------------------------------- *
|
||||||
|
* This library is free software; you can redistribute it and/or *
|
||||||
|
* modify it under the terms of the GNU Lesser General Public *
|
||||||
|
* License as published by the Free Software Foundation; either *
|
||||||
|
* version 2.1 of the License, or (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* This library is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
|
||||||
|
* Lesser General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* You should have received a copy of the GNU Lesser General Public *
|
||||||
|
* License along with this library; if not, write to the Free Software *
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
|
||||||
|
* ------------------------------------------------------------------------- *
|
||||||
|
*
|
||||||
|
* This command line script rips gettext strings from smarty file,
|
||||||
|
* and prints them to stdout in C format, that can later be used with the
|
||||||
|
* standard gettext tools.
|
||||||
|
*
|
||||||
|
* Usage:
|
||||||
|
* ./tsmarty2c.php <filename or directory> <file2> <..> > smarty.c
|
||||||
|
*
|
||||||
|
* If a parameter is a directory, the template files within will be parsed.
|
||||||
|
*
|
||||||
|
* @package smarty-gettext
|
||||||
|
* @version $Id: tsmarty2c.php,v 1.3 2005/07/27 17:59:39 sagi Exp $
|
||||||
|
* @link http://smarty-gettext.sf.net/
|
||||||
|
* @author Sagi Bashari <sagi@boom.org.il>
|
||||||
|
* @copyright 2004-2005 Sagi Bashari
|
||||||
|
*/
|
||||||
|
|
||||||
|
// smarty open tag
|
||||||
|
$ldq = preg_quote('{');
|
||||||
|
|
||||||
|
// smarty close tag
|
||||||
|
$rdq = preg_quote('}');
|
||||||
|
|
||||||
|
// smarty command
|
||||||
|
$cmd = preg_quote('t');
|
||||||
|
|
||||||
|
// extensions of smarty files, used when going through a directory
|
||||||
|
$extensions = array('tpl');
|
||||||
|
|
||||||
|
// "fix" string - strip slashes, escape and convert new lines to \n
|
||||||
|
function fs($str)
|
||||||
|
{
|
||||||
|
$str = stripslashes($str);
|
||||||
|
$str = str_replace('"', '\"', $str);
|
||||||
|
$str = str_replace("\n", '\n', $str);
|
||||||
|
return $str;
|
||||||
|
}
|
||||||
|
|
||||||
|
// rips gettext strings from $file and prints them in C format
|
||||||
|
function do_file($file)
|
||||||
|
{
|
||||||
|
$content = @file_get_contents($file);
|
||||||
|
|
||||||
|
if (empty($content)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
global $ldq, $rdq, $cmd;
|
||||||
|
|
||||||
|
preg_match_all(
|
||||||
|
"/{$ldq}\s*({$cmd})\s*([^{$rdq}]*){$rdq}([^{$ldq}]*){$ldq}\/\\1{$rdq}/",
|
||||||
|
$content,
|
||||||
|
$matches
|
||||||
|
);
|
||||||
|
|
||||||
|
for ($i=0; $i < count($matches[0]); $i++) {
|
||||||
|
// TODO: add line number
|
||||||
|
echo "/* $file */\n"; // credit: Mike van Lammeren 2005-02-14
|
||||||
|
|
||||||
|
if (preg_match('/plural\s*=\s*["\']?\s*(.[^\"\']*)\s*["\']?/', $matches[2][$i], $match)) {
|
||||||
|
echo 'ngettext("'.fs($matches[3][$i]).'","'.fs($match[1]).'",x);'."\n";
|
||||||
|
} else {
|
||||||
|
echo 'gettext("'.fs($matches[3][$i]).'");'."\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// go through a directory
|
||||||
|
function do_dir($dir)
|
||||||
|
{
|
||||||
|
$d = dir($dir);
|
||||||
|
|
||||||
|
while (false !== ($entry = $d->read())) {
|
||||||
|
if ($entry == '.' || $entry == '..') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$entry = $dir.'/'.$entry;
|
||||||
|
|
||||||
|
if (is_dir($entry)) { // if a directory, go through it
|
||||||
|
do_dir($entry);
|
||||||
|
} else { // if file, parse only if extension is matched
|
||||||
|
$pi = pathinfo($entry);
|
||||||
|
|
||||||
|
if (isset($pi['extension']) && in_array($pi['extension'], $GLOBALS['extensions'])) {
|
||||||
|
do_file($entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$d->close();
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($ac=1; $ac < $_SERVER['argc']; $ac++) {
|
||||||
|
if (is_dir($_SERVER['argv'][$ac])) { // go through directory
|
||||||
|
do_dir($_SERVER['argv'][$ac]);
|
||||||
|
} else { // do file
|
||||||
|
do_file($_SERVER['argv'][$ac]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if(isFroxlorVersion('0.9-r0'))
|
if(isFroxlorVersion('0.9-r0'))
|
||||||
@@ -1382,7 +1382,7 @@ if(isFroxlorVersion('0.9.16'))
|
|||||||
}
|
}
|
||||||
$check = $db->query_first("SELECT `varname` FROM `" . TABLE_PANEL_TEMPLATES . "` WHERE `varname`='trafficninetypercent_mailbody';");
|
$check = $db->query_first("SELECT `varname` FROM `" . TABLE_PANEL_TEMPLATES . "` WHERE `varname`='trafficninetypercent_mailbody';");
|
||||||
if(isset($check['varname']) && $check['varname'] == 'trafficninetypercent_mailbody')
|
if(isset($check['varname']) && $check['varname'] == 'trafficninetypercent_mailbody')
|
||||||
{
|
{
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_TEMPLATES . "` SET `varname` = 'trafficmaxpercent_mailbody' WHERE `varname`='trafficninetypercent_mailbody';");
|
$db->query("UPDATE `" . TABLE_PANEL_TEMPLATES . "` SET `varname` = 'trafficmaxpercent_mailbody' WHERE `varname`='trafficninetypercent_mailbody';");
|
||||||
}
|
}
|
||||||
lastStepStatus(0);
|
lastStepStatus(0);
|
||||||
@@ -1400,7 +1400,7 @@ if(isFroxlorVersion('0.9.17-svn1'))
|
|||||||
`fid` int(11) NOT NULL,
|
`fid` int(11) NOT NULL,
|
||||||
`docrootsettings` text NOT NULL,
|
`docrootsettings` text NOT NULL,
|
||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`)
|
||||||
) ENGINE=MyISAM;");
|
) ENGINE=MyISAM;");
|
||||||
$db->query("CREATE TABLE IF NOT EXISTS `domain_docrootsettings` (
|
$db->query("CREATE TABLE IF NOT EXISTS `domain_docrootsettings` (
|
||||||
`id` int(5) NOT NULL auto_increment,
|
`id` int(5) NOT NULL auto_increment,
|
||||||
`fid` int(11) NOT NULL,
|
`fid` int(11) NOT NULL,
|
||||||
@@ -1495,11 +1495,11 @@ if(isFroxlorVersion('0.9.19'))
|
|||||||
{
|
{
|
||||||
showUpdateStep("Updating from 0.9.19 to 0.9.20-svn1");
|
showUpdateStep("Updating from 0.9.19 to 0.9.20-svn1");
|
||||||
lastStepStatus(0);
|
lastStepStatus(0);
|
||||||
|
|
||||||
showUpdateStep("Adding new setting for domain validation");
|
showUpdateStep("Adding new setting for domain validation");
|
||||||
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'validate_domain', '1')");
|
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'validate_domain', '1')");
|
||||||
lastStepStatus(0);
|
lastStepStatus(0);
|
||||||
|
|
||||||
updateToVersion('0.9.20-svn1');
|
updateToVersion('0.9.20-svn1');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1542,3 +1542,140 @@ if(isFroxlorVersion('0.9.20'))
|
|||||||
|
|
||||||
updateToVersion('0.9.20.1');
|
updateToVersion('0.9.20.1');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.20.1'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.20.1 to 0.9.20.1-svn1");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Fixing possible broken tables");
|
||||||
|
|
||||||
|
// The customer-table may miss the columns, if installed a fresh 0.9.20 or 0.9.20.1 - add them
|
||||||
|
$result = $db->query("DESCRIBE `" . TABLE_PANEL_CUSTOMERS . "`");
|
||||||
|
$columnfound = 0;
|
||||||
|
while($row = $db->fetch_array($result))
|
||||||
|
{
|
||||||
|
if($row['Field'] == 'backup_allowed')
|
||||||
|
{
|
||||||
|
$columnfound = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$columnfound)
|
||||||
|
{
|
||||||
|
$db->query("ALTER TABLE `" . TABLE_PANEL_CUSTOMERS . "` ADD `backup_allowed` TINYINT( 1 ) NOT NULL DEFAULT '1'");
|
||||||
|
$db->query("ALTER TABLE `" . TABLE_PANEL_CUSTOMERS . "` ADD `backup_enabled` TINYINT( 1 ) NOT NULL DEFAULT '0'");
|
||||||
|
}
|
||||||
|
|
||||||
|
// The admin-table may have the columns, if installed a fresh 0.9.20.1 - remove them
|
||||||
|
$result = $db->query("DESCRIBE `" . TABLE_PANEL_ADMINS . "`");
|
||||||
|
$columnfound = 0;
|
||||||
|
while($row = $db->fetch_array($result))
|
||||||
|
{
|
||||||
|
if($row['Field'] == 'backup_allowed')
|
||||||
|
{
|
||||||
|
$columnfound = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($columnfound)
|
||||||
|
{
|
||||||
|
$db->query("ALTER TABLE `" . TABLE_PANEL_ADMINS . "` DROP `backup_allowed`;");
|
||||||
|
$db->query("ALTER TABLE `" . TABLE_PANEL_ADMINS . "` DROP `backup_enabled`;");
|
||||||
|
}
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.20.1-svn1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.20.1-svn1') || isFroxlorVersion('0.9.20.2-svn1'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.20.1-svn1 to 0.9.21-svn1");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
// add table column for gender
|
||||||
|
$db->query("ALTER TABLE `" . TABLE_PANEL_CUSTOMERS . "` ADD `gender` INT( 1 ) NOT NULL DEFAULT '0' AFTER `firstname`");
|
||||||
|
|
||||||
|
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.21-svn1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.21-svn1'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.21-svn1 to 0.9.21-svn2");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
/* add new setting: backup FTP mode */
|
||||||
|
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'backup_ftp_passive', '1')");
|
||||||
|
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.21-svn2');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.21-svn2'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.21-svn2 to 0.9.21");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.21');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.21'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.21 to 0.9.22-svn1");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
/* add new settings for diskspacequota - support */
|
||||||
|
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_enabled', '0');");
|
||||||
|
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_repquota_path', '/usr/sbin/repquota');");
|
||||||
|
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_quotatool_path', '/usr/bin/quotatool');");
|
||||||
|
$db->query("INSERT INTO `" . TABLE_PANEL_SETTINGS . "` (`settinggroup`, `varname`, `value`) VALUES ('system', 'diskquota_customer_partition', '/dev/root');");
|
||||||
|
|
||||||
|
updateToVersion('0.9.22-svn1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.22-svn1'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.22-svn1 to 0.9.22-svn2");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
/* add new settings for diskspacequota - support */
|
||||||
|
$db->query("UPDATE `" . TABLE_PANEL_SETTINGS . "` SET `value` = '/var/customers/backups/' WHERE `varname` = 'backup_dir';");
|
||||||
|
|
||||||
|
updateToVersion('0.9.22-svn2');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.22-svn2'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.22-svn2 to 0.9.22-rc1");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.22-rc1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.22-rc1'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.22-rc1 to 0.9.22");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.22');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.22'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.22 to 0.9.23-rc1");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.23-rc1');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(isFroxlorVersion('0.9.23-rc1'))
|
||||||
|
{
|
||||||
|
showUpdateStep("Updating from 0.9.23-rc1 to 0.9.23");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToVersion('0.9.23');
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$updateto = '0.9-r0';
|
$updateto = '0.9-r0';
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Language
|
* @package Language
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Language
|
* @package Language
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('TABLE_POSTFIX_TRANSPORT', 'postfix_transport');
|
define('TABLE_POSTFIX_TRANSPORT', 'postfix_transport');
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if($settings['panel']['version'] == '1.2-beta1'
|
if($settings['panel']['version'] == '1.2-beta1'
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if($settings['panel']['version'] == '1.2.19')
|
if($settings['panel']['version'] == '1.2.19')
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if($settings['panel']['version'] == '1.4')
|
if($settings['panel']['version'] == '1.4')
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2010-)
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Install
|
* @package Install
|
||||||
* @version $Id$
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$updatelog = FroxlorLogger::getInstanceOf(array('loginname' => 'updater'), $db, $settings);
|
$updatelog = FroxlorLogger::getInstanceOf(array('loginname' => 'updater'), $db, $settings);
|
||||||
|
|||||||
1
lib/classes/Smarty
Symbolic link
1
lib/classes/Smarty
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
Smarty-3.0.8/libs
|
||||||
165
lib/classes/Smarty-3.0.8/COPYING.lib
Normal file
165
lib/classes/Smarty-3.0.8/COPYING.lib
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
GNU LESSER GENERAL PUBLIC LICENSE
|
||||||
|
Version 3, 29 June 2007
|
||||||
|
|
||||||
|
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
|
||||||
|
This version of the GNU Lesser General Public License incorporates
|
||||||
|
the terms and conditions of version 3 of the GNU General Public
|
||||||
|
License, supplemented by the additional permissions listed below.
|
||||||
|
|
||||||
|
0. Additional Definitions.
|
||||||
|
|
||||||
|
As used herein, "this License" refers to version 3 of the GNU Lesser
|
||||||
|
General Public License, and the "GNU GPL" refers to version 3 of the GNU
|
||||||
|
General Public License.
|
||||||
|
|
||||||
|
"The Library" refers to a covered work governed by this License,
|
||||||
|
other than an Application or a Combined Work as defined below.
|
||||||
|
|
||||||
|
An "Application" is any work that makes use of an interface provided
|
||||||
|
by the Library, but which is not otherwise based on the Library.
|
||||||
|
Defining a subclass of a class defined by the Library is deemed a mode
|
||||||
|
of using an interface provided by the Library.
|
||||||
|
|
||||||
|
A "Combined Work" is a work produced by combining or linking an
|
||||||
|
Application with the Library. The particular version of the Library
|
||||||
|
with which the Combined Work was made is also called the "Linked
|
||||||
|
Version".
|
||||||
|
|
||||||
|
The "Minimal Corresponding Source" for a Combined Work means the
|
||||||
|
Corresponding Source for the Combined Work, excluding any source code
|
||||||
|
for portions of the Combined Work that, considered in isolation, are
|
||||||
|
based on the Application, and not on the Linked Version.
|
||||||
|
|
||||||
|
The "Corresponding Application Code" for a Combined Work means the
|
||||||
|
object code and/or source code for the Application, including any data
|
||||||
|
and utility programs needed for reproducing the Combined Work from the
|
||||||
|
Application, but excluding the System Libraries of the Combined Work.
|
||||||
|
|
||||||
|
1. Exception to Section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
You may convey a covered work under sections 3 and 4 of this License
|
||||||
|
without being bound by section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
2. Conveying Modified Versions.
|
||||||
|
|
||||||
|
If you modify a copy of the Library, and, in your modifications, a
|
||||||
|
facility refers to a function or data to be supplied by an Application
|
||||||
|
that uses the facility (other than as an argument passed when the
|
||||||
|
facility is invoked), then you may convey a copy of the modified
|
||||||
|
version:
|
||||||
|
|
||||||
|
a) under this License, provided that you make a good faith effort to
|
||||||
|
ensure that, in the event an Application does not supply the
|
||||||
|
function or data, the facility still operates, and performs
|
||||||
|
whatever part of its purpose remains meaningful, or
|
||||||
|
|
||||||
|
b) under the GNU GPL, with none of the additional permissions of
|
||||||
|
this License applicable to that copy.
|
||||||
|
|
||||||
|
3. Object Code Incorporating Material from Library Header Files.
|
||||||
|
|
||||||
|
The object code form of an Application may incorporate material from
|
||||||
|
a header file that is part of the Library. You may convey such object
|
||||||
|
code under terms of your choice, provided that, if the incorporated
|
||||||
|
material is not limited to numerical parameters, data structure
|
||||||
|
layouts and accessors, or small macros, inline functions and templates
|
||||||
|
(ten or fewer lines in length), you do both of the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the object code that the
|
||||||
|
Library is used in it and that the Library and its use are
|
||||||
|
covered by this License.
|
||||||
|
|
||||||
|
b) Accompany the object code with a copy of the GNU GPL and this license
|
||||||
|
document.
|
||||||
|
|
||||||
|
4. Combined Works.
|
||||||
|
|
||||||
|
You may convey a Combined Work under terms of your choice that,
|
||||||
|
taken together, effectively do not restrict modification of the
|
||||||
|
portions of the Library contained in the Combined Work and reverse
|
||||||
|
engineering for debugging such modifications, if you also do each of
|
||||||
|
the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the Combined Work that
|
||||||
|
the Library is used in it and that the Library and its use are
|
||||||
|
covered by this License.
|
||||||
|
|
||||||
|
b) Accompany the Combined Work with a copy of the GNU GPL and this license
|
||||||
|
document.
|
||||||
|
|
||||||
|
c) For a Combined Work that displays copyright notices during
|
||||||
|
execution, include the copyright notice for the Library among
|
||||||
|
these notices, as well as a reference directing the user to the
|
||||||
|
copies of the GNU GPL and this license document.
|
||||||
|
|
||||||
|
d) Do one of the following:
|
||||||
|
|
||||||
|
0) Convey the Minimal Corresponding Source under the terms of this
|
||||||
|
License, and the Corresponding Application Code in a form
|
||||||
|
suitable for, and under terms that permit, the user to
|
||||||
|
recombine or relink the Application with a modified version of
|
||||||
|
the Linked Version to produce a modified Combined Work, in the
|
||||||
|
manner specified by section 6 of the GNU GPL for conveying
|
||||||
|
Corresponding Source.
|
||||||
|
|
||||||
|
1) Use a suitable shared library mechanism for linking with the
|
||||||
|
Library. A suitable mechanism is one that (a) uses at run time
|
||||||
|
a copy of the Library already present on the user's computer
|
||||||
|
system, and (b) will operate properly with a modified version
|
||||||
|
of the Library that is interface-compatible with the Linked
|
||||||
|
Version.
|
||||||
|
|
||||||
|
e) Provide Installation Information, but only if you would otherwise
|
||||||
|
be required to provide such information under section 6 of the
|
||||||
|
GNU GPL, and only to the extent that such information is
|
||||||
|
necessary to install and execute a modified version of the
|
||||||
|
Combined Work produced by recombining or relinking the
|
||||||
|
Application with a modified version of the Linked Version. (If
|
||||||
|
you use option 4d0, the Installation Information must accompany
|
||||||
|
the Minimal Corresponding Source and Corresponding Application
|
||||||
|
Code. If you use option 4d1, you must provide the Installation
|
||||||
|
Information in the manner specified by section 6 of the GNU GPL
|
||||||
|
for conveying Corresponding Source.)
|
||||||
|
|
||||||
|
5. Combined Libraries.
|
||||||
|
|
||||||
|
You may place library facilities that are a work based on the
|
||||||
|
Library side by side in a single library together with other library
|
||||||
|
facilities that are not Applications and are not covered by this
|
||||||
|
License, and convey such a combined library under terms of your
|
||||||
|
choice, if you do both of the following:
|
||||||
|
|
||||||
|
a) Accompany the combined library with a copy of the same work based
|
||||||
|
on the Library, uncombined with any other library facilities,
|
||||||
|
conveyed under the terms of this License.
|
||||||
|
|
||||||
|
b) Give prominent notice with the combined library that part of it
|
||||||
|
is a work based on the Library, and explaining where to find the
|
||||||
|
accompanying uncombined form of the same work.
|
||||||
|
|
||||||
|
6. Revised Versions of the GNU Lesser General Public License.
|
||||||
|
|
||||||
|
The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the GNU Lesser General Public License from time to time. Such new
|
||||||
|
versions will be similar in spirit to the present version, but may
|
||||||
|
differ in detail to address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the
|
||||||
|
Library as you received it specifies that a certain numbered version
|
||||||
|
of the GNU Lesser General Public License "or any later version"
|
||||||
|
applies to it, you have the option of following the terms and
|
||||||
|
conditions either of that published version or of any later version
|
||||||
|
published by the Free Software Foundation. If the Library as you
|
||||||
|
received it does not specify a version number of the GNU Lesser
|
||||||
|
General Public License, you may choose any version of the GNU Lesser
|
||||||
|
General Public License ever published by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Library as you received it specifies that a proxy can decide
|
||||||
|
whether future versions of the GNU Lesser General Public License shall
|
||||||
|
apply, that proxy's public statement of acceptance of any version is
|
||||||
|
permanent authorization for you to choose that version for the
|
||||||
|
Library.
|
||||||
570
lib/classes/Smarty-3.0.8/README
Normal file
570
lib/classes/Smarty-3.0.8/README
Normal file
@@ -0,0 +1,570 @@
|
|||||||
|
Smarty 3.0.8
|
||||||
|
|
||||||
|
Author: Monte Ohrt <monte at ohrt dot com >
|
||||||
|
Author: Uwe Tews
|
||||||
|
|
||||||
|
AN INTRODUCTION TO SMARTY 3
|
||||||
|
|
||||||
|
NOTICE for 3.0.5 release:
|
||||||
|
|
||||||
|
Smarty now follows the PHP error_reporting level by default. If PHP does not mask E_NOTICE and you try to access an unset template variable, you will now get an E_NOTICE warning. To revert to the old behavior:
|
||||||
|
|
||||||
|
$smarty->error_reporting = E_ALL & ~E_NOTICE;
|
||||||
|
|
||||||
|
NOTICE for 3.0 release:
|
||||||
|
|
||||||
|
IMPORTANT: Some API adjustments have been made between the RC4 and 3.0 release.
|
||||||
|
We felt it is better to make these now instead of after a 3.0 release, then have to
|
||||||
|
immediately deprecate APIs in 3.1. Online documentation has been updated
|
||||||
|
to reflect these changes. Specifically:
|
||||||
|
|
||||||
|
---- API CHANGES RC4 -> 3.0 ----
|
||||||
|
|
||||||
|
$smarty->register->*
|
||||||
|
$smarty->unregister->*
|
||||||
|
$smarty->utility->*
|
||||||
|
$samrty->cache->*
|
||||||
|
|
||||||
|
Have all been changed to local method calls such as:
|
||||||
|
|
||||||
|
$smarty->clearAllCache()
|
||||||
|
$smarty->registerFoo()
|
||||||
|
$smarty->unregisterFoo()
|
||||||
|
$smarty->testInstall()
|
||||||
|
etc.
|
||||||
|
|
||||||
|
Registration of function, block, compiler, and modifier plugins have been
|
||||||
|
consolidated under two API calls:
|
||||||
|
|
||||||
|
$smarty->registerPlugin(...)
|
||||||
|
$smarty->unregisterPlugin(...)
|
||||||
|
|
||||||
|
Registration of pre, post, output and variable filters have been
|
||||||
|
consolidated under two API calls:
|
||||||
|
|
||||||
|
$smarty->registerFilter(...)
|
||||||
|
$smarty->unregisterFilter(...)
|
||||||
|
|
||||||
|
Please refer to the online documentation for all specific changes:
|
||||||
|
|
||||||
|
http://www.smarty.net/documentation
|
||||||
|
|
||||||
|
----
|
||||||
|
|
||||||
|
The Smarty 3 API has been refactored to a syntax geared
|
||||||
|
for consistency and modularity. The Smarty 2 API syntax is still supported, but
|
||||||
|
will throw a deprecation notice. You can disable the notices, but it is highly
|
||||||
|
recommended to adjust your syntax to Smarty 3, as the Smarty 2 syntax must run
|
||||||
|
through an extra rerouting wrapper.
|
||||||
|
|
||||||
|
Basically, all Smarty methods now follow the "fooBarBaz" camel case syntax. Also,
|
||||||
|
all Smarty properties now have getters and setters. So for example, the property
|
||||||
|
$smarty->cache_dir can be set with $smarty->setCacheDir('foo/') and can be
|
||||||
|
retrieved with $smarty->getCacheDir().
|
||||||
|
|
||||||
|
Some of the Smarty 3 APIs have been revoked such as the "is*" methods that were
|
||||||
|
just duplicate functions of the now available "get*" methods.
|
||||||
|
|
||||||
|
Here is a rundown of the Smarty 3 API:
|
||||||
|
|
||||||
|
$smarty->fetch($template, $cache_id = null, $compile_id = null, $parent = null)
|
||||||
|
$smarty->display($template, $cache_id = null, $compile_id = null, $parent = null)
|
||||||
|
$smarty->isCached($template, $cache_id = null, $compile_id = null)
|
||||||
|
$smarty->createData($parent = null)
|
||||||
|
$smarty->createTemplate($template, $cache_id = null, $compile_id = null, $parent = null)
|
||||||
|
$smarty->enableSecurity()
|
||||||
|
$smarty->disableSecurity()
|
||||||
|
$smarty->setTemplateDir($template_dir)
|
||||||
|
$smarty->addTemplateDir($template_dir)
|
||||||
|
$smarty->templateExists($resource_name)
|
||||||
|
$smarty->loadPlugin($plugin_name, $check = true)
|
||||||
|
$smarty->loadFilter($type, $name)
|
||||||
|
$smarty->setExceptionHandler($handler)
|
||||||
|
$smarty->addPluginsDir($plugins_dir)
|
||||||
|
$smarty->getGlobal($varname = null)
|
||||||
|
$smarty->getRegisteredObject($name)
|
||||||
|
$smarty->getDebugTemplate()
|
||||||
|
$smarty->setDebugTemplate($tpl_name)
|
||||||
|
$smarty->assign($tpl_var, $value = null, $nocache = false)
|
||||||
|
$smarty->assignGlobal($varname, $value = null, $nocache = false)
|
||||||
|
$smarty->assignByRef($tpl_var, &$value, $nocache = false)
|
||||||
|
$smarty->append($tpl_var, $value = null, $merge = false, $nocache = false)
|
||||||
|
$smarty->appendByRef($tpl_var, &$value, $merge = false)
|
||||||
|
$smarty->clearAssign($tpl_var)
|
||||||
|
$smarty->clearAllAssign()
|
||||||
|
$smarty->configLoad($config_file, $sections = null)
|
||||||
|
$smarty->getVariable($variable, $_ptr = null, $search_parents = true, $error_enable = true)
|
||||||
|
$smarty->getConfigVariable($variable)
|
||||||
|
$smarty->getStreamVariable($variable)
|
||||||
|
$smarty->getConfigVars($varname = null)
|
||||||
|
$smarty->clearConfig($varname = null)
|
||||||
|
$smarty->getTemplateVars($varname = null, $_ptr = null, $search_parents = true)
|
||||||
|
$smarty->clearAllCache($exp_time = null, $type = null)
|
||||||
|
$smarty->clearCache($template_name, $cache_id = null, $compile_id = null, $exp_time = null, $type = null)
|
||||||
|
|
||||||
|
$smarty->registerPlugin($type, $tag, $callback, $cacheable = true, $cache_attr = array())
|
||||||
|
|
||||||
|
$smarty->registerObject($object_name, $object_impl, $allowed = array(), $smarty_args = true, $block_methods = array())
|
||||||
|
|
||||||
|
$smarty->registerFilter($type, $function_name)
|
||||||
|
$smarty->registerResource($resource_type, $function_names)
|
||||||
|
$smarty->registerDefaultPluginHandler($function_name)
|
||||||
|
$smarty->registerDefaultTemplateHandler($function_name)
|
||||||
|
|
||||||
|
$smarty->unregisterPlugin($type, $tag)
|
||||||
|
$smarty->unregisterObject($object_name)
|
||||||
|
$smarty->unregisterFilter($type, $function_name)
|
||||||
|
$smarty->unregisterResource($resource_type)
|
||||||
|
|
||||||
|
$smarty->compileAllTemplates($extention = '.tpl', $force_compile = false, $time_limit = 0, $max_errors = null)
|
||||||
|
$smarty->clearCompiledTemplate($resource_name = null, $compile_id = null, $exp_time = null)
|
||||||
|
$smarty->testInstall()
|
||||||
|
|
||||||
|
// then all the getters/setters, available for all properties. Here are a few:
|
||||||
|
|
||||||
|
$caching = $smarty->getCaching(); // get $smarty->caching
|
||||||
|
$smarty->setCaching(true); // set $smarty->caching
|
||||||
|
$smarty->setDeprecationNotices(false); // set $smarty->deprecation_notices
|
||||||
|
$smarty->setCacheId($id); // set $smarty->cache_id
|
||||||
|
$debugging = $smarty->getDebugging(); // get $smarty->debugging
|
||||||
|
|
||||||
|
|
||||||
|
FILE STRUCTURE
|
||||||
|
|
||||||
|
The Smarty 3 file structure is similar to Smarty 2:
|
||||||
|
|
||||||
|
/libs/
|
||||||
|
Smarty.class.php
|
||||||
|
/libs/sysplugins/
|
||||||
|
internal.*
|
||||||
|
/libs/plugins/
|
||||||
|
function.mailto.php
|
||||||
|
modifier.escape.php
|
||||||
|
...
|
||||||
|
|
||||||
|
A lot of Smarty 3 core functionality lies in the sysplugins directory; you do
|
||||||
|
not need to change any files here. The /libs/plugins/ folder is where Smarty
|
||||||
|
plugins are located. You can add your own here, or create a separate plugin
|
||||||
|
directory, just the same as Smarty 2. You will still need to create your own
|
||||||
|
/cache/, /templates/, /templates_c/, /configs/ folders. Be sure /cache/ and
|
||||||
|
/templates_c/ are writable.
|
||||||
|
|
||||||
|
The typical way to use Smarty 3 should also look familiar:
|
||||||
|
|
||||||
|
require('Smarty.class.php');
|
||||||
|
$smarty = new Smarty;
|
||||||
|
$smarty->assign('foo','bar');
|
||||||
|
$smarty->display('index.tpl');
|
||||||
|
|
||||||
|
|
||||||
|
However, Smarty 3 works completely different on the inside. Smarty 3 is mostly
|
||||||
|
backward compatible with Smarty 2, except for the following items:
|
||||||
|
|
||||||
|
*) Smarty 3 is PHP 5 only. It will not work with PHP 4.
|
||||||
|
*) The {php} tag is disabled by default. Enable with $smarty->allow_php_tag=true.
|
||||||
|
*) Delimiters surrounded by whitespace are no longer treated as Smarty tags.
|
||||||
|
Therefore, { foo } will not compile as a tag, you must use {foo}. This change
|
||||||
|
Makes Javascript/CSS easier to work with, eliminating the need for {literal}.
|
||||||
|
This can be disabled by setting $smarty->auto_literal = false;
|
||||||
|
*) The Smarty 3 API is a bit different. Many Smarty 2 API calls are deprecated
|
||||||
|
but still work. You will want to update your calls to Smarty 3 for maximum
|
||||||
|
efficiency.
|
||||||
|
|
||||||
|
|
||||||
|
There are many things that are new to Smarty 3. Here are the notable items:
|
||||||
|
|
||||||
|
LEXER/PARSER
|
||||||
|
============
|
||||||
|
|
||||||
|
Smarty 3 now uses a lexing tokenizer for its parser/compiler. Basically, this
|
||||||
|
means Smarty has some syntax additions that make life easier such as in-template
|
||||||
|
math, shorter/intuitive function parameter options, infinite function recursion,
|
||||||
|
more accurate error handling, etc.
|
||||||
|
|
||||||
|
|
||||||
|
WHAT IS NEW IN SMARTY TEMPLATE SYNTAX
|
||||||
|
=====================================
|
||||||
|
|
||||||
|
Smarty 3 allows expressions almost anywhere. Expressions can include PHP
|
||||||
|
functions as long as they are not disabled by the security policy, object
|
||||||
|
methods and properties, etc. The {math} plugin is no longer necessary but
|
||||||
|
is still supported for BC.
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
{$x+$y} will output the sum of x and y.
|
||||||
|
{$foo = strlen($bar)} function in assignment
|
||||||
|
{assign var=foo value= $x+$y} in attributes
|
||||||
|
{$foo = myfunct( ($x+$y)*3 )} as function parameter
|
||||||
|
{$foo[$x+3]} as array index
|
||||||
|
|
||||||
|
Smarty tags can be used as values within other tags.
|
||||||
|
Example: {$foo={counter}+3}
|
||||||
|
|
||||||
|
Smarty tags can also be used inside double quoted strings.
|
||||||
|
Example: {$foo="this is message {counter}"}
|
||||||
|
|
||||||
|
You can define arrays within templates.
|
||||||
|
Examples:
|
||||||
|
{assign var=foo value=[1,2,3]}
|
||||||
|
{assign var=foo value=['y'=>'yellow','b'=>'blue']}
|
||||||
|
Arrays can be nested.
|
||||||
|
{assign var=foo value=[1,[9,8],3]}
|
||||||
|
|
||||||
|
There is a new short syntax supported for assigning variables.
|
||||||
|
Example: {$foo=$bar+2}
|
||||||
|
|
||||||
|
You can assign a value to a specific array element. If the variable exists but
|
||||||
|
is not an array, it is converted to an array before the new values are assigned.
|
||||||
|
Examples:
|
||||||
|
{$foo['bar']=1}
|
||||||
|
{$foo['bar']['blar']=1}
|
||||||
|
|
||||||
|
You can append values to an array. If the variable exists but is not an array,
|
||||||
|
it is converted to an array before the new values are assigned.
|
||||||
|
Example: {$foo[]=1}
|
||||||
|
|
||||||
|
You can use a PHP-like syntax for accessing array elements, as well as the
|
||||||
|
original "dot" notation.
|
||||||
|
Examples:
|
||||||
|
{$foo[1]} normal access
|
||||||
|
{$foo['bar']}
|
||||||
|
{$foo['bar'][1]}
|
||||||
|
{$foo[$x+$x]} index may contain any expression
|
||||||
|
{$foo[$bar[1]]} nested index
|
||||||
|
{$foo[section_name]} smarty section access, not array access!
|
||||||
|
|
||||||
|
The original "dot" notation stays, and with improvements.
|
||||||
|
Examples:
|
||||||
|
{$foo.a.b.c} => $foo['a']['b']['c']
|
||||||
|
{$foo.a.$b.c} => $foo['a'][$b]['c'] with variable index
|
||||||
|
{$foo.a.{$b+4}.c} => $foo['a'][$b+4]['c'] with expression as index
|
||||||
|
{$foo.a.{$b.c}} => $foo['a'][$b['c']] with nested index
|
||||||
|
|
||||||
|
note that { and } are used to address ambiguties when nesting the dot syntax.
|
||||||
|
|
||||||
|
Variable names themselves can be variable and contain expressions.
|
||||||
|
Examples:
|
||||||
|
$foo normal variable
|
||||||
|
$foo_{$bar} variable name containing other variable
|
||||||
|
$foo_{$x+$y} variable name containing expressions
|
||||||
|
$foo_{$bar}_buh_{$blar} variable name with multiple segments
|
||||||
|
{$foo_{$x}} will output the variable $foo_1 if $x has a value of 1.
|
||||||
|
|
||||||
|
Object method chaining is implemented.
|
||||||
|
Example: {$object->method1($x)->method2($y)}
|
||||||
|
|
||||||
|
{for} tag added for looping (replacement for {section} tag):
|
||||||
|
{for $x=0, $y=count($foo); $x<$y; $x++} .... {/for}
|
||||||
|
Any number of statements can be used separated by comma as the first
|
||||||
|
inital expression at {for}.
|
||||||
|
|
||||||
|
{for $x = $start to $end step $step} ... {/for}is in the SVN now .
|
||||||
|
You can use also
|
||||||
|
{for $x = $start to $end} ... {/for}
|
||||||
|
In this case the step value will be automaticall 1 or -1 depending on the start and end values.
|
||||||
|
Instead of $start and $end you can use any valid expression.
|
||||||
|
Inside the loop the following special vars can be accessed:
|
||||||
|
$x@iteration = number of iteration
|
||||||
|
$x@total = total number of iterations
|
||||||
|
$x@first = true on first iteration
|
||||||
|
$x@last = true on last iteration
|
||||||
|
|
||||||
|
|
||||||
|
The Smarty 2 {section} syntax is still supported.
|
||||||
|
|
||||||
|
New shorter {foreach} syntax to loop over an array.
|
||||||
|
Example: {foreach $myarray as $var}...{/foreach}
|
||||||
|
|
||||||
|
Within the foreach loop, properties are access via:
|
||||||
|
|
||||||
|
$var@key foreach $var array key
|
||||||
|
$var@iteration foreach current iteration count (1,2,3...)
|
||||||
|
$var@index foreach current index count (0,1,2...)
|
||||||
|
$var@total foreach $var array total
|
||||||
|
$var@first true on first iteration
|
||||||
|
$var@last true on last iteration
|
||||||
|
|
||||||
|
The Smarty 2 {foreach} tag syntax is still supported.
|
||||||
|
|
||||||
|
NOTE: {$bar[foo]} still indicates a variable inside of a {section} named foo.
|
||||||
|
If you want to access an array element with index foo, you must use quotes
|
||||||
|
such as {$bar['foo']}, or use the dot syntax {$bar.foo}.
|
||||||
|
|
||||||
|
while block tag is now implemented:
|
||||||
|
{while $foo}...{/while}
|
||||||
|
{while $x lt 10}...{/while}
|
||||||
|
|
||||||
|
Direct access to PHP functions:
|
||||||
|
Just as you can use PHP functions as modifiers directly, you can now access
|
||||||
|
PHP functions directly, provided they are permitted by security settings:
|
||||||
|
{time()}
|
||||||
|
|
||||||
|
There is a new {function}...{/function} block tag to implement a template function.
|
||||||
|
This enables reuse of code sequences like a plugin function. It can call itself recursively.
|
||||||
|
Template function must be called with the new {call name=foo...} tag.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
Template file:
|
||||||
|
{function name=menu level=0}
|
||||||
|
<ul class="level{$level}">
|
||||||
|
{foreach $data as $entry}
|
||||||
|
{if is_array($entry)}
|
||||||
|
<li>{$entry@key}</li>
|
||||||
|
{call name=menu data=$entry level=$level+1}
|
||||||
|
{else}
|
||||||
|
<li>{$entry}</li>
|
||||||
|
{/if}
|
||||||
|
{/foreach}
|
||||||
|
</ul>
|
||||||
|
{/function}
|
||||||
|
|
||||||
|
{$menu = ['item1','item2','item3' => ['item3-1','item3-2','item3-3' =>
|
||||||
|
['item3-3-1','item3-3-2']],'item4']}
|
||||||
|
|
||||||
|
{call name=menu data=$menu}
|
||||||
|
|
||||||
|
|
||||||
|
Generated output:
|
||||||
|
* item1
|
||||||
|
* item2
|
||||||
|
* item3
|
||||||
|
o item3-1
|
||||||
|
o item3-2
|
||||||
|
o item3-3
|
||||||
|
+ item3-3-1
|
||||||
|
+ item3-3-2
|
||||||
|
* item4
|
||||||
|
|
||||||
|
The function tag itself must have the "name" attribute. This name is the tag
|
||||||
|
name when calling the function. The function tag may have any number of
|
||||||
|
additional attributes. These will be default settings for local variables.
|
||||||
|
|
||||||
|
New {nocache} block function:
|
||||||
|
{nocache}...{/nocache} will declare a section of the template to be non-cached
|
||||||
|
when template caching is enabled.
|
||||||
|
|
||||||
|
New nocache attribute:
|
||||||
|
You can declare variable/function output as non-cached with the nocache attribute.
|
||||||
|
Examples:
|
||||||
|
|
||||||
|
{$foo nocache=true}
|
||||||
|
{$foo nocache} /* same */
|
||||||
|
|
||||||
|
{foo bar="baz" nocache=true}
|
||||||
|
{foo bar="baz" nocache} /* same */
|
||||||
|
|
||||||
|
{time() nocache=true}
|
||||||
|
{time() nocache} /* same */
|
||||||
|
|
||||||
|
Or you can also assign the variable in your script as nocache:
|
||||||
|
$smarty->assign('foo',$something,true); // third param is nocache setting
|
||||||
|
{$foo} /* non-cached */
|
||||||
|
|
||||||
|
$smarty.current_dir returns the directory name of the current template.
|
||||||
|
|
||||||
|
You can use strings directly as templates with the "string" resource type.
|
||||||
|
Examples:
|
||||||
|
$smarty->display('string:This is my template, {$foo}!'); // php
|
||||||
|
{include file="string:This is my template, {$foo}!"} // template
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
VARIABLE SCOPE / VARIABLE STORAGE
|
||||||
|
=================================
|
||||||
|
|
||||||
|
In Smarty 2, all assigned variables were stored within the Smarty object.
|
||||||
|
Therefore, all variables assigned in PHP were accessible by all subsequent
|
||||||
|
fetch and display template calls.
|
||||||
|
|
||||||
|
In Smarty 3, we have the choice to assign variables to the main Smarty object,
|
||||||
|
to user-created data objects, and to user-created template objects.
|
||||||
|
These objects can be chained. The object at the end of a chain can access all
|
||||||
|
variables belonging to that template and all variables within the parent objects.
|
||||||
|
The Smarty object can only be the root of a chain, but a chain can be isolated
|
||||||
|
from the Smarty object.
|
||||||
|
|
||||||
|
All known Smarty assignment interfaces will work on the data and template objects.
|
||||||
|
|
||||||
|
Besides the above mentioned objects, there is also a special storage area for
|
||||||
|
global variables.
|
||||||
|
|
||||||
|
A Smarty data object can be created as follows:
|
||||||
|
$data = $smarty->createData(); // create root data object
|
||||||
|
$data->assign('foo','bar'); // assign variables as usual
|
||||||
|
$data->config_load('my.conf'); // load config file
|
||||||
|
|
||||||
|
$data= $smarty->createData($smarty); // create data object having a parent link to
|
||||||
|
the Smarty object
|
||||||
|
|
||||||
|
$data2= $smarty->createData($data); // create data object having a parent link to
|
||||||
|
the $data data object
|
||||||
|
|
||||||
|
A template object can be created by using the createTemplate method. It has the
|
||||||
|
same parameter assignments as the fetch() or display() method.
|
||||||
|
Function definition:
|
||||||
|
function createTemplate($template, $cache_id = null, $compile_id = null, $parent = null)
|
||||||
|
|
||||||
|
The first parameter can be a template name, a smarty object or a data object.
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
$tpl = $smarty->createTemplate('mytpl.tpl'); // create template object not linked to any parent
|
||||||
|
$tpl->assign('foo','bar'); // directly assign variables
|
||||||
|
$tpl->config_load('my.conf'); // load config file
|
||||||
|
|
||||||
|
$tpl = $smarty->createTemplate('mytpl.tpl',$smarty); // create template having a parent link to the Smarty object
|
||||||
|
$tpl = $smarty->createTemplate('mytpl.tpl',$data); // create template having a parent link to the $data object
|
||||||
|
|
||||||
|
The standard fetch() and display() methods will implicitly create a template object.
|
||||||
|
If the $parent parameter is not specified in these method calls, the template object
|
||||||
|
is will link back to the Smarty object as it's parent.
|
||||||
|
|
||||||
|
If a template is called by an {include...} tag from another template, the
|
||||||
|
subtemplate links back to the calling template as it's parent.
|
||||||
|
|
||||||
|
All variables assigned locally or from a parent template are accessible. If the
|
||||||
|
template creates or modifies a variable by using the {assign var=foo...} or
|
||||||
|
{$foo=...} tags, these new values are only known locally (local scope). When the
|
||||||
|
template exits, none of the new variables or modifications can be seen in the
|
||||||
|
parent template(s). This is same behavior as in Smarty 2.
|
||||||
|
|
||||||
|
With Smarty 3, we can assign variables with a scope attribute which allows the
|
||||||
|
availablility of these new variables or modifications globally (ie in the parent
|
||||||
|
templates.)
|
||||||
|
|
||||||
|
Possible scopes are local, parent, root and global.
|
||||||
|
Examples:
|
||||||
|
{assign var=foo value='bar'} // no scope is specified, the default 'local'
|
||||||
|
{$foo='bar'} // same, local scope
|
||||||
|
{assign var=foo value='bar' scope='local'} // same, local scope
|
||||||
|
|
||||||
|
{assign var=foo value='bar' scope='parent'} // Values will be available to the parent object
|
||||||
|
{$foo='bar' scope='parent'} // (normally the calling template)
|
||||||
|
|
||||||
|
{assign var=foo value='bar' scope='root'} // Values will be exported up to the root object, so they can
|
||||||
|
{$foo='bar' scope='root'} // be seen from all templates using the same root.
|
||||||
|
|
||||||
|
{assign var=foo value='bar' scope='global'} // Values will be exported to global variable storage,
|
||||||
|
{$foo='bar' scope='global'} // they are available to any and all templates.
|
||||||
|
|
||||||
|
|
||||||
|
The scope attribute can also be attached to the {include...} tag. In this case,
|
||||||
|
the specified scope will be the default scope for all assignments within the
|
||||||
|
included template.
|
||||||
|
|
||||||
|
|
||||||
|
PLUGINS
|
||||||
|
=======
|
||||||
|
|
||||||
|
Smarty3 are following the same coding rules as in Smarty2.
|
||||||
|
The only difference is that the template object is passed as additional third parameter.
|
||||||
|
|
||||||
|
smarty_plugintype_name (array $params, object $smarty, object $template)
|
||||||
|
|
||||||
|
The Smarty 2 plugins are still compatible as long as they do not make use of specific Smarty2 internals.
|
||||||
|
|
||||||
|
|
||||||
|
TEMPLATE INHERITANCE:
|
||||||
|
=====================
|
||||||
|
|
||||||
|
With template inheritance you can define blocks, which are areas that can be
|
||||||
|
overriden by child templates, so your templates could look like this:
|
||||||
|
|
||||||
|
parent.tpl:
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>{block name='title'}My site name{/block}</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>{block name='page-title'}Default page title{/block}</h1>
|
||||||
|
<div id="content">
|
||||||
|
{block name='content'}
|
||||||
|
Default content
|
||||||
|
{/block}
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
|
child.tpl:
|
||||||
|
{extends file='parent.tpl'}
|
||||||
|
{block name='title'}
|
||||||
|
Child title
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
grandchild.tpl:
|
||||||
|
{extends file='child.tpl'}
|
||||||
|
{block name='title'}Home - {$smarty.block.parent}{/block}
|
||||||
|
{block name='page-title'}My home{/block}
|
||||||
|
{block name='content'}
|
||||||
|
{foreach $images as $img}
|
||||||
|
<img src="{$img.url}" alt="{$img.description}" />
|
||||||
|
{/foreach}
|
||||||
|
{/block}
|
||||||
|
|
||||||
|
We redefined all the blocks here, however in the title block we used {$smarty.block.parent},
|
||||||
|
which tells Smarty to insert the default content from the parent template in its place.
|
||||||
|
The content block was overriden to display the image files, and page-title has also be
|
||||||
|
overriden to display a completely different title.
|
||||||
|
|
||||||
|
If we render grandchild.tpl we will get this:
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Home - Child title</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>My home</h1>
|
||||||
|
<div id="content">
|
||||||
|
<img src="/example.jpg" alt="image" />
|
||||||
|
<img src="/example2.jpg" alt="image" />
|
||||||
|
<img src="/example3.jpg" alt="image" />
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
|
NOTE: In the child templates everything outside the {extends} or {block} tag sections
|
||||||
|
is ignored.
|
||||||
|
|
||||||
|
The inheritance tree can be as big as you want (meaning you can extend a file that
|
||||||
|
extends another one that extends another one and so on..), but be aware that all files
|
||||||
|
have to be checked for modifications at runtime so the more inheritance the more overhead you add.
|
||||||
|
|
||||||
|
Instead of defining the parent/child relationships with the {extends} tag in the child template you
|
||||||
|
can use the resource as follow:
|
||||||
|
|
||||||
|
$smarty->display('extends:parent.tpl|child.tpl|grandchild.tpl');
|
||||||
|
|
||||||
|
Child {block} tags may optionally have a append or prepend attribute. In this case the parent block content
|
||||||
|
is appended or prepended to the child block content.
|
||||||
|
|
||||||
|
{block name='title' append} My title {/block}
|
||||||
|
|
||||||
|
|
||||||
|
PHP STREAMS:
|
||||||
|
============
|
||||||
|
|
||||||
|
(see online documentation)
|
||||||
|
|
||||||
|
VARIBLE FILTERS:
|
||||||
|
================
|
||||||
|
|
||||||
|
(see online documentation)
|
||||||
|
|
||||||
|
|
||||||
|
STATIC CLASS ACCESS AND NAMESPACE SUPPORT
|
||||||
|
=========================================
|
||||||
|
|
||||||
|
You can register a class with optional namespace for the use in the template like:
|
||||||
|
|
||||||
|
$smarty->register->templateClass('foo','name\name2\myclass');
|
||||||
|
|
||||||
|
In the template you can use it like this:
|
||||||
|
{foo::method()} etc.
|
||||||
|
|
||||||
|
|
||||||
|
=======================
|
||||||
|
|
||||||
|
Please look through it and send any questions/suggestions/etc to the forums.
|
||||||
|
|
||||||
|
http://www.phpinsider.com/smarty-forum/viewtopic.php?t=14168
|
||||||
|
|
||||||
|
Monte and Uwe
|
||||||
108
lib/classes/Smarty-3.0.8/SMARTY2_BC_NOTES
Normal file
108
lib/classes/Smarty-3.0.8/SMARTY2_BC_NOTES
Normal file
@@ -0,0 +1,108 @@
|
|||||||
|
Smarty 2 and Smarty 3 are quite similar in implementation, but do have a few
|
||||||
|
differences you need to be aware of when upgrading from Smarty 2 to Smarty 3.
|
||||||
|
|
||||||
|
= Known incompatibilities with Smarty 2 =
|
||||||
|
|
||||||
|
== Syntax ==
|
||||||
|
|
||||||
|
The Smarty 3 API has been updated in various places. Some Smarty 2 API calls
|
||||||
|
need to be updated to comply with Smarty 3. You will get a deprecation notice
|
||||||
|
with old Smarty 2 API calls, and informed what the new one is. See the README that
|
||||||
|
comes with Smarty 3 for more information.
|
||||||
|
|
||||||
|
The {$array|@mod} syntax has always been a bit confusing, where an "@" is required
|
||||||
|
to apply a modifier to an array instead of the individual array elements. Normally you
|
||||||
|
always want the modifier to apply to the variable regardless of its type. In Smarty 3,
|
||||||
|
{$array|mod} and {$array|@mod} behave identical. It is safe to drop the "@" and the
|
||||||
|
modifier will still apply to the array. If you really want the modifier to apply to
|
||||||
|
each array element, you must loop the array in-template, or use a custom modifier that
|
||||||
|
supports array iteration. Most smarty functions already escape array elements where
|
||||||
|
necessary such as {html_options}
|
||||||
|
|
||||||
|
== PHP Version ==
|
||||||
|
Smarty 3 is PHP 5 only. It will not work with PHP 4.
|
||||||
|
|
||||||
|
== {php} Tag ==
|
||||||
|
The {php} tag is disabled by default. The use of {php} tags is
|
||||||
|
deprecated. It can be enabled with $smarty->allow_php_tag=true.
|
||||||
|
|
||||||
|
Variables inside {php} blocks no longer share scope with other
|
||||||
|
{php} blocks on the page, so be aware of this change if you use them.
|
||||||
|
|
||||||
|
== Delimiters and whitespace ==
|
||||||
|
Smarty delimiters {} surrounded by whitespace are no longer treated as Smarty tags.
|
||||||
|
Therefore, { foo } will be ignored by Smarty, but {foo} is recognized. This change
|
||||||
|
makes Javascript/CSS easier to work with, eliminating the need for {literal}.
|
||||||
|
This feature can be disabled by setting $smarty->auto_literal = false;
|
||||||
|
|
||||||
|
== Unquoted Strings ==
|
||||||
|
Smarty 2 was a bit more forgiving (and ambiguous) when it comes to unquoted strings
|
||||||
|
in parameters. Smarty3 is more restrictive. You can still pass strings without quotes
|
||||||
|
so long as they contain no special characters. (anything outside of A-Za-z0-9_)
|
||||||
|
|
||||||
|
For example filename strings must be quoted:
|
||||||
|
|
||||||
|
<source lang="smarty">
|
||||||
|
{assign var=foo value=baz} <-- works ok
|
||||||
|
{include file="path/foo.tpl"} <-- needs quotes!
|
||||||
|
</source>
|
||||||
|
|
||||||
|
== Extending the Smarty class ==
|
||||||
|
Smarty 3 follows standard PHP5 constructor rules. When extending the Smarty class,
|
||||||
|
use __construct() as the class constructor name. If you implement your own constructor,
|
||||||
|
be certain to call parent::__construct() first.
|
||||||
|
|
||||||
|
<source lang="php">
|
||||||
|
class MySmarty extends Smarty {
|
||||||
|
function __construct() {
|
||||||
|
parent::__construct();
|
||||||
|
|
||||||
|
// your initialization code goes here
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</source>
|
||||||
|
|
||||||
|
== Autoloader ==
|
||||||
|
Smarty implements its own autoloader with spl_autoload_register. If you
|
||||||
|
use an autoloader in your own application, you MUST register yours as well. Using
|
||||||
|
__autoload() WILL FAIL. This is standard PHP5 autoloader procedure for shared libraries.
|
||||||
|
See http://us3.php.net/manual/en/function.spl-autoload-register.php
|
||||||
|
|
||||||
|
== Plugin Filenames ==
|
||||||
|
Since Smarty 3 uses the default spl_autoloader, the plugin filenames are now required to be
|
||||||
|
lower case. Smarty 2 allowed mixed case plugin names, you must rename them for Smarty 3.
|
||||||
|
|
||||||
|
== Scope of Special Smarty Variables ==
|
||||||
|
In Smarty 2 the special Smarty variables $smarty.section.* and $smarty.foreach.*
|
||||||
|
had global scope. If you had loops with the same name in subtemplates, you could accidentally
|
||||||
|
overwrite values of a parent template.
|
||||||
|
|
||||||
|
In Smarty 3 these special Smarty variables now have local scope in the template which
|
||||||
|
is defining the loop. In the rare case you need these values in a subtemplate, you have to
|
||||||
|
pass them as parameters.
|
||||||
|
|
||||||
|
<source lang="smarty">
|
||||||
|
{include file="path/foo.tpl" index=$smarty.section.foo.index}
|
||||||
|
</source>
|
||||||
|
|
||||||
|
== SMARTY_RESOURCE_CHAR_SET ==
|
||||||
|
Smarty 3 sets the constant SMARTY_RESOURCE_CHAR_SET to utf-8 as the default template charset.
|
||||||
|
This is now used with modifiers like escape as the default charset. If your templates use
|
||||||
|
another charset, make sure that you define the constant accordingly.
|
||||||
|
|
||||||
|
== trigger_error() ==
|
||||||
|
The API function trigger_error() has been removed. It is still included in the Smarty2 API wrapper.
|
||||||
|
|
||||||
|
== Smarty constants ==
|
||||||
|
The constants
|
||||||
|
SMARTY_PHP_PASSTHRU
|
||||||
|
SMARTY_PHP_QUOTE
|
||||||
|
SMARTY_PHP_REMOVE
|
||||||
|
SMARTY_PHP_ALLOW
|
||||||
|
have been replaced with class constants
|
||||||
|
Smarty::PHP_PASSTHRU
|
||||||
|
Smarty::PHP_QUOTE
|
||||||
|
Smarty::PHP_REMOVE
|
||||||
|
Smarty::PHP_ALLOW
|
||||||
|
|
||||||
1457
lib/classes/Smarty-3.0.8/change_log.txt
Normal file
1457
lib/classes/Smarty-3.0.8/change_log.txt
Normal file
File diff suppressed because it is too large
Load Diff
5
lib/classes/Smarty-3.0.8/demo/configs/test.conf
Normal file
5
lib/classes/Smarty-3.0.8/demo/configs/test.conf
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
title = Welcome to Smarty!
|
||||||
|
cutoff_size = 40
|
||||||
|
|
||||||
|
[setup]
|
||||||
|
bold = true
|
||||||
27
lib/classes/Smarty-3.0.8/demo/index.php
Normal file
27
lib/classes/Smarty-3.0.8/demo/index.php
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
<?php
|
||||||
|
require('../libs/Smarty.class.php');
|
||||||
|
|
||||||
|
$smarty = new Smarty;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//$smarty->force_compile = true;
|
||||||
|
$smarty->debugging = true;
|
||||||
|
$smarty->caching = true;
|
||||||
|
$smarty->cache_lifetime = 120;
|
||||||
|
|
||||||
|
$smarty->assign("Name","Fred Irving Johnathan Bradley Peppergill",true);
|
||||||
|
$smarty->assign("FirstName",array("John","Mary","James","Henry"));
|
||||||
|
$smarty->assign("LastName",array("Doe","Smith","Johnson","Case"));
|
||||||
|
$smarty->assign("Class",array(array("A","B","C","D"), array("E", "F", "G", "H"),
|
||||||
|
array("I", "J", "K", "L"), array("M", "N", "O", "P")));
|
||||||
|
|
||||||
|
$smarty->assign("contacts", array(array("phone" => "1", "fax" => "2", "cell" => "3"),
|
||||||
|
array("phone" => "555-4444", "fax" => "555-3333", "cell" => "760-1234")));
|
||||||
|
|
||||||
|
$smarty->assign("option_values", array("NY","NE","KS","IA","OK","TX"));
|
||||||
|
$smarty->assign("option_output", array("New York","Nebraska","Kansas","Iowa","Oklahoma","Texas"));
|
||||||
|
$smarty->assign("option_selected", "NE");
|
||||||
|
|
||||||
|
$smarty->display('index.tpl');
|
||||||
|
?>
|
||||||
49
lib/classes/Smarty-3.0.8/demo/index_php_template.php
Normal file
49
lib/classes/Smarty-3.0.8/demo/index_php_template.php
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Test script for PHP template
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @package SmartyTestScripts
|
||||||
|
*/
|
||||||
|
require('../libs/Smarty.class.php');
|
||||||
|
|
||||||
|
class Person
|
||||||
|
{
|
||||||
|
private $m_szName;
|
||||||
|
private $m_iAge;
|
||||||
|
|
||||||
|
public function setName($szName)
|
||||||
|
{
|
||||||
|
$this->m_szName = $szName;
|
||||||
|
return $this; // We now return $this (the Person)
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setAge($iAge)
|
||||||
|
{
|
||||||
|
$this->m_iAge = $iAge;
|
||||||
|
return $this; // Again, return our Person
|
||||||
|
}
|
||||||
|
|
||||||
|
public function introduce()
|
||||||
|
{
|
||||||
|
return 'Hello my name is '.$this->m_szName.' and I am '.$this->m_iAge.' years old.';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$smarty = new Smarty();
|
||||||
|
$smarty->allow_php_templates= true;
|
||||||
|
$smarty->force_compile = false;
|
||||||
|
$smarty->caching = true;
|
||||||
|
$smarty->cache_lifetime = 100;
|
||||||
|
//$smarty->debugging = true;
|
||||||
|
|
||||||
|
$smarty->assign('foo',"'bar'");
|
||||||
|
|
||||||
|
$person = new Person;
|
||||||
|
|
||||||
|
$smarty->assign('person',$person);
|
||||||
|
|
||||||
|
$smarty->assign('array',array('a'=>array('aa'=>'This is a long string'),'b'=>2));
|
||||||
|
|
||||||
|
$smarty->display('php:index_view.php');
|
||||||
|
|
||||||
|
?>
|
||||||
2
lib/classes/Smarty-3.0.8/demo/templates/footer.tpl
Normal file
2
lib/classes/Smarty-3.0.8/demo/templates/footer.tpl
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
</BODY>
|
||||||
|
</HTML>
|
||||||
5
lib/classes/Smarty-3.0.8/demo/templates/header.tpl
Normal file
5
lib/classes/Smarty-3.0.8/demo/templates/header.tpl
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
<HTML>
|
||||||
|
<HEAD>
|
||||||
|
<TITLE>{$title} - {$Name}</TITLE>
|
||||||
|
</HEAD>
|
||||||
|
<BODY bgcolor="#ffffff">
|
||||||
82
lib/classes/Smarty-3.0.8/demo/templates/index.tpl
Normal file
82
lib/classes/Smarty-3.0.8/demo/templates/index.tpl
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
{config_load file="test.conf" section="setup"}
|
||||||
|
{include file="header.tpl" title=foo}
|
||||||
|
|
||||||
|
<PRE>
|
||||||
|
|
||||||
|
{* bold and title are read from the config file *}
|
||||||
|
{if #bold#}<b>{/if}
|
||||||
|
{* capitalize the first letters of each word of the title *}
|
||||||
|
Title: {#title#|capitalize}
|
||||||
|
{if #bold#}</b>{/if}
|
||||||
|
|
||||||
|
The current date and time is {$smarty.now|date_format:"%Y-%m-%d %H:%M:%S"}
|
||||||
|
|
||||||
|
The value of global assigned variable $SCRIPT_NAME is {$SCRIPT_NAME}
|
||||||
|
|
||||||
|
Example of accessing server environment variable SERVER_NAME: {$smarty.server.SERVER_NAME}
|
||||||
|
|
||||||
|
The value of {ldelim}$Name{rdelim} is <b>{$Name}</b>
|
||||||
|
|
||||||
|
variable modifier example of {ldelim}$Name|upper{rdelim}
|
||||||
|
|
||||||
|
<b>{$Name|upper}</b>
|
||||||
|
|
||||||
|
|
||||||
|
An example of a section loop:
|
||||||
|
|
||||||
|
{section name=outer
|
||||||
|
loop=$FirstName}
|
||||||
|
{if $smarty.section.outer.index is odd by 2}
|
||||||
|
{$smarty.section.outer.rownum} . {$FirstName[outer]} {$LastName[outer]}
|
||||||
|
{else}
|
||||||
|
{$smarty.section.outer.rownum} * {$FirstName[outer]} {$LastName[outer]}
|
||||||
|
{/if}
|
||||||
|
{sectionelse}
|
||||||
|
none
|
||||||
|
{/section}
|
||||||
|
|
||||||
|
An example of section looped key values:
|
||||||
|
|
||||||
|
{section name=sec1 loop=$contacts}
|
||||||
|
phone: {$contacts[sec1].phone}<br>
|
||||||
|
fax: {$contacts[sec1].fax}<br>
|
||||||
|
cell: {$contacts[sec1].cell}<br>
|
||||||
|
{/section}
|
||||||
|
<p>
|
||||||
|
|
||||||
|
testing strip tags
|
||||||
|
{strip}
|
||||||
|
<table border=0>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<A HREF="{$SCRIPT_NAME}">
|
||||||
|
<font color="red">This is a test </font>
|
||||||
|
</A>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
{/strip}
|
||||||
|
|
||||||
|
</PRE>
|
||||||
|
|
||||||
|
This is an example of the html_select_date function:
|
||||||
|
|
||||||
|
<form>
|
||||||
|
{html_select_date start_year=1998 end_year=2010}
|
||||||
|
</form>
|
||||||
|
|
||||||
|
This is an example of the html_select_time function:
|
||||||
|
|
||||||
|
<form>
|
||||||
|
{html_select_time use_24_hours=false}
|
||||||
|
</form>
|
||||||
|
|
||||||
|
This is an example of the html_options function:
|
||||||
|
|
||||||
|
<form>
|
||||||
|
<select name=states>
|
||||||
|
{html_options values=$option_values selected=$option_selected output=$option_output}
|
||||||
|
</select>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
{include file="footer.tpl"}
|
||||||
13
lib/classes/Smarty-3.0.8/demo/templates/index_view.php
Normal file
13
lib/classes/Smarty-3.0.8/demo/templates/index_view.php
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
PHP file test
|
||||||
|
$foo is <?=$foo?>
|
||||||
|
<br> Test functions
|
||||||
|
<? echo trim($foo,"'");?>
|
||||||
|
<br>Test objects
|
||||||
|
<?=$person->setName('Paul')->setAge(39)->introduce()?>
|
||||||
|
<br>Test Arrays
|
||||||
|
<?=$array['a']['aa']?> <?=$array['b']?>
|
||||||
|
<br>function time
|
||||||
|
<? echo time();?>
|
||||||
|
<br>nocache function time
|
||||||
|
<? echo '<? echo time();?>';?>
|
||||||
|
<br>DONE
|
||||||
815
lib/classes/Smarty-3.0.8/libs/Smarty.class.php
Normal file
815
lib/classes/Smarty-3.0.8/libs/Smarty.class.php
Normal file
@@ -0,0 +1,815 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Project: Smarty: the PHP compiling template engine
|
||||||
|
* File: Smarty.class.php
|
||||||
|
* SVN: $Id: Smarty.class.php 4074 2011-04-22 02:19:14Z uwe.tews@googlemail.com $
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*
|
||||||
|
* For questions, help, comments, discussion, etc., please join the
|
||||||
|
* Smarty mailing list. Send a blank e-mail to
|
||||||
|
* smarty-discussion-subscribe@googlegroups.com
|
||||||
|
*
|
||||||
|
* @link http://www.smarty.net/
|
||||||
|
* @copyright 2008 New Digital Group, Inc.
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @author Uwe Tews
|
||||||
|
* @package Smarty
|
||||||
|
* @version 3.0.8
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* define shorthand directory separator constant
|
||||||
|
*/
|
||||||
|
if (!defined('DS')) {
|
||||||
|
define('DS', DIRECTORY_SEPARATOR);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set SMARTY_DIR to absolute path to Smarty library files.
|
||||||
|
* Sets SMARTY_DIR only if user application has not already defined it.
|
||||||
|
*/
|
||||||
|
if (!defined('SMARTY_DIR')) {
|
||||||
|
define('SMARTY_DIR', dirname(__FILE__) . DS);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set SMARTY_SYSPLUGINS_DIR to absolute path to Smarty internal plugins.
|
||||||
|
* Sets SMARTY_SYSPLUGINS_DIR only if user application has not already defined it.
|
||||||
|
*/
|
||||||
|
if (!defined('SMARTY_SYSPLUGINS_DIR')) {
|
||||||
|
define('SMARTY_SYSPLUGINS_DIR', SMARTY_DIR . 'sysplugins' . DS);
|
||||||
|
}
|
||||||
|
if (!defined('SMARTY_PLUGINS_DIR')) {
|
||||||
|
define('SMARTY_PLUGINS_DIR', SMARTY_DIR . 'plugins' . DS);
|
||||||
|
}
|
||||||
|
if (!defined('SMARTY_RESOURCE_CHAR_SET')) {
|
||||||
|
define('SMARTY_RESOURCE_CHAR_SET', 'UTF-8');
|
||||||
|
}
|
||||||
|
if (!defined('SMARTY_RESOURCE_DATE_FORMAT')) {
|
||||||
|
define('SMARTY_RESOURCE_DATE_FORMAT', '%b %e, %Y');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* register the class autoloader
|
||||||
|
*/
|
||||||
|
if (!defined('SMARTY_SPL_AUTOLOAD')) {
|
||||||
|
define('SMARTY_SPL_AUTOLOAD', 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (SMARTY_SPL_AUTOLOAD && set_include_path(get_include_path() . PATH_SEPARATOR . SMARTY_SYSPLUGINS_DIR) !== false) {
|
||||||
|
$registeredAutoLoadFunctions = spl_autoload_functions();
|
||||||
|
if (!isset($registeredAutoLoadFunctions['spl_autoload'])) {
|
||||||
|
spl_autoload_register();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
spl_autoload_register('smartyAutoload');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is the main Smarty class
|
||||||
|
*/
|
||||||
|
class Smarty extends Smarty_Internal_Data {
|
||||||
|
/**
|
||||||
|
* constant definitions
|
||||||
|
*/
|
||||||
|
// smarty version
|
||||||
|
const SMARTY_VERSION = 'Smarty-3.0.8';
|
||||||
|
//define variable scopes
|
||||||
|
const SCOPE_LOCAL = 0;
|
||||||
|
const SCOPE_PARENT = 1;
|
||||||
|
const SCOPE_ROOT = 2;
|
||||||
|
const SCOPE_GLOBAL = 3;
|
||||||
|
// define caching modes
|
||||||
|
const CACHING_OFF = 0;
|
||||||
|
const CACHING_LIFETIME_CURRENT = 1;
|
||||||
|
const CACHING_LIFETIME_SAVED = 2;
|
||||||
|
/** modes for handling of "<?php ... ?>" tags in templates. **/
|
||||||
|
const PHP_PASSTHRU = 0; //-> print tags as plain text
|
||||||
|
const PHP_QUOTE = 1; //-> escape tags as entities
|
||||||
|
const PHP_REMOVE = 2; //-> escape tags as entities
|
||||||
|
const PHP_ALLOW = 3; //-> escape tags as entities
|
||||||
|
// filter types
|
||||||
|
const FILTER_POST = 'post';
|
||||||
|
const FILTER_PRE = 'pre';
|
||||||
|
const FILTER_OUTPUT = 'output';
|
||||||
|
const FILTER_VARIABLE = 'variable';
|
||||||
|
// plugin types
|
||||||
|
const PLUGIN_FUNCTION = 'function';
|
||||||
|
const PLUGIN_BLOCK = 'block';
|
||||||
|
const PLUGIN_COMPILER = 'compiler';
|
||||||
|
const PLUGIN_MODIFIER = 'modifier';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* static variables
|
||||||
|
*/
|
||||||
|
// assigned global tpl vars
|
||||||
|
static $global_tpl_vars = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* variables
|
||||||
|
*/
|
||||||
|
// auto literal on delimiters with whitspace
|
||||||
|
public $auto_literal = true;
|
||||||
|
// display error on not assigned variables
|
||||||
|
public $error_unassigned = false;
|
||||||
|
// template directory
|
||||||
|
public $template_dir = null;
|
||||||
|
// default template handler
|
||||||
|
public $default_template_handler_func = null;
|
||||||
|
// compile directory
|
||||||
|
public $compile_dir = null;
|
||||||
|
// plugins directory
|
||||||
|
public $plugins_dir = null;
|
||||||
|
// cache directory
|
||||||
|
public $cache_dir = null;
|
||||||
|
// config directory
|
||||||
|
public $config_dir = null;
|
||||||
|
// force template compiling?
|
||||||
|
public $force_compile = false;
|
||||||
|
// check template for modifications?
|
||||||
|
public $compile_check = true;
|
||||||
|
// locking concurrent compiles
|
||||||
|
public $compile_locking = true;
|
||||||
|
// use sub dirs for compiled/cached files?
|
||||||
|
public $use_sub_dirs = false;
|
||||||
|
// compile_error?
|
||||||
|
public $compile_error = false;
|
||||||
|
// caching enabled
|
||||||
|
public $caching = false;
|
||||||
|
// merge compiled includes
|
||||||
|
public $merge_compiled_includes = false;
|
||||||
|
// cache lifetime
|
||||||
|
public $cache_lifetime = 3600;
|
||||||
|
// force cache file creation
|
||||||
|
public $force_cache = false;
|
||||||
|
// cache_id
|
||||||
|
public $cache_id = null;
|
||||||
|
// compile_id
|
||||||
|
public $compile_id = null;
|
||||||
|
// template delimiters
|
||||||
|
public $left_delimiter = "{";
|
||||||
|
public $right_delimiter = "}";
|
||||||
|
// security
|
||||||
|
public $security_class = 'Smarty_Security';
|
||||||
|
public $security_policy = null;
|
||||||
|
public $php_handling = self::PHP_PASSTHRU;
|
||||||
|
public $allow_php_tag = false;
|
||||||
|
public $allow_php_templates = false;
|
||||||
|
public $direct_access_security = true;
|
||||||
|
public $trusted_dir = array();
|
||||||
|
// debug mode
|
||||||
|
public $debugging = false;
|
||||||
|
public $debugging_ctrl = 'NONE';
|
||||||
|
public $smarty_debug_id = 'SMARTY_DEBUG';
|
||||||
|
public $debug_tpl = null;
|
||||||
|
// When set, smarty does uses this value as error_reporting-level.
|
||||||
|
public $error_reporting = null;
|
||||||
|
// config var settings
|
||||||
|
public $config_overwrite = true; //Controls whether variables with the same name overwrite each other.
|
||||||
|
public $config_booleanize = true; //Controls whether config values of on/true/yes and off/false/no get converted to boolean
|
||||||
|
public $config_read_hidden = false; //Controls whether hidden config sections/vars are read from the file.
|
||||||
|
// config vars
|
||||||
|
public $config_vars = array();
|
||||||
|
// assigned tpl vars
|
||||||
|
public $tpl_vars = array();
|
||||||
|
// dummy parent object
|
||||||
|
public $parent = null;
|
||||||
|
// global template functions
|
||||||
|
public $template_functions = array();
|
||||||
|
// resource type used if none given
|
||||||
|
public $default_resource_type = 'file';
|
||||||
|
// caching type
|
||||||
|
public $caching_type = 'file';
|
||||||
|
// internal cache resource types
|
||||||
|
public $cache_resource_types = array('file');
|
||||||
|
// internal config properties
|
||||||
|
public $properties = array();
|
||||||
|
// config type
|
||||||
|
public $default_config_type = 'file';
|
||||||
|
// cached template objects
|
||||||
|
public $template_objects = null;
|
||||||
|
// check If-Modified-Since headers
|
||||||
|
public $cache_modified_check = false;
|
||||||
|
// registered plugins
|
||||||
|
public $registered_plugins = array();
|
||||||
|
// plugin search order
|
||||||
|
public $plugin_search_order = array('function', 'block', 'compiler', 'class');
|
||||||
|
// registered objects
|
||||||
|
public $registered_objects = array();
|
||||||
|
// registered classes
|
||||||
|
public $registered_classes = array();
|
||||||
|
// registered filters
|
||||||
|
public $registered_filters = array();
|
||||||
|
// registered resources
|
||||||
|
public $registered_resources = array();
|
||||||
|
// autoload filter
|
||||||
|
public $autoload_filters = array();
|
||||||
|
// status of filter on variable output
|
||||||
|
public $variable_filter = true;
|
||||||
|
// default modifier
|
||||||
|
public $default_modifiers = array();
|
||||||
|
// global internal smarty vars
|
||||||
|
static $_smarty_vars = array();
|
||||||
|
// start time for execution time calculation
|
||||||
|
public $start_time = 0;
|
||||||
|
// default file permissions
|
||||||
|
public $_file_perms = 0644;
|
||||||
|
// default dir permissions
|
||||||
|
public $_dir_perms = 0771;
|
||||||
|
// block tag hierarchy
|
||||||
|
public $_tag_stack = array();
|
||||||
|
// flag if {block} tag is compiled for template inheritance
|
||||||
|
public $inheritance = false;
|
||||||
|
// generate deprecated function call notices?
|
||||||
|
public $deprecation_notices = true;
|
||||||
|
// Smarty 2 BC
|
||||||
|
public $_version = self::SMARTY_VERSION;
|
||||||
|
// self pointer to Smarty object
|
||||||
|
public $smarty;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class constructor, initializes basic smarty properties
|
||||||
|
*/
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
// selfpointer need by some other class methods
|
||||||
|
$this->smarty = $this;
|
||||||
|
if (is_callable('mb_internal_encoding')) {
|
||||||
|
mb_internal_encoding(SMARTY_RESOURCE_CHAR_SET);
|
||||||
|
}
|
||||||
|
$this->start_time = microtime(true);
|
||||||
|
// set default dirs
|
||||||
|
$this->template_dir = array('.' . DS . 'templates' . DS);
|
||||||
|
$this->compile_dir = '.' . DS . 'templates_c' . DS;
|
||||||
|
$this->plugins_dir = array(SMARTY_PLUGINS_DIR);
|
||||||
|
$this->cache_dir = '.' . DS . 'cache' . DS;
|
||||||
|
$this->config_dir = '.' . DS . 'configs' . DS;
|
||||||
|
$this->debug_tpl = 'file:' . SMARTY_DIR . 'debug.tpl';
|
||||||
|
if (isset($_SERVER['SCRIPT_NAME'])) {
|
||||||
|
$this->assignGlobal('SCRIPT_NAME', $_SERVER['SCRIPT_NAME']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class destructor
|
||||||
|
*/
|
||||||
|
public function __destruct()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* fetches a rendered Smarty template
|
||||||
|
*
|
||||||
|
* @param string $template the resource handle of the template file or template object
|
||||||
|
* @param mixed $cache_id cache id to be used with this template
|
||||||
|
* @param mixed $compile_id compile id to be used with this template
|
||||||
|
* @param object $ |null $parent next higher level of Smarty variables
|
||||||
|
* @return string rendered template output
|
||||||
|
*/
|
||||||
|
public function fetch($template, $cache_id = null, $compile_id = null, $parent = null, $display = false)
|
||||||
|
{
|
||||||
|
if (!empty($cache_id) && is_object($cache_id)) {
|
||||||
|
$parent = $cache_id;
|
||||||
|
$cache_id = null;
|
||||||
|
}
|
||||||
|
if ($parent === null) {
|
||||||
|
// get default Smarty data object
|
||||||
|
$parent = $this;
|
||||||
|
}
|
||||||
|
// create template object if necessary
|
||||||
|
($template instanceof $this->template_class)? $_template = $template :
|
||||||
|
$_template = $this->createTemplate ($template, $cache_id, $compile_id, $parent, false);
|
||||||
|
if (isset($this->error_reporting)) {
|
||||||
|
$_smarty_old_error_level = error_reporting($this->error_reporting);
|
||||||
|
}
|
||||||
|
// check URL debugging control
|
||||||
|
if (!$this->debugging && $this->debugging_ctrl == 'URL') {
|
||||||
|
if (isset($_SERVER['QUERY_STRING'])) {
|
||||||
|
$_query_string = $_SERVER['QUERY_STRING'];
|
||||||
|
} else {
|
||||||
|
$_query_string = '';
|
||||||
|
}
|
||||||
|
if (false !== strpos($_query_string, $this->smarty_debug_id)) {
|
||||||
|
if (false !== strpos($_query_string, $this->smarty_debug_id . '=on')) {
|
||||||
|
// enable debugging for this browser session
|
||||||
|
setcookie('SMARTY_DEBUG', true);
|
||||||
|
$this->debugging = true;
|
||||||
|
} elseif (false !== strpos($_query_string, $this->smarty_debug_id . '=off')) {
|
||||||
|
// disable debugging for this browser session
|
||||||
|
setcookie('SMARTY_DEBUG', false);
|
||||||
|
$this->debugging = false;
|
||||||
|
} else {
|
||||||
|
// enable debugging for this page
|
||||||
|
$this->debugging = true;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (isset($_COOKIE['SMARTY_DEBUG'])) {
|
||||||
|
$this->debugging = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// obtain data for cache modified check
|
||||||
|
if ($this->cache_modified_check && $this->caching && $display) {
|
||||||
|
$_isCached = $_template->isCached() && !$_template->has_nocache_code;
|
||||||
|
if ($_isCached) {
|
||||||
|
$_gmt_mtime = gmdate('D, d M Y H:i:s', $_template->getCachedTimestamp()) . ' GMT';
|
||||||
|
} else {
|
||||||
|
$_gmt_mtime = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// return rendered template
|
||||||
|
if ((!$this->caching || $_template->resource_object->isEvaluated) && (isset($this->autoload_filters['output']) || isset($this->registered_filters['output']))) {
|
||||||
|
$_output = Smarty_Internal_Filter_Handler::runFilter('output', $_template->getRenderedTemplate(), $_template);
|
||||||
|
} else {
|
||||||
|
$_output = $_template->getRenderedTemplate();
|
||||||
|
}
|
||||||
|
$_template->rendered_content = null;
|
||||||
|
if (isset($this->error_reporting)) {
|
||||||
|
error_reporting($_smarty_old_error_level);
|
||||||
|
}
|
||||||
|
// display or fetch
|
||||||
|
if ($display) {
|
||||||
|
if ($this->caching && $this->cache_modified_check) {
|
||||||
|
$_last_modified_date = @substr($_SERVER['HTTP_IF_MODIFIED_SINCE'], 0, strpos($_SERVER['HTTP_IF_MODIFIED_SINCE'], 'GMT') + 3);
|
||||||
|
if ($_isCached && $_gmt_mtime == $_last_modified_date) {
|
||||||
|
if (php_sapi_name() == 'cgi')
|
||||||
|
header('Status: 304 Not Modified');
|
||||||
|
else
|
||||||
|
header('HTTP/1.1 304 Not Modified');
|
||||||
|
} else {
|
||||||
|
header('Last-Modified: ' . gmdate('D, d M Y H:i:s', $_template->getCachedTimestamp()) . ' GMT');
|
||||||
|
echo $_output;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
echo $_output;
|
||||||
|
}
|
||||||
|
// debug output
|
||||||
|
if ($this->debugging) {
|
||||||
|
Smarty_Internal_Debug::display_debug($this);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
// return fetched content
|
||||||
|
return $_output;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* displays a Smarty template
|
||||||
|
*
|
||||||
|
* @param string $ |object $template the resource handle of the template file or template object
|
||||||
|
* @param mixed $cache_id cache id to be used with this template
|
||||||
|
* @param mixed $compile_id compile id to be used with this template
|
||||||
|
* @param object $parent next higher level of Smarty variables
|
||||||
|
*/
|
||||||
|
public function display($template, $cache_id = null, $compile_id = null, $parent = null)
|
||||||
|
{
|
||||||
|
// display template
|
||||||
|
$this->fetch ($template, $cache_id, $compile_id, $parent, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* test if cache i valid
|
||||||
|
*
|
||||||
|
* @param string $ |object $template the resource handle of the template file or template object
|
||||||
|
* @param mixed $cache_id cache id to be used with this template
|
||||||
|
* @param mixed $compile_id compile id to be used with this template
|
||||||
|
* @param object $parent next higher level of Smarty variables
|
||||||
|
* @return boolean cache status
|
||||||
|
*/
|
||||||
|
public function isCached($template, $cache_id = null, $compile_id = null, $parent = null)
|
||||||
|
{
|
||||||
|
if ($parent === null) {
|
||||||
|
$parent = $this;
|
||||||
|
}
|
||||||
|
if (!($template instanceof $this->template_class)) {
|
||||||
|
$template = $this->createTemplate ($template, $cache_id, $compile_id, $parent, false);
|
||||||
|
}
|
||||||
|
// return cache status of template
|
||||||
|
return $template->isCached();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* creates a data object
|
||||||
|
*
|
||||||
|
* @param object $parent next higher level of Smarty variables
|
||||||
|
* @returns object data object
|
||||||
|
*/
|
||||||
|
public function createData($parent = null)
|
||||||
|
{
|
||||||
|
return new Smarty_Data($parent, $this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* creates a template object
|
||||||
|
*
|
||||||
|
* @param string $template the resource handle of the template file
|
||||||
|
* @param mixed $cache_id cache id to be used with this template
|
||||||
|
* @param mixed $compile_id compile id to be used with this template
|
||||||
|
* @param object $parent next higher level of Smarty variables
|
||||||
|
* @param boolean $do_clone flag is Smarty object shall be cloned
|
||||||
|
* @returns object template object
|
||||||
|
*/
|
||||||
|
public function createTemplate($template, $cache_id = null, $compile_id = null, $parent = null, $do_clone = true)
|
||||||
|
{
|
||||||
|
if (!empty($cache_id) && (is_object($cache_id) || is_array($cache_id))) {
|
||||||
|
$parent = $cache_id;
|
||||||
|
$cache_id = null;
|
||||||
|
}
|
||||||
|
if (!empty($parent) && is_array($parent)) {
|
||||||
|
$data = $parent;
|
||||||
|
$parent = null;
|
||||||
|
} else {
|
||||||
|
$data = null;
|
||||||
|
}
|
||||||
|
if (!is_object($template)) {
|
||||||
|
// we got a template resource
|
||||||
|
// already in template cache?
|
||||||
|
$_templateId = sha1($template . $cache_id . $compile_id);
|
||||||
|
if (isset($this->template_objects[$_templateId]) && $this->caching) {
|
||||||
|
// return cached template object
|
||||||
|
$tpl = $this->template_objects[$_templateId];
|
||||||
|
} else {
|
||||||
|
// create new template object
|
||||||
|
if ($do_clone) {
|
||||||
|
$tpl = new $this->template_class($template, clone $this, $parent, $cache_id, $compile_id);
|
||||||
|
} else {
|
||||||
|
$tpl = new $this->template_class($template, $this, $parent, $cache_id, $compile_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// just return a copy of template class
|
||||||
|
$tpl = $template;
|
||||||
|
}
|
||||||
|
// fill data if present
|
||||||
|
if (!empty($data) && is_array($data)) {
|
||||||
|
// set up variable values
|
||||||
|
foreach ($data as $_key => $_val) {
|
||||||
|
$tpl->tpl_vars[$_key] = new Smarty_variable($_val);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $tpl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a template resource exists
|
||||||
|
*
|
||||||
|
* @param string $resource_name template name
|
||||||
|
* @return boolean status
|
||||||
|
*/
|
||||||
|
function templateExists($resource_name)
|
||||||
|
{
|
||||||
|
// create template object
|
||||||
|
$save = $this->template_objects;
|
||||||
|
$tpl = new $this->template_class($resource_name, $this);
|
||||||
|
// check if it does exists
|
||||||
|
$result = $tpl->isExisting();
|
||||||
|
$this->template_objects = $save;
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a single or all global variables
|
||||||
|
*
|
||||||
|
* @param object $smarty
|
||||||
|
* @param string $varname variable name or null
|
||||||
|
* @return string variable value or or array of variables
|
||||||
|
*/
|
||||||
|
function getGlobal($varname = null)
|
||||||
|
{
|
||||||
|
if (isset($varname)) {
|
||||||
|
if (isset(self::$global_tpl_vars[$varname])) {
|
||||||
|
return self::$global_tpl_vars[$varname]->value;
|
||||||
|
} else {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$_result = array();
|
||||||
|
foreach (self::$global_tpl_vars AS $key => $var) {
|
||||||
|
$_result[$key] = $var->value;
|
||||||
|
}
|
||||||
|
return $_result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Empty cache folder
|
||||||
|
*
|
||||||
|
* @param integer $exp_time expiration time
|
||||||
|
* @param string $type resource type
|
||||||
|
* @return integer number of cache files deleted
|
||||||
|
*/
|
||||||
|
function clearAllCache($exp_time = null, $type = null)
|
||||||
|
{
|
||||||
|
// load cache resource and call clearAll
|
||||||
|
return $this->loadCacheResource($type)->clearAll($exp_time);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Empty cache for a specific template
|
||||||
|
*
|
||||||
|
* @param string $template_name template name
|
||||||
|
* @param string $cache_id cache id
|
||||||
|
* @param string $compile_id compile id
|
||||||
|
* @param integer $exp_time expiration time
|
||||||
|
* @param string $type resource type
|
||||||
|
* @return integer number of cache files deleted
|
||||||
|
*/
|
||||||
|
function clearCache($template_name, $cache_id = null, $compile_id = null, $exp_time = null, $type = null)
|
||||||
|
{
|
||||||
|
// load cache resource and call clear
|
||||||
|
return $this->loadCacheResource($type)->clear($template_name, $cache_id, $compile_id, $exp_time);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads security class and enables security
|
||||||
|
*/
|
||||||
|
public function enableSecurity($security_class = null)
|
||||||
|
{
|
||||||
|
if ($security_class instanceof Smarty_Security) {
|
||||||
|
$this->security_policy = $security_class;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if ($security_class == null) {
|
||||||
|
$security_class = $this->security_class;
|
||||||
|
}
|
||||||
|
if (class_exists($security_class)) {
|
||||||
|
$this->security_policy = new $security_class($this);
|
||||||
|
} else {
|
||||||
|
throw new SmartyException("Security class '$security_class' is not defined");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disable security
|
||||||
|
*/
|
||||||
|
public function disableSecurity()
|
||||||
|
{
|
||||||
|
$this->security_policy = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads cache resource.
|
||||||
|
*
|
||||||
|
* @param string $type cache resource type
|
||||||
|
* @return object of cache resource
|
||||||
|
*/
|
||||||
|
public function loadCacheResource($type = null) {
|
||||||
|
if (!isset($type)) {
|
||||||
|
$type = $this->caching_type;
|
||||||
|
}
|
||||||
|
if (in_array($type, $this->cache_resource_types)) {
|
||||||
|
$cache_resource_class = 'Smarty_Internal_CacheResource_' . ucfirst($type);
|
||||||
|
return new $cache_resource_class($this);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// try plugins dir
|
||||||
|
$cache_resource_class = 'Smarty_CacheResource_' . ucfirst($type);
|
||||||
|
if ($this->loadPlugin($cache_resource_class)) {
|
||||||
|
return new $cache_resource_class($this);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw new SmartyException("Unable to load cache resource '{$type}'");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set template directory
|
||||||
|
*
|
||||||
|
* @param string $ |array $template_dir folder(s) of template sorces
|
||||||
|
*/
|
||||||
|
public function setTemplateDir($template_dir)
|
||||||
|
{
|
||||||
|
$this->template_dir = (array)$template_dir;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds template directory(s) to existing ones
|
||||||
|
*
|
||||||
|
* @param string $ |array $template_dir folder(s) of template sources
|
||||||
|
*/
|
||||||
|
public function addTemplateDir($template_dir)
|
||||||
|
{
|
||||||
|
$this->template_dir = array_unique(array_merge((array)$this->template_dir, (array)$template_dir));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds directory of plugin files
|
||||||
|
*
|
||||||
|
* @param object $smarty
|
||||||
|
* @param string $ |array $ plugins folder
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
function addPluginsDir($plugins_dir)
|
||||||
|
{
|
||||||
|
$this->plugins_dir = array_unique(array_merge((array)$this->plugins_dir, (array)$plugins_dir));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return a reference to a registered object
|
||||||
|
*
|
||||||
|
* @param string $name object name
|
||||||
|
* @return object
|
||||||
|
*/
|
||||||
|
function getRegisteredObject($name)
|
||||||
|
{
|
||||||
|
if (!isset($this->registered_objects[$name]))
|
||||||
|
throw new SmartyException("'$name' is not a registered object");
|
||||||
|
|
||||||
|
if (!is_object($this->registered_objects[$name][0]))
|
||||||
|
throw new SmartyException("registered '$name' is not an object");
|
||||||
|
|
||||||
|
return $this->registered_objects[$name][0];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return name of debugging template
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
function getDebugTemplate()
|
||||||
|
{
|
||||||
|
return $this->debug_tpl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set the debug template
|
||||||
|
*
|
||||||
|
* @param string $tpl_name
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
function setDebugTemplate($tpl_name)
|
||||||
|
{
|
||||||
|
return $this->debug_tpl = $tpl_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Takes unknown classes and loads plugin files for them
|
||||||
|
* class name format: Smarty_PluginType_PluginName
|
||||||
|
* plugin filename format: plugintype.pluginname.php
|
||||||
|
*
|
||||||
|
* @param string $plugin_name class plugin name to load
|
||||||
|
* @return string |boolean filepath of loaded file or false
|
||||||
|
*/
|
||||||
|
public function loadPlugin($plugin_name, $check = true)
|
||||||
|
{
|
||||||
|
// if function or class exists, exit silently (already loaded)
|
||||||
|
if ($check && (is_callable($plugin_name) || class_exists($plugin_name, false)))
|
||||||
|
return true;
|
||||||
|
// Plugin name is expected to be: Smarty_[Type]_[Name]
|
||||||
|
$_plugin_name = strtolower($plugin_name);
|
||||||
|
$_name_parts = explode('_', $_plugin_name, 3);
|
||||||
|
// class name must have three parts to be valid plugin
|
||||||
|
if (count($_name_parts) < 3 || $_name_parts[0] !== 'smarty') {
|
||||||
|
throw new SmartyException("plugin {$plugin_name} is not a valid name format");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// if type is "internal", get plugin from sysplugins
|
||||||
|
if ($_name_parts[1] == 'internal') {
|
||||||
|
$file = SMARTY_SYSPLUGINS_DIR . $_plugin_name . '.php';
|
||||||
|
if (file_exists($file)) {
|
||||||
|
require_once($file);
|
||||||
|
return $file;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// plugin filename is expected to be: [type].[name].php
|
||||||
|
$_plugin_filename = "{$_name_parts[1]}.{$_name_parts[2]}.php";
|
||||||
|
// loop through plugin dirs and find the plugin
|
||||||
|
foreach((array)$this->plugins_dir as $_plugin_dir) {
|
||||||
|
if (strpos('/\\', substr($_plugin_dir, -1)) === false) {
|
||||||
|
$_plugin_dir .= DS;
|
||||||
|
}
|
||||||
|
$file = $_plugin_dir . $_plugin_filename;
|
||||||
|
if (file_exists($file)) {
|
||||||
|
require_once($file);
|
||||||
|
return $file;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// no plugin loaded
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* clean up properties on cloned object
|
||||||
|
*/
|
||||||
|
public function __clone()
|
||||||
|
{
|
||||||
|
// clear config vars
|
||||||
|
$this->config_vars = array();
|
||||||
|
// clear assigned tpl vars
|
||||||
|
$this->tpl_vars = array();
|
||||||
|
// clear objects for external methods
|
||||||
|
unset($this->register);
|
||||||
|
unset($this->filter);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle unknown class methods
|
||||||
|
*
|
||||||
|
* @param string $name unknown methode name
|
||||||
|
* @param array $args aurgument array
|
||||||
|
*/
|
||||||
|
public function __call($name, $args)
|
||||||
|
{
|
||||||
|
static $camel_func;
|
||||||
|
if (!isset($camel_func))
|
||||||
|
$camel_func = create_function('$c', 'return "_" . strtolower($c[1]);');
|
||||||
|
// see if this is a set/get for a property
|
||||||
|
$first3 = strtolower(substr($name, 0, 3));
|
||||||
|
if (in_array($first3, array('set', 'get')) && substr($name, 3, 1) !== '_') {
|
||||||
|
// try to keep case correct for future PHP 6.0 case-sensitive class methods
|
||||||
|
// lcfirst() not available < PHP 5.3.0, so improvise
|
||||||
|
$property_name = strtolower(substr($name, 3, 1)) . substr($name, 4);
|
||||||
|
// convert camel case to underscored name
|
||||||
|
$property_name = preg_replace_callback('/([A-Z])/', $camel_func, $property_name);
|
||||||
|
if (!property_exists($this, $property_name)) {
|
||||||
|
throw new SmartyException("property '$property_name' does not exist.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ($first3 == 'get')
|
||||||
|
return $this->$property_name;
|
||||||
|
else
|
||||||
|
return $this->$property_name = $args[0];
|
||||||
|
}
|
||||||
|
// Smarty Backward Compatible wrapper
|
||||||
|
if (strpos($name,'_') !== false) {
|
||||||
|
if (!isset($this->wrapper)) {
|
||||||
|
$this->wrapper = new Smarty_Internal_Wrapper($this);
|
||||||
|
}
|
||||||
|
return $this->wrapper->convert($name, $args);
|
||||||
|
}
|
||||||
|
// external Smarty methods ?
|
||||||
|
foreach(array('Filter','Register') as $external) {
|
||||||
|
if (class_exists("Smarty_Internal_{$external}") && method_exists("Smarty_Internal_{$external}",$name)) {
|
||||||
|
if (!isset($this->$external)) {
|
||||||
|
$class = "Smarty_Internal_{$external}";
|
||||||
|
$this->$external = new $class($this);
|
||||||
|
}
|
||||||
|
return call_user_func_array(array($this->$external,$name), $args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (in_array($name,array('clearCompiledTemplate','compileAllTemplates','compileAllConfig','testInstall','getTags'))) {
|
||||||
|
if (!isset($this->utility)) {
|
||||||
|
$this->utility = new Smarty_Internal_Utility($this);
|
||||||
|
}
|
||||||
|
return call_user_func_array(array($this->utility,$name), $args);
|
||||||
|
}
|
||||||
|
// PHP4 call to constructor?
|
||||||
|
if (strtolower($name) == 'smarty') {
|
||||||
|
throw new SmartyException('Please use parent::__construct() to call parent constuctor');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
throw new SmartyException("Call of unknown function '$name'.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Autoloader
|
||||||
|
*/
|
||||||
|
function smartyAutoload($class)
|
||||||
|
{
|
||||||
|
$_class = strtolower($class);
|
||||||
|
if (substr($_class, 0, 16) === 'smarty_internal_' || $_class == 'smarty_security') {
|
||||||
|
include SMARTY_SYSPLUGINS_DIR . $_class . '.php';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty exception class
|
||||||
|
*/
|
||||||
|
Class SmartyException extends Exception {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty compiler exception class
|
||||||
|
*/
|
||||||
|
Class SmartyCompilerException extends SmartyException {
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
133
lib/classes/Smarty-3.0.8/libs/debug.tpl
Normal file
133
lib/classes/Smarty-3.0.8/libs/debug.tpl
Normal file
@@ -0,0 +1,133 @@
|
|||||||
|
{capture name='_smarty_debug' assign=debug_output}
|
||||||
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
|
||||||
|
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
||||||
|
<head>
|
||||||
|
<title>Smarty Debug Console</title>
|
||||||
|
<style type="text/css">
|
||||||
|
{literal}
|
||||||
|
body, h1, h2, td, th, p {
|
||||||
|
font-family: sans-serif;
|
||||||
|
font-weight: normal;
|
||||||
|
font-size: 0.9em;
|
||||||
|
margin: 1px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
margin: 0;
|
||||||
|
text-align: left;
|
||||||
|
padding: 2px;
|
||||||
|
background-color: #f0c040;
|
||||||
|
color: black;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 1.2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
background-color: #9B410E;
|
||||||
|
color: white;
|
||||||
|
text-align: left;
|
||||||
|
font-weight: bold;
|
||||||
|
padding: 2px;
|
||||||
|
border-top: 1px solid black;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
background: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
p, table, div {
|
||||||
|
background: #f0ead8;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin: 0;
|
||||||
|
font-style: italic;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
th, td {
|
||||||
|
font-family: monospace;
|
||||||
|
vertical-align: top;
|
||||||
|
text-align: left;
|
||||||
|
width: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
td {
|
||||||
|
color: green;
|
||||||
|
}
|
||||||
|
|
||||||
|
.odd {
|
||||||
|
background-color: #eeeeee;
|
||||||
|
}
|
||||||
|
|
||||||
|
.even {
|
||||||
|
background-color: #fafafa;
|
||||||
|
}
|
||||||
|
|
||||||
|
.exectime {
|
||||||
|
font-size: 0.8em;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
#table_assigned_vars th {
|
||||||
|
color: blue;
|
||||||
|
}
|
||||||
|
|
||||||
|
#table_config_vars th {
|
||||||
|
color: maroon;
|
||||||
|
}
|
||||||
|
{/literal}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<h1>Smarty Debug Console - {if isset($template_name)}{$template_name|debug_print_var}{else}Total Time {$execution_time|string_format:"%.5f"}{/if}</h1>
|
||||||
|
|
||||||
|
{if !empty($template_data)}
|
||||||
|
<h2>included templates & config files (load time in seconds)</h2>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
{foreach $template_data as $template}
|
||||||
|
<font color=brown>{$template.name}</font>
|
||||||
|
<span class="exectime">
|
||||||
|
(compile {$template['compile_time']|string_format:"%.5f"}) (render {$template['render_time']|string_format:"%.5f"}) (cache {$template['cache_time']|string_format:"%.5f"})
|
||||||
|
</span>
|
||||||
|
<br>
|
||||||
|
{/foreach}
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
<h2>assigned template variables</h2>
|
||||||
|
|
||||||
|
<table id="table_assigned_vars">
|
||||||
|
{foreach $assigned_vars as $vars}
|
||||||
|
<tr class="{if $vars@iteration % 2 eq 0}odd{else}even{/if}">
|
||||||
|
<th>${$vars@key|escape:'html'}</th>
|
||||||
|
<td>{$vars|debug_print_var}</td></tr>
|
||||||
|
{/foreach}
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<h2>assigned config file variables (outer template scope)</h2>
|
||||||
|
|
||||||
|
<table id="table_config_vars">
|
||||||
|
{foreach $config_vars as $vars}
|
||||||
|
<tr class="{if $vars@iteration % 2 eq 0}odd{else}even{/if}">
|
||||||
|
<th>{$vars@key|escape:'html'}</th>
|
||||||
|
<td>{$vars|debug_print_var}</td></tr>
|
||||||
|
{/foreach}
|
||||||
|
|
||||||
|
</table>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
{/capture}
|
||||||
|
<script type="text/javascript">
|
||||||
|
{$id = $template_name|default:''|md5}
|
||||||
|
_smarty_console = window.open("","console{$id}","width=680,height=600,resizable,scrollbars=yes");
|
||||||
|
_smarty_console.document.write("{$debug_output|escape:'javascript'}");
|
||||||
|
_smarty_console.document.close();
|
||||||
|
</script>
|
||||||
27
lib/classes/Smarty-3.0.8/libs/plugins/block.php.php
Normal file
27
lib/classes/Smarty-3.0.8/libs/plugins/block.php.php
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin to execute PHP code
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsBlock
|
||||||
|
* @author Uwe Tews
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {php}{/php} block plugin
|
||||||
|
*
|
||||||
|
* @param string $content contents of the block
|
||||||
|
* @param object $template template object
|
||||||
|
* @param boolean $ &$repeat repeat flag
|
||||||
|
* @return string content re-formatted
|
||||||
|
*/
|
||||||
|
function smarty_block_php($params, $content, $template, &$repeat)
|
||||||
|
{
|
||||||
|
if (!$template->allow_php_tag) {
|
||||||
|
throw new SmartyException("{php} is deprecated, set allow_php_tag = true to enable");
|
||||||
|
}
|
||||||
|
eval($content);
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
102
lib/classes/Smarty-3.0.8/libs/plugins/block.textformat.php
Normal file
102
lib/classes/Smarty-3.0.8/libs/plugins/block.textformat.php
Normal file
@@ -0,0 +1,102 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin to format text blocks
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsBlock
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {textformat}{/textformat} block plugin
|
||||||
|
*
|
||||||
|
* Type: block function<br>
|
||||||
|
* Name: textformat<br>
|
||||||
|
* Purpose: format text a certain way with preset styles
|
||||||
|
* or custom wrap/indent settings<br>
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.textformat.php {textformat}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @param array $params parameters
|
||||||
|
* <pre>
|
||||||
|
* Params: style: string (email)
|
||||||
|
* indent: integer (0)
|
||||||
|
* wrap: integer (80)
|
||||||
|
* wrap_char string ("\n")
|
||||||
|
* indent_char: string (" ")
|
||||||
|
* wrap_boundary: boolean (true)
|
||||||
|
* </pre>
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @param string $content contents of the block
|
||||||
|
* @param object $template template object
|
||||||
|
* @param boolean &$repeat repeat flag
|
||||||
|
* @return string content re-formatted
|
||||||
|
*/
|
||||||
|
function smarty_block_textformat($params, $content, $template, &$repeat)
|
||||||
|
{
|
||||||
|
if (is_null($content)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$style = null;
|
||||||
|
$indent = 0;
|
||||||
|
$indent_first = 0;
|
||||||
|
$indent_char = ' ';
|
||||||
|
$wrap = 80;
|
||||||
|
$wrap_char = "\n";
|
||||||
|
$wrap_cut = false;
|
||||||
|
$assign = null;
|
||||||
|
|
||||||
|
foreach ($params as $_key => $_val) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'style':
|
||||||
|
case 'indent_char':
|
||||||
|
case 'wrap_char':
|
||||||
|
case 'assign':
|
||||||
|
$$_key = (string)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'indent':
|
||||||
|
case 'indent_first':
|
||||||
|
case 'wrap':
|
||||||
|
$$_key = (int)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'wrap_cut':
|
||||||
|
$$_key = (bool)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
trigger_error("textformat: unknown attribute '$_key'");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($style == 'email') {
|
||||||
|
$wrap = 72;
|
||||||
|
}
|
||||||
|
// split into paragraphs
|
||||||
|
$_paragraphs = preg_split('![\r\n][\r\n]!', $content);
|
||||||
|
$_output = '';
|
||||||
|
|
||||||
|
for($_x = 0, $_y = count($_paragraphs); $_x < $_y; $_x++) {
|
||||||
|
if ($_paragraphs[$_x] == '') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// convert mult. spaces & special chars to single space
|
||||||
|
$_paragraphs[$_x] = preg_replace(array('!\s+!', '!(^\s+)|(\s+$)!'), array(' ', ''), $_paragraphs[$_x]);
|
||||||
|
// indent first line
|
||||||
|
if ($indent_first > 0) {
|
||||||
|
$_paragraphs[$_x] = str_repeat($indent_char, $indent_first) . $_paragraphs[$_x];
|
||||||
|
}
|
||||||
|
// wordwrap sentences
|
||||||
|
$_paragraphs[$_x] = wordwrap($_paragraphs[$_x], $wrap - $indent, $wrap_char, $wrap_cut);
|
||||||
|
// indent lines
|
||||||
|
if ($indent > 0) {
|
||||||
|
$_paragraphs[$_x] = preg_replace('!^!m', str_repeat($indent_char, $indent), $_paragraphs[$_x]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$_output = implode($wrap_char . $wrap_char, $_paragraphs);
|
||||||
|
|
||||||
|
return $assign ? $template->assign($assign, $_output) : $_output;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
78
lib/classes/Smarty-3.0.8/libs/plugins/function.counter.php
Normal file
78
lib/classes/Smarty-3.0.8/libs/plugins/function.counter.php
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {counter} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: counter<br>
|
||||||
|
* Purpose: print out a counter value
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.counter.php {counter}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @param array parameters
|
||||||
|
* @param Smarty
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string|null
|
||||||
|
*/
|
||||||
|
function smarty_function_counter($params, $template)
|
||||||
|
{
|
||||||
|
static $counters = array();
|
||||||
|
|
||||||
|
$name = (isset($params['name'])) ? $params['name'] : 'default';
|
||||||
|
if (!isset($counters[$name])) {
|
||||||
|
$counters[$name] = array(
|
||||||
|
'start'=>1,
|
||||||
|
'skip'=>1,
|
||||||
|
'direction'=>'up',
|
||||||
|
'count'=>1
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$counter =& $counters[$name];
|
||||||
|
|
||||||
|
if (isset($params['start'])) {
|
||||||
|
$counter['start'] = $counter['count'] = (int)$params['start'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($params['assign'])) {
|
||||||
|
$counter['assign'] = $params['assign'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($counter['assign'])) {
|
||||||
|
$template->assign($counter['assign'], $counter['count']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($params['print'])) {
|
||||||
|
$print = (bool)$params['print'];
|
||||||
|
} else {
|
||||||
|
$print = empty($counter['assign']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($print) {
|
||||||
|
$retval = $counter['count'];
|
||||||
|
} else {
|
||||||
|
$retval = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($params['skip'])) {
|
||||||
|
$counter['skip'] = $params['skip'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($params['direction'])) {
|
||||||
|
$counter['direction'] = $params['direction'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($counter['direction'] == "down")
|
||||||
|
$counter['count'] -= $counter['skip'];
|
||||||
|
else
|
||||||
|
$counter['count'] += $counter['skip'];
|
||||||
|
|
||||||
|
return $retval;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
106
lib/classes/Smarty-3.0.8/libs/plugins/function.cycle.php
Normal file
106
lib/classes/Smarty-3.0.8/libs/plugins/function.cycle.php
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {cycle} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: cycle<br>
|
||||||
|
* Date: May 3, 2002<br>
|
||||||
|
* Purpose: cycle through given values<br>
|
||||||
|
* Input:
|
||||||
|
* - name = name of cycle (optional)
|
||||||
|
* - values = comma separated list of values to cycle,
|
||||||
|
* or an array of values to cycle
|
||||||
|
* (this can be left out for subsequent calls)
|
||||||
|
* - reset = boolean - resets given var to true
|
||||||
|
* - print = boolean - print var or not. default is true
|
||||||
|
* - advance = boolean - whether or not to advance the cycle
|
||||||
|
* - delimiter = the value delimiter, default is ","
|
||||||
|
* - assign = boolean, assigns to template var instead of
|
||||||
|
* printed.
|
||||||
|
*
|
||||||
|
* Examples:<br>
|
||||||
|
* <pre>
|
||||||
|
* {cycle values="#eeeeee,#d0d0d0d"}
|
||||||
|
* {cycle name=row values="one,two,three" reset=true}
|
||||||
|
* {cycle name=row}
|
||||||
|
* </pre>
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.cycle.php {cycle}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @author credit to Mark Priatel <mpriatel@rogers.com>
|
||||||
|
* @author credit to Gerard <gerard@interfold.com>
|
||||||
|
* @author credit to Jason Sweat <jsweat_php@yahoo.com>
|
||||||
|
* @version 1.3
|
||||||
|
* @param array
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string|null
|
||||||
|
*/
|
||||||
|
|
||||||
|
function smarty_function_cycle($params, $template)
|
||||||
|
{
|
||||||
|
static $cycle_vars;
|
||||||
|
|
||||||
|
$name = (empty($params['name'])) ? 'default' : $params['name'];
|
||||||
|
$print = (isset($params['print'])) ? (bool)$params['print'] : true;
|
||||||
|
$advance = (isset($params['advance'])) ? (bool)$params['advance'] : true;
|
||||||
|
$reset = (isset($params['reset'])) ? (bool)$params['reset'] : false;
|
||||||
|
|
||||||
|
if (!in_array('values', array_keys($params))) {
|
||||||
|
if(!isset($cycle_vars[$name]['values'])) {
|
||||||
|
trigger_error("cycle: missing 'values' parameter");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(isset($cycle_vars[$name]['values'])
|
||||||
|
&& $cycle_vars[$name]['values'] != $params['values'] ) {
|
||||||
|
$cycle_vars[$name]['index'] = 0;
|
||||||
|
}
|
||||||
|
$cycle_vars[$name]['values'] = $params['values'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($params['delimiter'])) {
|
||||||
|
$cycle_vars[$name]['delimiter'] = $params['delimiter'];
|
||||||
|
} elseif (!isset($cycle_vars[$name]['delimiter'])) {
|
||||||
|
$cycle_vars[$name]['delimiter'] = ',';
|
||||||
|
}
|
||||||
|
|
||||||
|
if(is_array($cycle_vars[$name]['values'])) {
|
||||||
|
$cycle_array = $cycle_vars[$name]['values'];
|
||||||
|
} else {
|
||||||
|
$cycle_array = explode($cycle_vars[$name]['delimiter'],$cycle_vars[$name]['values']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!isset($cycle_vars[$name]['index']) || $reset ) {
|
||||||
|
$cycle_vars[$name]['index'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($params['assign'])) {
|
||||||
|
$print = false;
|
||||||
|
$template->assign($params['assign'], $cycle_array[$cycle_vars[$name]['index']]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if($print) {
|
||||||
|
$retval = $cycle_array[$cycle_vars[$name]['index']];
|
||||||
|
} else {
|
||||||
|
$retval = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if($advance) {
|
||||||
|
if ( $cycle_vars[$name]['index'] >= count($cycle_array) -1 ) {
|
||||||
|
$cycle_vars[$name]['index'] = 0;
|
||||||
|
} else {
|
||||||
|
$cycle_vars[$name]['index']++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
216
lib/classes/Smarty-3.0.8/libs/plugins/function.fetch.php
Normal file
216
lib/classes/Smarty-3.0.8/libs/plugins/function.fetch.php
Normal file
@@ -0,0 +1,216 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {fetch} plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: fetch<br>
|
||||||
|
* Purpose: fetch file, web or ftp data and display results
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.fetch.php {fetch}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @param array $params parameters
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string|null if the assign parameter is passed, Smarty assigns the
|
||||||
|
* result to a template variable
|
||||||
|
*/
|
||||||
|
function smarty_function_fetch($params, $template)
|
||||||
|
{
|
||||||
|
if (empty($params['file'])) {
|
||||||
|
trigger_error("[plugin] fetch parameter 'file' cannot be empty",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$content = '';
|
||||||
|
if (isset($template->security_policy) && !preg_match('!^(http|ftp)://!i', $params['file'])) {
|
||||||
|
if(!$template->security_policy->isTrustedResourceDir($params['file'])) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// fetch the file
|
||||||
|
if($fp = @fopen($params['file'],'r')) {
|
||||||
|
while(!feof($fp)) {
|
||||||
|
$content .= fgets ($fp,4096);
|
||||||
|
}
|
||||||
|
fclose($fp);
|
||||||
|
} else {
|
||||||
|
trigger_error('[plugin] fetch cannot read file \'' . $params['file'] . '\'',E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// not a local file
|
||||||
|
if(preg_match('!^http://!i',$params['file'])) {
|
||||||
|
// http fetch
|
||||||
|
if($uri_parts = parse_url($params['file'])) {
|
||||||
|
// set defaults
|
||||||
|
$host = $server_name = $uri_parts['host'];
|
||||||
|
$timeout = 30;
|
||||||
|
$accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*";
|
||||||
|
$agent = "Smarty Template Engine ".$template->_version;
|
||||||
|
$referer = "";
|
||||||
|
$uri = !empty($uri_parts['path']) ? $uri_parts['path'] : '/';
|
||||||
|
$uri .= !empty($uri_parts['query']) ? '?' . $uri_parts['query'] : '';
|
||||||
|
$_is_proxy = false;
|
||||||
|
if(empty($uri_parts['port'])) {
|
||||||
|
$port = 80;
|
||||||
|
} else {
|
||||||
|
$port = $uri_parts['port'];
|
||||||
|
}
|
||||||
|
if(!empty($uri_parts['user'])) {
|
||||||
|
$user = $uri_parts['user'];
|
||||||
|
}
|
||||||
|
if(!empty($uri_parts['pass'])) {
|
||||||
|
$pass = $uri_parts['pass'];
|
||||||
|
}
|
||||||
|
// loop through parameters, setup headers
|
||||||
|
foreach($params as $param_key => $param_value) {
|
||||||
|
switch($param_key) {
|
||||||
|
case "file":
|
||||||
|
case "assign":
|
||||||
|
case "assign_headers":
|
||||||
|
break;
|
||||||
|
case "user":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
$user = $param_value;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "pass":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
$pass = $param_value;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "accept":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
$accept = $param_value;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "header":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
if(!preg_match('![\w\d-]+: .+!',$param_value)) {
|
||||||
|
trigger_error("[plugin] invalid header format '".$param_value."'",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
$extra_headers[] = $param_value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "proxy_host":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
$proxy_host = $param_value;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "proxy_port":
|
||||||
|
if(!preg_match('!\D!', $param_value)) {
|
||||||
|
$proxy_port = (int) $param_value;
|
||||||
|
} else {
|
||||||
|
trigger_error("[plugin] invalid value for attribute '".$param_key."'",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "agent":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
$agent = $param_value;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "referer":
|
||||||
|
if(!empty($param_value)) {
|
||||||
|
$referer = $param_value;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "timeout":
|
||||||
|
if(!preg_match('!\D!', $param_value)) {
|
||||||
|
$timeout = (int) $param_value;
|
||||||
|
} else {
|
||||||
|
trigger_error("[plugin] invalid value for attribute '".$param_key."'",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
trigger_error("[plugin] unrecognized attribute '".$param_key."'",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!empty($proxy_host) && !empty($proxy_port)) {
|
||||||
|
$_is_proxy = true;
|
||||||
|
$fp = fsockopen($proxy_host,$proxy_port,$errno,$errstr,$timeout);
|
||||||
|
} else {
|
||||||
|
$fp = fsockopen($server_name,$port,$errno,$errstr,$timeout);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!$fp) {
|
||||||
|
trigger_error("[plugin] unable to fetch: $errstr ($errno)",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
if($_is_proxy) {
|
||||||
|
fputs($fp, 'GET ' . $params['file'] . " HTTP/1.0\r\n");
|
||||||
|
} else {
|
||||||
|
fputs($fp, "GET $uri HTTP/1.0\r\n");
|
||||||
|
}
|
||||||
|
if(!empty($host)) {
|
||||||
|
fputs($fp, "Host: $host\r\n");
|
||||||
|
}
|
||||||
|
if(!empty($accept)) {
|
||||||
|
fputs($fp, "Accept: $accept\r\n");
|
||||||
|
}
|
||||||
|
if(!empty($agent)) {
|
||||||
|
fputs($fp, "User-Agent: $agent\r\n");
|
||||||
|
}
|
||||||
|
if(!empty($referer)) {
|
||||||
|
fputs($fp, "Referer: $referer\r\n");
|
||||||
|
}
|
||||||
|
if(isset($extra_headers) && is_array($extra_headers)) {
|
||||||
|
foreach($extra_headers as $curr_header) {
|
||||||
|
fputs($fp, $curr_header."\r\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!empty($user) && !empty($pass)) {
|
||||||
|
fputs($fp, "Authorization: BASIC ".base64_encode("$user:$pass")."\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
fputs($fp, "\r\n");
|
||||||
|
while(!feof($fp)) {
|
||||||
|
$content .= fgets($fp,4096);
|
||||||
|
}
|
||||||
|
fclose($fp);
|
||||||
|
$csplit = preg_split("!\r\n\r\n!",$content,2);
|
||||||
|
|
||||||
|
$content = $csplit[1];
|
||||||
|
|
||||||
|
if(!empty($params['assign_headers'])) {
|
||||||
|
$template->assign($params['assign_headers'],preg_split("!\r\n!",$csplit[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
trigger_error("[plugin fetch] unable to parse URL, check syntax",E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// ftp fetch
|
||||||
|
if($fp = @fopen($params['file'],'r')) {
|
||||||
|
while(!feof($fp)) {
|
||||||
|
$content .= fgets ($fp,4096);
|
||||||
|
}
|
||||||
|
fclose($fp);
|
||||||
|
} else {
|
||||||
|
trigger_error('[plugin] fetch cannot read file \'' . $params['file'] .'\'',E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!empty($params['assign'])) {
|
||||||
|
$template->assign($params['assign'],$content);
|
||||||
|
} else {
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
@@ -0,0 +1,143 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_checkboxes} function plugin
|
||||||
|
*
|
||||||
|
* File: function.html_checkboxes.php<br>
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_checkboxes<br>
|
||||||
|
* Date: 24.Feb.2003<br>
|
||||||
|
* Purpose: Prints out a list of checkbox input types<br>
|
||||||
|
* Examples:
|
||||||
|
* <pre>
|
||||||
|
* {html_checkboxes values=$ids output=$names}
|
||||||
|
* {html_checkboxes values=$ids name='box' separator='<br>' output=$names}
|
||||||
|
* {html_checkboxes values=$ids checked=$checked separator='<br>' output=$names}
|
||||||
|
* </pre>
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.checkboxes.php {html_checkboxes}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Christopher Kvarme <christopher.kvarme@flashjab.com>
|
||||||
|
* @author credits to Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @version 1.0
|
||||||
|
* @param array $params parameters
|
||||||
|
* Input:<br>
|
||||||
|
* - name (optional) - string default "checkbox"
|
||||||
|
* - values (required) - array
|
||||||
|
* - options (optional) - associative array
|
||||||
|
* - checked (optional) - array default not set
|
||||||
|
* - separator (optional) - ie <br> or
|
||||||
|
* - output (optional) - the output next to each checkbox
|
||||||
|
* - assign (optional) - assign the output as an array to this variable
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
* @uses smarty_function_escape_special_chars()
|
||||||
|
*/
|
||||||
|
function smarty_function_html_checkboxes($params, $template)
|
||||||
|
{
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
|
||||||
|
|
||||||
|
$name = 'checkbox';
|
||||||
|
$values = null;
|
||||||
|
$options = null;
|
||||||
|
$selected = null;
|
||||||
|
$separator = '';
|
||||||
|
$labels = true;
|
||||||
|
$output = null;
|
||||||
|
|
||||||
|
$extra = '';
|
||||||
|
|
||||||
|
foreach($params as $_key => $_val) {
|
||||||
|
switch($_key) {
|
||||||
|
case 'name':
|
||||||
|
case 'separator':
|
||||||
|
$$_key = $_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'labels':
|
||||||
|
$$_key = (bool)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'options':
|
||||||
|
$$_key = (array)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'values':
|
||||||
|
case 'output':
|
||||||
|
$$_key = array_values((array)$_val);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'checked':
|
||||||
|
case 'selected':
|
||||||
|
$selected = array_map('strval', array_values((array)$_val));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'checkboxes':
|
||||||
|
trigger_error('html_checkboxes: the use of the "checkboxes" attribute is deprecated, use "options" instead', E_USER_WARNING);
|
||||||
|
$options = (array)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'assign':
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if(!is_array($_val)) {
|
||||||
|
$extra .= ' '.$_key.'="'.smarty_function_escape_special_chars($_val).'"';
|
||||||
|
} else {
|
||||||
|
trigger_error("html_checkboxes: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($options) && !isset($values))
|
||||||
|
return ''; /* raise error here? */
|
||||||
|
|
||||||
|
settype($selected, 'array');
|
||||||
|
$_html_result = array();
|
||||||
|
|
||||||
|
if (isset($options)) {
|
||||||
|
|
||||||
|
foreach ($options as $_key=>$_val)
|
||||||
|
$_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels);
|
||||||
|
|
||||||
|
|
||||||
|
} else {
|
||||||
|
foreach ($values as $_i=>$_key) {
|
||||||
|
$_val = isset($output[$_i]) ? $output[$_i] : '';
|
||||||
|
$_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($params['assign'])) {
|
||||||
|
$template->assign($params['assign'], $_html_result);
|
||||||
|
} else {
|
||||||
|
return implode("\n",$_html_result);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function smarty_function_html_checkboxes_output($name, $value, $output, $selected, $extra, $separator, $labels) {
|
||||||
|
$_output = '';
|
||||||
|
if ($labels) $_output .= '<label>';
|
||||||
|
$_output .= '<input type="checkbox" name="'
|
||||||
|
. smarty_function_escape_special_chars($name) . '[]" value="'
|
||||||
|
. smarty_function_escape_special_chars($value) . '"';
|
||||||
|
|
||||||
|
if (in_array((string)$value, $selected)) {
|
||||||
|
$_output .= ' checked="checked"';
|
||||||
|
}
|
||||||
|
$_output .= $extra . ' />' . $output;
|
||||||
|
if ($labels) $_output .= '</label>';
|
||||||
|
$_output .= $separator;
|
||||||
|
|
||||||
|
return $_output;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
137
lib/classes/Smarty-3.0.8/libs/plugins/function.html_image.php
Normal file
137
lib/classes/Smarty-3.0.8/libs/plugins/function.html_image.php
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_image} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_image<br>
|
||||||
|
* Date: Feb 24, 2003<br>
|
||||||
|
* Purpose: format HTML tags for the image<br>
|
||||||
|
* Examples: {html_image file="/images/masthead.gif"}
|
||||||
|
* Output: <img src="/images/masthead.gif" width=400 height=23>
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.image.php {html_image}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @author credits to Duda <duda@big.hu>
|
||||||
|
* @version 1.0
|
||||||
|
* @param array $params parameters
|
||||||
|
* Input:<br>
|
||||||
|
* - file = file (and path) of image (required)
|
||||||
|
* - height = image height (optional, default actual height)
|
||||||
|
* - width = image width (optional, default actual width)
|
||||||
|
* - basedir = base directory for absolute paths, default
|
||||||
|
* is environment variable DOCUMENT_ROOT
|
||||||
|
* - path_prefix = prefix for path output (optional, default empty)
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
* @uses smarty_function_escape_special_chars()
|
||||||
|
*/
|
||||||
|
function smarty_function_html_image($params, $template)
|
||||||
|
{
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
|
||||||
|
|
||||||
|
$alt = '';
|
||||||
|
$file = '';
|
||||||
|
$height = '';
|
||||||
|
$width = '';
|
||||||
|
$extra = '';
|
||||||
|
$prefix = '';
|
||||||
|
$suffix = '';
|
||||||
|
$path_prefix = '';
|
||||||
|
$server_vars = $_SERVER;
|
||||||
|
$basedir = isset($server_vars['DOCUMENT_ROOT']) ? $server_vars['DOCUMENT_ROOT'] : '';
|
||||||
|
foreach($params as $_key => $_val) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'file':
|
||||||
|
case 'height':
|
||||||
|
case 'width':
|
||||||
|
case 'dpi':
|
||||||
|
case 'path_prefix':
|
||||||
|
case 'basedir':
|
||||||
|
$$_key = $_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'alt':
|
||||||
|
if (!is_array($_val)) {
|
||||||
|
$$_key = smarty_function_escape_special_chars($_val);
|
||||||
|
} else {
|
||||||
|
throw new SmartyException ("html_image: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'link':
|
||||||
|
case 'href':
|
||||||
|
$prefix = '<a href="' . $_val . '">';
|
||||||
|
$suffix = '</a>';
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (!is_array($_val)) {
|
||||||
|
$extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"';
|
||||||
|
} else {
|
||||||
|
throw new SmartyException ("html_image: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($file)) {
|
||||||
|
trigger_error("html_image: missing 'file' parameter", E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (substr($file, 0, 1) == '/') {
|
||||||
|
$_image_path = $basedir . $file;
|
||||||
|
} else {
|
||||||
|
$_image_path = $file;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($params['width']) || !isset($params['height'])) {
|
||||||
|
if (!$_image_data = @getimagesize($_image_path)) {
|
||||||
|
if (!file_exists($_image_path)) {
|
||||||
|
trigger_error("html_image: unable to find '$_image_path'", E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
} else if (!is_readable($_image_path)) {
|
||||||
|
trigger_error("html_image: unable to read '$_image_path'", E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
trigger_error("html_image: '$_image_path' is not a valid image file", E_USER_NOTICE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (isset($template->security_policy)) {
|
||||||
|
if (!$template->security_policy->isTrustedResourceDir($_image_path)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($params['width'])) {
|
||||||
|
$width = $_image_data[0];
|
||||||
|
}
|
||||||
|
if (!isset($params['height'])) {
|
||||||
|
$height = $_image_data[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($params['dpi'])) {
|
||||||
|
if (strstr($server_vars['HTTP_USER_AGENT'], 'Mac')) {
|
||||||
|
$dpi_default = 72;
|
||||||
|
} else {
|
||||||
|
$dpi_default = 96;
|
||||||
|
}
|
||||||
|
$_resize = $dpi_default / $params['dpi'];
|
||||||
|
$width = round($width * $_resize);
|
||||||
|
$height = round($height * $_resize);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $prefix . '<img src="' . $path_prefix . $file . '" alt="' . $alt . '" width="' . $width . '" height="' . $height . '"' . $extra . ' />' . $suffix;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
133
lib/classes/Smarty-3.0.8/libs/plugins/function.html_options.php
Normal file
133
lib/classes/Smarty-3.0.8/libs/plugins/function.html_options.php
Normal file
@@ -0,0 +1,133 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_options} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_options<br>
|
||||||
|
* Purpose: Prints the list of <option> tags generated from
|
||||||
|
* the passed parameters
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.options.php {html_image}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @param array $params parameters
|
||||||
|
* Input:<br>
|
||||||
|
* - name (optional) - string default "select"
|
||||||
|
* - values (required if no options supplied) - array
|
||||||
|
* - options (required if no values supplied) - associative array
|
||||||
|
* - selected (optional) - string default not set
|
||||||
|
* - output (required if not options supplied) - array
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
* @uses smarty_function_escape_special_chars()
|
||||||
|
*/
|
||||||
|
function smarty_function_html_options($params, $template)
|
||||||
|
{
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
|
||||||
|
|
||||||
|
$name = null;
|
||||||
|
$values = null;
|
||||||
|
$options = null;
|
||||||
|
$selected = array();
|
||||||
|
$output = null;
|
||||||
|
$id = null;
|
||||||
|
$class = null;
|
||||||
|
|
||||||
|
$extra = '';
|
||||||
|
$options_extra = '';
|
||||||
|
|
||||||
|
foreach($params as $_key => $_val) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'name':
|
||||||
|
case 'class':
|
||||||
|
case 'id':
|
||||||
|
$$_key = (string)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'options':
|
||||||
|
$$_key = (array)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'values':
|
||||||
|
case 'output':
|
||||||
|
$$_key = array_values((array)$_val);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'selected':
|
||||||
|
$$_key = array_map('strval', array_values((array)$_val));
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (!is_array($_val)) {
|
||||||
|
$extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"';
|
||||||
|
} else {
|
||||||
|
trigger_error("html_options: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($options) && !isset($values))
|
||||||
|
return '';
|
||||||
|
/* raise error here? */
|
||||||
|
|
||||||
|
$_html_result = '';
|
||||||
|
$_idx = 0;
|
||||||
|
|
||||||
|
if (isset($options)) {
|
||||||
|
foreach ($options as $_key => $_val) {
|
||||||
|
$_html_result .= smarty_function_html_options_optoutput($_key, $_val, $selected, $id, $class, $_idx);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
foreach ($values as $_i => $_key) {
|
||||||
|
$_val = isset($output[$_i]) ? $output[$_i] : '';
|
||||||
|
$_html_result .= smarty_function_html_options_optoutput($_key, $_val, $selected, $id, $class, $_idx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($name)) {
|
||||||
|
$_html_class = !empty($class) ? ' class="'.$class.'"' : '';
|
||||||
|
$_html_id = !empty($id) ? ' id="'.$id.'"' : '';
|
||||||
|
$_html_result = '<select name="' . $name . '"' . $_html_class . $_html_id . $extra . '>' . "\n" . $_html_result . '</select>' . "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $_html_result;
|
||||||
|
}
|
||||||
|
|
||||||
|
function smarty_function_html_options_optoutput($key, $value, $selected, $id, $class, &$idx)
|
||||||
|
{
|
||||||
|
if (!is_array($value)) {
|
||||||
|
$_html_result = '<option value="' .
|
||||||
|
smarty_function_escape_special_chars($key) . '"';
|
||||||
|
if (in_array((string)$key, $selected))
|
||||||
|
$_html_result .= ' selected="selected"';
|
||||||
|
$_html_class = !empty($class) ? ' class="'.$class.' option"' : '';
|
||||||
|
$_html_id = !empty($id) ? ' id="'.$id.'-'.$idx.'"' : '';
|
||||||
|
$_html_result .= $_html_class . $_html_id . '>' . smarty_function_escape_special_chars($value) . '</option>' . "\n";
|
||||||
|
$idx++;
|
||||||
|
} else {
|
||||||
|
$_idx = 0;
|
||||||
|
$_html_result = smarty_function_html_options_optgroup($key, $value, $selected, $id.'-'.$idx, $class, $_idx);
|
||||||
|
$idx++;
|
||||||
|
}
|
||||||
|
return $_html_result;
|
||||||
|
}
|
||||||
|
|
||||||
|
function smarty_function_html_options_optgroup($key, $values, $selected, $id, $class, &$idx)
|
||||||
|
{
|
||||||
|
$optgroup_html = '<optgroup label="' . smarty_function_escape_special_chars($key) . '">' . "\n";
|
||||||
|
foreach ($values as $key => $value) {
|
||||||
|
$optgroup_html .= smarty_function_html_options_optoutput($key, $value, $selected, $id, $class, $idx);
|
||||||
|
}
|
||||||
|
$optgroup_html .= "</optgroup>\n";
|
||||||
|
return $optgroup_html;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
154
lib/classes/Smarty-3.0.8/libs/plugins/function.html_radios.php
Normal file
154
lib/classes/Smarty-3.0.8/libs/plugins/function.html_radios.php
Normal file
@@ -0,0 +1,154 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_radios} function plugin
|
||||||
|
*
|
||||||
|
* File: function.html_radios.php<br>
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_radios<br>
|
||||||
|
* Date: 24.Feb.2003<br>
|
||||||
|
* Purpose: Prints out a list of radio input types<br>
|
||||||
|
* Examples:
|
||||||
|
* <pre>
|
||||||
|
* {html_radios values=$ids output=$names}
|
||||||
|
* {html_radios values=$ids name='box' separator='<br>' output=$names}
|
||||||
|
* {html_radios values=$ids checked=$checked separator='<br>' output=$names}
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.radios.php {html_radios}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Christopher Kvarme <christopher.kvarme@flashjab.com>
|
||||||
|
* @author credits to Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @version 1.0
|
||||||
|
* @param array $params parameters
|
||||||
|
* Input:<br>
|
||||||
|
* - name (optional) - string default "radio"
|
||||||
|
* - values (required) - array
|
||||||
|
* - options (optional) - associative array
|
||||||
|
* - checked (optional) - array default not set
|
||||||
|
* - separator (optional) - ie <br> or
|
||||||
|
* - output (optional) - the output next to each radio button
|
||||||
|
* - assign (optional) - assign the output as an array to this variable
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
* @uses smarty_function_escape_special_chars()
|
||||||
|
*/
|
||||||
|
function smarty_function_html_radios($params, $template)
|
||||||
|
{
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
|
||||||
|
|
||||||
|
$name = 'radio';
|
||||||
|
$values = null;
|
||||||
|
$options = null;
|
||||||
|
$selected = null;
|
||||||
|
$separator = '';
|
||||||
|
$labels = true;
|
||||||
|
$label_ids = false;
|
||||||
|
$output = null;
|
||||||
|
$extra = '';
|
||||||
|
|
||||||
|
foreach($params as $_key => $_val) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'name':
|
||||||
|
case 'separator':
|
||||||
|
$$_key = (string)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'checked':
|
||||||
|
case 'selected':
|
||||||
|
if (is_array($_val)) {
|
||||||
|
trigger_error('html_radios: the "' . $_key . '" attribute cannot be an array', E_USER_WARNING);
|
||||||
|
} else {
|
||||||
|
$selected = (string)$_val;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'labels':
|
||||||
|
case 'label_ids':
|
||||||
|
$$_key = (bool)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'options':
|
||||||
|
$$_key = (array)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'values':
|
||||||
|
case 'output':
|
||||||
|
$$_key = array_values((array)$_val);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'radios':
|
||||||
|
trigger_error('html_radios: the use of the "radios" attribute is deprecated, use "options" instead', E_USER_WARNING);
|
||||||
|
$options = (array)$_val;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'assign':
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (!is_array($_val)) {
|
||||||
|
$extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"';
|
||||||
|
} else {
|
||||||
|
trigger_error("html_radios: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($options) && !isset($values))
|
||||||
|
return '';
|
||||||
|
/* raise error here? */
|
||||||
|
|
||||||
|
$_html_result = array();
|
||||||
|
|
||||||
|
if (isset($options)) {
|
||||||
|
foreach ($options as $_key => $_val)
|
||||||
|
$_html_result[] = smarty_function_html_radios_output($name, $_key, $_val, $selected, $extra, $separator, $labels, $label_ids);
|
||||||
|
} else {
|
||||||
|
foreach ($values as $_i => $_key) {
|
||||||
|
$_val = isset($output[$_i]) ? $output[$_i] : '';
|
||||||
|
$_html_result[] = smarty_function_html_radios_output($name, $_key, $_val, $selected, $extra, $separator, $labels, $label_ids);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($params['assign'])) {
|
||||||
|
$template->assign($params['assign'], $_html_result);
|
||||||
|
} else {
|
||||||
|
return implode("\n", $_html_result);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function smarty_function_html_radios_output($name, $value, $output, $selected, $extra, $separator, $labels, $label_ids)
|
||||||
|
{
|
||||||
|
$_output = '';
|
||||||
|
if ($labels) {
|
||||||
|
if ($label_ids) {
|
||||||
|
$_id = smarty_function_escape_special_chars(preg_replace('![^\w\-\.]!', '_', $name . '_' . $value));
|
||||||
|
$_output .= '<label for="' . $_id . '">';
|
||||||
|
} else {
|
||||||
|
$_output .= '<label>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$_output .= '<input type="radio" name="'
|
||||||
|
. smarty_function_escape_special_chars($name) . '" value="'
|
||||||
|
. smarty_function_escape_special_chars($value) . '"';
|
||||||
|
|
||||||
|
if ($labels && $label_ids) $_output .= ' id="' . $_id . '"';
|
||||||
|
|
||||||
|
if ((string)$value == $selected) {
|
||||||
|
$_output .= ' checked="checked"';
|
||||||
|
}
|
||||||
|
$_output .= $extra . ' />' . $output;
|
||||||
|
if ($labels) $_output .= '</label>';
|
||||||
|
$_output .= $separator;
|
||||||
|
|
||||||
|
return $_output;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
@@ -0,0 +1,330 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_select_date} plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_select_date<br>
|
||||||
|
* Purpose: Prints the dropdowns for date selection.
|
||||||
|
*
|
||||||
|
* ChangeLog:<br>
|
||||||
|
* - 1.0 initial release
|
||||||
|
* - 1.1 added support for +/- N syntax for begin
|
||||||
|
* and end year values. (Monte)
|
||||||
|
* - 1.2 added support for yyyy-mm-dd syntax for
|
||||||
|
* time value. (Jan Rosier)
|
||||||
|
* - 1.3 added support for choosing format for
|
||||||
|
* month values (Gary Loescher)
|
||||||
|
* - 1.3.1 added support for choosing format for
|
||||||
|
* day values (Marcus Bointon)
|
||||||
|
* - 1.3.2 support negative timestamps, force year
|
||||||
|
* dropdown to include given date unless explicitly set (Monte)
|
||||||
|
* - 1.3.4 fix behaviour of 0000-00-00 00:00:00 dates to match that
|
||||||
|
* of 0000-00-00 dates (cybot, boots)
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.select.date.php {html_select_date}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @version 1.3.4
|
||||||
|
* @author Andrei Zmievski
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @param array $params parameters
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
function smarty_function_html_select_date($params, $template)
|
||||||
|
{
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php');
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.make_timestamp.php');
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'function.html_options.php');
|
||||||
|
|
||||||
|
/* Default values. */
|
||||||
|
$prefix = "Date_";
|
||||||
|
$start_year = strftime("%Y");
|
||||||
|
$end_year = $start_year;
|
||||||
|
$display_days = true;
|
||||||
|
$display_months = true;
|
||||||
|
$display_years = true;
|
||||||
|
$month_format = "%B";
|
||||||
|
/* Write months as numbers by default GL */
|
||||||
|
$month_value_format = "%m";
|
||||||
|
$day_format = "%02d";
|
||||||
|
/* Write day values using this format MB */
|
||||||
|
$day_value_format = "%d";
|
||||||
|
$year_as_text = false;
|
||||||
|
/* Display years in reverse order? Ie. 2000,1999,.... */
|
||||||
|
$reverse_years = false;
|
||||||
|
/* Should the select boxes be part of an array when returned from PHP?
|
||||||
|
e.g. setting it to "birthday", would create "birthday[Day]",
|
||||||
|
"birthday[Month]" & "birthday[Year]". Can be combined with prefix */
|
||||||
|
$field_array = null;
|
||||||
|
/* <select size>'s of the different <select> tags.
|
||||||
|
If not set, uses default dropdown. */
|
||||||
|
$day_size = null;
|
||||||
|
$month_size = null;
|
||||||
|
$year_size = null;
|
||||||
|
/* Unparsed attributes common to *ALL* the <select>/<input> tags.
|
||||||
|
An example might be in the template: all_extra ='class ="foo"'. */
|
||||||
|
$all_extra = null;
|
||||||
|
/* Separate attributes for the tags. */
|
||||||
|
$day_extra = null;
|
||||||
|
$month_extra = null;
|
||||||
|
$year_extra = null;
|
||||||
|
/* Order in which to display the fields.
|
||||||
|
"D" -> day, "M" -> month, "Y" -> year. */
|
||||||
|
$field_order = 'MDY';
|
||||||
|
/* String printed between the different fields. */
|
||||||
|
$field_separator = "\n";
|
||||||
|
$time = time();
|
||||||
|
$all_empty = null;
|
||||||
|
$day_empty = null;
|
||||||
|
$month_empty = null;
|
||||||
|
$year_empty = null;
|
||||||
|
$extra_attrs = '';
|
||||||
|
|
||||||
|
foreach ($params as $_key => $_value) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'prefix':
|
||||||
|
case 'time':
|
||||||
|
case 'start_year':
|
||||||
|
case 'end_year':
|
||||||
|
case 'month_format':
|
||||||
|
case 'day_format':
|
||||||
|
case 'day_value_format':
|
||||||
|
case 'field_array':
|
||||||
|
case 'day_size':
|
||||||
|
case 'month_size':
|
||||||
|
case 'year_size':
|
||||||
|
case 'all_extra':
|
||||||
|
case 'day_extra':
|
||||||
|
case 'month_extra':
|
||||||
|
case 'year_extra':
|
||||||
|
case 'field_order':
|
||||||
|
case 'field_separator':
|
||||||
|
case 'month_value_format':
|
||||||
|
case 'month_empty':
|
||||||
|
case 'day_empty':
|
||||||
|
case 'year_empty':
|
||||||
|
$$_key = (string)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'all_empty':
|
||||||
|
$$_key = (string)$_value;
|
||||||
|
$day_empty = $month_empty = $year_empty = $all_empty;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'display_days':
|
||||||
|
case 'display_months':
|
||||||
|
case 'display_years':
|
||||||
|
case 'year_as_text':
|
||||||
|
case 'reverse_years':
|
||||||
|
$$_key = (bool)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (!is_array($_value)) {
|
||||||
|
$extra_attrs .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_value) . '"';
|
||||||
|
} else {
|
||||||
|
trigger_error("html_select_date: extra attribute '$_key' cannot be an array", E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (preg_match('!^-\d+$!', $time)) {
|
||||||
|
// negative timestamp, use date()
|
||||||
|
$time = date('Y-m-d', $time);
|
||||||
|
}
|
||||||
|
// If $time is not in format yyyy-mm-dd
|
||||||
|
if (preg_match('/^(\d{0,4}-\d{0,2}-\d{0,2})/', $time, $found)) {
|
||||||
|
$time = $found[1];
|
||||||
|
} else {
|
||||||
|
// use smarty_make_timestamp to get an unix timestamp and
|
||||||
|
// strftime to make yyyy-mm-dd
|
||||||
|
$time = strftime('%Y-%m-%d', smarty_make_timestamp($time));
|
||||||
|
}
|
||||||
|
// Now split this in pieces, which later can be used to set the select
|
||||||
|
$time = explode("-", $time);
|
||||||
|
// make syntax "+N" or "-N" work with start_year and end_year
|
||||||
|
if (preg_match('!^(\+|\-)\s*(\d+)$!', $end_year, $match)) {
|
||||||
|
if ($match[1] == '+') {
|
||||||
|
$end_year = strftime('%Y') + $match[2];
|
||||||
|
} else {
|
||||||
|
$end_year = strftime('%Y') - $match[2];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (preg_match('!^(\+|\-)\s*(\d+)$!', $start_year, $match)) {
|
||||||
|
if ($match[1] == '+') {
|
||||||
|
$start_year = strftime('%Y') + $match[2];
|
||||||
|
} else {
|
||||||
|
$start_year = strftime('%Y') - $match[2];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (strlen($time[0]) > 0) {
|
||||||
|
if ($start_year > $time[0] && !isset($params['start_year'])) {
|
||||||
|
// force start year to include given date if not explicitly set
|
||||||
|
$start_year = $time[0];
|
||||||
|
}
|
||||||
|
if ($end_year < $time[0] && !isset($params['end_year'])) {
|
||||||
|
// force end year to include given date if not explicitly set
|
||||||
|
$end_year = $time[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$field_order = strtoupper($field_order);
|
||||||
|
|
||||||
|
$html_result = $month_result = $day_result = $year_result = "";
|
||||||
|
|
||||||
|
$field_separator_count = -1;
|
||||||
|
if ($display_months) {
|
||||||
|
$field_separator_count++;
|
||||||
|
$month_names = array();
|
||||||
|
$month_values = array();
|
||||||
|
if (isset($month_empty)) {
|
||||||
|
$month_names[''] = $month_empty;
|
||||||
|
$month_values[''] = '';
|
||||||
|
}
|
||||||
|
for ($i = 1; $i <= 12; $i++) {
|
||||||
|
$month_names[$i] = strftime($month_format, mktime(0, 0, 0, $i, 1, 2000));
|
||||||
|
$month_values[$i] = strftime($month_value_format, mktime(0, 0, 0, $i, 1, 2000));
|
||||||
|
}
|
||||||
|
|
||||||
|
$month_result .= '<select name=';
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$month_result .= '"' . $field_array . '[' . $prefix . 'Month]"';
|
||||||
|
} else {
|
||||||
|
$month_result .= '"' . $prefix . 'Month"';
|
||||||
|
}
|
||||||
|
if (null !== $month_size) {
|
||||||
|
$month_result .= ' size="' . $month_size . '"';
|
||||||
|
}
|
||||||
|
if (null !== $month_extra) {
|
||||||
|
$month_result .= ' ' . $month_extra;
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$month_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
$month_result .= $extra_attrs . '>' . "\n";
|
||||||
|
|
||||||
|
$month_result .= smarty_function_html_options(array('output' => $month_names,
|
||||||
|
'values' => $month_values,
|
||||||
|
'selected' => (int)$time[1] ? strftime($month_value_format, mktime(0, 0, 0, (int)$time[1], 1, 2000)) : '',
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$month_result .= '</select>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($display_days) {
|
||||||
|
$field_separator_count++;
|
||||||
|
$days = array();
|
||||||
|
if (isset($day_empty)) {
|
||||||
|
$days[''] = $day_empty;
|
||||||
|
$day_values[''] = '';
|
||||||
|
}
|
||||||
|
for ($i = 1; $i <= 31; $i++) {
|
||||||
|
$days[] = sprintf($day_format, $i);
|
||||||
|
$day_values[] = sprintf($day_value_format, $i);
|
||||||
|
}
|
||||||
|
|
||||||
|
$day_result .= '<select name=';
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$day_result .= '"' . $field_array . '[' . $prefix . 'Day]"';
|
||||||
|
} else {
|
||||||
|
$day_result .= '"' . $prefix . 'Day"';
|
||||||
|
}
|
||||||
|
if (null !== $day_size) {
|
||||||
|
$day_result .= ' size="' . $day_size . '"';
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$day_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
if (null !== $day_extra) {
|
||||||
|
$day_result .= ' ' . $day_extra;
|
||||||
|
}
|
||||||
|
$day_result .= $extra_attrs . '>' . "\n";
|
||||||
|
$day_result .= smarty_function_html_options(array('output' => $days,
|
||||||
|
'values' => $day_values,
|
||||||
|
'selected' => $time[2],
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$day_result .= '</select>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($display_years) {
|
||||||
|
$field_separator_count++;
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$year_name = $field_array . '[' . $prefix . 'Year]';
|
||||||
|
} else {
|
||||||
|
$year_name = $prefix . 'Year';
|
||||||
|
}
|
||||||
|
if ($year_as_text) {
|
||||||
|
$year_result .= '<input type="text" name="' . $year_name . '" value="' . $time[0] . '" size="4" maxlength="4"';
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$year_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
if (null !== $year_extra) {
|
||||||
|
$year_result .= ' ' . $year_extra;
|
||||||
|
}
|
||||||
|
$year_result .= ' />';
|
||||||
|
} else {
|
||||||
|
$years = range((int)$start_year, (int)$end_year);
|
||||||
|
if ($reverse_years) {
|
||||||
|
rsort($years, SORT_NUMERIC);
|
||||||
|
} else {
|
||||||
|
sort($years, SORT_NUMERIC);
|
||||||
|
}
|
||||||
|
$yearvals = $years;
|
||||||
|
if (isset($year_empty)) {
|
||||||
|
array_unshift($years, $year_empty);
|
||||||
|
array_unshift($yearvals, '');
|
||||||
|
}
|
||||||
|
$year_result .= '<select name="' . $year_name . '"';
|
||||||
|
if (null !== $year_size) {
|
||||||
|
$year_result .= ' size="' . $year_size . '"';
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$year_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
if (null !== $year_extra) {
|
||||||
|
$year_result .= ' ' . $year_extra;
|
||||||
|
}
|
||||||
|
$year_result .= $extra_attrs . '>' . "\n";
|
||||||
|
$year_result .= smarty_function_html_options(array('output' => $years,
|
||||||
|
'values' => $yearvals,
|
||||||
|
'selected' => $time[0],
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$year_result .= '</select>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Loop thru the field_order field
|
||||||
|
for ($i = 0; $i <= 2; $i++) {
|
||||||
|
$c = substr($field_order, $i, 1);
|
||||||
|
switch ($c) {
|
||||||
|
case 'D':
|
||||||
|
$html_result .= $day_result;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'M':
|
||||||
|
$html_result .= $month_result;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'Y':
|
||||||
|
$html_result .= $year_result;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// Add the field seperator
|
||||||
|
if ($i < $field_separator_count) {
|
||||||
|
$html_result .= $field_separator;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $html_result;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
@@ -0,0 +1,194 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_select_time} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_select_time<br>
|
||||||
|
* Purpose: Prints the dropdowns for time selection
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.select.time.php {html_select_time}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @author Roberto Berto <roberto@berto.net>
|
||||||
|
* @credits Monte Ohrt <monte AT ohrt DOT com>
|
||||||
|
* @param array $params parameters
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
* @uses smarty_make_timestamp()
|
||||||
|
*/
|
||||||
|
function smarty_function_html_select_time($params, $template)
|
||||||
|
{
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'shared.make_timestamp.php');
|
||||||
|
require_once(SMARTY_PLUGINS_DIR . 'function.html_options.php');
|
||||||
|
|
||||||
|
/* Default values. */
|
||||||
|
$prefix = "Time_";
|
||||||
|
$time = time();
|
||||||
|
$display_hours = true;
|
||||||
|
$display_minutes = true;
|
||||||
|
$display_seconds = true;
|
||||||
|
$display_meridian = true;
|
||||||
|
$use_24_hours = true;
|
||||||
|
$minute_interval = 1;
|
||||||
|
$second_interval = 1;
|
||||||
|
/* Should the select boxes be part of an array when returned from PHP?
|
||||||
|
e.g. setting it to "birthday", would create "birthday[Hour]",
|
||||||
|
"birthday[Minute]", "birthday[Seconds]" & "birthday[Meridian]".
|
||||||
|
Can be combined with prefix. */
|
||||||
|
$field_array = null;
|
||||||
|
$all_extra = null;
|
||||||
|
$hour_extra = null;
|
||||||
|
$minute_extra = null;
|
||||||
|
$second_extra = null;
|
||||||
|
$meridian_extra = null;
|
||||||
|
|
||||||
|
foreach ($params as $_key => $_value) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'prefix':
|
||||||
|
case 'time':
|
||||||
|
case 'field_array':
|
||||||
|
case 'all_extra':
|
||||||
|
case 'hour_extra':
|
||||||
|
case 'minute_extra':
|
||||||
|
case 'second_extra':
|
||||||
|
case 'meridian_extra':
|
||||||
|
$$_key = (string)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'display_hours':
|
||||||
|
case 'display_minutes':
|
||||||
|
case 'display_seconds':
|
||||||
|
case 'display_meridian':
|
||||||
|
case 'use_24_hours':
|
||||||
|
$$_key = (bool)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'minute_interval':
|
||||||
|
case 'second_interval':
|
||||||
|
$$_key = (int)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
trigger_error("[html_select_time] unknown parameter $_key", E_USER_WARNING);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$time = smarty_make_timestamp($time);
|
||||||
|
|
||||||
|
$html_result = '';
|
||||||
|
|
||||||
|
if ($display_hours) {
|
||||||
|
$hours = $use_24_hours ? range(0, 23) : range(1, 12);
|
||||||
|
$hour_fmt = $use_24_hours ? '%H' : '%I';
|
||||||
|
for ($i = 0, $for_max = count($hours); $i < $for_max; $i++)
|
||||||
|
$hours[$i] = sprintf('%02d', $hours[$i]);
|
||||||
|
$html_result .= '<select name=';
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$html_result .= '"' . $field_array . '[' . $prefix . 'Hour]"';
|
||||||
|
} else {
|
||||||
|
$html_result .= '"' . $prefix . 'Hour"';
|
||||||
|
}
|
||||||
|
if (null !== $hour_extra) {
|
||||||
|
$html_result .= ' ' . $hour_extra;
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$html_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
$html_result .= '>' . "\n";
|
||||||
|
$html_result .= smarty_function_html_options(array('output' => $hours,
|
||||||
|
'values' => $hours,
|
||||||
|
'selected' => strftime($hour_fmt, $time),
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$html_result .= "</select>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($display_minutes) {
|
||||||
|
$all_minutes = range(0, 59);
|
||||||
|
for ($i = 0, $for_max = count($all_minutes); $i < $for_max; $i += $minute_interval)
|
||||||
|
$minutes[] = sprintf('%02d', $all_minutes[$i]);
|
||||||
|
$selected = intval(floor(strftime('%M', $time) / $minute_interval) * $minute_interval);
|
||||||
|
$html_result .= '<select name=';
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$html_result .= '"' . $field_array . '[' . $prefix . 'Minute]"';
|
||||||
|
} else {
|
||||||
|
$html_result .= '"' . $prefix . 'Minute"';
|
||||||
|
}
|
||||||
|
if (null !== $minute_extra) {
|
||||||
|
$html_result .= ' ' . $minute_extra;
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$html_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
$html_result .= '>' . "\n";
|
||||||
|
|
||||||
|
$html_result .= smarty_function_html_options(array('output' => $minutes,
|
||||||
|
'values' => $minutes,
|
||||||
|
'selected' => $selected,
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$html_result .= "</select>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($display_seconds) {
|
||||||
|
$all_seconds = range(0, 59);
|
||||||
|
for ($i = 0, $for_max = count($all_seconds); $i < $for_max; $i += $second_interval)
|
||||||
|
$seconds[] = sprintf('%02d', $all_seconds[$i]);
|
||||||
|
$selected = intval(floor(strftime('%S', $time) / $second_interval) * $second_interval);
|
||||||
|
$html_result .= '<select name=';
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$html_result .= '"' . $field_array . '[' . $prefix . 'Second]"';
|
||||||
|
} else {
|
||||||
|
$html_result .= '"' . $prefix . 'Second"';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null !== $second_extra) {
|
||||||
|
$html_result .= ' ' . $second_extra;
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$html_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
$html_result .= '>' . "\n";
|
||||||
|
|
||||||
|
$html_result .= smarty_function_html_options(array('output' => $seconds,
|
||||||
|
'values' => $seconds,
|
||||||
|
'selected' => $selected,
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$html_result .= "</select>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($display_meridian && !$use_24_hours) {
|
||||||
|
$html_result .= '<select name=';
|
||||||
|
if (null !== $field_array) {
|
||||||
|
$html_result .= '"' . $field_array . '[' . $prefix . 'Meridian]"';
|
||||||
|
} else {
|
||||||
|
$html_result .= '"' . $prefix . 'Meridian"';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null !== $meridian_extra) {
|
||||||
|
$html_result .= ' ' . $meridian_extra;
|
||||||
|
}
|
||||||
|
if (null !== $all_extra) {
|
||||||
|
$html_result .= ' ' . $all_extra;
|
||||||
|
}
|
||||||
|
$html_result .= '>' . "\n";
|
||||||
|
|
||||||
|
$html_result .= smarty_function_html_options(array('output' => array('AM', 'PM'),
|
||||||
|
'values' => array('am', 'pm'),
|
||||||
|
'selected' => strtolower(strftime('%p', $time)),
|
||||||
|
'print_result' => false),
|
||||||
|
$template);
|
||||||
|
$html_result .= "</select>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $html_result;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
177
lib/classes/Smarty-3.0.8/libs/plugins/function.html_table.php
Normal file
177
lib/classes/Smarty-3.0.8/libs/plugins/function.html_table.php
Normal file
@@ -0,0 +1,177 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {html_table} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: html_table<br>
|
||||||
|
* Date: Feb 17, 2003<br>
|
||||||
|
* Purpose: make an html table from an array of data<br>
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Examples:
|
||||||
|
* <pre>
|
||||||
|
* {table loop=$data}
|
||||||
|
* {table loop=$data cols=4 tr_attr='"bgcolor=red"'}
|
||||||
|
* {table loop=$data cols="first,second,third" tr_attr=$colors}
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @author credit to Messju Mohr <messju at lammfellpuschen dot de>
|
||||||
|
* @author credit to boots <boots dot smarty at yahoo dot com>
|
||||||
|
* @version 1.1
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.html.table.php {html_table}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @param array $params parameters
|
||||||
|
* Input:<br>
|
||||||
|
* - loop = array to loop through
|
||||||
|
* - cols = number of columns, comma separated list of column names
|
||||||
|
* or array of column names
|
||||||
|
* - rows = number of rows
|
||||||
|
* - table_attr = table attributes
|
||||||
|
* - th_attr = table heading attributes (arrays are cycled)
|
||||||
|
* - tr_attr = table row attributes (arrays are cycled)
|
||||||
|
* - td_attr = table cell attributes (arrays are cycled)
|
||||||
|
* - trailpad = value to pad trailing cells with
|
||||||
|
* - caption = text for caption element
|
||||||
|
* - vdir = vertical direction (default: "down", means top-to-bottom)
|
||||||
|
* - hdir = horizontal direction (default: "right", means left-to-right)
|
||||||
|
* - inner = inner loop (default "cols": print $loop line by line,
|
||||||
|
* $loop will be printed column by column otherwise)
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
function smarty_function_html_table($params, $template)
|
||||||
|
{
|
||||||
|
$table_attr = 'border="1"';
|
||||||
|
$tr_attr = '';
|
||||||
|
$th_attr = '';
|
||||||
|
$td_attr = '';
|
||||||
|
$cols = $cols_count = 3;
|
||||||
|
$rows = 3;
|
||||||
|
$trailpad = ' ';
|
||||||
|
$vdir = 'down';
|
||||||
|
$hdir = 'right';
|
||||||
|
$inner = 'cols';
|
||||||
|
$caption = '';
|
||||||
|
$loop = null;
|
||||||
|
|
||||||
|
if (!isset($params['loop'])) {
|
||||||
|
trigger_error("html_table: missing 'loop' parameter",E_USER_WARNING);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($params as $_key => $_value) {
|
||||||
|
switch ($_key) {
|
||||||
|
case 'loop':
|
||||||
|
$$_key = (array)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'cols':
|
||||||
|
if (is_array($_value) && !empty($_value)) {
|
||||||
|
$cols = $_value;
|
||||||
|
$cols_count = count($_value);
|
||||||
|
} elseif (!is_numeric($_value) && is_string($_value) && !empty($_value)) {
|
||||||
|
$cols = explode(',', $_value);
|
||||||
|
$cols_count = count($cols);
|
||||||
|
} elseif (!empty($_value)) {
|
||||||
|
$cols_count = (int)$_value;
|
||||||
|
} else {
|
||||||
|
$cols_count = $cols;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'rows':
|
||||||
|
$$_key = (int)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'table_attr':
|
||||||
|
case 'trailpad':
|
||||||
|
case 'hdir':
|
||||||
|
case 'vdir':
|
||||||
|
case 'inner':
|
||||||
|
case 'caption':
|
||||||
|
$$_key = (string)$_value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'tr_attr':
|
||||||
|
case 'td_attr':
|
||||||
|
case 'th_attr':
|
||||||
|
$$_key = $_value;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$loop_count = count($loop);
|
||||||
|
if (empty($params['rows'])) {
|
||||||
|
/* no rows specified */
|
||||||
|
$rows = ceil($loop_count / $cols_count);
|
||||||
|
} elseif (empty($params['cols'])) {
|
||||||
|
if (!empty($params['rows'])) {
|
||||||
|
/* no cols specified, but rows */
|
||||||
|
$cols_count = ceil($loop_count / $rows);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$output = "<table $table_attr>\n";
|
||||||
|
|
||||||
|
if (!empty($caption)) {
|
||||||
|
$output .= '<caption>' . $caption . "</caption>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_array($cols)) {
|
||||||
|
$cols = ($hdir == 'right') ? $cols : array_reverse($cols);
|
||||||
|
$output .= "<thead><tr>\n";
|
||||||
|
|
||||||
|
for ($r = 0; $r < $cols_count; $r++) {
|
||||||
|
$output .= '<th' . smarty_function_html_table_cycle('th', $th_attr, $r) . '>';
|
||||||
|
$output .= $cols[$r];
|
||||||
|
$output .= "</th>\n";
|
||||||
|
}
|
||||||
|
$output .= "</tr></thead>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
$output .= "<tbody>\n";
|
||||||
|
for ($r = 0; $r < $rows; $r++) {
|
||||||
|
$output .= "<tr" . smarty_function_html_table_cycle('tr', $tr_attr, $r) . ">\n";
|
||||||
|
$rx = ($vdir == 'down') ? $r * $cols_count : ($rows-1 - $r) * $cols_count;
|
||||||
|
|
||||||
|
for ($c = 0; $c < $cols_count; $c++) {
|
||||||
|
$x = ($hdir == 'right') ? $rx + $c : $rx + $cols_count-1 - $c;
|
||||||
|
if ($inner != 'cols') {
|
||||||
|
/* shuffle x to loop over rows*/
|
||||||
|
$x = floor($x / $cols_count) + ($x % $cols_count) * $rows;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($x < $loop_count) {
|
||||||
|
$output .= "<td" . smarty_function_html_table_cycle('td', $td_attr, $c) . ">" . $loop[$x] . "</td>\n";
|
||||||
|
} else {
|
||||||
|
$output .= "<td" . smarty_function_html_table_cycle('td', $td_attr, $c) . ">$trailpad</td>\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$output .= "</tr>\n";
|
||||||
|
}
|
||||||
|
$output .= "</tbody>\n";
|
||||||
|
$output .= "</table>\n";
|
||||||
|
|
||||||
|
return $output;
|
||||||
|
}
|
||||||
|
|
||||||
|
function smarty_function_html_table_cycle($name, $var, $no)
|
||||||
|
{
|
||||||
|
if (!is_array($var)) {
|
||||||
|
$ret = $var;
|
||||||
|
} else {
|
||||||
|
$ret = $var[$no % count($var)];
|
||||||
|
}
|
||||||
|
|
||||||
|
return ($ret) ? ' ' . $ret : '';
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
156
lib/classes/Smarty-3.0.8/libs/plugins/function.mailto.php
Normal file
156
lib/classes/Smarty-3.0.8/libs/plugins/function.mailto.php
Normal file
@@ -0,0 +1,156 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Smarty plugin
|
||||||
|
*
|
||||||
|
* @package Smarty
|
||||||
|
* @subpackage PluginsFunction
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Smarty {mailto} function plugin
|
||||||
|
*
|
||||||
|
* Type: function<br>
|
||||||
|
* Name: mailto<br>
|
||||||
|
* Date: May 21, 2002
|
||||||
|
* Purpose: automate mailto address link creation, and optionally
|
||||||
|
* encode them.<br>
|
||||||
|
*
|
||||||
|
* Examples:
|
||||||
|
* <pre>
|
||||||
|
* {mailto address="me@domain.com"}
|
||||||
|
* {mailto address="me@domain.com" encode="javascript"}
|
||||||
|
* {mailto address="me@domain.com" encode="hex"}
|
||||||
|
* {mailto address="me@domain.com" subject="Hello to you!"}
|
||||||
|
* {mailto address="me@domain.com" cc="you@domain.com,they@domain.com"}
|
||||||
|
* {mailto address="me@domain.com" extra='class="mailto"'}
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @link http://smarty.php.net/manual/en/language.function.mailto.php {mailto}
|
||||||
|
* (Smarty online manual)
|
||||||
|
* @version 1.2
|
||||||
|
* @author Monte Ohrt <monte at ohrt dot com>
|
||||||
|
* @author credits to Jason Sweat (added cc, bcc and subject functionality)
|
||||||
|
* @param array $params parameters
|
||||||
|
* Input:<br>
|
||||||
|
* - address = e-mail address
|
||||||
|
* - text = (optional) text to display, default is address
|
||||||
|
* - encode = (optional) can be one of:
|
||||||
|
* * none : no encoding (default)
|
||||||
|
* * javascript : encode with javascript
|
||||||
|
* * javascript_charcode : encode with javascript charcode
|
||||||
|
* * hex : encode with hexidecimal (no javascript)
|
||||||
|
* - cc = (optional) address(es) to carbon copy
|
||||||
|
* - bcc = (optional) address(es) to blind carbon copy
|
||||||
|
* - subject = (optional) e-mail subject
|
||||||
|
* - newsgroups = (optional) newsgroup(s) to post to
|
||||||
|
* - followupto = (optional) address(es) to follow up to
|
||||||
|
* - extra = (optional) extra tags for the href link
|
||||||
|
* @param object $template template object
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
function smarty_function_mailto($params, $template)
|
||||||
|
{
|
||||||
|
$extra = '';
|
||||||
|
|
||||||
|
if (empty($params['address'])) {
|
||||||
|
trigger_error("mailto: missing 'address' parameter",E_USER_WARNING);
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
$address = $params['address'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$text = $address;
|
||||||
|
// netscape and mozilla do not decode %40 (@) in BCC field (bug?)
|
||||||
|
// so, don't encode it.
|
||||||
|
$search = array('%40', '%2C');
|
||||||
|
$replace = array('@', ',');
|
||||||
|
$mail_parms = array();
|
||||||
|
foreach ($params as $var => $value) {
|
||||||
|
switch ($var) {
|
||||||
|
case 'cc':
|
||||||
|
case 'bcc':
|
||||||
|
case 'followupto':
|
||||||
|
if (!empty($value))
|
||||||
|
$mail_parms[] = $var . '=' . str_replace($search, $replace, rawurlencode($value));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'subject':
|
||||||
|
case 'newsgroups':
|
||||||
|
$mail_parms[] = $var . '=' . rawurlencode($value);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'extra':
|
||||||
|
case 'text':
|
||||||
|
$$var = $value;
|
||||||
|
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail_parm_vals = '';
|
||||||
|
for ($i = 0; $i < count($mail_parms); $i++) {
|
||||||
|
$mail_parm_vals .= (0 == $i) ? '?' : '&';
|
||||||
|
$mail_parm_vals .= $mail_parms[$i];
|
||||||
|
}
|
||||||
|
$address .= $mail_parm_vals;
|
||||||
|
|
||||||
|
$encode = (empty($params['encode'])) ? 'none' : $params['encode'];
|
||||||
|
if (!in_array($encode, array('javascript', 'javascript_charcode', 'hex', 'none'))) {
|
||||||
|
trigger_error("mailto: 'encode' parameter must be none, javascript or hex",E_USER_WARNING);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($encode == 'javascript') {
|
||||||
|
$string = 'document.write(\'<a href="mailto:' . $address . '" ' . $extra . '>' . $text . '</a>\');';
|
||||||
|
|
||||||
|
$js_encode = '';
|
||||||
|
for ($x = 0; $x < strlen($string); $x++) {
|
||||||
|
$js_encode .= '%' . bin2hex($string[$x]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return '<script type="text/javascript">eval(unescape(\'' . $js_encode . '\'))</script>';
|
||||||
|
} elseif ($encode == 'javascript_charcode') {
|
||||||
|
$string = '<a href="mailto:' . $address . '" ' . $extra . '>' . $text . '</a>';
|
||||||
|
|
||||||
|
for($x = 0, $y = strlen($string); $x < $y; $x++) {
|
||||||
|
$ord[] = ord($string[$x]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$_ret = "<script type=\"text/javascript\" language=\"javascript\">\n";
|
||||||
|
$_ret .= "<!--\n";
|
||||||
|
$_ret .= "{document.write(String.fromCharCode(";
|
||||||
|
$_ret .= implode(',', $ord);
|
||||||
|
$_ret .= "))";
|
||||||
|
$_ret .= "}\n";
|
||||||
|
$_ret .= "//-->\n";
|
||||||
|
$_ret .= "</script>\n";
|
||||||
|
|
||||||
|
return $_ret;
|
||||||
|
} elseif ($encode == 'hex') {
|
||||||
|
preg_match('!^(.*)(\?.*)$!', $address, $match);
|
||||||
|
if (!empty($match[2])) {
|
||||||
|
trigger_error("mailto: hex encoding does not work with extra attributes. Try javascript.",E_USER_WARNING);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$address_encode = '';
|
||||||
|
for ($x = 0; $x < strlen($address); $x++) {
|
||||||
|
if (preg_match('!\w!', $address[$x])) {
|
||||||
|
$address_encode .= '%' . bin2hex($address[$x]);
|
||||||
|
} else {
|
||||||
|
$address_encode .= $address[$x];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$text_encode = '';
|
||||||
|
for ($x = 0; $x < strlen($text); $x++) {
|
||||||
|
$text_encode .= '&#x' . bin2hex($text[$x]) . ';';
|
||||||
|
}
|
||||||
|
|
||||||
|
$mailto = "mailto:";
|
||||||
|
return '<a href="' . $mailto . $address_encode . '" ' . $extra . '>' . $text_encode . '</a>';
|
||||||
|
} else {
|
||||||
|
// no encoding
|
||||||
|
return '<a href="mailto:' . $address . '" ' . $extra . '>' . $text . '</a>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user