Compare commits
252 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
247efb1c0a | ||
|
|
98c55435ae | ||
|
|
981f5840b3 | ||
|
|
c1809fc084 | ||
|
|
090bdaaea8 | ||
|
|
611bec6849 | ||
|
|
8cf797374d | ||
|
|
20177e06fc | ||
|
|
aa6f3d33eb | ||
|
|
23d4bee184 | ||
|
|
37988fa645 | ||
|
|
6c7ee0c222 | ||
|
|
108c4c25b3 | ||
|
|
095e54d88d | ||
|
|
bd036a0fde | ||
|
|
f766c6f920 | ||
|
|
4588bc7f5c | ||
|
|
9e289a2380 | ||
|
|
f0edf97ac7 | ||
|
|
91195fda89 | ||
|
|
6161ad1bd3 | ||
|
|
f72d87228b | ||
|
|
4f0acd176a | ||
|
|
5f29b2cc4a | ||
|
|
164f1a921e | ||
|
|
94c4d52476 | ||
|
|
b777053133 | ||
|
|
d0c2888508 | ||
|
|
ff8afef614 | ||
|
|
a28b2e8115 | ||
|
|
b0e348a2c5 | ||
|
|
512abda38d | ||
|
|
1690cadab9 | ||
|
|
436d141bd1 | ||
|
|
aa881560cc | ||
|
|
06ef81cc5b | ||
|
|
4a99e4ba57 | ||
|
|
2ba4137e7d | ||
|
|
72835c56ad | ||
|
|
b80bdcbc4f | ||
|
|
c1e62e6be7 | ||
|
|
10330f8a7a | ||
|
|
18fb422a69 | ||
|
|
f8236dff7b | ||
|
|
bad680cfdb | ||
|
|
5a070d6d91 | ||
|
|
07a3f76568 | ||
|
|
67b95a301b | ||
|
|
6f9187d1bb | ||
|
|
84b8cda7ac | ||
|
|
75616cc727 | ||
|
|
b3d018c506 | ||
|
|
2508d855e3 | ||
|
|
a21f3c5a3f | ||
|
|
20d9be537a | ||
|
|
30d39d622d | ||
|
|
e58192edc2 | ||
|
|
be0099bf01 | ||
|
|
724e88b94f | ||
|
|
3c802038f2 | ||
|
|
38b57117e2 | ||
|
|
349fa7a761 | ||
|
|
7b52c0c78c | ||
|
|
cd5cef51e8 | ||
|
|
a621fd3b09 | ||
|
|
0c43c5d2b5 | ||
|
|
aff6d82321 | ||
|
|
91cecf8c1e | ||
|
|
26c3c8e6f0 | ||
|
|
08814f8c9a | ||
|
|
632eb98df9 | ||
|
|
909c983aec | ||
|
|
8642254175 | ||
|
|
7e81b0bb5a | ||
|
|
20eaa7bc08 | ||
|
|
abb94c9189 | ||
|
|
2b366c8f23 | ||
|
|
d5b9ad3452 | ||
|
|
5437fcdc89 | ||
|
|
131efc544d | ||
|
|
160474f2b6 | ||
|
|
168738b23a | ||
|
|
9619abdad7 | ||
|
|
fd287e7be4 | ||
|
|
350e3d733a | ||
|
|
6f91bece17 | ||
|
|
5c30961d3c | ||
|
|
edd5ef0ca0 | ||
|
|
6befe85656 | ||
|
|
27f8c8b438 | ||
|
|
fc0c796b68 | ||
|
|
482e8c9a11 | ||
|
|
7a664a9990 | ||
|
|
372ab5d9c8 | ||
|
|
de70dbb888 | ||
|
|
4d7ceb9efe | ||
|
|
bb792f228f | ||
|
|
017396197e | ||
|
|
216f013c96 | ||
|
|
05f1bf0a1f | ||
|
|
295fbae6f5 | ||
|
|
ca4c93ac92 | ||
|
|
13b1503bf2 | ||
|
|
2980397545 | ||
|
|
5612720342 | ||
|
|
4d3fa6eca5 | ||
|
|
05b4c58aa8 | ||
|
|
f290497b64 | ||
|
|
b4dd35eed2 | ||
|
|
ec21e28000 | ||
|
|
0aa707ebc9 | ||
|
|
f38a0fd8b6 | ||
|
|
a6b2daa77d | ||
|
|
7ae31496ac | ||
|
|
c62dd2ecf4 | ||
|
|
840b5ea229 | ||
|
|
d8a3015303 | ||
|
|
194b7863b8 | ||
|
|
f034695290 | ||
|
|
f896fe11a0 | ||
|
|
2603a9c869 | ||
|
|
fcd0dddfd5 | ||
|
|
3fb92259a8 | ||
|
|
54d7b01ac5 | ||
|
|
ca0ab1f97a | ||
|
|
f3733ca249 | ||
|
|
7442bf7347 | ||
|
|
6ac3cb2014 | ||
|
|
ca76e572a2 | ||
|
|
c3fb6f6a1c | ||
|
|
1796a8ff17 | ||
|
|
52c7839b9b | ||
|
|
d16a7b2089 | ||
|
|
9a00a67f71 | ||
|
|
6e651200ca | ||
|
|
29968e6026 | ||
|
|
8c61773280 | ||
|
|
29433ce963 | ||
|
|
eed3a91385 | ||
|
|
62006d584e | ||
|
|
bba872618a | ||
|
|
941dd14c72 | ||
|
|
f2a79d4d96 | ||
|
|
281b131c62 | ||
|
|
4bcdfc0786 | ||
|
|
9312e4967e | ||
|
|
6b44dfe9b2 | ||
|
|
ba58991d11 | ||
|
|
84abb33e54 | ||
|
|
07a4f045f1 | ||
|
|
f49cb81e49 | ||
|
|
b2b9d4e31a | ||
|
|
d40d1f30b6 | ||
|
|
9aaadb1f8b | ||
|
|
3969ef63c5 | ||
|
|
d8abe30c44 | ||
|
|
eaa10ce6a5 | ||
|
|
c434249616 | ||
|
|
b849a5f29a | ||
|
|
3dc6a64252 | ||
|
|
ebd636494a | ||
|
|
07caf55f79 | ||
|
|
73868b7947 | ||
|
|
af55fe5b82 | ||
|
|
de408347fc | ||
|
|
ea96039128 | ||
|
|
c49539258e | ||
|
|
64653a2bb1 | ||
|
|
732c6e3a78 | ||
|
|
66a4309fe5 | ||
|
|
57277eb1e3 | ||
|
|
148b2fc1be | ||
|
|
cf4f15a83c | ||
|
|
297f3f638c | ||
|
|
d2a9fa8632 | ||
|
|
a5251824ae | ||
|
|
cb31c5258d | ||
|
|
5540b02e35 | ||
|
|
e725b48c4c | ||
|
|
45c0915b59 | ||
|
|
1e03946df7 | ||
|
|
dd3e5e9c6b | ||
|
|
421c29c491 | ||
|
|
15b62aae04 | ||
|
|
181848290f | ||
|
|
b263b211a5 | ||
|
|
1753d2895b | ||
|
|
64ebb0ca38 | ||
|
|
bab982a0e6 | ||
|
|
c2c5178831 | ||
|
|
56e8e32965 | ||
|
|
47cd30a45e | ||
|
|
bd8f659272 | ||
|
|
82c719d786 | ||
|
|
dc22ff6aa3 | ||
|
|
c68682b084 | ||
|
|
aa8a7ee0a9 | ||
|
|
e95a917812 | ||
|
|
332e627007 | ||
|
|
a3201481f6 | ||
|
|
dae233dd05 | ||
|
|
9aa2cc269b | ||
|
|
434f202832 | ||
|
|
552d58848c | ||
|
|
bea1677d5d | ||
|
|
a2e0de23e1 | ||
|
|
ebb33c9cee | ||
|
|
22414096ad | ||
|
|
9db7434876 | ||
|
|
9fabfd539d | ||
|
|
54f6c3e019 | ||
|
|
5930ab1c9d | ||
|
|
3870cc1002 | ||
|
|
f880e1c9f1 | ||
|
|
9285a169dd | ||
|
|
95b7b57fc6 | ||
|
|
872928fb38 | ||
|
|
cb2f094e3d | ||
|
|
b11b423217 | ||
|
|
567827e2cb | ||
|
|
ec1bd6e19a | ||
|
|
d4cd827284 | ||
|
|
50f85fb6d0 | ||
|
|
9cc69e5b3d | ||
|
|
d9e8f43298 | ||
|
|
ad7cf52f21 | ||
|
|
398d45deae | ||
|
|
541ab1fe6e | ||
|
|
c0fddbce81 | ||
|
|
2284706e0c | ||
|
|
a4f72cbb40 | ||
|
|
d1c776b706 | ||
|
|
8ef315014c | ||
|
|
2d59e569df | ||
|
|
202eb0931f | ||
|
|
4cd1a8d656 | ||
|
|
01a363456e | ||
|
|
8f4da0638e | ||
|
|
3e6c3d725b | ||
|
|
95a18be5c5 | ||
|
|
8030aae37a | ||
|
|
0eaa81b503 | ||
|
|
c2b864a20f | ||
|
|
e00cb8926d | ||
|
|
afb2bce16d | ||
|
|
1033f502b1 | ||
|
|
ab18d94053 | ||
|
|
9afbe7fb71 | ||
|
|
5e0270e6a8 | ||
|
|
c6962b0992 | ||
|
|
9fdcd09089 | ||
|
|
338cf161d2 |
58
.github/CONTRIBUTING.md
vendored
Normal file
58
.github/CONTRIBUTING.md
vendored
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
# Contributing
|
||||||
|
|
||||||
|
Before you start working on a PR, contact us via IRC in #froxlor on Freenode or
|
||||||
|
the forum at https://forum.froxlor.org to get a clue whether someone else isn't
|
||||||
|
already working on it or if we don't want to invest the effort in favour of
|
||||||
|
working on Froxlor 2.0.
|
||||||
|
Of course, bug fixes are always welcome.
|
||||||
|
However, at this stage of the 0.9.x branch, we are not looking for new
|
||||||
|
features or refactoring, especially not the kind which requires changes to a
|
||||||
|
lot of files.
|
||||||
|
Currently, we are working on a complete re-write, which, at this point in
|
||||||
|
time, is not yet public to keep delays due to discussions about internal
|
||||||
|
details to a minimum.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Checklist
|
||||||
|
|
||||||
|
General rules for PRs are:
|
||||||
|
* Please save us all some trouble and unnecessary round-trips by _testing_ your
|
||||||
|
changes.
|
||||||
|
|
||||||
|
* Re-write your commit history to provide a CLEAN history!
|
||||||
|
|
||||||
|
* i.e. do not provide PRs which contain a commit that changes something,
|
||||||
|
the next changes it back, a third one changes it again, only a little
|
||||||
|
differently...
|
||||||
|
|
||||||
|
|
||||||
|
Thanks!
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### Webserver changes
|
||||||
|
If you make changes to the functionality of webserver configuration, please
|
||||||
|
make sure your implementation covers both apache **and** nginx.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### l10n
|
||||||
|
|
||||||
|
If you add new language strings, please make sure you add the english fallback
|
||||||
|
strings in
|
||||||
|
|
||||||
|
* `lng/english.lng.php`
|
||||||
|
* `install/lng/english.lng.php` (if applicable)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### New settings
|
||||||
|
If you add new settings, please make sure you add the default values to
|
||||||
|
|
||||||
|
* `install/froxlor.sql`
|
||||||
|
* handle the update (see `install/updates/froxlor/0.9/update_0.9.inc.php`)
|
||||||
64
.github/ISSUE_TEMPLATE.md
vendored
Normal file
64
.github/ISSUE_TEMPLATE.md
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
# Bug report vs. support request
|
||||||
|
If you're unsure of whether your problem is a bug or a configuration error
|
||||||
|
* contact us via IRC in #froxlor on freenode
|
||||||
|
* or post a thread in our forum at https://forum.froxlor.org
|
||||||
|
|
||||||
|
As a rule of thumb: before reporting an issue
|
||||||
|
* see if it hasn't been [reported](https://github.com/Froxlor/froxlor/issues) (and possibly already been [fixed](https://github.com/Froxlor/froxlor/issues?utf8=✓&q=is:issue%20is:closed)) first
|
||||||
|
* try with the git master
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Summary
|
||||||
|
|
||||||
|
Please provide a concise summary of the problem you're experiencing...
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# System information
|
||||||
|
* Froxlor version: $version/$gitSHA1
|
||||||
|
* Web server: apache2/nginx/lighttpd
|
||||||
|
* DNS server: Bind/PowerDNS (standalone)/PowerDNS (Bind-backend)
|
||||||
|
* POP/IMAP server: Courier/Dovecot
|
||||||
|
* SMTP server: postfix/exim
|
||||||
|
* FTP server: proftpd/pureftpd
|
||||||
|
* OS/Version: ...
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Steps to reproduce
|
||||||
|
|
||||||
|
1.
|
||||||
|
2.
|
||||||
|
3.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Expected behavior
|
||||||
|
|
||||||
|
1.
|
||||||
|
2.
|
||||||
|
3.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Actual behavior
|
||||||
|
|
||||||
|
1.
|
||||||
|
2.
|
||||||
|
3.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Log files/log entries
|
||||||
|
syslog:
|
||||||
|
<pre>
|
||||||
|
example
|
||||||
|
</pre>
|
||||||
30
README.md
30
README.md
@@ -17,7 +17,7 @@ Developed by experienced server administrators, this panel simplifies the effort
|
|||||||
9. Have fun!
|
9. Have fun!
|
||||||
|
|
||||||
### Detailed installation
|
### Detailed installation
|
||||||
http://redmine.froxlor.org/projects/froxlor/wiki/Installationtarball
|
https://github.com/Froxlor/Froxlor/wiki/Install-froxlor-from-tarball
|
||||||
|
|
||||||
## Help
|
## Help
|
||||||
|
|
||||||
@@ -30,12 +30,12 @@ irc://chat.freenode.net/froxlor
|
|||||||
|
|
||||||
### Forum
|
### Forum
|
||||||
|
|
||||||
The community is located on http://forum.froxlor.org
|
The community is located on https://forum.froxlor.org/
|
||||||
|
|
||||||
### Wiki
|
### Wiki
|
||||||
|
|
||||||
More documentation may be found in the froxlor - wiki:
|
More documentation may be found in the froxlor - wiki:
|
||||||
http://redmine.froxlor.org/projects/froxlor/wiki
|
https://github.com/Froxlor/Froxlor/wiki
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
@@ -44,31 +44,21 @@ May be found in COPYING
|
|||||||
## Downloads
|
## Downloads
|
||||||
|
|
||||||
### Tarball
|
### Tarball
|
||||||
http://files.froxlor.org/releases/froxlor-latest.tar.gz [MD5](http://files.froxlor.org/releases/froxlor-latest.tar.gz.md5) [SHA1](http://files.froxlor.org/releases/froxlor-latest.tar.gz.sha1)
|
https://files.froxlor.org/releases/froxlor-latest.tar.gz [MD5](https://files.froxlor.org/releases/froxlor-latest.tar.gz.md5) [SHA1](https://files.froxlor.org/releases/froxlor-latest.tar.gz.sha1)
|
||||||
|
|
||||||
### Debian repository
|
### Debian repository
|
||||||
|
|
||||||
[HowTo](http://redmine.froxlor.org/projects/froxlor/wiki/Installationdebian)
|
[HowTo](https://github.com/Froxlor/Froxlor/wiki/Install-froxlor-on-debian)
|
||||||
|
|
||||||
/etc/apt/sources.list.d/froxlor.list
|
/etc/apt/sources.list.d/froxlor.list
|
||||||
> deb http://debian.froxlor.org {wheezy|jessie} main
|
> deb http://debian.froxlor.org {wheezy|jessie|stretch} main
|
||||||
|
|
||||||
### Gentoo repository
|
### Gentoo repository
|
||||||
|
|
||||||
[HowTo](http://redmine.froxlor.org/projects/froxlor/wiki/Installationgentoo)
|
[HowTo](https://github.com/Froxlor/Froxlor/wiki/Install-froxlor-on-gentoo)
|
||||||
|
|
||||||
http://files.froxlor.org/gentoo/repositories.xml
|
https://files.froxlor.org/gentoo/repositories.xml
|
||||||
|
|
||||||
## Let's Encrypt support
|
## Contributing
|
||||||
|
|
||||||
This version of Froxlor contains a test implementation of support for [Let's Encrypt](https://letsencrypt.org). This is (as Let's Encrypt is in itself)
|
|
||||||
still a beta version and may break your system. The way it currently works is by creating a (sub-)domain with the default system - certificate,
|
|
||||||
after which the Let's Encrypt cronjob orders the certificate for this (sub-)domain and inserts the certificates in the database. With the next run
|
|
||||||
of the default cronjob, the certificates will be updated on the disk and the webserver reloaded.
|
|
||||||
|
|
||||||
This has 2 known side-effects at the moment:
|
|
||||||
* The basic ip/port combinations don't work with the Froxlor - integration of Let's Encrypt, since it needs a certificate for the very first creation
|
|
||||||
* After creating a domain, it will have the default certificate for a short time (by default 5 minutes until the cronjob runs the next time)
|
|
||||||
|
|
||||||
It may be possible to fix these issues, but they are not a priority at the moment
|
|
||||||
|
|
||||||
|
[see here](.github/CONTRIBUTING.md)
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ return array(
|
|||||||
'settinggroup' => 'panel',
|
'settinggroup' => 'panel',
|
||||||
'varname' => 'no_robots',
|
'varname' => 'no_robots',
|
||||||
'type' => 'bool',
|
'type' => 'bool',
|
||||||
'default' => false,
|
'default' => true,
|
||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField',
|
||||||
),
|
),
|
||||||
'panel_paging' => array(
|
'panel_paging' => array(
|
||||||
|
|||||||
@@ -94,6 +94,14 @@ return array(
|
|||||||
'plausibility_check_method' => 'checkMysqlAccessHost',
|
'plausibility_check_method' => 'checkMysqlAccessHost',
|
||||||
'save_method' => 'storeSettingMysqlAccessHost',
|
'save_method' => 'storeSettingMysqlAccessHost',
|
||||||
),
|
),
|
||||||
|
'system_nssextrausers' => array(
|
||||||
|
'label' => $lng['serversettings']['nssextrausers'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'nssextrausers',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => false,
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
'system_index_file_extension' => array(
|
'system_index_file_extension' => array(
|
||||||
'label' => $lng['serversettings']['index_file_extension'],
|
'label' => $lng['serversettings']['index_file_extension'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
|
|||||||
@@ -60,6 +60,19 @@ return array(
|
|||||||
'apache2'
|
'apache2'
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
'system_http2_support' => array(
|
||||||
|
'label' => $lng['serversettings']['http2_support'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'http2_support',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => false,
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'websrv_avail' => array(
|
||||||
|
'apache2',
|
||||||
|
'nginx'
|
||||||
|
),
|
||||||
|
'visible' => Settings::Get('system.use_ssl')
|
||||||
|
),
|
||||||
'system_httpuser' => array(
|
'system_httpuser' => array(
|
||||||
'label' => $lng['admin']['webserver_user'],
|
'label' => $lng['admin']['webserver_user'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
@@ -112,6 +125,58 @@ return array(
|
|||||||
'default' => '/var/customers/logs/',
|
'default' => '/var/customers/logs/',
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
|
'system_logfiles_script' => array(
|
||||||
|
'label' => $lng['serversettings']['logfiles_script'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'logfiles_script',
|
||||||
|
'type' => 'string',
|
||||||
|
'string_type' => '',
|
||||||
|
'default' => '',
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'websrv_avail' => array(
|
||||||
|
'apache2'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'system_logfiles_piped' => array(
|
||||||
|
'label' => $lng['serversettings']['logfiles_piped'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'logfiles_piped',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => false,
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'websrv_avail' => array(
|
||||||
|
'apache2'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'system_logfiles_format' => array(
|
||||||
|
'label' => $lng['serversettings']['logfiles_format'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'logfiles_format',
|
||||||
|
'type' => 'string',
|
||||||
|
'default' => '',
|
||||||
|
'string_emptyallowed' => true,
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'websrv_avail' => array(
|
||||||
|
'apache2',
|
||||||
|
'nginx'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'system_logfiles_type' => array(
|
||||||
|
'label' => $lng['serversettings']['logfiles_type'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'logfiles_type',
|
||||||
|
'type' => 'option',
|
||||||
|
'default' => '1',
|
||||||
|
'option_mode' => 'one',
|
||||||
|
'option_options' => array(
|
||||||
|
'1' => 'combined',
|
||||||
|
'2' => 'vhost_combined'
|
||||||
|
),
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
'websrv_avail' => array(
|
||||||
|
'apache2'
|
||||||
|
)
|
||||||
|
),
|
||||||
'system_customersslpath' => array(
|
'system_customersslpath' => array(
|
||||||
'label' => $lng['serversettings']['customerssl_directory'],
|
'label' => $lng['serversettings']['customerssl_directory'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
@@ -179,17 +244,6 @@ return array(
|
|||||||
'nginx'
|
'nginx'
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
'system_nginx_http2_support' => array(
|
|
||||||
'label' => $lng['serversettings']['nginx_http2_support'],
|
|
||||||
'settinggroup' => 'system',
|
|
||||||
'varname' => 'nginx_http2_support',
|
|
||||||
'type' => 'bool',
|
|
||||||
'default' => false,
|
|
||||||
'save_method' => 'storeSettingField',
|
|
||||||
'websrv_avail' => array(
|
|
||||||
'nginx'
|
|
||||||
)
|
|
||||||
),
|
|
||||||
'system_nginx_php_backend' => array(
|
'system_nginx_php_backend' => array(
|
||||||
'label' => $lng['serversettings']['nginx_php_backend'],
|
'label' => $lng['serversettings']['nginx_php_backend'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
|
|||||||
@@ -30,6 +30,21 @@ return array(
|
|||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField',
|
||||||
'overview_option' => true
|
'overview_option' => true
|
||||||
),
|
),
|
||||||
|
'system_ssl_protocols' => array(
|
||||||
|
'label' => $lng['serversettings']['ssl']['ssl_protocols'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'ssl_protocols',
|
||||||
|
'type' => 'option',
|
||||||
|
'default' => 'TLSv1,TLSv1.2',
|
||||||
|
'option_mode' => 'multiple',
|
||||||
|
'option_options' => array(
|
||||||
|
'TLSv1' => 'TLSv1',
|
||||||
|
'TLSv1.1' => 'TLSv1.1',
|
||||||
|
'TLSv1.2' => 'TLSv1.2',
|
||||||
|
'TLSv1.3' => 'TLSv1.3'
|
||||||
|
),
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
'system_ssl_cipher_list' => array(
|
'system_ssl_cipher_list' => array(
|
||||||
'label' => $lng['serversettings']['ssl']['ssl_cipher_list'],
|
'label' => $lng['serversettings']['ssl']['ssl_cipher_list'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
@@ -79,6 +94,17 @@ return array(
|
|||||||
'default' => '',
|
'default' => '',
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
|
'system_apache24_ocsp_cache_path' => array(
|
||||||
|
'label' => $lng['serversettings']['ssl']['apache24_ocsp_cache_path'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'apache24_ocsp_cache_path',
|
||||||
|
'type' => 'string',
|
||||||
|
'string_type' => 'string',
|
||||||
|
'string_emptyallowed' => false,
|
||||||
|
'default' => 'shmcb:/var/run/apache2/ocsp-stapling.cache(131072)',
|
||||||
|
'visible' => Settings::Get('system.webserver') == "apache2" && Settings::Get('system.apache24') == 1,
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
'system_leenabled' => array(
|
'system_leenabled' => array(
|
||||||
'label' => $lng['serversettings']['leenabled'],
|
'label' => $lng['serversettings']['leenabled'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
@@ -95,7 +121,20 @@ return array(
|
|||||||
'type' => 'string',
|
'type' => 'string',
|
||||||
'string_type' => 'file',
|
'string_type' => 'file',
|
||||||
'default' => '/etc/apache2/conf-enabled/acme.conf',
|
'default' => '/etc/apache2/conf-enabled/acme.conf',
|
||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
|
'system_leapiversion' => array(
|
||||||
|
'label' => $lng['serversettings']['leapiversion'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'leapiversion',
|
||||||
|
'type' => 'option',
|
||||||
|
'default' => '1',
|
||||||
|
'option_mode' => 'one',
|
||||||
|
'option_options' => array(
|
||||||
|
'1' => 'ACME v1',
|
||||||
|
'2' => 'ACME v2'
|
||||||
|
),
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
'system_letsencryptca' => array(
|
'system_letsencryptca' => array(
|
||||||
'label' => $lng['serversettings']['letsencryptca'],
|
'label' => $lng['serversettings']['letsencryptca'],
|
||||||
@@ -105,8 +144,8 @@ return array(
|
|||||||
'default' => 'testing',
|
'default' => 'testing',
|
||||||
'option_mode' => 'one',
|
'option_mode' => 'one',
|
||||||
'option_options' => array(
|
'option_options' => array(
|
||||||
'testing' => 'https://acme-staging.api.letsencrypt.org (Test)',
|
'testing' => 'https://acme-staging' . (Settings::Get('system.leapiversion') == '2' ? '-v02' : '') . '.api.letsencrypt.org (Test)',
|
||||||
'production' => 'https://acme-v01.api.letsencrypt.org (Live)'
|
'production' => 'https://acme-v0' . Settings::Get('system.leapiversion') . '.api.letsencrypt.org (Live)'
|
||||||
),
|
),
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
@@ -153,6 +192,14 @@ return array(
|
|||||||
'type' => 'bool',
|
'type' => 'bool',
|
||||||
'default' => false,
|
'default' => false,
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
|
'system_disable_le_selfcheck' => array(
|
||||||
|
'label' => $lng['serversettings']['disable_le_selfcheck'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'disable_le_selfcheck',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => false,
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -104,7 +104,7 @@ return array(
|
|||||||
'type' => 'int',
|
'type' => 'int',
|
||||||
'default' => 30,
|
'default' => 30,
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -40,15 +40,6 @@ return array(
|
|||||||
'option_options_method' => 'getPhpConfigs',
|
'option_options_method' => 'getPhpConfigs',
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
'system_phpfpm_configdir' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['configdir'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'configdir',
|
|
||||||
'type' => 'string',
|
|
||||||
'string_type' => 'confdir',
|
|
||||||
'default' => '/etc/php-fpm.d/',
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_aliasconfigdir' => array(
|
'system_phpfpm_aliasconfigdir' => array(
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['aliasconfigdir'],
|
'label' => $lng['serversettings']['phpfpm_settings']['aliasconfigdir'],
|
||||||
'settinggroup' => 'phpfpm',
|
'settinggroup' => 'phpfpm',
|
||||||
@@ -73,9 +64,22 @@ return array(
|
|||||||
'varname' => 'peardir',
|
'varname' => 'peardir',
|
||||||
'type' => 'string',
|
'type' => 'string',
|
||||||
'string_type' => 'dir',
|
'string_type' => 'dir',
|
||||||
|
'string_delimiter' => ':',
|
||||||
|
'string_emptyallowed' => true,
|
||||||
'default' => '/usr/share/php/:/usr/share/php5/',
|
'default' => '/usr/share/php/:/usr/share/php5/',
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
|
'system_phpfpm_envpath' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['envpath'],
|
||||||
|
'settinggroup' => 'phpfpm',
|
||||||
|
'varname' => 'envpath',
|
||||||
|
'type' => 'string',
|
||||||
|
'string_type' => 'dir',
|
||||||
|
'string_delimiter' => ':',
|
||||||
|
'string_emptyallowed' => true,
|
||||||
|
'default' => '/usr/local/bin:/usr/bin:/bin',
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
'system_phpfpm_fastcgi_ipcdir' => array(
|
'system_phpfpm_fastcgi_ipcdir' => array(
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['ipcdir'],
|
'label' => $lng['serversettings']['phpfpm_settings']['ipcdir'],
|
||||||
'settinggroup' => 'phpfpm',
|
'settinggroup' => 'phpfpm',
|
||||||
@@ -85,72 +89,6 @@ return array(
|
|||||||
'default' => '/var/lib/apache2/fastcgi/',
|
'default' => '/var/lib/apache2/fastcgi/',
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
'system_phpfpm_reload' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['reload'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'reload',
|
|
||||||
'type' => 'string',
|
|
||||||
'default' => '/etc/init.d/php-fpm restart',
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_pm' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['pm'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'pm',
|
|
||||||
'type' => 'option',
|
|
||||||
'default' => 'static',
|
|
||||||
'option_mode' => 'one',
|
|
||||||
'option_options' => array('static' => 'static', 'dynamic' => 'dynamic', 'ondemand' => 'ondemand'),
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_max_children' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['max_children'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'max_children',
|
|
||||||
'type' => 'int',
|
|
||||||
'default' => 1,
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_start_servers' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['start_servers'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'start_servers',
|
|
||||||
'type' => 'int',
|
|
||||||
'default' => 20,
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_min_spare_servers' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['min_spare_servers'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'min_spare_servers',
|
|
||||||
'type' => 'int',
|
|
||||||
'default' => 5,
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_max_spare_servers' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['max_spare_servers'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'max_spare_servers',
|
|
||||||
'type' => 'int',
|
|
||||||
'default' => 35,
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_max_requests' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['max_requests'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'max_requests',
|
|
||||||
'type' => 'int',
|
|
||||||
'default' => 0,
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_idle_timeout' => array(
|
|
||||||
'label' => $lng['serversettings']['phpfpm_settings']['idle_timeout'],
|
|
||||||
'settinggroup' => 'phpfpm',
|
|
||||||
'varname' => 'idle_timeout',
|
|
||||||
'type' => 'int',
|
|
||||||
'default' => 30,
|
|
||||||
'save_method' => 'storeSettingField'
|
|
||||||
),
|
|
||||||
'system_phpfpm_use_mod_proxy' => array(
|
'system_phpfpm_use_mod_proxy' => array(
|
||||||
'label' => $lng['phpfpm']['use_mod_proxy'],
|
'label' => $lng['phpfpm']['use_mod_proxy'],
|
||||||
'settinggroup' => 'phpfpm',
|
'settinggroup' => 'phpfpm',
|
||||||
@@ -160,6 +98,38 @@ return array(
|
|||||||
'visible' => Settings::Get('system.apache24'),
|
'visible' => Settings::Get('system.apache24'),
|
||||||
'save_method' => 'storeSettingField'
|
'save_method' => 'storeSettingField'
|
||||||
),
|
),
|
||||||
|
'system_phpfpm_ini_flags' => array(
|
||||||
|
'label' => $lng['phpfpm']['ini_flags'],
|
||||||
|
'settinggroup' => 'phpfpm',
|
||||||
|
'varname' => 'ini_flags',
|
||||||
|
'type' => 'text',
|
||||||
|
'default' => '',
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
|
'system_phpfpm_ini_values' => array(
|
||||||
|
'label' => $lng['phpfpm']['ini_values'],
|
||||||
|
'settinggroup' => 'phpfpm',
|
||||||
|
'varname' => 'ini_values',
|
||||||
|
'type' => 'text',
|
||||||
|
'default' => '',
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
|
'system_phpfpm_ini_admin_flags' => array(
|
||||||
|
'label' => $lng['phpfpm']['ini_admin_flags'],
|
||||||
|
'settinggroup' => 'phpfpm',
|
||||||
|
'varname' => 'ini_admin_flags',
|
||||||
|
'type' => 'text',
|
||||||
|
'default' => '',
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
),
|
||||||
|
'system_phpfpm_ini_admin_values' => array(
|
||||||
|
'label' => $lng['phpfpm']['ini_admin_values'],
|
||||||
|
'settinggroup' => 'phpfpm',
|
||||||
|
'varname' => 'ini_admin_values',
|
||||||
|
'type' => 'text',
|
||||||
|
'default' => '',
|
||||||
|
'save_method' => 'storeSettingField'
|
||||||
|
)
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ return array(
|
|||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
'varname' => 'mailpwcleartext',
|
'varname' => 'mailpwcleartext',
|
||||||
'type' => 'bool',
|
'type' => 'bool',
|
||||||
'default' => true,
|
'default' => false,
|
||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField',
|
||||||
),
|
),
|
||||||
'system_passwordcryptfunc' => array(
|
'system_passwordcryptfunc' => array(
|
||||||
|
|||||||
@@ -170,6 +170,11 @@ if ($page == 'admins'
|
|||||||
");
|
");
|
||||||
Database::pexecute($del_stmt, array('adminid' => $id));
|
Database::pexecute($del_stmt, array('adminid' => $id));
|
||||||
|
|
||||||
|
$del_stmt = Database::prepare("
|
||||||
|
DELETE FROM `" . TABLE_PANEL_DISKSPACE_ADMINS . "` WHERE `adminid` = :adminid
|
||||||
|
");
|
||||||
|
Database::pexecute($del_stmt, array('adminid' => $id));
|
||||||
|
|
||||||
$upd_stmt = Database::prepare("
|
$upd_stmt = Database::prepare("
|
||||||
UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET
|
UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET
|
||||||
`adminid` = :userid WHERE `adminid` = :adminid
|
`adminid` = :userid WHERE `adminid` = :adminid
|
||||||
@@ -440,7 +445,7 @@ if ($page == 'admins'
|
|||||||
} else {
|
} else {
|
||||||
|
|
||||||
$language_options = '';
|
$language_options = '';
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options.= makeoption($language_name, $language_file, $userinfo['language'], true);
|
$language_options.= makeoption($language_name, $language_file, $userinfo['language'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -840,13 +845,13 @@ if ($page == 'admins'
|
|||||||
}
|
}
|
||||||
|
|
||||||
$language_options = '';
|
$language_options = '';
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options.= makeoption($language_name, $language_file, $result['def_language'], true);
|
$language_options.= makeoption($language_name, $language_file, $result['def_language'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$ipaddress = makeoption($lng['admin']['allips'], "-1", $result['ip']);
|
$ipaddress = makeoption($lng['admin']['allips'], "-1", $result['ip']);
|
||||||
$ipsandports_stmt = Database::query("
|
$ipsandports_stmt = Database::query("
|
||||||
SELECT `id`, `ip` FROM `" . TABLE_PANEL_IPSANDPORTS . "` GROUP BY `ip` ORDER BY `ip`, `port` ASC
|
SELECT `id`, `ip` FROM `" . TABLE_PANEL_IPSANDPORTS . "` GROUP BY `id`, `ip` ORDER BY `ip`, `port` ASC
|
||||||
");
|
");
|
||||||
|
|
||||||
while ($row = $ipsandports_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $ipsandports_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|||||||
@@ -17,7 +17,6 @@
|
|||||||
* @since 0.9.35
|
* @since 0.9.35
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
require './lib/init.php';
|
require './lib/init.php';
|
||||||
|
|
||||||
@@ -26,177 +25,188 @@ define('UPDATE_URI', "https://version.froxlor.org/Froxlor/legacy/" . $version);
|
|||||||
define('RELEASE_URI', "https://autoupdate.froxlor.org/froxlor-{version}.zip");
|
define('RELEASE_URI', "https://autoupdate.froxlor.org/froxlor-{version}.zip");
|
||||||
define('CHECKSUM_URI', "https://autoupdate.froxlor.org/froxlor-{version}.zip.sha256");
|
define('CHECKSUM_URI', "https://autoupdate.froxlor.org/froxlor-{version}.zip.sha256");
|
||||||
|
|
||||||
// check for allow_url_fopen
|
|
||||||
if (ini_get('allow_url_fopen') === false) {
|
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 1));
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for archive-stuff
|
// check for archive-stuff
|
||||||
if (! extension_loaded('zip')) {
|
if (! extension_loaded('zip')) {
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 2));
|
redirectTo($filename, array(
|
||||||
|
's' => $s,
|
||||||
|
'page' => 'error',
|
||||||
|
'errno' => 2
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// display initial version check
|
// display initial version check
|
||||||
if ($page == 'overview') {
|
if ($page == 'overview') {
|
||||||
|
|
||||||
// log our actions
|
// log our actions
|
||||||
$log->logAction(ADM_ACTION, LOG_NOTICE, "checking auto-update");
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "checking auto-update");
|
||||||
|
|
||||||
// check for new version
|
// check for new version
|
||||||
$latestversion = @file(UPDATE_URI);
|
$latestversion = HttpClient::urlGet(UPDATE_URI);
|
||||||
|
|
||||||
if (isset($latestversion[0])) {
|
$latestversion = explode('|', $latestversion);
|
||||||
$latestversion = explode('|', $latestversion[0]);
|
|
||||||
|
if (is_array($latestversion) && count($latestversion) >= 1) {
|
||||||
if (is_array($latestversion)
|
$_version = $latestversion[0];
|
||||||
&& count($latestversion) >= 1
|
$_message = isset($latestversion[1]) ? $latestversion[1] : '';
|
||||||
) {
|
$_link = isset($latestversion[2]) ? $latestversion[2] : htmlspecialchars($filename . '?s=' . urlencode($s) . '&page=' . urlencode($page) . '&lookfornewversion=yes');
|
||||||
$_version = $latestversion[0];
|
|
||||||
$_message = isset($latestversion[1]) ? $latestversion[1] : '';
|
// add the branding so debian guys are not gettings confused
|
||||||
$_link = isset($latestversion[2]) ? $latestversion[2] : htmlspecialchars($filename . '?s=' . urlencode($s) . '&page=' . urlencode($page) . '&lookfornewversion=yes');
|
// about their version-number
|
||||||
|
$version_label = $_version . $branding;
|
||||||
// add the branding so debian guys are not gettings confused
|
$version_link = $_link;
|
||||||
// about their version-number
|
$message_addinfo = $_message;
|
||||||
$version_label = $_version.$branding;
|
|
||||||
$version_link = $_link;
|
// not numeric -> error-message
|
||||||
$message_addinfo = $_message;
|
if (! preg_match('/^((\d+\\.)(\d+\\.)(\d+\\.)?(\d+)?(\-(svn|dev|rc)(\d+))?)$/', $_version)) {
|
||||||
|
// check for customized version to not output
|
||||||
// not numeric -> error-message
|
// "There is a newer version of froxlor" besides the error-message
|
||||||
if (!preg_match('/^((\d+\\.)(\d+\\.)(\d+\\.)?(\d+)?(\-(svn|dev|rc)(\d+))?)$/', $_version)) {
|
redirectTo($filename, array(
|
||||||
// check for customized version to not output
|
's' => $s,
|
||||||
// "There is a newer version of froxlor" besides the error-message
|
'page' => 'error',
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 3));
|
'errno' => 3
|
||||||
} elseif (version_compare2($version, $_version) == -1) {
|
));
|
||||||
// there is a newer version - yay
|
} elseif (version_compare2($version, $_version) == - 1) {
|
||||||
$isnewerversion = 1;
|
// there is a newer version - yay
|
||||||
} else {
|
$isnewerversion = 1;
|
||||||
// nothing new
|
} else {
|
||||||
$isnewerversion = 0;
|
// nothing new
|
||||||
}
|
$isnewerversion = 0;
|
||||||
|
}
|
||||||
// anzeige über version-status mit ggfls. formular
|
|
||||||
// zum update schritt #1 -> download
|
// anzeige über version-status mit ggfls. formular
|
||||||
if ($isnewerversion == 1) {
|
// zum update schritt #1 -> download
|
||||||
$text = 'There is a newer version available. Update to version <b>'.$_version.'</b> now?<br/>(Your current version is: '.$version.')';
|
if ($isnewerversion == 1) {
|
||||||
$hiddenparams = '<input type="hidden" name="newversion" value="'.$_version.'" />';
|
$text = 'There is a newer version available. Update to version <b>' . $_version . '</b> now?<br/>(Your current version is: ' . $version . ')';
|
||||||
$yesfile = $filename.'?s='.$s.'&page=getdownload';
|
$hiddenparams = '<input type="hidden" name="newversion" value="' . $_version . '" />';
|
||||||
eval("echo \"" . getTemplate("misc/question_yesno", true) . "\";");
|
$yesfile = $filename . '?s=' . $s . '&page=getdownload';
|
||||||
exit;
|
eval("echo \"" . getTemplate("misc/question_yesno", true) . "\";");
|
||||||
}
|
exit();
|
||||||
elseif ($isnewerversion == 0) {
|
} elseif ($isnewerversion == 0) {
|
||||||
// all good
|
// all good
|
||||||
standard_success ('noupdatesavail');
|
standard_success('noupdatesavail');
|
||||||
} else {
|
} else {
|
||||||
standard_error ('customized_version');
|
standard_error('customized_version');
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// error (something weird came from version.froxlor.org)
|
}// download the new archive
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 5));
|
|
||||||
}
|
|
||||||
// download the new archive
|
|
||||||
elseif ($page == 'getdownload') {
|
elseif ($page == 'getdownload') {
|
||||||
|
|
||||||
// retrieve the new version from the form
|
// retrieve the new version from the form
|
||||||
$newversion = isset($_POST['newversion']) ? $_POST['newversion'] : null;
|
$newversion = isset($_POST['newversion']) ? $_POST['newversion'] : null;
|
||||||
|
|
||||||
// valid?
|
// valid?
|
||||||
if ($newversion !== null) {
|
if ($newversion !== null) {
|
||||||
|
|
||||||
// define files to get
|
// define files to get
|
||||||
$toLoad = str_replace('{version}', $newversion, RELEASE_URI);
|
$toLoad = str_replace('{version}', $newversion, RELEASE_URI);
|
||||||
$toCheck = str_replace('{version}', $newversion, CHECKSUM_URI);
|
$toCheck = str_replace('{version}', $newversion, CHECKSUM_URI);
|
||||||
|
|
||||||
// get archive data
|
|
||||||
$newArchive = @file_get_contents($toLoad);
|
|
||||||
|
|
||||||
// check for local destination folder
|
// check for local destination folder
|
||||||
if (!is_dir(FROXLOR_INSTALL_DIR.'/updates/')) {
|
if (! is_dir(FROXLOR_INSTALL_DIR . '/updates/')) {
|
||||||
mkdir(FROXLOR_INSTALL_DIR.'/updates/');
|
mkdir(FROXLOR_INSTALL_DIR . '/updates/');
|
||||||
}
|
}
|
||||||
|
|
||||||
// name archive
|
// name archive
|
||||||
$localArchive = FROXLOR_INSTALL_DIR.'/updates/'.basename($toLoad);
|
$localArchive = FROXLOR_INSTALL_DIR . '/updates/' . basename($toLoad);
|
||||||
|
|
||||||
$log->logAction(ADM_ACTION, LOG_NOTICE, "Downloading ".$toLoad." to ".$localArchive);
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "Downloading " . $toLoad . " to " . $localArchive);
|
||||||
|
|
||||||
// remove old archive
|
// remove old archive
|
||||||
if (file_exists($localArchive)) {
|
if (file_exists($localArchive)) {
|
||||||
@unlink($localArchive);
|
@unlink($localArchive);
|
||||||
}
|
}
|
||||||
|
|
||||||
// store archive
|
// get archive data
|
||||||
$fh = fopen($localArchive, 'w');
|
try {
|
||||||
if (!fwrite($fh, $newArchive)) {
|
HttpClient::fileGet($toLoad, $localArchive);
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 4));
|
} catch (Exception $e) {
|
||||||
|
redirectTo($filename, array(
|
||||||
|
's' => $s,
|
||||||
|
'page' => 'error',
|
||||||
|
'errno' => 4
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// close file-handle
|
|
||||||
fclose($fh);
|
|
||||||
|
|
||||||
// validate the integrity of the downloaded file
|
// validate the integrity of the downloaded file
|
||||||
$_shouldsum = @file_get_contents($toCheck);
|
$_shouldsum = HttpClient::urlGet($toCheck);
|
||||||
if (!empty($_shouldsum)) {
|
if (! empty($_shouldsum)) {
|
||||||
$_t = explode(" ", $_shouldsum);
|
$_t = explode(" ", $_shouldsum);
|
||||||
$shouldsum = $_t[0];
|
$shouldsum = $_t[0];
|
||||||
} else {
|
} else {
|
||||||
$shouldsum = null;
|
$shouldsum = null;
|
||||||
}
|
}
|
||||||
$filesum = hash_file('sha256', $localArchive);
|
$filesum = hash_file('sha256', $localArchive);
|
||||||
|
|
||||||
if ($filesum != $shouldsum) {
|
if ($filesum != $shouldsum) {
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 9));
|
redirectTo($filename, array(
|
||||||
|
's' => $s,
|
||||||
|
'page' => 'error',
|
||||||
|
'errno' => 9
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// to the next step
|
// to the next step
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'extract', 'archive' => basename($localArchive)));
|
redirectTo($filename, array(
|
||||||
|
's' => $s,
|
||||||
|
'page' => 'extract',
|
||||||
|
'archive' => basename($localArchive)
|
||||||
|
));
|
||||||
}
|
}
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 6));
|
redirectTo($filename, array(
|
||||||
}
|
's' => $s,
|
||||||
// extract and install new version
|
'page' => 'error',
|
||||||
|
'errno' => 6
|
||||||
|
));
|
||||||
|
}// extract and install new version
|
||||||
elseif ($page == 'extract') {
|
elseif ($page == 'extract') {
|
||||||
|
|
||||||
$toExtract = isset($_GET['archive']) ? $_GET['archive'] : null;
|
$toExtract = isset($_GET['archive']) ? $_GET['archive'] : null;
|
||||||
$localArchive = FROXLOR_INSTALL_DIR.'/updates/'.$toExtract;
|
$localArchive = FROXLOR_INSTALL_DIR . '/updates/' . $toExtract;
|
||||||
|
|
||||||
if (isset($_POST['send'])
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
&& $_POST['send'] == 'send'
|
|
||||||
) {
|
|
||||||
// decompress from zip
|
// decompress from zip
|
||||||
$zip = new ZipArchive;
|
$zip = new ZipArchive();
|
||||||
$res = $zip->open($localArchive);
|
$res = $zip->open($localArchive);
|
||||||
if ($res === true) {
|
if ($res === true) {
|
||||||
$log->logAction(ADM_ACTION, LOG_NOTICE, "Extracting ".$localArchive." to ".FROXLOR_INSTALL_DIR);
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "Extracting " . $localArchive . " to " . FROXLOR_INSTALL_DIR);
|
||||||
$zip->extractTo(FROXLOR_INSTALL_DIR);
|
$zip->extractTo(FROXLOR_INSTALL_DIR);
|
||||||
$zip->close();
|
$zip->close();
|
||||||
// success - remove unused archive
|
// success - remove unused archive
|
||||||
@unlink($localArchive);
|
@unlink($localArchive);
|
||||||
} else {
|
} else {
|
||||||
// error
|
// error
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 8));
|
redirectTo($filename, array(
|
||||||
|
's' => $s,
|
||||||
|
'page' => 'error',
|
||||||
|
'errno' => 8
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// redirect to update-page?
|
// redirect to update-page?
|
||||||
redirectTo('admin_updates.php', array('s' => $s));
|
redirectTo('admin_updates.php', array(
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!file_exists($localArchive)) {
|
if (! file_exists($localArchive)) {
|
||||||
redirectTo($filename, array('s' => $s, 'page' => 'error', 'errno' => 7));
|
redirectTo($filename, array(
|
||||||
|
's' => $s,
|
||||||
|
'page' => 'error',
|
||||||
|
'errno' => 7
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
$text = 'Extract downloaded archive "'.$toExtract.'"?';
|
$text = 'Extract downloaded archive "' . $toExtract . '"?';
|
||||||
$hiddenparams = '';
|
$hiddenparams = '';
|
||||||
$yesfile = $filename.'?s='.$s.'&page=extract&archive='.$toExtract;
|
$yesfile = $filename . '?s=' . $s . '&page=extract&archive=' . $toExtract;
|
||||||
eval("echo \"" . getTemplate("misc/question_yesno", true) . "\";");
|
eval("echo \"" . getTemplate("misc/question_yesno", true) . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
// display error
|
// display error
|
||||||
elseif ($page == 'error') {
|
elseif ($page == 'error') {
|
||||||
|
|
||||||
// retrieve error-number via url-parameter
|
// retrieve error-number via url-parameter
|
||||||
$errno = isset($_GET['errno']) ? (int)$_GET['errno'] : 0;
|
$errno = isset($_GET['errno']) ? (int) $_GET['errno'] : 0;
|
||||||
|
|
||||||
// 1 = no allow_url_fopen
|
|
||||||
// 2 = no Zlib
|
// 2 = no Zlib
|
||||||
// 3 = custom version detected
|
// 3 = custom version detected
|
||||||
// 4 = could not store archive to local hdd
|
// 4 = could not store archive to local hdd
|
||||||
@@ -205,5 +215,5 @@ elseif ($page == 'error') {
|
|||||||
// 7 = local archive does not exist
|
// 7 = local archive does not exist
|
||||||
// 8 = could not extract archive
|
// 8 = could not extract archive
|
||||||
// 9 = checksum mismatch
|
// 9 = checksum mismatch
|
||||||
standard_error ('autoupdate_'.$errno);
|
standard_error('autoupdate_' . $errno);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ if ($userinfo['change_serversettings'] == '1') {
|
|||||||
|
|
||||||
$replace_arr = Array(
|
$replace_arr = Array(
|
||||||
'<SQL_UNPRIVILEGED_USER>' => $sql['user'],
|
'<SQL_UNPRIVILEGED_USER>' => $sql['user'],
|
||||||
'<SQL_UNPRIVILEGED_PASSWORD>' => 'MYSQL_PASSWORD',
|
'<SQL_UNPRIVILEGED_PASSWORD>' => 'FROXLOR_MYSQL_PASSWORD',
|
||||||
'<SQL_DB>' => $sql['db'],
|
'<SQL_DB>' => $sql['db'],
|
||||||
'<SQL_HOST>' => $sql['host'],
|
'<SQL_HOST>' => $sql['host'],
|
||||||
'<SQL_SOCKET>' => isset($sql['socket']) ? $sql['socket'] : null,
|
'<SQL_SOCKET>' => isset($sql['socket']) ? $sql['socket'] : null,
|
||||||
@@ -82,6 +82,12 @@ if ($userinfo['change_serversettings'] == '1') {
|
|||||||
$config_dir = makeCorrectDir(FROXLOR_INSTALL_DIR . '/lib/configfiles/');
|
$config_dir = makeCorrectDir(FROXLOR_INSTALL_DIR . '/lib/configfiles/');
|
||||||
|
|
||||||
if ($distribution != "") {
|
if ($distribution != "") {
|
||||||
|
|
||||||
|
if (!file_exists($config_dir . '/' . $distribution . ".xml")) {
|
||||||
|
trigger_error("Unknown distribution, are you playing around with the URL?");
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
// create configparser object
|
// create configparser object
|
||||||
$configfiles = new ConfigParser($config_dir . '/' . $distribution . ".xml");
|
$configfiles = new ConfigParser($config_dir . '/' . $distribution . ".xml");
|
||||||
|
|
||||||
@@ -93,6 +99,11 @@ if ($userinfo['change_serversettings'] == '1') {
|
|||||||
|
|
||||||
if ($service != "") {
|
if ($service != "") {
|
||||||
|
|
||||||
|
if (!isset($services[$service])) {
|
||||||
|
trigger_error("Unknown service, are you playing around with the URL?");
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
$daemons = $services[$service]->getDaemons();
|
$daemons = $services[$service]->getDaemons();
|
||||||
|
|
||||||
if ($daemon == "") {
|
if ($daemon == "") {
|
||||||
@@ -136,6 +147,11 @@ if ($userinfo['change_serversettings'] == '1') {
|
|||||||
|
|
||||||
if ($distribution != "" && $service != "" && $daemon != "") {
|
if ($distribution != "" && $service != "" && $daemon != "") {
|
||||||
|
|
||||||
|
if (!isset($daemons[$daemon])) {
|
||||||
|
trigger_error("Unknown daemon, are you playing around with the URL?");
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
$confarr = $daemons[$daemon]->getConfig();
|
$confarr = $daemons[$daemon]->getConfig();
|
||||||
|
|
||||||
$configpage = '';
|
$configpage = '';
|
||||||
|
|||||||
@@ -307,6 +307,8 @@ if ($page == 'customers'
|
|||||||
Database::pexecute($stmt, array('id' => $id));
|
Database::pexecute($stmt, array('id' => $id));
|
||||||
$stmt = Database::prepare("DELETE FROM `" . TABLE_PANEL_TRAFFIC . "` WHERE `customerid` = :id");
|
$stmt = Database::prepare("DELETE FROM `" . TABLE_PANEL_TRAFFIC . "` WHERE `customerid` = :id");
|
||||||
Database::pexecute($stmt, array('id' => $id));
|
Database::pexecute($stmt, array('id' => $id));
|
||||||
|
$stmt = Database::prepare("DELETE FROM `" . TABLE_PANEL_DISKSPACE . "` WHERE `customerid` = :id");
|
||||||
|
Database::pexecute($stmt, array('id' => $id));
|
||||||
$stmt = Database::prepare("DELETE FROM `" . TABLE_MAIL_USERS . "` WHERE `customerid` = :id");
|
$stmt = Database::prepare("DELETE FROM `" . TABLE_MAIL_USERS . "` WHERE `customerid` = :id");
|
||||||
Database::pexecute($stmt, array('id' => $id));
|
Database::pexecute($stmt, array('id' => $id));
|
||||||
$stmt = Database::prepare("DELETE FROM `" . TABLE_MAIL_VIRTUAL . "` WHERE `customerid` = :id");
|
$stmt = Database::prepare("DELETE FROM `" . TABLE_MAIL_VIRTUAL . "` WHERE `customerid` = :id");
|
||||||
@@ -532,6 +534,14 @@ if ($page == 'customers'
|
|||||||
$phpenabled = intval($_POST['phpenabled']);
|
$phpenabled = intval($_POST['phpenabled']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$allowed_phpconfigs = array();
|
||||||
|
if (isset($_POST['allowed_phpconfigs']) && is_array($_POST['allowed_phpconfigs'])) {
|
||||||
|
foreach ($_POST['allowed_phpconfigs'] as $allowed_phpconfig) {
|
||||||
|
$allowed_phpconfig = intval($allowed_phpconfig);
|
||||||
|
$allowed_phpconfigs[] = $allowed_phpconfig;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$perlenabled = 0;
|
$perlenabled = 0;
|
||||||
if (isset($_POST['perlenabled'])) {
|
if (isset($_POST['perlenabled'])) {
|
||||||
$perlenabled = intval($_POST['perlenabled']);
|
$perlenabled = intval($_POST['perlenabled']);
|
||||||
@@ -693,6 +703,7 @@ if ($page == 'customers'
|
|||||||
'tickets' => $tickets,
|
'tickets' => $tickets,
|
||||||
'mysqls' => $mysqls,
|
'mysqls' => $mysqls,
|
||||||
'phpenabled' => $phpenabled,
|
'phpenabled' => $phpenabled,
|
||||||
|
'allowed_phpconfigs' => empty($allowed_phpconfigs) ? "" : json_encode($allowed_phpconfigs),
|
||||||
'imap' => $email_imap,
|
'imap' => $email_imap,
|
||||||
'pop3' => $email_pop3,
|
'pop3' => $email_pop3,
|
||||||
'perlenabled' => $perlenabled,
|
'perlenabled' => $perlenabled,
|
||||||
@@ -733,6 +744,7 @@ if ($page == 'customers'
|
|||||||
`mysqls` = :mysqls,
|
`mysqls` = :mysqls,
|
||||||
`standardsubdomain` = '0',
|
`standardsubdomain` = '0',
|
||||||
`phpenabled` = :phpenabled,
|
`phpenabled` = :phpenabled,
|
||||||
|
`allowed_phpconfigs` = :allowed_phpconfigs,
|
||||||
`imap` = :imap,
|
`imap` = :imap,
|
||||||
`pop3` = :pop3,
|
`pop3` = :pop3,
|
||||||
`perlenabled` = :perlenabled,
|
`perlenabled` = :perlenabled,
|
||||||
@@ -910,7 +922,8 @@ if ($page == 'customers'
|
|||||||
'customerid' => $customerid,
|
'customerid' => $customerid,
|
||||||
'adminid' => $userinfo['adminid'],
|
'adminid' => $userinfo['adminid'],
|
||||||
'docroot' => $documentroot,
|
'docroot' => $documentroot,
|
||||||
'adddate' => date('Y-m-d')
|
'adddate' => time(),
|
||||||
|
'phpenabled' => $phpenabled
|
||||||
);
|
);
|
||||||
$ins_stmt = Database::prepare("
|
$ins_stmt = Database::prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
||||||
@@ -928,6 +941,7 @@ if ($page == 'customers'
|
|||||||
`dkim_id` = '0',
|
`dkim_id` = '0',
|
||||||
`dkim_privkey` = '',
|
`dkim_privkey` = '',
|
||||||
`dkim_pubkey` = '',
|
`dkim_pubkey` = '',
|
||||||
|
`phpenabled` = :phpenabled,
|
||||||
`add_date` = :adddate"
|
`add_date` = :adddate"
|
||||||
);
|
);
|
||||||
Database::pexecute($ins_stmt, $ins_data);
|
Database::pexecute($ins_stmt, $ins_data);
|
||||||
@@ -1022,7 +1036,7 @@ if ($page == 'customers'
|
|||||||
} else {
|
} else {
|
||||||
$language_options = '';
|
$language_options = '';
|
||||||
|
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options.= makeoption($language_name, $language_file, Settings::Get('panel.standardlanguage'), true);
|
$language_options.= makeoption($language_name, $language_file, Settings::Get('panel.standardlanguage'), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1041,6 +1055,40 @@ if ($page == 'customers'
|
|||||||
$gender_options .= makeoption($lng['gender']['male'], 1, null, true, true);
|
$gender_options .= makeoption($lng['gender']['male'], 1, null, true, true);
|
||||||
$gender_options .= makeoption($lng['gender']['female'], 2, null, true, true);
|
$gender_options .= makeoption($lng['gender']['female'], 2, null, true, true);
|
||||||
|
|
||||||
|
$phpconfigs = array();
|
||||||
|
$configs = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
");
|
||||||
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description'] . " [".$row['interpreter']."]<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description']."<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// hosting plans
|
||||||
|
$hosting_plans = "";
|
||||||
|
$plans = Database::query("
|
||||||
|
SELECT *
|
||||||
|
FROM `" . TABLE_PANEL_PLANS . "`
|
||||||
|
ORDER BY name ASC
|
||||||
|
");
|
||||||
|
if (Database::num_rows() > 0){
|
||||||
|
$hosting_plans .= makeoption("---", 0, 0, true, true);
|
||||||
|
}
|
||||||
|
while ($row = $plans->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$hosting_plans .= makeoption($row['name'], $row['id'], 0, 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);
|
||||||
|
|
||||||
@@ -1203,6 +1251,14 @@ if ($page == 'customers'
|
|||||||
$phpenabled = intval($_POST['phpenabled']);
|
$phpenabled = intval($_POST['phpenabled']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$allowed_phpconfigs = array();
|
||||||
|
if (isset($_POST['allowed_phpconfigs']) && is_array($_POST['allowed_phpconfigs'])) {
|
||||||
|
foreach ($_POST['allowed_phpconfigs'] as $allowed_phpconfig) {
|
||||||
|
$allowed_phpconfig = intval($allowed_phpconfig);
|
||||||
|
$allowed_phpconfigs[] = $allowed_phpconfig;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$perlenabled = 0;
|
$perlenabled = 0;
|
||||||
if (isset($_POST['perlenabled'])) {
|
if (isset($_POST['perlenabled'])) {
|
||||||
$perlenabled = intval($_POST['perlenabled']);
|
$perlenabled = intval($_POST['perlenabled']);
|
||||||
@@ -1281,7 +1337,7 @@ if ($page == 'customers'
|
|||||||
'customerid' => $result['customerid'],
|
'customerid' => $result['customerid'],
|
||||||
'adminid' => $userinfo['adminid'],
|
'adminid' => $userinfo['adminid'],
|
||||||
'docroot' => $result['documentroot'],
|
'docroot' => $result['documentroot'],
|
||||||
'adddate' => date('Y-m-d')
|
'adddate' => time()
|
||||||
);
|
);
|
||||||
$ins_stmt = Database::prepare("
|
$ins_stmt = Database::prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
||||||
@@ -1455,6 +1511,7 @@ if ($page == 'customers'
|
|||||||
'mysqls' => $mysqls,
|
'mysqls' => $mysqls,
|
||||||
'deactivated' => $deactivated,
|
'deactivated' => $deactivated,
|
||||||
'phpenabled' => $phpenabled,
|
'phpenabled' => $phpenabled,
|
||||||
|
'allowed_phpconfigs' => empty($allowed_phpconfigs) ? "" : json_encode($allowed_phpconfigs),
|
||||||
'imap' => $email_imap,
|
'imap' => $email_imap,
|
||||||
'pop3' => $email_pop3,
|
'pop3' => $email_pop3,
|
||||||
'perlenabled' => $perlenabled,
|
'perlenabled' => $perlenabled,
|
||||||
@@ -1488,6 +1545,7 @@ if ($page == 'customers'
|
|||||||
`mysqls` = :mysqls,
|
`mysqls` = :mysqls,
|
||||||
`deactivated` = :deactivated,
|
`deactivated` = :deactivated,
|
||||||
`phpenabled` = :phpenabled,
|
`phpenabled` = :phpenabled,
|
||||||
|
`allowed_phpconfigs` = :allowed_phpconfigs,
|
||||||
`email_quota` = :email_quota,
|
`email_quota` = :email_quota,
|
||||||
`imap` = :imap,
|
`imap` = :imap,
|
||||||
`pop3` = :pop3,
|
`pop3` = :pop3,
|
||||||
@@ -1628,7 +1686,7 @@ if ($page == 'customers'
|
|||||||
} else {
|
} else {
|
||||||
$language_options = '';
|
$language_options = '';
|
||||||
|
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options.= makeoption($language_name, $language_file, $result['def_language'], true);
|
$language_options.= makeoption($language_name, $language_file, $result['def_language'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1693,6 +1751,40 @@ if ($page == 'customers'
|
|||||||
$gender_options .= makeoption($lng['gender']['male'], 1, ($result['gender'] == '1' ? 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);
|
$gender_options .= makeoption($lng['gender']['female'], 2, ($result['gender'] == '2' ? true : false), true, true);
|
||||||
|
|
||||||
|
$phpconfigs = array();
|
||||||
|
$configs = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
");
|
||||||
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description'] . " [".$row['interpreter']."]<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description']."<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// hosting plans
|
||||||
|
$hosting_plans = "";
|
||||||
|
$plans = Database::query("
|
||||||
|
SELECT *
|
||||||
|
FROM `" . TABLE_PANEL_PLANS . "`
|
||||||
|
ORDER BY name ASC
|
||||||
|
");
|
||||||
|
if (Database::num_rows() > 0){
|
||||||
|
$hosting_plans .= makeoption("---", 0, 0, true, true);
|
||||||
|
}
|
||||||
|
while ($row = $plans->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$hosting_plans .= makeoption($row['name'], $row['id'], 0, 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);
|
||||||
|
|
||||||
|
|||||||
@@ -55,7 +55,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$syshostname = "AND `d`.`id` <> " . Settings::Get('system.hostname_id');
|
$syshostname = "AND `d`.`id` <> " . Settings::Get('system.hostname_id');
|
||||||
}
|
}
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT `d`.*, `c`.`loginname`, `c`.`name`, `c`.`firstname`, `c`.`company`, `c`.`standardsubdomain`, `ad`.`id` AS `aliasdomainid`, `ad`.`domain` AS `aliasdomain`
|
SELECT `d`.*, `c`.`loginname`, `c`.`deactivated`, `c`.`name`, `c`.`firstname`, `c`.`company`, `c`.`standardsubdomain`, `ad`.`id` AS `aliasdomainid`, `ad`.`domain` AS `aliasdomain`
|
||||||
FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
||||||
LEFT JOIN `" . TABLE_PANEL_CUSTOMERS . "` `c` USING(`customerid`)
|
LEFT JOIN `" . TABLE_PANEL_CUSTOMERS . "` `c` USING(`customerid`)
|
||||||
LEFT JOIN `" . TABLE_PANEL_DOMAINS . "` `ad` ON `d`.`aliasdomain`=`ad`.`id`
|
LEFT JOIN `" . TABLE_PANEL_DOMAINS . "` `ad` ON `d`.`aliasdomain`=`ad`.`id`
|
||||||
@@ -306,7 +306,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
standard_error('admin_domain_emailsystemhostname');
|
standard_error('admin_domain_emailsystemhostname');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strpos($_POST['domain'], '--') !== false) {
|
if (substr($_POST['domain'], 0, 4) == 'xn--') {
|
||||||
standard_error('domain_nopunycode');
|
standard_error('domain_nopunycode');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -429,6 +429,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$specialsettings = validate(str_replace("\r\n", "\n", $_POST['specialsettings']), 'specialsettings', '/^[^\0]*$/');
|
$specialsettings = validate(str_replace("\r\n", "\n", $_POST['specialsettings']), 'specialsettings', '/^[^\0]*$/');
|
||||||
|
$notryfiles = isset($_POST['notryfiles']) && (int)$_POST['notryfiles'] == 1 ? 1 : 0;
|
||||||
validate($_POST['documentroot'], 'documentroot');
|
validate($_POST['documentroot'], 'documentroot');
|
||||||
|
|
||||||
// If path is empty and 'Use domain name as default value for DocumentRoot path' is enabled in settings,
|
// If path is empty and 'Use domain name as default value for DocumentRoot path' is enabled in settings,
|
||||||
@@ -451,11 +452,12 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$zonefile = '';
|
$zonefile = '';
|
||||||
$dkim = '1';
|
$dkim = '1';
|
||||||
$specialsettings = '';
|
$specialsettings = '';
|
||||||
|
$notryfiles = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($userinfo['caneditphpsettings'] == '1' || $userinfo['change_serversettings'] == '1') {
|
if ($userinfo['caneditphpsettings'] == '1' || $userinfo['change_serversettings'] == '1') {
|
||||||
|
|
||||||
$phpenabled = isset($POST_['phpenabled']) ? intval($_POST['phpenabled']) : 0;
|
$phpenabled = isset($_POST['phpenabled']) ? intval($_POST['phpenabled']) : 0;
|
||||||
$openbasedir = isset($_POST['openbasedir']) ? intval($_POST['openbasedir']) : 0;
|
$openbasedir = isset($_POST['openbasedir']) ? intval($_POST['openbasedir']) : 0;
|
||||||
|
|
||||||
if ((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) {
|
if ((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
@@ -496,7 +498,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$phpenabled = '1';
|
$phpenabled = '1';
|
||||||
$openbasedir = '1';
|
$openbasedir = '1';
|
||||||
|
|
||||||
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
@@ -526,7 +528,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
|
|
||||||
$ipandports = array();
|
$ipandports = array();
|
||||||
if (isset($_POST['ipandport']) && ! is_array($_POST['ipandport'])) {
|
if (isset($_POST['ipandport']) && ! is_array($_POST['ipandport'])) {
|
||||||
$_POST['ipandport'] = unserialize($_POST['ipandport']);
|
$_POST['ipandport'] = json_decode($_POST['ipandport'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($_POST['ipandport']) && is_array($_POST['ipandport'])) {
|
if (isset($_POST['ipandport']) && is_array($_POST['ipandport'])) {
|
||||||
@@ -562,7 +564,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
|
|
||||||
$ssl_ipandports = array();
|
$ssl_ipandports = array();
|
||||||
if (isset($_POST['ssl_ipandport']) && ! is_array($_POST['ssl_ipandport'])) {
|
if (isset($_POST['ssl_ipandport']) && ! is_array($_POST['ssl_ipandport'])) {
|
||||||
$_POST['ssl_ipandport'] = unserialize($_POST['ssl_ipandport']);
|
$_POST['ssl_ipandport'] = json_decode($_POST['ssl_ipandport'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Verify SSL-Ports
|
// Verify SSL-Ports
|
||||||
@@ -590,15 +592,21 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$http2 = isset($_POST['http2']) && (int)$_POST['http2'] == 1 ? 1 : 0;
|
||||||
|
|
||||||
// HSTS
|
// HSTS
|
||||||
$hsts_maxage = isset($_POST['hsts_maxage']) ? (int)$_POST['hsts_maxage'] : 0;
|
$hsts_maxage = isset($_POST['hsts_maxage']) ? (int)$_POST['hsts_maxage'] : 0;
|
||||||
$hsts_sub = isset($_POST['hsts_sub']) && (int)$_POST['hsts_sub'] == 1 ? 1 : 0;
|
$hsts_sub = isset($_POST['hsts_sub']) && (int)$_POST['hsts_sub'] == 1 ? 1 : 0;
|
||||||
$hsts_preload = isset($_POST['hsts_preload']) && (int)$_POST['hsts_preload'] == 1 ? 1 : 0;
|
$hsts_preload = isset($_POST['hsts_preload']) && (int)$_POST['hsts_preload'] == 1 ? 1 : 0;
|
||||||
|
|
||||||
|
// OCSP stapling
|
||||||
|
$ocsp_stapling = isset($_POST['ocsp_stapling']) && (int)$_POST['ocsp_stapling'] == 1 ? 1 : 0;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$ssl_redirect = 0;
|
$ssl_redirect = 0;
|
||||||
$letsencrypt = 0;
|
$letsencrypt = 0;
|
||||||
// we need this for the serialize
|
$http2 = 0;
|
||||||
|
// we need this for the json-encode
|
||||||
// if ssl is disabled or no ssl-ip/port exists
|
// if ssl is disabled or no ssl-ip/port exists
|
||||||
$ssl_ipandports[] = - 1;
|
$ssl_ipandports[] = - 1;
|
||||||
|
|
||||||
@@ -606,11 +614,15 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$hsts_maxage = 0;
|
$hsts_maxage = 0;
|
||||||
$hsts_sub = 0;
|
$hsts_sub = 0;
|
||||||
$hsts_preload = 0;
|
$hsts_preload = 0;
|
||||||
|
|
||||||
|
// OCSP stapling
|
||||||
|
$ocsp_stapling = 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$ssl_redirect = 0;
|
$ssl_redirect = 0;
|
||||||
$letsencrypt = 0;
|
$letsencrypt = 0;
|
||||||
// we need this for the serialize
|
$http2 = 0;
|
||||||
|
// we need this for the json-encode
|
||||||
// if ssl is disabled or no ssl-ip/port exists
|
// if ssl is disabled or no ssl-ip/port exists
|
||||||
$ssl_ipandports[] = - 1;
|
$ssl_ipandports[] = - 1;
|
||||||
|
|
||||||
@@ -618,12 +630,20 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$hsts_maxage = 0;
|
$hsts_maxage = 0;
|
||||||
$hsts_sub = 0;
|
$hsts_sub = 0;
|
||||||
$hsts_preload = 0;
|
$hsts_preload = 0;
|
||||||
|
|
||||||
|
// OCSP stapling
|
||||||
|
$ocsp_stapling = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// We can't enable let's encrypt for wildcard - domains
|
// We can't enable let's encrypt for wildcard - domains if using acme-v1
|
||||||
if ($serveraliasoption == '0' && $letsencrypt == '1') {
|
if ($serveraliasoption == '0' && $letsencrypt == '1' && Settings::Get('system.leapiversion') == '1') {
|
||||||
standard_error('nowildcardwithletsencrypt');
|
standard_error('nowildcardwithletsencrypt');
|
||||||
}
|
}
|
||||||
|
// if using acme-v2 we cannot issue wildcard-certificates
|
||||||
|
// because they currently only support the dns-01 challenge
|
||||||
|
if ($serveraliasoption == '0' && $letsencrypt == '1' && Settings::Get('system.leapiversion') == '2') {
|
||||||
|
standard_error('nowildcardwithletsencryptv2');
|
||||||
|
}
|
||||||
|
|
||||||
// Temporarily deactivate ssl_redirect until Let's Encrypt certificate was generated
|
// Temporarily deactivate ssl_redirect until Let's Encrypt certificate was generated
|
||||||
if ($ssl_redirect > 0 && $letsencrypt == 1) {
|
if ($ssl_redirect > 0 && $letsencrypt == 1) {
|
||||||
@@ -672,7 +692,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (count($ssl_ipandports) == 0) {
|
if (count($ssl_ipandports) == 0) {
|
||||||
// we need this for the serialize
|
// we need this for the json-encode
|
||||||
// if ssl is disabled or no ssl-ip/port exists
|
// if ssl is disabled or no ssl-ip/port exists
|
||||||
$ssl_ipandports[] = - 1;
|
$ssl_ipandports[] = - 1;
|
||||||
}
|
}
|
||||||
@@ -693,8 +713,8 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
if (count($ipandports) == 0) {
|
if (count($ipandports) == 0) {
|
||||||
standard_error('noipportgiven');
|
standard_error('noipportgiven');
|
||||||
}
|
}
|
||||||
|
|
||||||
if($phpenabled != '1') {
|
if ($phpenabled != '1') {
|
||||||
$phpenabled = '0';
|
$phpenabled = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -774,22 +794,25 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
'dkim' => $dkim,
|
'dkim' => $dkim,
|
||||||
'speciallogfile' => $speciallogfile,
|
'speciallogfile' => $speciallogfile,
|
||||||
'selectserveralias' => $serveraliasoption,
|
'selectserveralias' => $serveraliasoption,
|
||||||
'ipandport' => serialize($ipandports),
|
'ipandport' => json_encode($ipandports),
|
||||||
'ssl_redirect' => $ssl_redirect,
|
'ssl_redirect' => $ssl_redirect,
|
||||||
'ssl_ipandport' => serialize($ssl_ipandports),
|
'ssl_ipandport' => json_encode($ssl_ipandports),
|
||||||
'phpenabled' => $phpenabled,
|
'phpenabled' => $phpenabled,
|
||||||
'openbasedir' => $openbasedir,
|
'openbasedir' => $openbasedir,
|
||||||
'phpsettingid' => $phpsettingid,
|
'phpsettingid' => $phpsettingid,
|
||||||
'mod_fcgid_starter' => $mod_fcgid_starter,
|
'mod_fcgid_starter' => $mod_fcgid_starter,
|
||||||
'mod_fcgid_maxrequests' => $mod_fcgid_maxrequests,
|
'mod_fcgid_maxrequests' => $mod_fcgid_maxrequests,
|
||||||
'specialsettings' => $specialsettings,
|
'specialsettings' => $specialsettings,
|
||||||
|
'notryfiles' => $notryfiles,
|
||||||
'registration_date' => $registration_date,
|
'registration_date' => $registration_date,
|
||||||
'termination_date' => $termination_date,
|
'termination_date' => $termination_date,
|
||||||
'issubof' => $issubof,
|
'issubof' => $issubof,
|
||||||
'letsencrypt' => $letsencrypt,
|
'letsencrypt' => $letsencrypt,
|
||||||
|
'http2' => $http2,
|
||||||
'hsts_maxage' => $hsts_maxage,
|
'hsts_maxage' => $hsts_maxage,
|
||||||
'hsts_sub' => $hsts_sub,
|
'hsts_sub' => $hsts_sub,
|
||||||
'hsts_preload' => $hsts_preload
|
'hsts_preload' => $hsts_preload,
|
||||||
|
'ocsp_stapling' => $ocsp_stapling
|
||||||
);
|
);
|
||||||
|
|
||||||
$security_questions = array(
|
$security_questions = array(
|
||||||
@@ -830,6 +853,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
'openbasedir' => $openbasedir,
|
'openbasedir' => $openbasedir,
|
||||||
'speciallogfile' => $speciallogfile,
|
'speciallogfile' => $speciallogfile,
|
||||||
'specialsettings' => $specialsettings,
|
'specialsettings' => $specialsettings,
|
||||||
|
'notryfiles' => $notryfiles,
|
||||||
'ssl_redirect' => $ssl_redirect,
|
'ssl_redirect' => $ssl_redirect,
|
||||||
'add_date' => time(),
|
'add_date' => time(),
|
||||||
'registration_date' => $registration_date,
|
'registration_date' => $registration_date,
|
||||||
@@ -839,9 +863,11 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
'mod_fcgid_maxrequests' => $mod_fcgid_maxrequests,
|
'mod_fcgid_maxrequests' => $mod_fcgid_maxrequests,
|
||||||
'ismainbutsubto' => $issubof,
|
'ismainbutsubto' => $issubof,
|
||||||
'letsencrypt' => $letsencrypt,
|
'letsencrypt' => $letsencrypt,
|
||||||
|
'http2' => $http2,
|
||||||
'hsts' => $hsts_maxage,
|
'hsts' => $hsts_maxage,
|
||||||
'hsts_sub' => $hsts_sub,
|
'hsts_sub' => $hsts_sub,
|
||||||
'hsts_preload' => $hsts_preload
|
'hsts_preload' => $hsts_preload,
|
||||||
|
'ocsp_stapling' => $ocsp_stapling
|
||||||
);
|
);
|
||||||
|
|
||||||
$ins_stmt = Database::prepare("
|
$ins_stmt = Database::prepare("
|
||||||
@@ -867,6 +893,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
`openbasedir` = :openbasedir,
|
`openbasedir` = :openbasedir,
|
||||||
`speciallogfile` = :speciallogfile,
|
`speciallogfile` = :speciallogfile,
|
||||||
`specialsettings` = :specialsettings,
|
`specialsettings` = :specialsettings,
|
||||||
|
`notryfiles` = :notryfiles,
|
||||||
`ssl_redirect` = :ssl_redirect,
|
`ssl_redirect` = :ssl_redirect,
|
||||||
`add_date` = :add_date,
|
`add_date` = :add_date,
|
||||||
`registration_date` = :registration_date,
|
`registration_date` = :registration_date,
|
||||||
@@ -876,9 +903,11 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
`mod_fcgid_maxrequests` = :mod_fcgid_maxrequests,
|
`mod_fcgid_maxrequests` = :mod_fcgid_maxrequests,
|
||||||
`ismainbutsubto` = :ismainbutsubto,
|
`ismainbutsubto` = :ismainbutsubto,
|
||||||
`letsencrypt` = :letsencrypt,
|
`letsencrypt` = :letsencrypt,
|
||||||
|
`http2` = :http2,
|
||||||
`hsts` = :hsts,
|
`hsts` = :hsts,
|
||||||
`hsts_sub` = :hsts_sub,
|
`hsts_sub` = :hsts_sub,
|
||||||
`hsts_preload` = :hsts_preload
|
`hsts_preload` = :hsts_preload,
|
||||||
|
`ocsp_stapling` = :ocsp_stapling
|
||||||
");
|
");
|
||||||
Database::pexecute($ins_stmt, $ins_data);
|
Database::pexecute($ins_stmt, $ins_data);
|
||||||
$domainid = Database::lastInsertId();
|
$domainid = Database::lastInsertId();
|
||||||
@@ -1058,11 +1087,15 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$phpconfigs = '';
|
$phpconfigs = '';
|
||||||
$configs = Database::query("SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "`");
|
$configs = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
");
|
||||||
|
|
||||||
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
$phpconfigs .= makeoption($row['description'], $row['id'], Settings::Get('phpfpm.defaultini'), true, true);
|
$phpconfigs .= makeoption($row['description'] . " [".$row['interpreter']."]", $row['id'], Settings::Get('phpfpm.defaultini'), true, true);
|
||||||
} else {
|
} else {
|
||||||
$phpconfigs .= makeoption($row['description'], $row['id'], Settings::Get('system.mod_fcgid_defaultini'), true, true);
|
$phpconfigs .= makeoption($row['description'], $row['id'], Settings::Get('system.mod_fcgid_defaultini'), true, true);
|
||||||
}
|
}
|
||||||
@@ -1091,7 +1124,6 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} elseif ($action == 'edit' && $id != 0) {
|
} elseif ($action == 'edit' && $id != 0) {
|
||||||
|
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT `d`.*, `c`.`customerid`
|
SELECT `d`.*, `c`.`customerid`
|
||||||
FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
||||||
@@ -1310,6 +1342,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
|
|
||||||
$specialsettings = validate(str_replace("\r\n", "\n", $_POST['specialsettings']), 'specialsettings', '/^[^\0]*$/');
|
$specialsettings = validate(str_replace("\r\n", "\n", $_POST['specialsettings']), 'specialsettings', '/^[^\0]*$/');
|
||||||
$ssfs = (isset($_POST['specialsettingsforsubdomains']) && intval($_POST['specialsettingsforsubdomains']) == 1) ? 1 : 0;
|
$ssfs = (isset($_POST['specialsettingsforsubdomains']) && intval($_POST['specialsettingsforsubdomains']) == 1) ? 1 : 0;
|
||||||
|
$notryfiles = isset($_POST['notryfiles']) && (int)$_POST['notryfiles'] == 1 ? 1 : 0;
|
||||||
$documentroot = validate($_POST['documentroot'], 'documentroot');
|
$documentroot = validate($_POST['documentroot'], 'documentroot');
|
||||||
|
|
||||||
if ($documentroot == '') {
|
if ($documentroot == '') {
|
||||||
@@ -1331,6 +1364,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$dkim = $result['dkim'];
|
$dkim = $result['dkim'];
|
||||||
$specialsettings = $result['specialsettings'];
|
$specialsettings = $result['specialsettings'];
|
||||||
$ssfs = (empty($specialsettings) ? 0 : 1);
|
$ssfs = (empty($specialsettings) ? 0 : 1);
|
||||||
|
$notryfiles = $result['notryfiles'];
|
||||||
$documentroot = $result['documentroot'];
|
$documentroot = $result['documentroot'];
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1340,6 +1374,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
|
|
||||||
$phpenabled = isset($_POST['phpenabled']) ? intval($_POST['phpenabled']) : 0;
|
$phpenabled = isset($_POST['phpenabled']) ? intval($_POST['phpenabled']) : 0;
|
||||||
$openbasedir = isset($_POST['openbasedir']) ? intval($_POST['openbasedir']) : 0;
|
$openbasedir = isset($_POST['openbasedir']) ? intval($_POST['openbasedir']) : 0;
|
||||||
|
$phpfs = (isset($_POST['phpsettingsforsubdomains']) && intval($_POST['phpsettingsforsubdomains']) == 1) ? 1 : 0;
|
||||||
|
|
||||||
if ((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) {
|
if ((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
$phpsettingid = (int) $_POST['phpsettingid'];
|
$phpsettingid = (int) $_POST['phpsettingid'];
|
||||||
@@ -1369,6 +1404,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$phpsettingid = $result['phpsettingid'];
|
$phpsettingid = $result['phpsettingid'];
|
||||||
|
$phpfs = 1;
|
||||||
$mod_fcgid_starter = $result['mod_fcgid_starter'];
|
$mod_fcgid_starter = $result['mod_fcgid_starter'];
|
||||||
$mod_fcgid_maxrequests = $result['mod_fcgid_maxrequests'];
|
$mod_fcgid_maxrequests = $result['mod_fcgid_maxrequests'];
|
||||||
}
|
}
|
||||||
@@ -1376,13 +1412,14 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$phpenabled = $result['phpenabled'];
|
$phpenabled = $result['phpenabled'];
|
||||||
$openbasedir = $result['openbasedir'];
|
$openbasedir = $result['openbasedir'];
|
||||||
$phpsettingid = $result['phpsettingid'];
|
$phpsettingid = $result['phpsettingid'];
|
||||||
|
$phpfs = 1;
|
||||||
$mod_fcgid_starter = $result['mod_fcgid_starter'];
|
$mod_fcgid_starter = $result['mod_fcgid_starter'];
|
||||||
$mod_fcgid_maxrequests = $result['mod_fcgid_maxrequests'];
|
$mod_fcgid_maxrequests = $result['mod_fcgid_maxrequests'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$ipandports = array();
|
$ipandports = array();
|
||||||
if (isset($_POST['ipandport']) && ! is_array($_POST['ipandport'])) {
|
if (isset($_POST['ipandport']) && ! is_array($_POST['ipandport'])) {
|
||||||
$_POST['ipandport'] = unserialize($_POST['ipandport']);
|
$_POST['ipandport'] = json_decode($_POST['ipandport'], true);
|
||||||
}
|
}
|
||||||
if (isset($_POST['ipandport']) && is_array($_POST['ipandport'])) {
|
if (isset($_POST['ipandport']) && is_array($_POST['ipandport'])) {
|
||||||
|
|
||||||
@@ -1416,14 +1453,19 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$letsencrypt = (int) $_POST['letsencrypt'];
|
$letsencrypt = (int) $_POST['letsencrypt'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$http2 = isset($_POST['http2']) && (int)$_POST['http2'] == 1 ? 1 : 0;
|
||||||
|
|
||||||
// HSTS
|
// HSTS
|
||||||
$hsts_maxage = isset($_POST['hsts_maxage']) ? (int)$_POST['hsts_maxage'] : 0;
|
$hsts_maxage = isset($_POST['hsts_maxage']) ? (int)$_POST['hsts_maxage'] : 0;
|
||||||
$hsts_sub = isset($_POST['hsts_sub']) && (int)$_POST['hsts_sub'] == 1 ? 1 : 0;
|
$hsts_sub = isset($_POST['hsts_sub']) && (int)$_POST['hsts_sub'] == 1 ? 1 : 0;
|
||||||
$hsts_preload = isset($_POST['hsts_preload']) && (int)$_POST['hsts_preload'] == 1 ? 1 : 0;
|
$hsts_preload = isset($_POST['hsts_preload']) && (int)$_POST['hsts_preload'] == 1 ? 1 : 0;
|
||||||
|
|
||||||
|
// OCSP stapling
|
||||||
|
$ocsp_stapling = isset($_POST['ocsp_stapling']) && (int)$_POST['ocsp_stapling'] == 1 ? 1 : 0;
|
||||||
|
|
||||||
$ssl_ipandports = array();
|
$ssl_ipandports = array();
|
||||||
if (isset($_POST['ssl_ipandport']) && ! is_array($_POST['ssl_ipandport'])) {
|
if (isset($_POST['ssl_ipandport']) && ! is_array($_POST['ssl_ipandport'])) {
|
||||||
$_POST['ssl_ipandport'] = unserialize($_POST['ssl_ipandport']);
|
$_POST['ssl_ipandport'] = json_decode($_POST['ssl_ipandport'], true);
|
||||||
}
|
}
|
||||||
if (isset($_POST['ssl_ipandport']) && is_array($_POST['ssl_ipandport'])) {
|
if (isset($_POST['ssl_ipandport']) && is_array($_POST['ssl_ipandport'])) {
|
||||||
|
|
||||||
@@ -1450,7 +1492,8 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
} else {
|
} else {
|
||||||
$ssl_redirect = 0;
|
$ssl_redirect = 0;
|
||||||
$letsencrypt = 0;
|
$letsencrypt = 0;
|
||||||
// we need this for the serialize
|
$http2 = 0;
|
||||||
|
// we need this for the json-encode
|
||||||
// if ssl is disabled or no ssl-ip/port exists
|
// if ssl is disabled or no ssl-ip/port exists
|
||||||
$ssl_ipandports[] = - 1;
|
$ssl_ipandports[] = - 1;
|
||||||
|
|
||||||
@@ -1458,11 +1501,15 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$hsts_maxage = 0;
|
$hsts_maxage = 0;
|
||||||
$hsts_sub = 0;
|
$hsts_sub = 0;
|
||||||
$hsts_preload = 0;
|
$hsts_preload = 0;
|
||||||
|
|
||||||
|
// OCSP stapling
|
||||||
|
$ocsp_stapling = 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$ssl_redirect = 0;
|
$ssl_redirect = 0;
|
||||||
$letsencrypt = 0;
|
$letsencrypt = 0;
|
||||||
// we need this for the serialize
|
$http2 = 0;
|
||||||
|
// we need this for the json-encode
|
||||||
// if ssl is disabled or no ssl-ip/port exists
|
// if ssl is disabled or no ssl-ip/port exists
|
||||||
$ssl_ipandports[] = - 1;
|
$ssl_ipandports[] = - 1;
|
||||||
|
|
||||||
@@ -1470,12 +1517,20 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$hsts_maxage = 0;
|
$hsts_maxage = 0;
|
||||||
$hsts_sub = 0;
|
$hsts_sub = 0;
|
||||||
$hsts_preload = 0;
|
$hsts_preload = 0;
|
||||||
|
|
||||||
|
// OCSP stapling
|
||||||
|
$ocsp_stapling = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// We can't enable let's encrypt for wildcard domains
|
// We can't enable let's encrypt for wildcard domains when using acme-v1
|
||||||
if ($serveraliasoption == '0' && $letsencrypt == '1') {
|
if ($serveraliasoption == '0' && $letsencrypt == '1' && Settings::Get('system.leapiversion') == '1') {
|
||||||
standard_error('nowildcardwithletsencrypt');
|
standard_error('nowildcardwithletsencrypt');
|
||||||
}
|
}
|
||||||
|
// if using acme-v2 we cannot issue wildcard-certificates
|
||||||
|
// because they currently only support the dns-01 challenge
|
||||||
|
if ($serveraliasoption == '0' && $letsencrypt == '1' && Settings::Get('system.leapiversion') == '2') {
|
||||||
|
standard_error('nowildcardwithletsencryptv2');
|
||||||
|
}
|
||||||
|
|
||||||
// Temporarily deactivate ssl_redirect until Let's Encrypt certificate was generated
|
// Temporarily deactivate ssl_redirect until Let's Encrypt certificate was generated
|
||||||
if ($ssl_redirect > 0 && $letsencrypt == 1 && $result['letsencrypt'] != $letsencrypt) {
|
if ($ssl_redirect > 0 && $letsencrypt == 1 && $result['letsencrypt'] != $letsencrypt) {
|
||||||
@@ -1485,7 +1540,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
if (! preg_match('/^https?\:\/\//', $documentroot)) {
|
if (! preg_match('/^https?\:\/\//', $documentroot)) {
|
||||||
$documentroot = makeCorrectDir($documentroot);
|
$documentroot = makeCorrectDir($documentroot);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($phpenabled != '1') {
|
if ($phpenabled != '1') {
|
||||||
$phpenabled = '0';
|
$phpenabled = '0';
|
||||||
}
|
}
|
||||||
@@ -1547,7 +1602,7 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (count($ssl_ipandports) == 0) {
|
if (count($ssl_ipandports) == 0) {
|
||||||
// we need this for the serialize
|
// we need this for the json-encode
|
||||||
// if ssl is disabled or no ssl-ip/port exists
|
// if ssl is disabled or no ssl-ip/port exists
|
||||||
$ssl_ipandports[] = - 1;
|
$ssl_ipandports[] = - 1;
|
||||||
}
|
}
|
||||||
@@ -1601,21 +1656,25 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
'phpenabled' => $phpenabled,
|
'phpenabled' => $phpenabled,
|
||||||
'openbasedir' => $openbasedir,
|
'openbasedir' => $openbasedir,
|
||||||
'phpsettingid' => $phpsettingid,
|
'phpsettingid' => $phpsettingid,
|
||||||
|
'phpsettingsforsubdomains' => $phpfs,
|
||||||
'mod_fcgid_starter' => $mod_fcgid_starter,
|
'mod_fcgid_starter' => $mod_fcgid_starter,
|
||||||
'mod_fcgid_maxrequests' => $mod_fcgid_maxrequests,
|
'mod_fcgid_maxrequests' => $mod_fcgid_maxrequests,
|
||||||
'specialsettings' => $specialsettings,
|
'specialsettings' => $specialsettings,
|
||||||
'specialsettingsforsubdomains' => $ssfs,
|
'specialsettingsforsubdomains' => $ssfs,
|
||||||
|
'notryfiles' => $notryfiles,
|
||||||
'registration_date' => $registration_date,
|
'registration_date' => $registration_date,
|
||||||
'termination_date' => $termination_date,
|
'termination_date' => $termination_date,
|
||||||
'issubof' => $issubof,
|
'issubof' => $issubof,
|
||||||
'speciallogfile' => $speciallogfile,
|
'speciallogfile' => $speciallogfile,
|
||||||
'speciallogverified' => $speciallogverified,
|
'speciallogverified' => $speciallogverified,
|
||||||
'ipandport' => serialize($ipandports),
|
'ipandport' => json_encode($ipandports),
|
||||||
'ssl_ipandport' => serialize($ssl_ipandports),
|
'ssl_ipandport' => json_encode($ssl_ipandports),
|
||||||
'letsencrypt' => $letsencrypt,
|
'letsencrypt' => $letsencrypt,
|
||||||
|
'http2' => $http2,
|
||||||
'hsts_maxage' => $hsts_maxage,
|
'hsts_maxage' => $hsts_maxage,
|
||||||
'hsts_sub' => $hsts_sub,
|
'hsts_sub' => $hsts_sub,
|
||||||
'hsts_preload' => $hsts_preload
|
'hsts_preload' => $hsts_preload,
|
||||||
|
'ocsp_stapling' => $ocsp_stapling
|
||||||
);
|
);
|
||||||
|
|
||||||
$security_questions = array(
|
$security_questions = array(
|
||||||
@@ -1634,7 +1693,29 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$wwwserveralias = ($serveraliasoption == '1') ? '1' : '0';
|
$wwwserveralias = ($serveraliasoption == '1') ? '1' : '0';
|
||||||
$iswildcarddomain = ($serveraliasoption == '0') ? '1' : '0';
|
$iswildcarddomain = ($serveraliasoption == '0') ? '1' : '0';
|
||||||
|
|
||||||
if ($documentroot != $result['documentroot'] || $ssl_redirect != $result['ssl_redirect'] || $wwwserveralias != $result['wwwserveralias'] || $iswildcarddomain != $result['iswildcarddomain'] || $phpenabled != $result['phpenabled'] || $openbasedir != $result['openbasedir'] || $phpsettingid != $result['phpsettingid'] || $mod_fcgid_starter != $result['mod_fcgid_starter'] || $mod_fcgid_maxrequests != $result['mod_fcgid_maxrequests'] || $specialsettings != $result['specialsettings'] || $aliasdomain != $result['aliasdomain'] || $issubof != $result['ismainbutsubto'] || $email_only != $result['email_only'] || ($speciallogfile != $result['speciallogfile'] && $speciallogverified == '1') || $letsencrypt != $result['letsencrypt'] || $hsts_maxage != $result['hsts'] || $hsts_sub != $result['hsts_sub'] || $hsts_preload != $result['hsts_preload']) {
|
if (
|
||||||
|
$documentroot != $result['documentroot'] ||
|
||||||
|
$ssl_redirect != $result['ssl_redirect'] ||
|
||||||
|
$wwwserveralias != $result['wwwserveralias'] ||
|
||||||
|
$iswildcarddomain != $result['iswildcarddomain'] ||
|
||||||
|
$phpenabled != $result['phpenabled'] ||
|
||||||
|
$openbasedir != $result['openbasedir'] ||
|
||||||
|
$phpsettingid != $result['phpsettingid'] ||
|
||||||
|
$mod_fcgid_starter != $result['mod_fcgid_starter'] ||
|
||||||
|
$mod_fcgid_maxrequests != $result['mod_fcgid_maxrequests'] ||
|
||||||
|
$specialsettings != $result['specialsettings'] ||
|
||||||
|
$notryfiles != $result['notryfiles'] ||
|
||||||
|
$aliasdomain != $result['aliasdomain'] ||
|
||||||
|
$issubof != $result['ismainbutsubto'] ||
|
||||||
|
$email_only != $result['email_only'] ||
|
||||||
|
($speciallogfile != $result['speciallogfile'] && $speciallogverified == '1') ||
|
||||||
|
$letsencrypt != $result['letsencrypt'] ||
|
||||||
|
$http2 != $result['http2'] ||
|
||||||
|
$hsts_maxage != $result['hsts'] ||
|
||||||
|
$hsts_sub != $result['hsts_sub'] ||
|
||||||
|
$hsts_preload != $result['hsts_preload'] ||
|
||||||
|
$ocsp_stapling != $result['ocsp_stapling']
|
||||||
|
) {
|
||||||
inserttask('1');
|
inserttask('1');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1782,13 +1863,16 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$update_data['mod_fcgid_starter'] = $mod_fcgid_starter;
|
$update_data['mod_fcgid_starter'] = $mod_fcgid_starter;
|
||||||
$update_data['mod_fcgid_maxrequests'] = $mod_fcgid_maxrequests;
|
$update_data['mod_fcgid_maxrequests'] = $mod_fcgid_maxrequests;
|
||||||
$update_data['specialsettings'] = $specialsettings;
|
$update_data['specialsettings'] = $specialsettings;
|
||||||
|
$update_data['notryfiles'] = $notryfiles;
|
||||||
$update_data['registration_date'] = $registration_date;
|
$update_data['registration_date'] = $registration_date;
|
||||||
$update_data['termination_date'] = $termination_date;
|
$update_data['termination_date'] = $termination_date;
|
||||||
$update_data['ismainbutsubto'] = $issubof;
|
$update_data['ismainbutsubto'] = $issubof;
|
||||||
$update_data['letsencrypt'] = $letsencrypt;
|
$update_data['letsencrypt'] = $letsencrypt;
|
||||||
|
$update_data['http2'] = $http2;
|
||||||
$update_data['hsts'] = $hsts_maxage;
|
$update_data['hsts'] = $hsts_maxage;
|
||||||
$update_data['hsts_sub'] = $hsts_sub;
|
$update_data['hsts_sub'] = $hsts_sub;
|
||||||
$update_data['hsts_preload'] = $hsts_preload;
|
$update_data['hsts_preload'] = $hsts_preload;
|
||||||
|
$update_data['ocsp_stapling'] = $ocsp_stapling;
|
||||||
$update_data['id'] = $id;
|
$update_data['id'] = $id;
|
||||||
|
|
||||||
$update_stmt = Database::prepare("
|
$update_stmt = Database::prepare("
|
||||||
@@ -1814,13 +1898,16 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
`mod_fcgid_starter` = :mod_fcgid_starter,
|
`mod_fcgid_starter` = :mod_fcgid_starter,
|
||||||
`mod_fcgid_maxrequests` = :mod_fcgid_maxrequests,
|
`mod_fcgid_maxrequests` = :mod_fcgid_maxrequests,
|
||||||
`specialsettings` = :specialsettings,
|
`specialsettings` = :specialsettings,
|
||||||
|
`notryfiles` = :notryfiles,
|
||||||
`registration_date` = :registration_date,
|
`registration_date` = :registration_date,
|
||||||
`termination_date` = :termination_date,
|
`termination_date` = :termination_date,
|
||||||
`ismainbutsubto` = :ismainbutsubto,
|
`ismainbutsubto` = :ismainbutsubto,
|
||||||
`letsencrypt` = :letsencrypt,
|
`letsencrypt` = :letsencrypt,
|
||||||
|
`http2` = :http2,
|
||||||
`hsts` = :hsts,
|
`hsts` = :hsts,
|
||||||
`hsts_sub` = :hsts_sub,
|
`hsts_sub` = :hsts_sub,
|
||||||
`hsts_preload` = :hsts_preload
|
`hsts_preload` = :hsts_preload,
|
||||||
|
`ocsp_stapling` = :ocsp_stapling
|
||||||
WHERE `id` = :id
|
WHERE `id` = :id
|
||||||
");
|
");
|
||||||
Database::pexecute($update_stmt, $update_data);
|
Database::pexecute($update_stmt, $update_data);
|
||||||
@@ -1829,11 +1916,18 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$_update_data['adminid'] = $adminid;
|
$_update_data['adminid'] = $adminid;
|
||||||
$_update_data['phpenabled'] = $phpenabled;
|
$_update_data['phpenabled'] = $phpenabled;
|
||||||
$_update_data['openbasedir'] = $openbasedir;
|
$_update_data['openbasedir'] = $openbasedir;
|
||||||
$_update_data['phpsettingid'] = $phpsettingid;
|
|
||||||
$_update_data['mod_fcgid_starter'] = $mod_fcgid_starter;
|
$_update_data['mod_fcgid_starter'] = $mod_fcgid_starter;
|
||||||
$_update_data['mod_fcgid_maxrequests'] = $mod_fcgid_maxrequests;
|
$_update_data['mod_fcgid_maxrequests'] = $mod_fcgid_maxrequests;
|
||||||
$_update_data['parentdomainid'] = $id;
|
$_update_data['parentdomainid'] = $id;
|
||||||
|
|
||||||
|
// if php config is to be set for all subdomains, check here
|
||||||
|
$update_phpconfig = '';
|
||||||
|
$phpfs = isset($_POST['phpsettingsforsubdomains']) ? 1 : 0;
|
||||||
|
if ($phpfs == 1) {
|
||||||
|
$_update_data['phpsettingid'] = $phpsettingid;
|
||||||
|
$update_phpconfig = ", `phpsettingid` = :phpsettingid";
|
||||||
|
}
|
||||||
|
|
||||||
// if we have no more ssl-ip's for this domain,
|
// if we have no more ssl-ip's for this domain,
|
||||||
// all its subdomains must have "ssl-redirect = 0"
|
// all its subdomains must have "ssl-redirect = 0"
|
||||||
// and disable let's encrypt
|
// and disable let's encrypt
|
||||||
@@ -1848,10 +1942,9 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
`adminid` = :adminid,
|
`adminid` = :adminid,
|
||||||
`phpenabled` = :phpenabled,
|
`phpenabled` = :phpenabled,
|
||||||
`openbasedir` = :openbasedir,
|
`openbasedir` = :openbasedir,
|
||||||
`phpsettingid` = :phpsettingid,
|
|
||||||
`mod_fcgid_starter` = :mod_fcgid_starter,
|
`mod_fcgid_starter` = :mod_fcgid_starter,
|
||||||
`mod_fcgid_maxrequests` = :mod_fcgid_maxrequests
|
`mod_fcgid_maxrequests` = :mod_fcgid_maxrequests
|
||||||
" . $upd_specialsettings . $updatechildren . $update_sslredirect . "
|
" . $update_phpconfig . $upd_specialsettings . $updatechildren . $update_sslredirect . "
|
||||||
WHERE `parentdomainid` = :parentdomainid
|
WHERE `parentdomainid` = :parentdomainid
|
||||||
");
|
");
|
||||||
Database::pexecute($_update_stmt, $_update_data);
|
Database::pexecute($_update_stmt, $_update_data);
|
||||||
@@ -1934,7 +2027,15 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
} else
|
} else
|
||||||
if ($result['wwwserveralias'] != $wwwserveralias || $result['letsencrypt'] != $letsencrypt) {
|
if ($result['wwwserveralias'] != $wwwserveralias || $result['letsencrypt'] != $letsencrypt) {
|
||||||
// or when wwwserveralias or letsencrypt was changed
|
// or when wwwserveralias or letsencrypt was changed
|
||||||
|
|
||||||
triggerLetsEncryptCSRForAliasDestinationDomain($aliasdomain, $log);
|
triggerLetsEncryptCSRForAliasDestinationDomain($aliasdomain, $log);
|
||||||
|
|
||||||
|
if ($aliasdomain === 0) {
|
||||||
|
// in case the wwwserveralias is set on a main domain, $aliasdomain is 0
|
||||||
|
// --> the call just above to triggerLetsEncryptCSRForAliasDestinationDomain
|
||||||
|
// is a noop...let's repeat it with the domain id of the main domain
|
||||||
|
triggerLetsEncryptCSRForAliasDestinationDomain($id, $log);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "edited domain #" . $id);
|
$log->logAction(ADM_ACTION, LOG_INFO, "edited domain #" . $id);
|
||||||
@@ -2121,10 +2222,25 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
$result['add_date'] = date('Y-m-d', $result['add_date']);
|
$result['add_date'] = date('Y-m-d', $result['add_date']);
|
||||||
|
|
||||||
$phpconfigs = '';
|
$phpconfigs = '';
|
||||||
$phpconfigs_result_stmt = Database::query("SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "`");
|
$phpconfigs_result_stmt = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
");
|
||||||
|
$c_allowed_configs = getCustomerDetail($result['customerid'], 'allowed_phpconfigs');
|
||||||
|
if (!empty($c_allowed_configs)) {
|
||||||
|
$c_allowed_configs = json_decode($c_allowed_configs, true);
|
||||||
|
} else {
|
||||||
|
$c_allowed_configs = array();
|
||||||
|
}
|
||||||
|
|
||||||
while ($phpconfigs_row = $phpconfigs_result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($phpconfigs_row = $phpconfigs_result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
$phpconfigs .= makeoption($phpconfigs_row['description'], $phpconfigs_row['id'], $result['phpsettingid'], true, true);
|
$disabled = !empty($c_allowed_configs) && !in_array($phpconfigs_row['id'], $c_allowed_configs);
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs .= makeoption($phpconfigs_row['description'] . " [".$phpconfigs_row['interpreter']."]", $phpconfigs_row['id'], $result['phpsettingid'], true, true, null, $disabled);
|
||||||
|
} else {
|
||||||
|
$phpconfigs .= makeoption($phpconfigs_row['description'], $phpconfigs_row['id'], $result['phpsettingid'], true, true, null, $disabled);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = htmlentities_array($result);
|
$result = htmlentities_array($result);
|
||||||
@@ -2140,6 +2256,13 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
eval("echo \"" . getTemplate("domains/domains_edit") . "\";");
|
eval("echo \"" . getTemplate("domains/domains_edit") . "\";");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} elseif ($action == 'jqGetCustomerPHPConfigs') {
|
||||||
|
|
||||||
|
$customerid = intval($_POST['customerid']);
|
||||||
|
$allowed_phpconfigs = getCustomerDetail($customerid, 'allowed_phpconfigs');
|
||||||
|
echo !empty($allowed_phpconfigs) ? $allowed_phpconfigs : json_encode(array());
|
||||||
|
exit;
|
||||||
|
|
||||||
} elseif ($action == 'import') {
|
} elseif ($action == 'import') {
|
||||||
|
|
||||||
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
@@ -2164,6 +2287,8 @@ if ($page == 'domains' || $page == 'overview') {
|
|||||||
|
|
||||||
// update customer/admin counters
|
// update customer/admin counters
|
||||||
updateCounters(false);
|
updateCounters(false);
|
||||||
|
inserttask('1');
|
||||||
|
inserttask('4');
|
||||||
|
|
||||||
$result_str = $result['imported'] . ' / ' . $result['all'];
|
$result_str = $result['imported'] . ' / ' . $result['all'];
|
||||||
standard_success('domain_import_successfully', $result_str, array(
|
standard_success('domain_import_successfully', $result_str, array(
|
||||||
|
|||||||
@@ -85,45 +85,42 @@ if ($page == 'overview') {
|
|||||||
if ((isset($_GET['lookfornewversion']) && $_GET['lookfornewversion'] == 'yes')
|
if ((isset($_GET['lookfornewversion']) && $_GET['lookfornewversion'] == 'yes')
|
||||||
|| (isset($lookfornewversion) && $lookfornewversion == 'yes')
|
|| (isset($lookfornewversion) && $lookfornewversion == 'yes')
|
||||||
) {
|
) {
|
||||||
$update_check_uri = 'http://version.froxlor.org/Froxlor/legacy/' . $version;
|
if (function_exists('curl_version')) {
|
||||||
|
$update_check_uri = 'http://version.froxlor.org/Froxlor/legacy/' . $version;
|
||||||
|
$latestversion = HttpClient::urlGet($update_check_uri);
|
||||||
|
$latestversion = explode('|', $latestversion);
|
||||||
|
|
||||||
if (ini_get('allow_url_fopen')) {
|
if (is_array($latestversion)
|
||||||
$latestversion = @file($update_check_uri);
|
&& count($latestversion) >= 1
|
||||||
|
) {
|
||||||
|
$_version = $latestversion[0];
|
||||||
|
$_message = isset($latestversion[1]) ? $latestversion[1] : '';
|
||||||
|
$_link = isset($latestversion[2]) ? $latestversion[2] : htmlspecialchars($filename . '?s=' . urlencode($s) . '&page=' . urlencode($page) . '&lookfornewversion=yes');
|
||||||
|
|
||||||
if (isset($latestversion[0])) {
|
// add the branding so debian guys are not gettings confused
|
||||||
$latestversion = explode('|', $latestversion[0]);
|
// about their version-number
|
||||||
|
$lookfornewversion_lable = $_version.$branding;
|
||||||
|
$lookfornewversion_link = $_link;
|
||||||
|
$lookfornewversion_addinfo = $_message;
|
||||||
|
|
||||||
if (is_array($latestversion)
|
// not numeric -> error-message
|
||||||
&& count($latestversion) >= 1
|
if (!preg_match('/^((\d+\\.)(\d+\\.)(\d+\\.)?(\d+)?(\-(svn|dev|rc)(\d+))?)$/', $_version)) {
|
||||||
) {
|
// check for customized version to not output
|
||||||
$_version = $latestversion[0];
|
// "There is a newer version of froxlor" besides the error-message
|
||||||
$_message = isset($latestversion[1]) ? $latestversion[1] : '';
|
$isnewerversion = 2;
|
||||||
$_link = isset($latestversion[2]) ? $latestversion[2] : htmlspecialchars($filename . '?s=' . urlencode($s) . '&page=' . urlencode($page) . '&lookfornewversion=yes');
|
} elseif (version_compare2($version, $_version) == -1) {
|
||||||
|
$isnewerversion = 1;
|
||||||
// add the branding so debian guys are not gettings confused
|
|
||||||
// about their version-number
|
|
||||||
$lookfornewversion_lable = $_version.$branding;
|
|
||||||
$lookfornewversion_link = $_link;
|
|
||||||
$lookfornewversion_addinfo = $_message;
|
|
||||||
|
|
||||||
// not numeric -> error-message
|
|
||||||
if (!preg_match('/^((\d+\\.)(\d+\\.)(\d+\\.)?(\d+)?(\-(svn|dev|rc)(\d+))?)$/', $_version)) {
|
|
||||||
// check for customized version to not output
|
|
||||||
// "There is a newer version of froxlor" besides the error-message
|
|
||||||
$isnewerversion = 2;
|
|
||||||
} elseif (version_compare2($version, $_version) == -1) {
|
|
||||||
$isnewerversion = 1;
|
|
||||||
} else {
|
|
||||||
$isnewerversion = 0;
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
redirectTo($update_check_uri.'/pretty', NULL, false);
|
$isnewerversion = 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
redirectTo($update_check_uri.'/pretty', NULL, false);
|
redirectTo($update_check_uri.'/pretty', NULL, false);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
redirectTo($update_check_uri.'/pretty', NULL, false);
|
$lookfornewversion_lable = "Version-check not available due to missing php-curl extension";
|
||||||
|
$lookfornewversion_link = htmlspecialchars($filename . '?s=' . urlencode($s) . '&page=' . urlencode($page) . '&lookfornewversion=yes');
|
||||||
|
$lookfornewversion_addinfo = '';
|
||||||
|
$isnewerversion = 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$lookfornewversion_lable = $lng['admin']['lookfornewversion']['clickhere'];
|
$lookfornewversion_lable = $lng['admin']['lookfornewversion']['clickhere'];
|
||||||
@@ -280,7 +277,7 @@ if ($page == 'overview') {
|
|||||||
$default_lang = $userinfo['def_language'];
|
$default_lang = $userinfo['def_language'];
|
||||||
}
|
}
|
||||||
|
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options.= makeoption($language_name, $language_file, $default_lang, true);
|
$language_options.= makeoption($language_name, $language_file, $default_lang, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -30,11 +30,11 @@ if ($page == 'log'
|
|||||||
'user' => $lng['logger']['user'],
|
'user' => $lng['logger']['user'],
|
||||||
'text' => $lng['logger']['action']
|
'text' => $lng['logger']['action']
|
||||||
);
|
);
|
||||||
$paging = new paging($userinfo, TABLE_PANEL_LOG, $fields, null, null, 0, 'desc');
|
$paging = new paging($userinfo, TABLE_PANEL_LOG, $fields, null, null, 0, 'desc', 30);
|
||||||
$result_stmt = Database::query('
|
$query = 'SELECT * FROM `' . TABLE_PANEL_LOG . '` ' . $paging->getSqlWhere(false) . ' ' . $paging->getSqlOrderBy();
|
||||||
SELECT * FROM `' . TABLE_PANEL_LOG . '` ' . $paging->getSqlWhere(false) . ' ' . $paging->getSqlOrderBy() . ' ' . $paging->getSqlLimit()
|
$result_stmt = Database::query($query . ' ' . $paging->getSqlLimit());
|
||||||
);
|
$result_cnt_stmt = Database::query($query);
|
||||||
$logs_count = Database::num_rows();
|
$logs_count = $result_cnt_stmt->rowCount();
|
||||||
$paging->setEntries($logs_count);
|
$paging->setEntries($logs_count);
|
||||||
$sortcode = $paging->getHtmlSortCode($lng);
|
$sortcode = $paging->getHtmlSortCode($lng);
|
||||||
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
||||||
@@ -67,7 +67,7 @@ if ($page == 'log'
|
|||||||
foreach ($clog as $action => $logrows) {
|
foreach ($clog as $action => $logrows) {
|
||||||
$_action = 0;
|
$_action = 0;
|
||||||
foreach ($logrows as $row) {
|
foreach ($logrows as $row) {
|
||||||
if ($paging->checkDisplay($i)) {
|
// if ($paging->checkDisplay($i)) {
|
||||||
$row = htmlentities_array($row);
|
$row = htmlentities_array($row);
|
||||||
$row['date'] = date("d.m.y H:i:s", $row['date']);
|
$row['date'] = date("d.m.y H:i:s", $row['date']);
|
||||||
|
|
||||||
@@ -105,7 +105,7 @@ if ($page == 'log'
|
|||||||
eval("\$log.=\"" . getTemplate('logger/logger_log') . "\";");
|
eval("\$log.=\"" . getTemplate('logger/logger_log') . "\";");
|
||||||
$count++;
|
$count++;
|
||||||
$_action = $action;
|
$_action = $action;
|
||||||
}
|
// }
|
||||||
$i++;
|
$i++;
|
||||||
}
|
}
|
||||||
$i++;
|
$i++;
|
||||||
|
|||||||
@@ -16,7 +16,6 @@
|
|||||||
* @package Panel
|
* @package Panel
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'admin');
|
define('AREA', 'admin');
|
||||||
require './lib/init.php';
|
require './lib/init.php';
|
||||||
|
|
||||||
@@ -27,104 +26,134 @@ if (isset($_POST['id'])) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($page == 'overview') {
|
if ($page == 'overview') {
|
||||||
|
|
||||||
if ($action == '') {
|
if ($action == '') {
|
||||||
|
|
||||||
$tablecontent = '';
|
$tablecontent = '';
|
||||||
$count = 0;
|
$count = 0;
|
||||||
$result = Database::query("SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "`");
|
$result = Database::query("
|
||||||
|
SELECT c.*, fd.description as fpmdesc
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fd ON fd.id = c.fpmsettingid
|
||||||
|
ORDER BY c.description ASC
|
||||||
|
");
|
||||||
|
|
||||||
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
$domainresult = false;
|
$domainresult = false;
|
||||||
$query_params = array('id' => $row['id']);
|
$query_params = array(
|
||||||
|
'id' => $row['id']
|
||||||
$query = "SELECT * FROM `".TABLE_PANEL_DOMAINS."`
|
);
|
||||||
|
|
||||||
|
$query = "SELECT * FROM `" . TABLE_PANEL_DOMAINS . "`
|
||||||
WHERE `phpsettingid` = :id
|
WHERE `phpsettingid` = :id
|
||||||
AND `parentdomainid` = '0'";
|
AND `parentdomainid` = '0'";
|
||||||
|
|
||||||
if ((int)$userinfo['domains_see_all'] == 0) {
|
if ((int) $userinfo['domains_see_all'] == 0) {
|
||||||
$query .= " AND `adminid` = :adminid";
|
$query .= " AND `adminid` = :adminid";
|
||||||
$query_params['adminid'] = $userinfo['adminid'];
|
$query_params['adminid'] = $userinfo['adminid'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((int)Settings::Get('panel.phpconfigs_hidestdsubdomain') == 1) {
|
if ((int) Settings::Get('panel.phpconfigs_hidestdsubdomain') == 1) {
|
||||||
$ssdids_res = Database::query("
|
$ssdids_res = Database::query("
|
||||||
SELECT DISTINCT `standardsubdomain` FROM `".TABLE_PANEL_CUSTOMERS."`
|
SELECT DISTINCT `standardsubdomain` FROM `" . TABLE_PANEL_CUSTOMERS . "`
|
||||||
WHERE `standardsubdomain` > 0 ORDER BY `standardsubdomain` ASC;"
|
WHERE `standardsubdomain` > 0 ORDER BY `standardsubdomain` ASC;");
|
||||||
);
|
|
||||||
$ssdids = array();
|
$ssdids = array();
|
||||||
while ($ssd = $ssdids_res->fetch(PDO::FETCH_ASSOC)) {
|
while ($ssd = $ssdids_res->fetch(PDO::FETCH_ASSOC)) {
|
||||||
$ssdids[] = $ssd['standardsubdomain'];
|
$ssdids[] = $ssd['standardsubdomain'];
|
||||||
}
|
}
|
||||||
if (count($ssdids) > 0) {
|
if (count($ssdids) > 0) {
|
||||||
$query .= " AND `id` NOT IN (".implode(', ', $ssdids).")";
|
$query .= " AND `id` NOT IN (" . implode(', ', $ssdids) . ")";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$domainresult_stmt = Database::prepare($query);
|
$domainresult_stmt = Database::prepare($query);
|
||||||
Database::pexecute($domainresult_stmt, $query_params);
|
Database::pexecute($domainresult_stmt, $query_params);
|
||||||
|
|
||||||
$domains = '';
|
$domains = '';
|
||||||
if (Database::num_rows() > 0) {
|
if (Database::num_rows() > 0) {
|
||||||
while ($row2 = $domainresult_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($row2 = $domainresult_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
$domains.= $row2['domain'] . '<br/>';
|
$domains .= $row2['domain'] . '<br/>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// check whether we use that config as froxor-vhost config
|
// check whether we use that config as froxor-vhost config
|
||||||
if (Settings::Get('system.mod_fcgid_defaultini_ownvhost') == $row['id']
|
if (Settings::Get('system.mod_fcgid_defaultini_ownvhost') == $row['id'] || Settings::Get('phpfpm.vhost_defaultini') == $row['id']) {
|
||||||
|| Settings::Get('phpfpm.vhost_defaultini') == $row['id']
|
|
||||||
) {
|
|
||||||
$domains .= Settings::Get('system.hostname');
|
$domains .= Settings::Get('system.hostname');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($domains == '') {
|
if ($domains == '') {
|
||||||
$domains = $lng['admin']['phpsettings']['notused'];
|
$domains = $lng['admin']['phpsettings']['notused'];
|
||||||
}
|
}
|
||||||
|
|
||||||
// check whether this is our default config
|
// check whether this is our default config
|
||||||
if ((Settings::Get('system.mod_fcgid') == '1'
|
if ((Settings::Get('system.mod_fcgid') == '1' && Settings::Get('system.mod_fcgid_defaultini') == $row['id']) || (Settings::Get('phpfpm.enabled') == '1' && Settings::Get('phpfpm.defaultini') == $row['id'])) {
|
||||||
&& Settings::Get('system.mod_fcgid_defaultini') == $row['id'])
|
$row['description'] = '<b>' . $row['description'] . '</b>';
|
||||||
|| (Settings::Get('phpfpm.enabled') == '1'
|
|
||||||
&& Settings::Get('phpfpm.defaultini') == $row['id'])
|
|
||||||
) {
|
|
||||||
$row['description'] = '<b>'.$row['description'].'</b>';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$count ++;
|
$count ++;
|
||||||
eval("\$tablecontent.=\"" . getTemplate("phpconfig/overview_overview") . "\";");
|
eval("\$tablecontent.=\"" . getTemplate("phpconfig/overview_overview") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting overview has been viewed by '" . $userinfo['loginname'] . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting overview has been viewed by '" . $userinfo['loginname'] . "'");
|
||||||
eval("echo \"" . getTemplate("phpconfig/overview") . "\";");
|
eval("echo \"" . getTemplate("phpconfig/overview") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'add') {
|
if ($action == 'add') {
|
||||||
|
|
||||||
if ((int)$userinfo['change_serversettings'] == 1) {
|
if ((int) $userinfo['change_serversettings'] == 1) {
|
||||||
|
|
||||||
if (isset($_POST['send'])
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
&& $_POST['send'] == 'send'
|
|
||||||
) {
|
|
||||||
$description = validate($_POST['description'], 'description');
|
$description = validate($_POST['description'], 'description');
|
||||||
$phpsettings = validate(str_replace("\r\n", "\n", $_POST['phpsettings']), 'phpsettings', '/^[^\0]*$/');
|
$phpsettings = validate(str_replace("\r\n", "\n", $_POST['phpsettings']), 'phpsettings', '/^[^\0]*$/');
|
||||||
|
|
||||||
if (Settings::Get('system.mod_fcgid') == 1) {
|
if (Settings::Get('system.mod_fcgid') == 1) {
|
||||||
$binary = makeCorrectFile(validate($_POST['binary'], 'binary'));
|
$binary = makeCorrectFile(validate($_POST['binary'], 'binary'));
|
||||||
$file_extensions = validate($_POST['file_extensions'], 'file_extensions', '/^[a-zA-Z0-9\s]*$/');
|
$file_extensions = validate($_POST['file_extensions'], 'file_extensions', '/^[a-zA-Z0-9\s]*$/');
|
||||||
$mod_fcgid_starter = validate($_POST['mod_fcgid_starter'], 'mod_fcgid_starter', '/^[0-9]*$/', '', array('-1', ''));
|
$mod_fcgid_starter = validate($_POST['mod_fcgid_starter'], 'mod_fcgid_starter', '/^[0-9]*$/', '', array(
|
||||||
$mod_fcgid_maxrequests = validate($_POST['mod_fcgid_maxrequests'], 'mod_fcgid_maxrequests', '/^[0-9]*$/', '', array('-1', ''));
|
'-1',
|
||||||
|
''
|
||||||
|
));
|
||||||
|
$mod_fcgid_maxrequests = validate($_POST['mod_fcgid_maxrequests'], 'mod_fcgid_maxrequests', '/^[0-9]*$/', '', array(
|
||||||
|
'-1',
|
||||||
|
''
|
||||||
|
));
|
||||||
$mod_fcgid_umask = validate($_POST['mod_fcgid_umask'], 'mod_fcgid_umask', '/^[0-9]*$/');
|
$mod_fcgid_umask = validate($_POST['mod_fcgid_umask'], 'mod_fcgid_umask', '/^[0-9]*$/');
|
||||||
// disable fpm stuff
|
// disable fpm stuff
|
||||||
|
$fpm_config_id = 1;
|
||||||
$fpm_enableslowlog = 0;
|
$fpm_enableslowlog = 0;
|
||||||
$fpm_reqtermtimeout = 0;
|
$fpm_reqtermtimeout = 0;
|
||||||
$fpm_reqslowtimeout = 0;
|
$fpm_reqslowtimeout = 0;
|
||||||
}
|
$fpm_pass_authorizationheader = 0;
|
||||||
elseif (Settings::Get('phpfpm.enabled') == 1) {
|
$override_fpmconfig = 0;
|
||||||
$fpm_enableslowlog = isset($_POST['phpfpm_enable_slowlog']) ? (int)$_POST['phpfpm_enable_slowlog'] : 0;
|
$stmt = Database::prepare("SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id");
|
||||||
|
$def_fpmconfig = Database::pexecute_first($stmt, array(
|
||||||
|
'id' => $fpm_config_id
|
||||||
|
));
|
||||||
|
$pm = $def_fpmconfig['pm'];
|
||||||
|
$max_children = $def_fpmconfig['max_children'];
|
||||||
|
$start_servers = $def_fpmconfig['start_servers'];
|
||||||
|
$min_spare_servers = $def_fpmconfig['min_spare_servers'];
|
||||||
|
$max_spare_servers = $def_fpmconfig['max_spare_servers'];
|
||||||
|
$max_requests = $def_fpmconfig['max_requests'];
|
||||||
|
$idle_timeout = $def_fpmconfig['idle_timeout'];
|
||||||
|
$limit_extensions = $def_fpmconfig['limit_extensions'];
|
||||||
|
|
||||||
|
} elseif (Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$fpm_config_id = intval($_POST['fpmconfig']);
|
||||||
|
$fpm_enableslowlog = isset($_POST['phpfpm_enable_slowlog']) ? (int) $_POST['phpfpm_enable_slowlog'] : 0;
|
||||||
$fpm_reqtermtimeout = validate($_POST['phpfpm_reqtermtimeout'], 'phpfpm_reqtermtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
$fpm_reqtermtimeout = validate($_POST['phpfpm_reqtermtimeout'], 'phpfpm_reqtermtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
||||||
$fpm_reqslowtimeout = validate($_POST['phpfpm_reqslowtimeout'], 'phpfpm_reqslowtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
$fpm_reqslowtimeout = validate($_POST['phpfpm_reqslowtimeout'], 'phpfpm_reqslowtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
||||||
|
$fpm_pass_authorizationheader = isset($_POST['phpfpm_pass_authorizationheader']) ? (int) $_POST['phpfpm_pass_authorizationheader'] : 0;
|
||||||
|
$override_fpmconfig = isset($_POST['override_fpmconfig']) ? (int) $_POST['override_fpmconfig'] : 0;
|
||||||
|
$pm = $_POST['pm'];
|
||||||
|
$max_children = isset($_POST['max_children']) ? (int) $_POST['max_children'] : 0;
|
||||||
|
$start_servers = isset($_POST['start_servers']) ? (int) $_POST['start_servers'] : 0;
|
||||||
|
$min_spare_servers = isset($_POST['min_spare_servers']) ? (int) $_POST['min_spare_servers'] : 0;
|
||||||
|
$max_spare_servers = isset($_POST['max_spare_servers']) ? (int) $_POST['max_spare_servers'] : 0;
|
||||||
|
$max_requests = isset($_POST['max_requests']) ? (int) $_POST['max_requests'] : 0;
|
||||||
|
$idle_timeout = isset($_POST['idle_timeout']) ? (int) $_POST['idle_timeout'] : 0;
|
||||||
|
$limit_extensions = validate($_POST['limit_extensions'], 'limit_extensions', '/^(\.[a-z]([a-z0-9]+)\ ?)+$/');
|
||||||
// disable fcgid stuff
|
// disable fcgid stuff
|
||||||
$binary = '/usr/bin/php-cgi';
|
$binary = '/usr/bin/php-cgi';
|
||||||
$file_extensions = 'php';
|
$file_extensions = 'php';
|
||||||
@@ -132,13 +161,11 @@ if ($page == 'overview') {
|
|||||||
$mod_fcgid_maxrequests = 0;
|
$mod_fcgid_maxrequests = 0;
|
||||||
$mod_fcgid_umask = "022";
|
$mod_fcgid_umask = "022";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strlen($description) == 0
|
if (strlen($description) == 0 || strlen($description) > 50) {
|
||||||
|| strlen($description) > 50
|
|
||||||
) {
|
|
||||||
standard_error('descriptioninvalid');
|
standard_error('descriptioninvalid');
|
||||||
}
|
}
|
||||||
|
|
||||||
$ins_stmt = Database::prepare("
|
$ins_stmt = Database::prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_PHPCONFIGS . "` SET
|
INSERT INTO `" . TABLE_PANEL_PHPCONFIGS . "` SET
|
||||||
`description` = :desc,
|
`description` = :desc,
|
||||||
@@ -150,8 +177,18 @@ if ($page == 'overview') {
|
|||||||
`fpm_slowlog` = :fpmslow,
|
`fpm_slowlog` = :fpmslow,
|
||||||
`fpm_reqterm` = :fpmreqterm,
|
`fpm_reqterm` = :fpmreqterm,
|
||||||
`fpm_reqslow` = :fpmreqslow,
|
`fpm_reqslow` = :fpmreqslow,
|
||||||
`phpsettings` = :phpsettings"
|
`phpsettings` = :phpsettings,
|
||||||
);
|
`fpmsettingid` = :fpmsettingid,
|
||||||
|
`pass_authorizationheader` = :fpmpassauth,
|
||||||
|
`override_fpmconfig` = :ofc,
|
||||||
|
`pm` = :pm,
|
||||||
|
`max_children` = :max_children,
|
||||||
|
`start_servers` = :start_servers,
|
||||||
|
`min_spare_servers` = :min_spare_servers,
|
||||||
|
`max_spare_servers` = :max_spare_servers,
|
||||||
|
`max_requests` = :max_requests,
|
||||||
|
`idle_timeout` = :idle_timeout,
|
||||||
|
`limit_extensions` = :limit_extensions");
|
||||||
$ins_data = array(
|
$ins_data = array(
|
||||||
'desc' => $description,
|
'desc' => $description,
|
||||||
'binary' => $binary,
|
'binary' => $binary,
|
||||||
@@ -162,123 +199,169 @@ if ($page == 'overview') {
|
|||||||
'fpmslow' => $fpm_enableslowlog,
|
'fpmslow' => $fpm_enableslowlog,
|
||||||
'fpmreqterm' => $fpm_reqtermtimeout,
|
'fpmreqterm' => $fpm_reqtermtimeout,
|
||||||
'fpmreqslow' => $fpm_reqslowtimeout,
|
'fpmreqslow' => $fpm_reqslowtimeout,
|
||||||
'phpsettings' => $phpsettings
|
'phpsettings' => $phpsettings,
|
||||||
|
'fpmsettingid' => $fpm_config_id,
|
||||||
|
'fpmpassauth' => $fpm_pass_authorizationheader,
|
||||||
|
'ofc' => $override_fpmconfig,
|
||||||
|
'pm' => $pm,
|
||||||
|
'max_children' => $max_children,
|
||||||
|
'start_servers' => $start_servers,
|
||||||
|
'min_spare_servers' => $min_spare_servers,
|
||||||
|
'max_spare_servers' => $max_spare_servers,
|
||||||
|
'max_requests' => $max_requests,
|
||||||
|
'idle_timeout' => $idle_timeout,
|
||||||
|
'limit_extensions' => $limit_extensions
|
||||||
);
|
);
|
||||||
Database::pexecute($ins_stmt, $ins_data);
|
Database::pexecute($ins_stmt, $ins_data);
|
||||||
|
|
||||||
inserttask('1');
|
inserttask('1');
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting with description '" . $description . "' has been created by '" . $userinfo['loginname'] . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting with description '" . $description . "' has been created by '" . $userinfo['loginname'] . "'");
|
||||||
redirectTo($filename, array('page' => $page, 's' => $s));
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$result_stmt = Database::query("SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = 1");
|
$result_stmt = Database::query("SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = 1");
|
||||||
$result = $result_stmt->fetch(PDO::FETCH_ASSOC);
|
$result = $result_stmt->fetch(PDO::FETCH_ASSOC);
|
||||||
|
|
||||||
$phpconfig_add_data = include_once dirname(__FILE__).'/lib/formfields/admin/phpconfig/formfield.phpconfig_add.php';
|
$fpmconfigs = '';
|
||||||
|
$configs = Database::query("SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` ORDER BY `description` ASC");
|
||||||
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$fpmconfigs .= makeoption($row['description'], $row['id'], 1, true, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
$pm_select = makeoption('static', 'static', 'static', true, true);
|
||||||
|
$pm_select.= makeoption('dynamic', 'dynamic', 'static', true, true);
|
||||||
|
$pm_select.= makeoption('ondemand', 'ondemand', 'static', true, true);
|
||||||
|
|
||||||
|
$phpconfig_add_data = include_once dirname(__FILE__) . '/lib/formfields/admin/phpconfig/formfield.phpconfig_add.php';
|
||||||
$phpconfig_add_form = htmlform::genHTMLForm($phpconfig_add_data);
|
$phpconfig_add_form = htmlform::genHTMLForm($phpconfig_add_data);
|
||||||
|
|
||||||
$title = $phpconfig_add_data['phpconfig_add']['title'];
|
$title = $phpconfig_add_data['phpconfig_add']['title'];
|
||||||
$image = $phpconfig_add_data['phpconfig_add']['image'];
|
$image = $phpconfig_add_data['phpconfig_add']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("phpconfig/overview_add") . "\";");
|
eval("echo \"" . getTemplate("phpconfig/overview_add") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
standard_error('nopermissionsorinvalidid');
|
standard_error('nopermissionsorinvalidid');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'delete') {
|
if ($action == 'delete') {
|
||||||
|
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id"
|
SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id");
|
||||||
);
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
$result = Database::pexecute_first($result_stmt, array('id' => $id));
|
'id' => $id
|
||||||
|
));
|
||||||
if ((Settings::Get('system.mod_fcgid') == '1'
|
|
||||||
&& Settings::Get('system.mod_fcgid_defaultini_ownvhost') == $id)
|
if ((Settings::Get('system.mod_fcgid') == '1' && Settings::Get('system.mod_fcgid_defaultini_ownvhost') == $id) || (Settings::Get('phpfpm.enabled') == '1' && Settings::Get('phpfpm.vhost_defaultini') == $id)) {
|
||||||
|| (Settings::Get('phpfpm.enabled') == '1'
|
|
||||||
&& Settings::Get('phpfpm.vhost_defaultini') == $id)
|
|
||||||
) {
|
|
||||||
standard_error('cannotdeletehostnamephpconfig');
|
standard_error('cannotdeletehostnamephpconfig');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((Settings::Get('system.mod_fcgid') == '1'
|
if ((Settings::Get('system.mod_fcgid') == '1' && Settings::Get('system.mod_fcgid_defaultini') == $id) || (Settings::Get('phpfpm.enabled') == '1' && Settings::Get('phpfpm.defaultini') == $id)) {
|
||||||
&& Settings::Get('system.mod_fcgid_defaultini') == $id)
|
|
||||||
|| (Settings::Get('phpfpm.enabled') == '1'
|
|
||||||
&& Settings::Get('phpfpm.defaultini') == $id)
|
|
||||||
) {
|
|
||||||
standard_error('cannotdeletedefaultphpconfig');
|
standard_error('cannotdeletedefaultphpconfig');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($result['id'] != 0
|
if ($result['id'] != 0 && $result['id'] == $id && (int) $userinfo['change_serversettings'] == 1 && $id != 1) // cannot delete the default php.config
|
||||||
&& $result['id'] == $id
|
{
|
||||||
&& (int)$userinfo['change_serversettings'] == 1
|
|
||||||
&& $id != 1 // cannot delete the default php.config
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
) {
|
|
||||||
|
|
||||||
if (isset($_POST['send'])
|
|
||||||
&& $_POST['send'] == 'send'
|
|
||||||
) {
|
|
||||||
// set php-config to default for all domains using the
|
// set php-config to default for all domains using the
|
||||||
// config that is to be deleted
|
// config that is to be deleted
|
||||||
$upd_stmt = Database::prepare("
|
$upd_stmt = Database::prepare("
|
||||||
UPDATE `" . TABLE_PANEL_DOMAINS . "` SET
|
UPDATE `" . TABLE_PANEL_DOMAINS . "` SET
|
||||||
`phpsettingid` = '1' WHERE `phpsettingid` = :id"
|
`phpsettingid` = '1' WHERE `phpsettingid` = :id");
|
||||||
);
|
Database::pexecute($upd_stmt, array(
|
||||||
Database::pexecute($upd_stmt, array('id' => $id));
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
$del_stmt = Database::prepare("
|
$del_stmt = Database::prepare("
|
||||||
DELETE FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id"
|
DELETE FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id");
|
||||||
);
|
Database::pexecute($del_stmt, array(
|
||||||
Database::pexecute($del_stmt, array('id' => $id));
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
inserttask('1');
|
inserttask('1');
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting with id #" . (int)$id . " has been deleted by '" . $userinfo['loginname'] . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting with id #" . (int) $id . " has been deleted by '" . $userinfo['loginname'] . "'");
|
||||||
redirectTo($filename, array('page' => $page, 's' => $s));
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
} else {
|
} else {
|
||||||
ask_yesno('phpsetting_reallydelete', $filename, array('id' => $id, 'page' => $page, 'action' => $action), $result['description']);
|
ask_yesno('phpsetting_reallydelete', $filename, array(
|
||||||
|
'id' => $id,
|
||||||
|
'page' => $page,
|
||||||
|
'action' => $action
|
||||||
|
), $result['description']);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
standard_error('nopermissionsorinvalidid');
|
standard_error('nopermissionsorinvalidid');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'edit') {
|
if ($action == 'edit') {
|
||||||
|
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id"
|
SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id");
|
||||||
);
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
$result = Database::pexecute_first($result_stmt, array('id' => $id));
|
'id' => $id
|
||||||
|
));
|
||||||
if ($result['id'] != 0
|
|
||||||
&& $result['id'] == $id
|
if ($result['id'] != 0 && $result['id'] == $id && (int) $userinfo['change_serversettings'] == 1) {
|
||||||
&& (int)$userinfo['change_serversettings'] == 1
|
|
||||||
) {
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
|
||||||
if (isset($_POST['send'])
|
|
||||||
&& $_POST['send'] == 'send'
|
|
||||||
) {
|
|
||||||
$description = validate($_POST['description'], 'description');
|
$description = validate($_POST['description'], 'description');
|
||||||
$phpsettings = validate(str_replace("\r\n", "\n", $_POST['phpsettings']), 'phpsettings', '/^[^\0]*$/');
|
$phpsettings = validate(str_replace("\r\n", "\n", $_POST['phpsettings']), 'phpsettings', '/^[^\0]*$/');
|
||||||
|
|
||||||
if (Settings::Get('system.mod_fcgid') == 1) {
|
if (Settings::Get('system.mod_fcgid') == 1) {
|
||||||
$binary = makeCorrectFile(validate($_POST['binary'], 'binary'));
|
$binary = makeCorrectFile(validate($_POST['binary'], 'binary'));
|
||||||
$file_extensions = validate($_POST['file_extensions'], 'file_extensions', '/^[a-zA-Z0-9\s]*$/');
|
$file_extensions = validate($_POST['file_extensions'], 'file_extensions', '/^[a-zA-Z0-9\s]*$/');
|
||||||
$mod_fcgid_starter = validate($_POST['mod_fcgid_starter'], 'mod_fcgid_starter', '/^[0-9]*$/', '', array('-1', ''));
|
$mod_fcgid_starter = validate($_POST['mod_fcgid_starter'], 'mod_fcgid_starter', '/^[0-9]*$/', '', array(
|
||||||
$mod_fcgid_maxrequests = validate($_POST['mod_fcgid_maxrequests'], 'mod_fcgid_maxrequests', '/^[0-9]*$/', '', array('-1', ''));
|
'-1',
|
||||||
|
''
|
||||||
|
));
|
||||||
|
$mod_fcgid_maxrequests = validate($_POST['mod_fcgid_maxrequests'], 'mod_fcgid_maxrequests', '/^[0-9]*$/', '', array(
|
||||||
|
'-1',
|
||||||
|
''
|
||||||
|
));
|
||||||
$mod_fcgid_umask = validate($_POST['mod_fcgid_umask'], 'mod_fcgid_umask', '/^[0-9]*$/');
|
$mod_fcgid_umask = validate($_POST['mod_fcgid_umask'], 'mod_fcgid_umask', '/^[0-9]*$/');
|
||||||
// disable fpm stuff
|
// disable fpm stuff
|
||||||
|
$fpm_config_id = 1;
|
||||||
$fpm_enableslowlog = 0;
|
$fpm_enableslowlog = 0;
|
||||||
$fpm_reqtermtimeout = 0;
|
$fpm_reqtermtimeout = 0;
|
||||||
$fpm_reqslowtimeout = 0;
|
$fpm_reqslowtimeout = 0;
|
||||||
}
|
$fpm_pass_authorizationheader = 0;
|
||||||
elseif (Settings::Get('phpfpm.enabled') == 1) {
|
$override_fpmconfig = 0;
|
||||||
$fpm_enableslowlog = isset($_POST['phpfpm_enable_slowlog']) ? (int)$_POST['phpfpm_enable_slowlog'] : 0;
|
$stmt = Database::prepare("SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id");
|
||||||
|
$def_fpmconfig = Database::pexecute_first($stmt, array(
|
||||||
|
'id' => $fpm_config_id
|
||||||
|
));
|
||||||
|
$pm = $def_fpmconfig['pm'];
|
||||||
|
$max_children = $def_fpmconfig['max_children'];
|
||||||
|
$start_servers = $def_fpmconfig['start_servers'];
|
||||||
|
$min_spare_servers = $def_fpmconfig['min_spare_servers'];
|
||||||
|
$max_spare_servers = $def_fpmconfig['max_spare_servers'];
|
||||||
|
$max_requests = $def_fpmconfig['max_requests'];
|
||||||
|
$idle_timeout = $def_fpmconfig['idle_timeout'];
|
||||||
|
$limit_extensions = $def_fpmconfig['limit_extensions'];
|
||||||
|
|
||||||
|
} elseif (Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$fpm_config_id = intval($_POST['fpmconfig']);
|
||||||
|
$fpm_enableslowlog = isset($_POST['phpfpm_enable_slowlog']) ? (int) $_POST['phpfpm_enable_slowlog'] : 0;
|
||||||
$fpm_reqtermtimeout = validate($_POST['phpfpm_reqtermtimeout'], 'phpfpm_reqtermtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
$fpm_reqtermtimeout = validate($_POST['phpfpm_reqtermtimeout'], 'phpfpm_reqtermtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
||||||
$fpm_reqslowtimeout = validate($_POST['phpfpm_reqslowtimeout'], 'phpfpm_reqslowtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
$fpm_reqslowtimeout = validate($_POST['phpfpm_reqslowtimeout'], 'phpfpm_reqslowtimeout', '/^([0-9]+)(|s|m|h|d)$/');
|
||||||
|
$fpm_pass_authorizationheader = isset($_POST['phpfpm_pass_authorizationheader']) ? (int) $_POST['phpfpm_pass_authorizationheader'] : 0;
|
||||||
|
$override_fpmconfig = isset($_POST['override_fpmconfig']) ? (int) $_POST['override_fpmconfig'] : $result['override_fpmconfig'];
|
||||||
|
$pm = $_POST['pm'];
|
||||||
|
$max_children = isset($_POST['max_children']) ? (int) $_POST['max_children'] : $result['max_children'];
|
||||||
|
$start_servers = isset($_POST['start_servers']) ? (int) $_POST['start_servers'] : $result['start_servers'];
|
||||||
|
$min_spare_servers = isset($_POST['min_spare_servers']) ? (int) $_POST['min_spare_servers'] : $result['min_spare_servers'];
|
||||||
|
$max_spare_servers = isset($_POST['max_spare_servers']) ? (int) $_POST['max_spare_servers'] : $result['max_spare_servers'];
|
||||||
|
$max_requests = isset($_POST['max_requests']) ? (int) $_POST['max_requests'] : $result['max_requests'];
|
||||||
|
$idle_timeout = isset($_POST['idle_timeout']) ? (int) $_POST['idle_timeout'] : $result['idle_timeout'];
|
||||||
|
$limit_extensions = validate($_POST['limit_extensions'], 'limit_extensions', '/^(\.[a-z]([a-z0-9]+)\ ?)+$/');
|
||||||
// disable fcgid stuff
|
// disable fcgid stuff
|
||||||
$binary = '/usr/bin/php-cgi';
|
$binary = '/usr/bin/php-cgi';
|
||||||
$file_extensions = 'php';
|
$file_extensions = 'php';
|
||||||
@@ -286,13 +369,11 @@ if ($page == 'overview') {
|
|||||||
$mod_fcgid_maxrequests = 0;
|
$mod_fcgid_maxrequests = 0;
|
||||||
$mod_fcgid_umask = "022";
|
$mod_fcgid_umask = "022";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strlen($description) == 0
|
if (strlen($description) == 0 || strlen($description) > 50) {
|
||||||
|| strlen($description) > 50
|
|
||||||
) {
|
|
||||||
standard_error('descriptioninvalid');
|
standard_error('descriptioninvalid');
|
||||||
}
|
}
|
||||||
|
|
||||||
$upd_stmt = Database::prepare("
|
$upd_stmt = Database::prepare("
|
||||||
UPDATE `" . TABLE_PANEL_PHPCONFIGS . "` SET
|
UPDATE `" . TABLE_PANEL_PHPCONFIGS . "` SET
|
||||||
`description` = :desc,
|
`description` = :desc,
|
||||||
@@ -304,39 +385,314 @@ if ($page == 'overview') {
|
|||||||
`fpm_slowlog` = :fpmslow,
|
`fpm_slowlog` = :fpmslow,
|
||||||
`fpm_reqterm` = :fpmreqterm,
|
`fpm_reqterm` = :fpmreqterm,
|
||||||
`fpm_reqslow` = :fpmreqslow,
|
`fpm_reqslow` = :fpmreqslow,
|
||||||
`phpsettings` = :phpsettings
|
`phpsettings` = :phpsettings,
|
||||||
WHERE `id` = :id"
|
`fpmsettingid` = :fpmsettingid,
|
||||||
);
|
`pass_authorizationheader` = :fpmpassauth,
|
||||||
|
`override_fpmconfig` = :ofc,
|
||||||
|
`pm` = :pm,
|
||||||
|
`max_children` = :max_children,
|
||||||
|
`start_servers` = :start_servers,
|
||||||
|
`min_spare_servers` = :min_spare_servers,
|
||||||
|
`max_spare_servers` = :max_spare_servers,
|
||||||
|
`max_requests` = :max_requests,
|
||||||
|
`idle_timeout` = :idle_timeout,
|
||||||
|
`limit_extensions` = :limit_extensions
|
||||||
|
WHERE `id` = :id");
|
||||||
$upd_data = array(
|
$upd_data = array(
|
||||||
'desc' => $description,
|
'desc' => $description,
|
||||||
'binary' => $binary,
|
'binary' => $binary,
|
||||||
'fext' => $file_extensions,
|
'fext' => $file_extensions,
|
||||||
'starter' => $mod_fcgid_starter,
|
'starter' => $mod_fcgid_starter,
|
||||||
'mreq' => $mod_fcgid_maxrequests,
|
'mreq' => $mod_fcgid_maxrequests,
|
||||||
'umask' => $mod_fcgid_umask,
|
'umask' => $mod_fcgid_umask,
|
||||||
'fpmslow' => $fpm_enableslowlog,
|
'fpmslow' => $fpm_enableslowlog,
|
||||||
'fpmreqterm' => $fpm_reqtermtimeout,
|
'fpmreqterm' => $fpm_reqtermtimeout,
|
||||||
'fpmreqslow' => $fpm_reqslowtimeout,
|
'fpmreqslow' => $fpm_reqslowtimeout,
|
||||||
'phpsettings' => $phpsettings,
|
'phpsettings' => $phpsettings,
|
||||||
'id' => $id
|
'fpmsettingid' => $fpm_config_id,
|
||||||
|
'fpmpassauth' => $fpm_pass_authorizationheader,
|
||||||
|
'ofc' => $override_fpmconfig,
|
||||||
|
'pm' => $pm,
|
||||||
|
'max_children' => $max_children,
|
||||||
|
'start_servers' => $start_servers,
|
||||||
|
'min_spare_servers' => $min_spare_servers,
|
||||||
|
'max_spare_servers' => $max_spare_servers,
|
||||||
|
'max_requests' => $max_requests,
|
||||||
|
'idle_timeout' => $idle_timeout,
|
||||||
|
'limit_extensions' => $limit_extensions,
|
||||||
|
'id' => $id
|
||||||
);
|
);
|
||||||
Database::pexecute($upd_stmt, $upd_data);
|
Database::pexecute($upd_stmt, $upd_data);
|
||||||
|
|
||||||
inserttask('1');
|
inserttask('1');
|
||||||
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting with description '" . $description . "' has been changed by '" . $userinfo['loginname'] . "'");
|
$log->logAction(ADM_ACTION, LOG_INFO, "php.ini setting with description '" . $description . "' has been changed by '" . $userinfo['loginname'] . "'");
|
||||||
redirectTo($filename, array('page' => $page, 's' => $s));
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$phpconfig_edit_data = include_once dirname(__FILE__).'/lib/formfields/admin/phpconfig/formfield.phpconfig_edit.php';
|
$fpmconfigs = '';
|
||||||
|
$configs = Database::query("SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` ORDER BY `description` ASC");
|
||||||
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$fpmconfigs .= makeoption($row['description'], $row['id'], $result['fpmsettingid'], true, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
$pm_select = makeoption('static', 'static', $result['pm'], true, true);
|
||||||
|
$pm_select.= makeoption('dynamic', 'dynamic', $result['pm'], true, true);
|
||||||
|
$pm_select.= makeoption('ondemand', 'ondemand', $result['pm'], true, true);
|
||||||
|
|
||||||
|
$phpconfig_edit_data = include_once dirname(__FILE__) . '/lib/formfields/admin/phpconfig/formfield.phpconfig_edit.php';
|
||||||
$phpconfig_edit_form = htmlform::genHTMLForm($phpconfig_edit_data);
|
$phpconfig_edit_form = htmlform::genHTMLForm($phpconfig_edit_data);
|
||||||
|
|
||||||
$title = $phpconfig_edit_data['phpconfig_edit']['title'];
|
$title = $phpconfig_edit_data['phpconfig_edit']['title'];
|
||||||
$image = $phpconfig_edit_data['phpconfig_edit']['image'];
|
$image = $phpconfig_edit_data['phpconfig_edit']['image'];
|
||||||
|
|
||||||
eval("echo \"" . getTemplate("phpconfig/overview_edit") . "\";");
|
eval("echo \"" . getTemplate("phpconfig/overview_edit") . "\";");
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
standard_error('nopermissionsorinvalidid');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} elseif ($page == 'fpmdaemons') {
|
||||||
|
|
||||||
|
if ($action == '') {
|
||||||
|
|
||||||
|
$tablecontent = '';
|
||||||
|
$count = 0;
|
||||||
|
$result = Database::query("SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` ORDER BY `description` ASC");
|
||||||
|
|
||||||
|
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
|
$query_params = array(
|
||||||
|
'id' => $row['id']
|
||||||
|
);
|
||||||
|
|
||||||
|
$query = "SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `fpmsettingid` = :id";
|
||||||
|
|
||||||
|
$configresult_stmt = Database::prepare($query);
|
||||||
|
Database::pexecute($configresult_stmt, $query_params);
|
||||||
|
|
||||||
|
$configs = '';
|
||||||
|
if (Database::num_rows() > 0) {
|
||||||
|
while ($row2 = $configresult_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$configs .= $row2['description'] . '<br/>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($configs == '') {
|
||||||
|
$configs = $lng['admin']['phpsettings']['notused'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$count ++;
|
||||||
|
eval("\$tablecontent.=\"" . getTemplate("phpconfig/fpmdaemons_overview") . "\";");
|
||||||
|
}
|
||||||
|
|
||||||
|
$log->logAction(ADM_ACTION, LOG_INFO, "fpm daemons setting overview has been viewed by '" . $userinfo['loginname'] . "'");
|
||||||
|
eval("echo \"" . getTemplate("phpconfig/fpmdaemons") . "\";");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($action == 'add') {
|
||||||
|
|
||||||
|
if ((int) $userinfo['change_serversettings'] == 1) {
|
||||||
|
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
$description = validate($_POST['description'], 'description');
|
||||||
|
$reload_cmd = validate($_POST['reload_cmd'], 'reload_cmd');
|
||||||
|
$config_dir = validate($_POST['config_dir'], 'config_dir');
|
||||||
|
$pm = $_POST['pm'];
|
||||||
|
$max_children = isset($_POST['max_children']) ? (int) $_POST['max_children'] : 0;
|
||||||
|
$start_servers = isset($_POST['start_servers']) ? (int) $_POST['start_servers'] : 0;
|
||||||
|
$min_spare_servers = isset($_POST['min_spare_servers']) ? (int) $_POST['min_spare_servers'] : 0;
|
||||||
|
$max_spare_servers = isset($_POST['max_spare_servers']) ? (int) $_POST['max_spare_servers'] : 0;
|
||||||
|
$max_requests = isset($_POST['max_requests']) ? (int) $_POST['max_requests'] : 0;
|
||||||
|
$idle_timeout = isset($_POST['idle_timeout']) ? (int) $_POST['idle_timeout'] : 0;
|
||||||
|
$limit_extensions = validate($_POST['limit_extensions'], 'limit_extensions', '/^(\.[a-z]([a-z0-9]+)\ ?)+$/');
|
||||||
|
|
||||||
|
if (strlen($description) == 0 || strlen($description) > 50) {
|
||||||
|
standard_error('descriptioninvalid');
|
||||||
|
}
|
||||||
|
|
||||||
|
$ins_stmt = Database::prepare("
|
||||||
|
INSERT INTO `" . TABLE_PANEL_FPMDAEMONS . "` SET
|
||||||
|
`description` = :desc,
|
||||||
|
`reload_cmd` = :reload_cmd,
|
||||||
|
`config_dir` = :config_dir,
|
||||||
|
`pm` = :pm,
|
||||||
|
`max_children` = :max_children,
|
||||||
|
`start_servers` = :start_servers,
|
||||||
|
`min_spare_servers` = :min_spare_servers,
|
||||||
|
`max_spare_servers` = :max_spare_servers,
|
||||||
|
`max_requests` = :max_requests,
|
||||||
|
`idle_timeout` = :idle_timeout,
|
||||||
|
`limit_extensions` = :limit_extensions
|
||||||
|
");
|
||||||
|
$ins_data = array(
|
||||||
|
'desc' => $description,
|
||||||
|
'reload_cmd' => $reload_cmd,
|
||||||
|
'config_dir' => makeCorrectDir($config_dir),
|
||||||
|
'pm' => $pm,
|
||||||
|
'max_children' => $max_children,
|
||||||
|
'start_servers' => $start_servers,
|
||||||
|
'min_spare_servers' => $min_spare_servers,
|
||||||
|
'max_spare_servers' => $max_spare_servers,
|
||||||
|
'max_requests' => $max_requests,
|
||||||
|
'idle_timeout' => $idle_timeout,
|
||||||
|
'limit_extensions' => $limit_extensions
|
||||||
|
);
|
||||||
|
Database::pexecute($ins_stmt, $ins_data);
|
||||||
|
|
||||||
|
inserttask('1');
|
||||||
|
$log->logAction(ADM_ACTION, LOG_INFO, "fpm-daemon setting with description '" . $description . "' has been created by '" . $userinfo['loginname'] . "'");
|
||||||
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$pm_select = makeoption('static', 'static', 'static', true, true);
|
||||||
|
$pm_select.= makeoption('dynamic', 'dynamic', 'static', true, true);
|
||||||
|
$pm_select.= makeoption('ondemand', 'ondemand', 'static', true, true);
|
||||||
|
|
||||||
|
$fpmconfig_add_data = include_once dirname(__FILE__) . '/lib/formfields/admin/phpconfig/formfield.fpmconfig_add.php';
|
||||||
|
$fpmconfig_add_form = htmlform::genHTMLForm($fpmconfig_add_data);
|
||||||
|
|
||||||
|
$title = $fpmconfig_add_data['fpmconfig_add']['title'];
|
||||||
|
$image = $fpmconfig_add_data['fpmconfig_add']['image'];
|
||||||
|
|
||||||
|
eval("echo \"" . getTemplate("phpconfig/fpmconfig_add") . "\";");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
standard_error('nopermissionsorinvalidid');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($action == 'delete') {
|
||||||
|
|
||||||
|
$result_stmt = Database::prepare("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id");
|
||||||
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
if ($id == 1) {
|
||||||
|
standard_error('cannotdeletedefaultphpconfig');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($result['id'] != 0 && $result['id'] == $id && (int) $userinfo['change_serversettings'] == 1 && $id != 1) // cannot delete the default php.config
|
||||||
|
{
|
||||||
|
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
// set default fpm daemon config for all php-config that use this config that is to be deleted
|
||||||
|
$upd_stmt = Database::prepare("
|
||||||
|
UPDATE `" . TABLE_PANEL_PHPCONFIGS . "` SET
|
||||||
|
`fpmsettingid` = '1' WHERE `fpmsettingid` = :id");
|
||||||
|
Database::pexecute($upd_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
$del_stmt = Database::prepare("
|
||||||
|
DELETE FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id");
|
||||||
|
Database::pexecute($del_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
inserttask('1');
|
||||||
|
$log->logAction(ADM_ACTION, LOG_INFO, "fpm-daemon setting with id #" . (int) $id . " has been deleted by '" . $userinfo['loginname'] . "'");
|
||||||
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
ask_yesno('fpmsetting_reallydelete', $filename, array(
|
||||||
|
'id' => $id,
|
||||||
|
'page' => $page,
|
||||||
|
'action' => $action
|
||||||
|
), $result['description']);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
standard_error('nopermissionsorinvalidid');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($action == 'edit') {
|
||||||
|
|
||||||
|
$result_stmt = Database::prepare("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id");
|
||||||
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
if ($result['id'] != 0 && $result['id'] == $id && (int) $userinfo['change_serversettings'] == 1) {
|
||||||
|
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
$description = validate($_POST['description'], 'description');
|
||||||
|
$reload_cmd = validate($_POST['reload_cmd'], 'reload_cmd');
|
||||||
|
$config_dir = validate($_POST['config_dir'], 'config_dir');
|
||||||
|
$pm = $_POST['pm'];
|
||||||
|
$max_children = isset($_POST['max_children']) ? (int) $_POST['max_children'] : $result['max_children'];
|
||||||
|
$start_servers = isset($_POST['start_servers']) ? (int) $_POST['start_servers'] : $result['start_servers'];
|
||||||
|
$min_spare_servers = isset($_POST['min_spare_servers']) ? (int) $_POST['min_spare_servers'] : $result['min_spare_servers'];
|
||||||
|
$max_spare_servers = isset($_POST['max_spare_servers']) ? (int) $_POST['max_spare_servers'] : $result['max_spare_servers'];
|
||||||
|
$max_requests = isset($_POST['max_requests']) ? (int) $_POST['max_requests'] : $result['max_requests'];
|
||||||
|
$idle_timeout = isset($_POST['idle_timeout']) ? (int) $_POST['idle_timeout'] : $result['idle_timeout'];
|
||||||
|
$limit_extensions = validate($_POST['limit_extensions'], 'limit_extensions', '/^(\.[a-z]([a-z0-9]+)\ ?)+$/');
|
||||||
|
|
||||||
|
if (strlen($description) == 0 || strlen($description) > 50) {
|
||||||
|
standard_error('descriptioninvalid');
|
||||||
|
}
|
||||||
|
|
||||||
|
$upd_stmt = Database::prepare("
|
||||||
|
UPDATE `" . TABLE_PANEL_FPMDAEMONS . "` SET
|
||||||
|
`description` = :desc,
|
||||||
|
`reload_cmd` = :reload_cmd,
|
||||||
|
`config_dir` = :config_dir,
|
||||||
|
`pm` = :pm,
|
||||||
|
`max_children` = :max_children,
|
||||||
|
`start_servers` = :start_servers,
|
||||||
|
`min_spare_servers` = :min_spare_servers,
|
||||||
|
`max_spare_servers` = :max_spare_servers,
|
||||||
|
`max_requests` = :max_requests,
|
||||||
|
`idle_timeout` = :idle_timeout,
|
||||||
|
`limit_extensions` = :limit_extensions
|
||||||
|
WHERE `id` = :id
|
||||||
|
");
|
||||||
|
$upd_data = array(
|
||||||
|
'desc' => $description,
|
||||||
|
'reload_cmd' => $reload_cmd,
|
||||||
|
'config_dir' => makeCorrectDir($config_dir),
|
||||||
|
'pm' => $pm,
|
||||||
|
'max_children' => $max_children,
|
||||||
|
'start_servers' => $start_servers,
|
||||||
|
'min_spare_servers' => $min_spare_servers,
|
||||||
|
'max_spare_servers' => $max_spare_servers,
|
||||||
|
'max_requests' => $max_requests,
|
||||||
|
'idle_timeout' => $idle_timeout,
|
||||||
|
'limit_extensions' => $limit_extensions,
|
||||||
|
'id' => $id
|
||||||
|
);
|
||||||
|
Database::pexecute($upd_stmt, $upd_data);
|
||||||
|
|
||||||
|
inserttask('1');
|
||||||
|
$log->logAction(ADM_ACTION, LOG_INFO, "fpm-daemon setting with description '" . $description . "' has been changed by '" . $userinfo['loginname'] . "'");
|
||||||
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$pm_select = makeoption('static', 'static', $result['pm'], true, true);
|
||||||
|
$pm_select.= makeoption('dynamic', 'dynamic', $result['pm'], true, true);
|
||||||
|
$pm_select.= makeoption('ondemand', 'ondemand', $result['pm'], true, true);
|
||||||
|
|
||||||
|
$fpmconfig_edit_data = include_once dirname(__FILE__) . '/lib/formfields/admin/phpconfig/formfield.fpmconfig_edit.php';
|
||||||
|
$fpmconfig_edit_form = htmlform::genHTMLForm($fpmconfig_edit_data);
|
||||||
|
|
||||||
|
$title = $fpmconfig_edit_data['fpmconfig_edit']['title'];
|
||||||
|
$image = $fpmconfig_edit_data['fpmconfig_edit']['image'];
|
||||||
|
|
||||||
|
eval("echo \"" . getTemplate("phpconfig/fpmconfig_edit") . "\";");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
standard_error('nopermissionsorinvalidid');
|
standard_error('nopermissionsorinvalidid');
|
||||||
}
|
}
|
||||||
|
|||||||
522
admin_plans.php
Normal file
522
admin_plans.php
Normal file
@@ -0,0 +1,522 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2010 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> (2010-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Panel
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
define('AREA', 'admin');
|
||||||
|
require './lib/init.php';
|
||||||
|
|
||||||
|
if (isset($_POST['id'])) {
|
||||||
|
$id = intval($_POST['id']);
|
||||||
|
} elseif (isset($_GET['id'])) {
|
||||||
|
$id = intval($_GET['id']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($page == '' || $page == 'overview') {
|
||||||
|
|
||||||
|
if ($action == '') {
|
||||||
|
|
||||||
|
$log->logAction(ADM_ACTION, LOG_NOTICE, "viewed admin_plans");
|
||||||
|
$fields = array(
|
||||||
|
'p.name' => $lng['admin']['plans']['name'],
|
||||||
|
'p.description' => $lng['admin']['plans']['description'],
|
||||||
|
'adminname' => $lng['admin']['admin'],
|
||||||
|
'p.ts' => $lng['admin']['plans']['last_update']
|
||||||
|
);
|
||||||
|
$paging = new paging($userinfo, TABLE_PANEL_PLANS, $fields);
|
||||||
|
$plans = '';
|
||||||
|
$result_stmt = Database::prepare("
|
||||||
|
SELECT p.*, a.loginname as adminname
|
||||||
|
FROM `" . TABLE_PANEL_PLANS . "` p, `" . TABLE_PANEL_ADMINS . "` a
|
||||||
|
WHERE " . ($userinfo['customers_see_all'] ? '' : " `p`.`adminid` = :adminid AND ") . "
|
||||||
|
`p`.`adminid` = `a`.`adminid` " . $paging->getSqlWhere(false) . " " . $paging->getSqlOrderBy() . " " . $paging->getSqlLimit());
|
||||||
|
Database::pexecute($result_stmt, array(
|
||||||
|
'adminid' => $userinfo['adminid']
|
||||||
|
));
|
||||||
|
$paging->setEntries(Database::num_rows());
|
||||||
|
$sortcode = $paging->getHtmlSortCode($lng);
|
||||||
|
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
||||||
|
$searchcode = $paging->getHtmlSearchCode($lng);
|
||||||
|
$pagingcode = $paging->getHtmlPagingCode($filename . '?page=' . $page . '&s=' . $s);
|
||||||
|
$i = 0;
|
||||||
|
$count = 0;
|
||||||
|
|
||||||
|
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
|
if ($paging->checkDisplay($i)) {
|
||||||
|
$row = htmlentities_array($row);
|
||||||
|
$row['ts_format'] = date("d.m.Y H:i", $row['ts']);
|
||||||
|
eval("\$plans.=\"" . getTemplate("plans/plans_plan") . "\";");
|
||||||
|
$count ++;
|
||||||
|
}
|
||||||
|
$i ++;
|
||||||
|
}
|
||||||
|
|
||||||
|
eval("echo \"" . getTemplate("plans/plans") . "\";");
|
||||||
|
} elseif ($action == 'delete' && $id != 0) {
|
||||||
|
|
||||||
|
$result_stmt = Database::prepare("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_PLANS . "` WHERE `id` = :id");
|
||||||
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
if ($result['id'] != 0 && $result['id'] == $id && (int) $userinfo['adminid'] == $result['adminid']) {
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
|
||||||
|
$del_stmt = Database::prepare("
|
||||||
|
DELETE FROM `" . TABLE_PANEL_PLANS . "` WHERE `id` = :id");
|
||||||
|
Database::pexecute($del_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
$log->logAction(ADM_ACTION, LOG_INFO, "Plan '" . $result['name'] . "' has been deleted by '" . $userinfo['loginname'] . "'");
|
||||||
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
ask_yesno('plan_reallydelete', $filename, array(
|
||||||
|
'id' => $id,
|
||||||
|
'page' => $page,
|
||||||
|
'action' => $action
|
||||||
|
), $result['name']);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
standard_error('nopermissionsorinvalidid');
|
||||||
|
}
|
||||||
|
} elseif ($action == 'add') {
|
||||||
|
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
$name = validate($_POST['name'], 'name');
|
||||||
|
$description = validate(str_replace("\r\n", "\n", $_POST['description']), 'description', '/^[^\0]*$/');
|
||||||
|
|
||||||
|
$value_arr = array();
|
||||||
|
|
||||||
|
$value_arr['diskspace'] = intval_ressource($_POST['diskspace']);
|
||||||
|
if (isset($_POST['diskspace_ul'])) {
|
||||||
|
$value_arr['diskspace'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['traffic'] = doubleval_ressource($_POST['traffic']);
|
||||||
|
if (isset($_POST['traffic_ul'])) {
|
||||||
|
$value_arr['traffic'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['subdomains'] = intval_ressource($_POST['subdomains']);
|
||||||
|
if (isset($_POST['subdomains_ul'])) {
|
||||||
|
$value_arr['subdomains'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['emails'] = intval_ressource($_POST['emails']);
|
||||||
|
if (isset($_POST['emails_ul'])) {
|
||||||
|
$value_arr['emails'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_accounts'] = intval_ressource($_POST['email_accounts']);
|
||||||
|
if (isset($_POST['email_accounts_ul'])) {
|
||||||
|
$value_arr['email_accounts'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_forwarders'] = intval_ressource($_POST['email_forwarders']);
|
||||||
|
if (isset($_POST['email_forwarders_ul'])) {
|
||||||
|
$value_arr['email_forwarders'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Settings::Get('system.mail_quota_enabled') == '1') {
|
||||||
|
$value_arr['email_quota'] = validate($_POST['email_quota'], 'email_quota', '/^\d+$/', 'vmailquotawrong', array(
|
||||||
|
'0',
|
||||||
|
''
|
||||||
|
));
|
||||||
|
if (isset($_POST['email_quota_ul'])) {
|
||||||
|
$value_arr['email_quota'] = - 1;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$value_arr['email_quota'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_imap'] = 0;
|
||||||
|
if (isset($_POST['email_imap'])) {
|
||||||
|
$value_arr['email_imap'] = intval_ressource($_POST['email_imap']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_pop3'] = 0;
|
||||||
|
if (isset($_POST['email_pop3'])) {
|
||||||
|
$value_arr['email_pop3'] = intval_ressource($_POST['email_pop3']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['ftps'] = intval_ressource($_POST['ftps']);
|
||||||
|
if (isset($_POST['ftps_ul'])) {
|
||||||
|
$value_arr['ftps'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['tickets'] = (Settings::Get('ticket.enabled') == 1 ? intval_ressource($_POST['tickets']) : 0);
|
||||||
|
if (isset($_POST['tickets_ul']) && Settings::Get('ticket.enabled') == '1') {
|
||||||
|
$value_arr['tickets'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['mysqls'] = intval_ressource($_POST['mysqls']);
|
||||||
|
if (isset($_POST['mysqls_ul'])) {
|
||||||
|
$value_arr['mysqls'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['phpenabled'] = 0;
|
||||||
|
if (isset($_POST['phpenabled'])) {
|
||||||
|
$value_arr['phpenabled'] = intval($_POST['phpenabled']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['allowed_phpconfigs'] = array();
|
||||||
|
if (isset($_POST['allowed_phpconfigs']) && is_array($_POST['allowed_phpconfigs'])) {
|
||||||
|
foreach ($_POST['allowed_phpconfigs'] as $allowed_phpconfig) {
|
||||||
|
$allowed_phpconfig = intval($allowed_phpconfig);
|
||||||
|
$value_arr['allowed_phpconfigs'][] = $allowed_phpconfig;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['perlenabled'] = 0;
|
||||||
|
if (isset($_POST['perlenabled'])) {
|
||||||
|
$value_arr['perlenabled'] = intval($_POST['perlenabled']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['dnsenabled'] = 0;
|
||||||
|
if (isset($_POST['dnsenabled'])) {
|
||||||
|
$value_arr['dnsenabled'] = intval($_POST['dnsenabled']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$ins_stmt = Database::prepare("
|
||||||
|
INSERT INTO `" . TABLE_PANEL_PLANS . "`
|
||||||
|
SET `adminid` = :adminid, `name` = :name, `description` = :desc, `value` = :valuearr, `ts` = UNIX_TIMESTAMP();
|
||||||
|
");
|
||||||
|
$ins_data = array(
|
||||||
|
'adminid' => $userinfo['adminid'],
|
||||||
|
'name' => $name,
|
||||||
|
'desc' => $description,
|
||||||
|
'valuearr' => json_encode($value_arr)
|
||||||
|
);
|
||||||
|
Database::pexecute($ins_stmt, $ins_data);
|
||||||
|
|
||||||
|
$log->logAction(ADM_ACTION, LOG_WARNING, "added plan '" . $name . "'");
|
||||||
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$diskspace_ul = makecheckbox('diskspace_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$traffic_ul = makecheckbox('traffic_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$subdomains_ul = makecheckbox('subdomains_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$emails_ul = makecheckbox('emails_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$email_accounts_ul = makecheckbox('email_accounts_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$email_forwarders_ul = makecheckbox('email_forwarders_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$email_quota_ul = makecheckbox('email_quota_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$ftps_ul = makecheckbox('ftps_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$tickets_ul = makecheckbox('tickets_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
$mysqls_ul = makecheckbox('mysqls_ul', $lng['customer']['unlimited'], '-1', false, '0', true, true);
|
||||||
|
|
||||||
|
$phpconfigs = array();
|
||||||
|
$configs = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
");
|
||||||
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description'] . " [" . $row['interpreter'] . "]<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description'] . "<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// dummy to avoid unknown variables
|
||||||
|
$language_options = null;
|
||||||
|
$gender_options = null;
|
||||||
|
$hosting_plans = null;
|
||||||
|
|
||||||
|
$plans_add_data = include_once dirname(__FILE__) . '/lib/formfields/admin/plans/formfield.plans_add.php';
|
||||||
|
$cust_add_data = include_once dirname(__FILE__) . '/lib/formfields/admin/customer/formfield.customer_add.php';
|
||||||
|
// unset unneeded stuff
|
||||||
|
unset($cust_add_data['customer_add']['sections']['section_a']);
|
||||||
|
unset($cust_add_data['customer_add']['sections']['section_b']);
|
||||||
|
unset($cust_add_data['customer_add']['sections']['section_cpre']);
|
||||||
|
// merge
|
||||||
|
$plans_add_data['plans_add']['sections'] = array_merge($plans_add_data['plans_add']['sections'], $cust_add_data['customer_add']['sections']);
|
||||||
|
$plans_add_form = htmlform::genHTMLForm($plans_add_data);
|
||||||
|
|
||||||
|
$title = $plans_add_data['plans_add']['title'];
|
||||||
|
$image = $plans_add_data['plans_add']['image'];
|
||||||
|
|
||||||
|
eval("echo \"" . getTemplate("plans/plans_add") . "\";");
|
||||||
|
}
|
||||||
|
} elseif ($action == 'edit' && $id != 0) {
|
||||||
|
$result_stmt = Database::prepare("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_PLANS . "` WHERE `id` = :id");
|
||||||
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
|
'id' => $id
|
||||||
|
));
|
||||||
|
|
||||||
|
if ($result['name'] != '') {
|
||||||
|
|
||||||
|
$result['value'] = json_decode($result['value'], true);
|
||||||
|
$result = htmlentities_array($result);
|
||||||
|
|
||||||
|
foreach ($result['value'] as $index => $value) {
|
||||||
|
$result[$index] = $value;
|
||||||
|
}
|
||||||
|
$result['allowed_phpconfigs'] = json_encode($result['allowed_phpconfigs']);
|
||||||
|
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
|
||||||
|
$name = validate($_POST['name'], 'name');
|
||||||
|
$description = validate(str_replace("\r\n", "\n", $_POST['description']), 'description', '/^[^\0]*$/');
|
||||||
|
|
||||||
|
$value_arr = array();
|
||||||
|
|
||||||
|
$value_arr['diskspace'] = intval_ressource($_POST['diskspace']);
|
||||||
|
if (isset($_POST['diskspace_ul'])) {
|
||||||
|
$value_arr['diskspace'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['traffic'] = doubleval_ressource($_POST['traffic']);
|
||||||
|
if (isset($_POST['traffic_ul'])) {
|
||||||
|
$value_arr['traffic'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['subdomains'] = intval_ressource($_POST['subdomains']);
|
||||||
|
if (isset($_POST['subdomains_ul'])) {
|
||||||
|
$value_arr['subdomains'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['emails'] = intval_ressource($_POST['emails']);
|
||||||
|
if (isset($_POST['emails_ul'])) {
|
||||||
|
$value_arr['emails'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_accounts'] = intval_ressource($_POST['email_accounts']);
|
||||||
|
if (isset($_POST['email_accounts_ul'])) {
|
||||||
|
$value_arr['email_accounts'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_forwarders'] = intval_ressource($_POST['email_forwarders']);
|
||||||
|
if (isset($_POST['email_forwarders_ul'])) {
|
||||||
|
$value_arr['email_forwarders'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Settings::Get('system.mail_quota_enabled') == '1') {
|
||||||
|
$value_arr['email_quota'] = validate($_POST['email_quota'], 'email_quota', '/^\d+$/', 'vmailquotawrong', array(
|
||||||
|
'0',
|
||||||
|
''
|
||||||
|
));
|
||||||
|
if (isset($_POST['email_quota_ul'])) {
|
||||||
|
$value_arr['email_quota'] = - 1;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$value_arr['email_quota'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_imap'] = 0;
|
||||||
|
if (isset($_POST['email_imap'])) {
|
||||||
|
$value_arr['email_imap'] = intval_ressource($_POST['email_imap']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['email_pop3'] = 0;
|
||||||
|
if (isset($_POST['email_pop3'])) {
|
||||||
|
$value_arr['email_pop3'] = intval_ressource($_POST['email_pop3']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['ftps'] = intval_ressource($_POST['ftps']);
|
||||||
|
if (isset($_POST['ftps_ul'])) {
|
||||||
|
$value_arr['ftps'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['tickets'] = (Settings::Get('ticket.enabled') == 1 ? intval_ressource($_POST['tickets']) : 0);
|
||||||
|
if (isset($_POST['tickets_ul']) && Settings::Get('ticket.enabled') == '1') {
|
||||||
|
$value_arr['tickets'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['mysqls'] = intval_ressource($_POST['mysqls']);
|
||||||
|
if (isset($_POST['mysqls_ul'])) {
|
||||||
|
$value_arr['mysqls'] = - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['phpenabled'] = 0;
|
||||||
|
if (isset($_POST['phpenabled'])) {
|
||||||
|
$value_arr['phpenabled'] = intval($_POST['phpenabled']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['allowed_phpconfigs'] = array();
|
||||||
|
if (isset($_POST['allowed_phpconfigs']) && is_array($_POST['allowed_phpconfigs'])) {
|
||||||
|
foreach ($_POST['allowed_phpconfigs'] as $allowed_phpconfig) {
|
||||||
|
$allowed_phpconfig = intval($allowed_phpconfig);
|
||||||
|
$value_arr['allowed_phpconfigs'][] = $allowed_phpconfig;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['perlenabled'] = 0;
|
||||||
|
if (isset($_POST['perlenabled'])) {
|
||||||
|
$value_arr['perlenabled'] = intval($_POST['perlenabled']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$value_arr['dnsenabled'] = 0;
|
||||||
|
if (isset($_POST['dnsenabled'])) {
|
||||||
|
$value_arr['dnsenabled'] = intval($_POST['dnsenabled']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$ins_stmt = Database::prepare("
|
||||||
|
UPDATE `" . TABLE_PANEL_PLANS . "`
|
||||||
|
SET `name` = :name, `description` = :desc, `value` = :valuearr, `ts` = UNIX_TIMESTAMP()
|
||||||
|
WHERE `id` = :id
|
||||||
|
");
|
||||||
|
$ins_data = array(
|
||||||
|
'name' => $name,
|
||||||
|
'desc' => $description,
|
||||||
|
'valuearr' => json_encode($value_arr),
|
||||||
|
'id' => $id
|
||||||
|
);
|
||||||
|
Database::pexecute($ins_stmt, $ins_data);
|
||||||
|
|
||||||
|
$log->logAction(ADM_ACTION, LOG_WARNING, "updated plan '" . $name . "'");
|
||||||
|
redirectTo($filename, array(
|
||||||
|
'page' => $page,
|
||||||
|
's' => $s
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$diskspace_ul = makecheckbox('diskspace_ul', $lng['customer']['unlimited'], '-1', false, $result['diskspace'], true, true);
|
||||||
|
if ($result['diskspace'] == '-1') {
|
||||||
|
$result['diskspace'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$traffic_ul = makecheckbox('traffic_ul', $lng['customer']['unlimited'], '-1', false, $result['traffic'], true, true);
|
||||||
|
if ($result['traffic'] == '-1') {
|
||||||
|
$result['traffic'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$subdomains_ul = makecheckbox('subdomains_ul', $lng['customer']['unlimited'], '-1', false, $result['subdomains'], true, true);
|
||||||
|
if ($result['subdomains'] == '-1') {
|
||||||
|
$result['subdomains'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$emails_ul = makecheckbox('emails_ul', $lng['customer']['unlimited'], '-1', false, $result['emails'], true, true);
|
||||||
|
if ($result['emails'] == '-1') {
|
||||||
|
$result['emails'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$email_accounts_ul = makecheckbox('email_accounts_ul', $lng['customer']['unlimited'], '-1', false, $result['email_accounts'], true, true);
|
||||||
|
if ($result['email_accounts'] == '-1') {
|
||||||
|
$result['email_accounts'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$email_forwarders_ul = makecheckbox('email_forwarders_ul', $lng['customer']['unlimited'], '-1', false, $result['email_forwarders'], true, true);
|
||||||
|
if ($result['email_forwarders'] == '-1') {
|
||||||
|
$result['email_forwarders'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$email_quota_ul = makecheckbox('email_quota_ul', $lng['customer']['unlimited'], '-1', false, $result['email_quota'], true, true);
|
||||||
|
if ($result['email_quota'] == '-1') {
|
||||||
|
$result['email_quota'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$ftps_ul = makecheckbox('ftps_ul', $lng['customer']['unlimited'], '-1', false, $result['ftps'], true, true);
|
||||||
|
if ($result['ftps'] == '-1') {
|
||||||
|
$result['ftps'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$tickets_ul = makecheckbox('tickets_ul', $lng['customer']['unlimited'], '-1', false, $result['tickets'], true, true);
|
||||||
|
if ($result['tickets'] == '-1') {
|
||||||
|
$result['tickets'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$mysqls_ul = makecheckbox('mysqls_ul', $lng['customer']['unlimited'], '-1', false, $result['mysqls'], true, true);
|
||||||
|
if ($result['mysqls'] == '-1') {
|
||||||
|
$result['mysqls'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$phpconfigs = array();
|
||||||
|
$configs = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
");
|
||||||
|
while ($row = $configs->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description'] . " [" . $row['interpreter'] . "]<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$phpconfigs[] = array(
|
||||||
|
'label' => $row['description'] . "<br />",
|
||||||
|
'value' => $row['id']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$result['imap'] = $result['email_imap'];
|
||||||
|
$result['pop3'] = $result['email_pop3'];
|
||||||
|
|
||||||
|
// dummy to avoid unknown variables
|
||||||
|
$result['loginname'] = null;
|
||||||
|
$result['documentroot'] = null;
|
||||||
|
$result['standardsubdomain'] = null;
|
||||||
|
$result['deactivated'] = null;
|
||||||
|
$language_options = null;
|
||||||
|
$result['firstname'] = null;
|
||||||
|
$gender_options = null;
|
||||||
|
$result['company'] = null;
|
||||||
|
$result['street'] = null;
|
||||||
|
$result['zipcode'] = null;
|
||||||
|
$result['city'] = null;
|
||||||
|
$result['phone'] = null;
|
||||||
|
$result['fax'] = null;
|
||||||
|
$result['email'] = null;
|
||||||
|
$result['customernumber'] = null;
|
||||||
|
$result['custom_notes'] = null;
|
||||||
|
$result['custom_notes_show'] = null;
|
||||||
|
$hosting_plans = null;
|
||||||
|
$admin_select_cnt = null;
|
||||||
|
$admin_select = null;
|
||||||
|
|
||||||
|
$plans_edit_data = include_once dirname(__FILE__) . '/lib/formfields/admin/plans/formfield.plans_edit.php';
|
||||||
|
$cust_edit_data = include_once dirname(__FILE__) . '/lib/formfields/admin/customer/formfield.customer_edit.php';
|
||||||
|
// unset unneeded stuff
|
||||||
|
unset($cust_edit_data['customer_edit']['sections']['section_a']);
|
||||||
|
unset($cust_edit_data['customer_edit']['sections']['section_b']);
|
||||||
|
unset($cust_edit_data['customer_edit']['sections']['section_cpre']);
|
||||||
|
// merge
|
||||||
|
$plans_edit_data['plans_edit']['sections'] = array_merge($plans_edit_data['plans_edit']['sections'], $cust_edit_data['customer_edit']['sections']);
|
||||||
|
$plans_edit_form = htmlform::genHTMLForm($plans_edit_data);
|
||||||
|
|
||||||
|
$title = $plans_edit_data['plans_edit']['title'];
|
||||||
|
$image = $plans_edit_data['plans_edit']['image'];
|
||||||
|
|
||||||
|
eval("echo \"" . getTemplate("plans/plans_edit") . "\";");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} elseif ($action == 'jqGetPlanValues') {
|
||||||
|
$planid = isset($_POST['planid']) ? (int)$_POST['planid'] : 0;
|
||||||
|
$result_stmt = Database::prepare("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_PLANS . "` WHERE `id` = :id");
|
||||||
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
|
'id' => $planid
|
||||||
|
));
|
||||||
|
echo $result['value'];
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -290,3 +290,113 @@ if ($page == 'overview' && $userinfo['change_serversettings'] == '1') {
|
|||||||
}
|
}
|
||||||
eval("echo \"" . getTemplate("settings/integritycheck") . "\";");
|
eval("echo \"" . getTemplate("settings/integritycheck") . "\";");
|
||||||
}
|
}
|
||||||
|
elseif ($page == 'importexport' && $userinfo['change_serversettings'] == '1')
|
||||||
|
{
|
||||||
|
// check for json-stuff
|
||||||
|
if (! extension_loaded('json')) {
|
||||||
|
standard_error('jsonextensionnotfound');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($_GET['action']) && $_GET['action'] == "export") {
|
||||||
|
// export
|
||||||
|
try {
|
||||||
|
$json_export = SImExporter::export();
|
||||||
|
} catch(Exception $e) {
|
||||||
|
dynamic_error($e->getMessage());
|
||||||
|
}
|
||||||
|
header('Content-disposition: attachment; filename=Froxlor_settings-'.$version.'-'.$dbversion.'_'.date('d.m.Y').'.json');
|
||||||
|
header('Content-type: application/json');
|
||||||
|
echo $json_export;
|
||||||
|
exit;
|
||||||
|
} elseif (isset($_GET['action']) && $_GET['action'] == "import") {
|
||||||
|
// import
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
// get uploaded file
|
||||||
|
if (isset($_FILES["import_file"]["tmp_name"])) {
|
||||||
|
$imp_content = file_get_contents($_FILES["import_file"]["tmp_name"]);
|
||||||
|
try {
|
||||||
|
SImExporter::import($imp_content);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
dynamic_error($e->getMessage());
|
||||||
|
}
|
||||||
|
inserttask('1');
|
||||||
|
inserttask('10');
|
||||||
|
// Using nameserver, insert a task which rebuilds the server config
|
||||||
|
inserttask('4');
|
||||||
|
// cron.d file
|
||||||
|
inserttask('99');
|
||||||
|
standard_success('settingsimported', '', array('filename' => 'admin_settings.php'));
|
||||||
|
}
|
||||||
|
dynamic_error("Upload failed");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
eval("echo \"" . getTemplate("settings/importexport/index") . "\";");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elseif ($page == 'testmail')
|
||||||
|
{
|
||||||
|
if (isset($_POST['send']) && $_POST['send'] == 'send')
|
||||||
|
{
|
||||||
|
$test_addr = isset($_POST['test_addr']) ? $_POST['test_addr'] : null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the mailingsystem
|
||||||
|
*/
|
||||||
|
$testmail = new PHPMailer(true);
|
||||||
|
$testmail->CharSet = "UTF-8";
|
||||||
|
|
||||||
|
if (Settings::Get('system.mail_use_smtp')) {
|
||||||
|
$testmail->isSMTP();
|
||||||
|
$testmail->Host = Settings::Get('system.mail_smtp_host');
|
||||||
|
$testmail->SMTPAuth = Settings::Get('system.mail_smtp_auth') == '1' ? true : false;
|
||||||
|
$testmail->Username = Settings::Get('system.mail_smtp_user');
|
||||||
|
$testmail->Password = Settings::Get('system.mail_smtp_passwd');
|
||||||
|
if (Settings::Get('system.mail_smtp_usetls')) {
|
||||||
|
$testmail->SMTPSecure = 'tls';
|
||||||
|
} else {
|
||||||
|
$testmail->SMTPAutoTLS = false;
|
||||||
|
}
|
||||||
|
$testmail->Port = Settings::Get('system.mail_smtp_port');
|
||||||
|
}
|
||||||
|
|
||||||
|
$_mailerror = false;
|
||||||
|
if (PHPMailer::ValidateAddress(Settings::Get('panel.adminmail')) !== false) {
|
||||||
|
// set return-to address and custom sender-name, see #76
|
||||||
|
$testmail->SetFrom(Settings::Get('panel.adminmail'), Settings::Get('panel.adminmail_defname'));
|
||||||
|
if (Settings::Get('panel.adminmail_return') != '') {
|
||||||
|
$testmail->AddReplyTo(Settings::Get('panel.adminmail_return'), Settings::Get('panel.adminmail_defname'));
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$testmail->Subject = "Froxlor Test-Mail";
|
||||||
|
$mail_body = "Yay, this worked :)";
|
||||||
|
$testmail->AltBody = $mail_body;
|
||||||
|
$testmail->MsgHTML(str_replace("\n", "<br />", $mail_body));
|
||||||
|
$testmail->AddAddress($test_addr);
|
||||||
|
$testmail->Send();
|
||||||
|
} catch(phpmailerException $e) {
|
||||||
|
$mailerr_msg = $e->errorMessage();
|
||||||
|
$_mailerror = true;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
$mailerr_msg = $e->getMessage();
|
||||||
|
$_mailerror = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$_mailerror) {
|
||||||
|
// success
|
||||||
|
$mail->ClearAddresses();
|
||||||
|
standard_success('testmailsent', '', array('filename' => 'admin_settings.php', 'page' => 'testmail'));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// invalid sender e-mail
|
||||||
|
$mailerr_msg = "Invalid sender e-mail address: ".Settings::Get('panel.adminmail');
|
||||||
|
$_mailerror = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail_smtp_user = Settings::Get('system.mail_smtp_user');
|
||||||
|
$mail_smtp_host = Settings::Get('system.mail_smtp_host');
|
||||||
|
$mail_smtp_port = Settings::Get('system.mail_smtp_port');
|
||||||
|
|
||||||
|
eval("echo \"" . getTemplate("settings/testmail") . "\";");
|
||||||
|
}
|
||||||
|
|||||||
@@ -99,7 +99,7 @@ if ($action == '') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$add = false;
|
$add = false;
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
|
|
||||||
$templates_done = array();
|
$templates_done = array();
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
@@ -328,7 +328,7 @@ if ($action == '') {
|
|||||||
$language_options = '';
|
$language_options = '';
|
||||||
$template_options = '';
|
$template_options = '';
|
||||||
|
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$templates = array();
|
$templates = array();
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT `varname` FROM `" . TABLE_PANEL_TEMPLATES . "`
|
SELECT `varname` FROM `" . TABLE_PANEL_TEMPLATES . "`
|
||||||
|
|||||||
@@ -260,7 +260,7 @@ if ($page == 'overview') {
|
|||||||
if ($userinfo['subdomains_used'] < $userinfo['subdomains'] || $userinfo['subdomains'] == '-1') {
|
if ($userinfo['subdomains_used'] < $userinfo['subdomains'] || $userinfo['subdomains'] == '-1') {
|
||||||
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
|
|
||||||
if (strpos($_POST['subdomain'], '--') !== false) {
|
if (substr($_POST['subdomain'], 0, 4) == 'xn--') {
|
||||||
standard_error('domain_nopunycode');
|
standard_error('domain_nopunycode');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -327,6 +327,9 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!preg_match('/^https?\:\/\//', $path) || !validateUrl($path)) {
|
if (!preg_match('/^https?\:\/\//', $path) || !validateUrl($path)) {
|
||||||
|
if (strstr($path, ":") !== FALSE) {
|
||||||
|
standard_error('pathmaynotcontaincolon');
|
||||||
|
}
|
||||||
// If path is empty or '/' and 'Use domain name as default value for DocumentRoot path' is enabled in settings,
|
// If path is empty or '/' and 'Use domain name as default value for DocumentRoot path' is enabled in settings,
|
||||||
// set default path to subdomain or domain name
|
// set default path to subdomain or domain name
|
||||||
if ((($path == '') || ($path == '/')) && Settings::Get('system.documentroot_use_default_value') == 1) {
|
if ((($path == '') || ($path == '/')) && Settings::Get('system.documentroot_use_default_value') == 1) {
|
||||||
@@ -334,9 +337,6 @@ if ($page == 'overview') {
|
|||||||
} else {
|
} else {
|
||||||
$path = makeCorrectDir($userinfo['documentroot'] . '/' . $path);
|
$path = makeCorrectDir($userinfo['documentroot'] . '/' . $path);
|
||||||
}
|
}
|
||||||
if (strstr($path, ":") !== FALSE) {
|
|
||||||
standard_error('pathmaynotcontaincolon');
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
$_doredirect = true;
|
$_doredirect = true;
|
||||||
}
|
}
|
||||||
@@ -405,6 +405,10 @@ if ($page == 'overview') {
|
|||||||
// assign default config
|
// assign default config
|
||||||
$phpsid_result['phpsettingid'] = 1;
|
$phpsid_result['phpsettingid'] = 1;
|
||||||
}
|
}
|
||||||
|
// check whether the customer has chosen its own php-config
|
||||||
|
if (isset($_POST['phpsettingid']) && intval($_POST['phpsettingid']) != $phpsid_result['phpsettingid']) {
|
||||||
|
$phpsid_result['phpsettingid'] = intval($_POST['phpsettingid']);
|
||||||
|
}
|
||||||
|
|
||||||
$stmt = Database::prepare("INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
$stmt = Database::prepare("INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
||||||
`customerid` = :customerid,
|
`customerid` = :customerid,
|
||||||
@@ -415,6 +419,7 @@ if ($page == 'overview') {
|
|||||||
`wwwserveralias` = :wwwserveralias,
|
`wwwserveralias` = :wwwserveralias,
|
||||||
`isemaildomain` = :isemaildomain,
|
`isemaildomain` = :isemaildomain,
|
||||||
`iswildcarddomain` = :iswildcarddomain,
|
`iswildcarddomain` = :iswildcarddomain,
|
||||||
|
`phpenabled` = :phpenabled,
|
||||||
`openbasedir` = :openbasedir,
|
`openbasedir` = :openbasedir,
|
||||||
`openbasedir_path` = :openbasedir_path,
|
`openbasedir_path` = :openbasedir_path,
|
||||||
`speciallogfile` = :speciallogfile,
|
`speciallogfile` = :speciallogfile,
|
||||||
@@ -437,6 +442,7 @@ if ($page == 'overview') {
|
|||||||
"isemaildomain" => $domain_check['subcanemaildomain'] == '3' ? '1' : '0',
|
"isemaildomain" => $domain_check['subcanemaildomain'] == '3' ? '1' : '0',
|
||||||
"openbasedir" => $domain_check['openbasedir'],
|
"openbasedir" => $domain_check['openbasedir'],
|
||||||
"openbasedir_path" => $openbasedir_path,
|
"openbasedir_path" => $openbasedir_path,
|
||||||
|
"phpenabled" => $domain_check['phpenabled'],
|
||||||
"speciallogfile" => $domain_check['speciallogfile'],
|
"speciallogfile" => $domain_check['speciallogfile'],
|
||||||
"specialsettings" => $domain_check['specialsettings'],
|
"specialsettings" => $domain_check['specialsettings'],
|
||||||
"ssl_redirect" => $ssl_redirect,
|
"ssl_redirect" => $ssl_redirect,
|
||||||
@@ -532,6 +538,27 @@ if ($page == 'overview') {
|
|||||||
$openbasedir = makeoption($lng['domain']['docroot'], 0, NULL, true) . makeoption($lng['domain']['homedir'], 1, NULL, true);
|
$openbasedir = makeoption($lng['domain']['docroot'], 0, NULL, true) . makeoption($lng['domain']['homedir'], 1, NULL, true);
|
||||||
$pathSelect = makePathfield($userinfo['documentroot'], $userinfo['guid'], $userinfo['guid']);
|
$pathSelect = makePathfield($userinfo['documentroot'], $userinfo['guid'], $userinfo['guid']);
|
||||||
|
|
||||||
|
$phpconfigs = '';
|
||||||
|
$has_phpconfigs = false;
|
||||||
|
if (isset($userinfo['allowed_phpconfigs']) && !empty($userinfo['allowed_phpconfigs']))
|
||||||
|
{
|
||||||
|
$has_phpconfigs = true;
|
||||||
|
$allowed_cfg = json_decode($userinfo['allowed_phpconfigs'], JSON_OBJECT_AS_ARRAY);
|
||||||
|
$phpconfigs_result_stmt = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
WHERE c.id IN (".implode(", ", $allowed_cfg).")
|
||||||
|
");
|
||||||
|
while ($phpconfigs_row = $phpconfigs_result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs .= makeoption($phpconfigs_row['description'] . " [".$phpconfigs_row['interpreter']."]", $phpconfigs_row['id'], Settings::Get('phpfpm.defaultini'), true, true);
|
||||||
|
} else {
|
||||||
|
$phpconfigs .= makeoption($phpconfigs_row['description'], $phpconfigs_row['id'], Settings::Get('system.mod_fcgid_defaultini'), true, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$subdomain_add_data = include_once dirname(__FILE__).'/lib/formfields/customer/domains/formfield.domains_add.php';
|
$subdomain_add_data = include_once dirname(__FILE__).'/lib/formfields/customer/domains/formfield.domains_add.php';
|
||||||
$subdomain_add_form = htmlform::genHTMLForm($subdomain_add_data);
|
$subdomain_add_form = htmlform::genHTMLForm($subdomain_add_data);
|
||||||
|
|
||||||
@@ -569,6 +596,9 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!preg_match('/^https?\:\/\//', $path) || !validateUrl($path)) {
|
if (!preg_match('/^https?\:\/\//', $path) || !validateUrl($path)) {
|
||||||
|
if (strstr($path, ":") !== FALSE) {
|
||||||
|
standard_error('pathmaynotcontaincolon');
|
||||||
|
}
|
||||||
// If path is empty or '/' and 'Use domain name as default value for DocumentRoot path' is enabled in settings,
|
// If path is empty or '/' and 'Use domain name as default value for DocumentRoot path' is enabled in settings,
|
||||||
// set default path to subdomain or domain name
|
// set default path to subdomain or domain name
|
||||||
if ((($path == '') || ($path == '/')) && Settings::Get('system.documentroot_use_default_value') == 1) {
|
if ((($path == '') || ($path == '/')) && Settings::Get('system.documentroot_use_default_value') == 1) {
|
||||||
@@ -576,9 +606,6 @@ if ($page == 'overview') {
|
|||||||
} else {
|
} else {
|
||||||
$path = makeCorrectDir($userinfo['documentroot'] . '/' . $path);
|
$path = makeCorrectDir($userinfo['documentroot'] . '/' . $path);
|
||||||
}
|
}
|
||||||
if (strstr($path, ":") !== FALSE) {
|
|
||||||
standard_error('pathmaynotcontaincolon');
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
$_doredirect = true;
|
$_doredirect = true;
|
||||||
}
|
}
|
||||||
@@ -622,6 +649,13 @@ if ($page == 'overview') {
|
|||||||
$openbasedir_path = '0';
|
$openbasedir_path = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check whether the customer has chosen its own php-config
|
||||||
|
if (isset($_POST['phpsettingid'])) {
|
||||||
|
$phpsettingid = intval($_POST['phpsettingid']);
|
||||||
|
} else {
|
||||||
|
$phpsettingid = $result['phpsettingid'];
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($_POST['ssl_redirect']) && $_POST['ssl_redirect'] == '1') {
|
if (isset($_POST['ssl_redirect']) && $_POST['ssl_redirect'] == '1') {
|
||||||
// a ssl-redirect only works if there actually is a
|
// a ssl-redirect only works if there actually is a
|
||||||
// ssl ip/port assigned to the domain
|
// ssl ip/port assigned to the domain
|
||||||
@@ -647,10 +681,15 @@ if ($page == 'overview') {
|
|||||||
$letsencrypt = '0';
|
$letsencrypt = '0';
|
||||||
}
|
}
|
||||||
|
|
||||||
// We can't enable let's encrypt for wildcard - domains
|
// We can't enable let's encrypt for wildcard - domains when using acme-v1
|
||||||
if ($iswildcarddomain == '1' && $letsencrypt == '1') {
|
if ($iswildcarddomain == '1' && $letsencrypt == '1' && Settings::Get('system.leapiversion') == '1') {
|
||||||
standard_error('nowildcardwithletsencrypt');
|
standard_error('nowildcardwithletsencrypt');
|
||||||
}
|
}
|
||||||
|
// if using acme-v2 we cannot issue wildcard-certificates
|
||||||
|
// because they currently only support the dns-01 challenge
|
||||||
|
if ($iswildcarddomain == '0' && $letsencrypt == '1' && Settings::Get('system.leapiversion') == '2') {
|
||||||
|
standard_error('nowildcardwithletsencryptv2');
|
||||||
|
}
|
||||||
|
|
||||||
// Temporarily deactivate ssl_redirect until Let's Encrypt certificate was generated
|
// Temporarily deactivate ssl_redirect until Let's Encrypt certificate was generated
|
||||||
if ($ssl_redirect > 0 && $letsencrypt == 1 && $result['letsencrypt'] != $letsencrypt) {
|
if ($ssl_redirect > 0 && $letsencrypt == 1 && $result['letsencrypt'] != $letsencrypt) {
|
||||||
@@ -690,6 +729,7 @@ if ($page == 'overview') {
|
|||||||
|| $hsts_maxage != $result['hsts']
|
|| $hsts_maxage != $result['hsts']
|
||||||
|| $hsts_sub != $result['hsts_sub']
|
|| $hsts_sub != $result['hsts_sub']
|
||||||
|| $hsts_preload != $result['hsts_preload']
|
|| $hsts_preload != $result['hsts_preload']
|
||||||
|
|| $phpsettingid != $result['phpsettingid']
|
||||||
) {
|
) {
|
||||||
$log->logAction(USR_ACTION, LOG_INFO, "edited domain '" . $idna_convert->decode($result['domain']) . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "edited domain '" . $idna_convert->decode($result['domain']) . "'");
|
||||||
|
|
||||||
@@ -704,7 +744,8 @@ if ($page == 'overview') {
|
|||||||
`letsencrypt`= :letsencrypt,
|
`letsencrypt`= :letsencrypt,
|
||||||
`hsts` = :hsts,
|
`hsts` = :hsts,
|
||||||
`hsts_sub` = :hsts_sub,
|
`hsts_sub` = :hsts_sub,
|
||||||
`hsts_preload` = :hsts_preload
|
`hsts_preload` = :hsts_preload,
|
||||||
|
`phpsettingid` = :phpsettingid
|
||||||
WHERE `customerid`= :customerid
|
WHERE `customerid`= :customerid
|
||||||
AND `id`= :id"
|
AND `id`= :id"
|
||||||
);
|
);
|
||||||
@@ -720,6 +761,7 @@ if ($page == 'overview') {
|
|||||||
"hsts" => $hsts_maxage,
|
"hsts" => $hsts_maxage,
|
||||||
"hsts_sub" => $hsts_sub,
|
"hsts_sub" => $hsts_sub,
|
||||||
"hsts_preload" => $hsts_preload,
|
"hsts_preload" => $hsts_preload,
|
||||||
|
"phpsettingid" => $phpsettingid,
|
||||||
"customerid" => $userinfo['customerid'],
|
"customerid" => $userinfo['customerid'],
|
||||||
"id" => $id
|
"id" => $id
|
||||||
);
|
);
|
||||||
@@ -731,7 +773,15 @@ if ($page == 'overview') {
|
|||||||
triggerLetsEncryptCSRForAliasDestinationDomain($aliasdomain, $log);
|
triggerLetsEncryptCSRForAliasDestinationDomain($aliasdomain, $log);
|
||||||
} elseif ($result['wwwserveralias'] != $wwwserveralias || $result['letsencrypt'] != $letsencrypt) {
|
} elseif ($result['wwwserveralias'] != $wwwserveralias || $result['letsencrypt'] != $letsencrypt) {
|
||||||
// or when wwwserveralias or letsencrypt was changed
|
// or when wwwserveralias or letsencrypt was changed
|
||||||
|
|
||||||
triggerLetsEncryptCSRForAliasDestinationDomain($aliasdomain, $log);
|
triggerLetsEncryptCSRForAliasDestinationDomain($aliasdomain, $log);
|
||||||
|
|
||||||
|
if ($aliasdomain === 0) {
|
||||||
|
// in case the wwwserveralias is set on a main domain, $aliasdomain is 0
|
||||||
|
// --> the call just above to triggerLetsEncryptCSRForAliasDestinationDomain
|
||||||
|
// is a noop...let's repeat it with the domain id of the main domain
|
||||||
|
triggerLetsEncryptCSRForAliasDestinationDomain($id, $log);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// check whether LE has been disabled, so we remove the certificate
|
// check whether LE has been disabled, so we remove the certificate
|
||||||
@@ -844,6 +894,27 @@ if ($page == 'overview') {
|
|||||||
$result_ipandport['ip'] .= $rowip['ip'] . "<br />";
|
$result_ipandport['ip'] .= $rowip['ip'] . "<br />";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$phpconfigs = '';
|
||||||
|
$has_phpconfigs = false;
|
||||||
|
if (isset($userinfo['allowed_phpconfigs']) && !empty($userinfo['allowed_phpconfigs']))
|
||||||
|
{
|
||||||
|
$has_phpconfigs = true;
|
||||||
|
$allowed_cfg = json_decode($userinfo['allowed_phpconfigs'], JSON_OBJECT_AS_ARRAY);
|
||||||
|
$phpconfigs_result_stmt = Database::query("
|
||||||
|
SELECT c.*, fc.description as interpreter
|
||||||
|
FROM `" . TABLE_PANEL_PHPCONFIGS . "` c
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_FPMDAEMONS . "` fc ON fc.id = c.fpmsettingid
|
||||||
|
WHERE c.id IN (".implode(", ", $allowed_cfg).")
|
||||||
|
");
|
||||||
|
while ($phpconfigs_row = $phpconfigs_result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$phpconfigs .= makeoption($phpconfigs_row['description'] . " [".$phpconfigs_row['interpreter']."]", $phpconfigs_row['id'], $result['phpsettingid'], true, true);
|
||||||
|
} else {
|
||||||
|
$phpconfigs .= makeoption($phpconfigs_row['description'], $phpconfigs_row['id'], $result['phpsettingid'], true, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$domainip = $result_ipandport['ip'];
|
$domainip = $result_ipandport['ip'];
|
||||||
$result = htmlentities_array($result);
|
$result = htmlentities_array($result);
|
||||||
|
|
||||||
|
|||||||
@@ -96,7 +96,8 @@ if ($page == 'overview') {
|
|||||||
$row['destination'] = explode(' ', $row['destination']);
|
$row['destination'] = explode(' ', $row['destination']);
|
||||||
uasort($row['destination'], 'strcasecmp');
|
uasort($row['destination'], 'strcasecmp');
|
||||||
|
|
||||||
while (list($dest_id, $destination) = each($row['destination'])) {
|
$dest_list = $row['destination'];
|
||||||
|
foreach ($dest_list as $dest_id => $destination) {
|
||||||
$row['destination'][$dest_id] = $idna_convert->decode($row['destination'][$dest_id]);
|
$row['destination'][$dest_id] = $idna_convert->decode($row['destination'][$dest_id]);
|
||||||
|
|
||||||
if ($row['destination'][$dest_id] == $row['email_full']) {
|
if ($row['destination'][$dest_id] == $row['email_full']) {
|
||||||
@@ -164,7 +165,7 @@ if ($page == 'overview') {
|
|||||||
Database::pexecute($stmt, array("customerid" => $userinfo['customerid'], "id" => $result['popaccountid']));
|
Database::pexecute($stmt, array("customerid" => $userinfo['customerid'], "id" => $result['popaccountid']));
|
||||||
$update_users_query_addon .= " , `email_accounts_used` = `email_accounts_used` - 1 ";
|
$update_users_query_addon .= " , `email_accounts_used` = `email_accounts_used` - 1 ";
|
||||||
$number_forwarders-= 1;
|
$number_forwarders-= 1;
|
||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "deleted forwarder for email address '" . $result['email'] . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "deleted forwarder for email address '" . $result['email'] . "'");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$number_forwarders = 0;
|
$number_forwarders = 0;
|
||||||
@@ -323,7 +324,7 @@ if ($page == 'overview') {
|
|||||||
$forwarders = '';
|
$forwarders = '';
|
||||||
$forwarders_count = 0;
|
$forwarders_count = 0;
|
||||||
|
|
||||||
while (list($dest_id, $destination) = each($result['destination'])) {
|
foreach ($result['destination'] as $dest_id => $destination) {
|
||||||
$destination = $idna_convert->decode($destination);
|
$destination = $idna_convert->decode($destination);
|
||||||
|
|
||||||
if ($destination != $result['email_full'] && $destination != '') {
|
if ($destination != $result['email_full'] && $destination != '') {
|
||||||
@@ -652,7 +653,7 @@ if ($page == 'overview') {
|
|||||||
|
|
||||||
$password = validatePassword($password);
|
$password = validatePassword($password);
|
||||||
|
|
||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "changed email password for '" . $result['email_full'] . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "changed email password for '" . $result['email_full'] . "'");
|
||||||
$cryptPassword = makeCryptPassword($password);
|
$cryptPassword = makeCryptPassword($password);
|
||||||
$stmt = Database::prepare("UPDATE `" . TABLE_MAIL_USERS . "`
|
$stmt = Database::prepare("UPDATE `" . TABLE_MAIL_USERS . "`
|
||||||
SET " . (Settings::Get('system.mailpwcleartext') == '1' ? "`password` = :password, " : '') . "
|
SET " . (Settings::Get('system.mailpwcleartext') == '1' ? "`password` = :password, " : '') . "
|
||||||
@@ -699,7 +700,7 @@ if ($page == 'overview') {
|
|||||||
if ($userinfo['email_quota'] != '-1' && ($quota == 0 || ($quota + $userinfo['email_quota_used'] - $result['quota']) > $userinfo['email_quota'])) {
|
if ($userinfo['email_quota'] != '-1' && ($quota == 0 || ($quota + $userinfo['email_quota_used'] - $result['quota']) > $userinfo['email_quota'])) {
|
||||||
standard_error('allocatetoomuchquota', $quota);
|
standard_error('allocatetoomuchquota', $quota);
|
||||||
} else {
|
} else {
|
||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "updated quota for email address '" . $result['email'] . "' to " . $quota . " MB");
|
$log->logAction(USR_ACTION, LOG_INFO, "updated quota for email address '" . $result['email'] . "' to " . $quota . " MB");
|
||||||
$stmt = Database::prepare("UPDATE `" . TABLE_MAIL_USERS . "`
|
$stmt = Database::prepare("UPDATE `" . TABLE_MAIL_USERS . "`
|
||||||
SET `quota` = :quota
|
SET `quota` = :quota
|
||||||
WHERE `id` = :id
|
WHERE `id` = :id
|
||||||
@@ -834,7 +835,7 @@ if ($page == 'overview') {
|
|||||||
);
|
);
|
||||||
Database::pexecute($stmt, array("cid" => $userinfo['customerid']));
|
Database::pexecute($stmt, array("cid" => $userinfo['customerid']));
|
||||||
|
|
||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "added email forwarder for '" . $result['email_full'] . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "added email forwarder for '" . $result['email_full'] . "'");
|
||||||
redirectTo($filename, array('page' => 'emails', 'action' => 'edit', 'id' => $id, 's' => $s));
|
redirectTo($filename, array('page' => 'emails', 'action' => 'edit', 'id' => $id, 's' => $s));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@@ -895,7 +896,7 @@ if ($page == 'overview') {
|
|||||||
);
|
);
|
||||||
Database::pexecute($stmt, array("cid" => $userinfo['customerid']));
|
Database::pexecute($stmt, array("cid" => $userinfo['customerid']));
|
||||||
|
|
||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "deleted email forwarder for '" . $result['email_full'] . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "deleted email forwarder for '" . $result['email_full'] . "'");
|
||||||
redirectTo($filename, array('page' => 'emails', 'action' => 'edit', 'id' => $id, 's' => $s));
|
redirectTo($filename, array('page' => 'emails', 'action' => 'edit', 'id' => $id, 's' => $s));
|
||||||
} else {
|
} else {
|
||||||
ask_yesno('email_reallydelete_forwarder', $filename, array('id' => $id, 'forwarderid' => $forwarderid, 'page' => $page, 'action' => $action), $idna_convert->decode($result['email_full']) . ' -> ' . $idna_convert->decode($forwarder));
|
ask_yesno('email_reallydelete_forwarder', $filename, array('id' => $id, 'forwarderid' => $forwarderid, 'page' => $page, 'action' => $action), $idna_convert->decode($result['email_full']) . ' -> ' . $idna_convert->decode($forwarder));
|
||||||
|
|||||||
@@ -563,7 +563,7 @@ if ($page == 'overview') {
|
|||||||
$existing_backupJob = null;
|
$existing_backupJob = null;
|
||||||
while ($entry = $sel_stmt->fetch())
|
while ($entry = $sel_stmt->fetch())
|
||||||
{
|
{
|
||||||
$data = unserialize($entry['data']);
|
$data = json_decode($entry['data'], true);
|
||||||
if ($data['customerid'] == $userinfo['customerid']) {
|
if ($data['customerid'] == $userinfo['customerid']) {
|
||||||
$existing_backupJob = $entry;
|
$existing_backupJob = $entry;
|
||||||
break;
|
break;
|
||||||
@@ -579,6 +579,11 @@ if ($page == 'overview') {
|
|||||||
$path = makeCorrectDir(validate($_POST['path'], 'path'));
|
$path = makeCorrectDir(validate($_POST['path'], 'path'));
|
||||||
$path = makeCorrectDir($userinfo['documentroot'] . '/' . $path);
|
$path = makeCorrectDir($userinfo['documentroot'] . '/' . $path);
|
||||||
|
|
||||||
|
// path cannot be the customers docroot
|
||||||
|
if ($path == makeCorrectDir($userinfo['documentroot'])) {
|
||||||
|
standar_error('backupfoldercannotbedocroot');
|
||||||
|
}
|
||||||
|
|
||||||
$backup_dbs = isset($_POST['backup_dbs']) ? intval($_POST['backup_dbs']) : 0;
|
$backup_dbs = isset($_POST['backup_dbs']) ? intval($_POST['backup_dbs']) : 0;
|
||||||
$backup_mail = isset($_POST['backup_mail']) ? intval($_POST['backup_mail']) : 0;
|
$backup_mail = isset($_POST['backup_mail']) ? intval($_POST['backup_mail']) : 0;
|
||||||
$backup_web = isset($_POST['backup_web']) ? intval($_POST['backup_web']) : 0;
|
$backup_web = isset($_POST['backup_web']) ? intval($_POST['backup_web']) : 0;
|
||||||
@@ -613,7 +618,7 @@ if ($page == 'overview') {
|
|||||||
|
|
||||||
if (!empty($existing_backupJob)) {
|
if (!empty($existing_backupJob)) {
|
||||||
$action = "abort";
|
$action = "abort";
|
||||||
$row = unserialize($entry['data']);
|
$row = json_decode($entry['data'], true);
|
||||||
$row['path'] = makeCorrectDir(str_replace($userinfo['documentroot'], "/", $row['destdir']));
|
$row['path'] = makeCorrectDir(str_replace($userinfo['documentroot'], "/", $row['destdir']));
|
||||||
$row['backup_web'] = ($row['backup_web'] == '1') ? $lng['panel']['yes'] : $lng['panel']['no'];
|
$row['backup_web'] = ($row['backup_web'] == '1') ? $lng['panel']['yes'] : $lng['panel']['no'];
|
||||||
$row['backup_mail'] = ($row['backup_mail'] == '1') ? $lng['panel']['yes'] : $lng['panel']['no'];
|
$row['backup_mail'] = ($row['backup_mail'] == '1') ? $lng['panel']['yes'] : $lng['panel']['no'];
|
||||||
|
|||||||
@@ -134,6 +134,12 @@ if ($page == 'overview') {
|
|||||||
// refs #293
|
// refs #293
|
||||||
if (isset($_POST['delete_userfiles']) && (int)$_POST['delete_userfiles'] == 1) {
|
if (isset($_POST['delete_userfiles']) && (int)$_POST['delete_userfiles'] == 1) {
|
||||||
inserttask('8', $userinfo['loginname'], $result['homedir']);
|
inserttask('8', $userinfo['loginname'], $result['homedir']);
|
||||||
|
} else {
|
||||||
|
if (Settings::Get('system.nssextrausers') == 1)
|
||||||
|
{
|
||||||
|
// this is used so that the libnss-extrausers cron is fired
|
||||||
|
inserttask(5);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "`
|
$stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "`
|
||||||
@@ -431,6 +437,7 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$log->logAction(USR_ACTION, LOG_INFO, "edited ftp-account '" . $result['username'] . "'");
|
$log->logAction(USR_ACTION, LOG_INFO, "edited ftp-account '" . $result['username'] . "'");
|
||||||
|
inserttask(5);
|
||||||
$description = validate($_POST['ftp_description'], 'description');
|
$description = validate($_POST['ftp_description'], 'description');
|
||||||
$stmt = Database::prepare("UPDATE `" . TABLE_FTP_USERS . "`
|
$stmt = Database::prepare("UPDATE `" . TABLE_FTP_USERS . "`
|
||||||
SET `description` = :desc, `shell` = :shell
|
SET `description` = :desc, `shell` = :shell
|
||||||
|
|||||||
@@ -204,7 +204,7 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$language_options = '';
|
$language_options = '';
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options .= makeoption($language_name, $language_file, $default_lang, true);
|
$language_options .= makeoption($language_name, $language_file, $default_lang, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -16,17 +16,15 @@
|
|||||||
* @package Panel
|
* @package Panel
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
require './lib/init.php';
|
require './lib/init.php';
|
||||||
|
|
||||||
// redirect if this customer page is hidden via settings
|
// redirect if this customer page is hidden via settings
|
||||||
if (Settings::IsInList('panel.customer_hide_options','extras.logger')) {
|
if (Settings::IsInList('panel.customer_hide_options', 'extras.logger')) {
|
||||||
redirectTo('customer_index.php');
|
redirectTo('customer_index.php');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($page == 'log'
|
if ($page == 'log') {
|
||||||
) {
|
|
||||||
if ($action == '') {
|
if ($action == '') {
|
||||||
$fields = array(
|
$fields = array(
|
||||||
'date' => $lng['logger']['date'],
|
'date' => $lng['logger']['date'],
|
||||||
@@ -34,37 +32,39 @@ if ($page == 'log'
|
|||||||
'user' => $lng['logger']['user'],
|
'user' => $lng['logger']['user'],
|
||||||
'text' => $lng['logger']['action']
|
'text' => $lng['logger']['action']
|
||||||
);
|
);
|
||||||
$paging = new paging($userinfo, TABLE_PANEL_LOG, $fields, null, null, 0, 'desc');
|
$paging = new paging($userinfo, TABLE_PANEL_LOG, $fields, null, null, 0, 'desc', 30);
|
||||||
$result_stmt = Database::prepare('
|
$query = 'SELECT * FROM `' . TABLE_PANEL_LOG . '` WHERE `user` = :loginname ' . $paging->getSqlWhere(true) . ' ' . $paging->getSqlOrderBy();
|
||||||
SELECT * FROM `' . TABLE_PANEL_LOG . '` WHERE `user` = :loginname ' . $paging->getSqlWhere(true) . ' ' . $paging->getSqlOrderBy() . ' ' . $paging->getSqlLimit()
|
$result_stmt = Database::prepare($query . ' ' . $paging->getSqlLimit());
|
||||||
);
|
Database::pexecute($result_stmt, array(
|
||||||
Database::pexecute($result_stmt, array("loginname" => $userinfo['loginname']));
|
"loginname" => $userinfo['loginname']
|
||||||
$logs_count = Database::num_rows();
|
));
|
||||||
|
$result_cnt_stmt = Database::prepare($query);
|
||||||
|
Database::pexecute($result_cnt_stmt, array(
|
||||||
|
"loginname" => $userinfo['loginname']
|
||||||
|
));
|
||||||
|
$res_cnt = $result_cnt_stmt->fetch(PDO::FETCH_ASSOC);
|
||||||
|
$logs_count = $result_cnt_stmt->rowCount();
|
||||||
$paging->setEntries($logs_count);
|
$paging->setEntries($logs_count);
|
||||||
$sortcode = $paging->getHtmlSortCode($lng);
|
$sortcode = $paging->getHtmlSortCode($lng);
|
||||||
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
$arrowcode = $paging->getHtmlArrowCode($filename . '?page=' . $page . '&s=' . $s);
|
||||||
$searchcode = $paging->getHtmlSearchCode($lng);
|
$searchcode = $paging->getHtmlSearchCode($lng);
|
||||||
$pagingcode = $paging->getHtmlPagingCode($filename . '?page=' . $page . '&s=' . $s);
|
$pagingcode = $paging->getHtmlPagingCode($filename . '?page=' . $page . '&s=' . $s);
|
||||||
$clog = array();
|
$clog = array();
|
||||||
|
|
||||||
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
if (!isset($clog[$row['action']])
|
if (! isset($clog[$row['action']]) || ! is_array($clog[$row['action']])) {
|
||||||
|| !is_array($clog[$row['action']])
|
|
||||||
) {
|
|
||||||
$clog[$row['action']] = array();
|
$clog[$row['action']] = array();
|
||||||
}
|
}
|
||||||
$clog[$row['action']][$row['logid']] = $row;
|
$clog[$row['action']][$row['logid']] = $row;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($paging->sortfield == 'date'
|
if ($paging->sortfield == 'date' && $paging->sortorder == 'desc') {
|
||||||
&& $paging->sortorder == 'desc'
|
|
||||||
) {
|
|
||||||
krsort($clog);
|
krsort($clog);
|
||||||
} else {
|
} else {
|
||||||
ksort($clog);
|
ksort($clog);
|
||||||
}
|
}
|
||||||
|
|
||||||
$i = 0;
|
$i = 0;
|
||||||
$count = 0;
|
$count = 0;
|
||||||
$log_count = 0;
|
$log_count = 0;
|
||||||
@@ -72,51 +72,50 @@ if ($page == 'log'
|
|||||||
foreach ($clog as $action => $logrows) {
|
foreach ($clog as $action => $logrows) {
|
||||||
$_action = 0;
|
$_action = 0;
|
||||||
foreach ($logrows as $row) {
|
foreach ($logrows as $row) {
|
||||||
if ($paging->checkDisplay($i)) {
|
// if ($paging->checkDisplay($i)) {
|
||||||
$row = htmlentities_array($row);
|
$row = htmlentities_array($row);
|
||||||
$row['date'] = date("d.m.y H:i:s", $row['date']);
|
$row['date'] = date("d.m.y H:i:s", $row['date']);
|
||||||
|
|
||||||
if ($_action != $action) {
|
if ($_action != $action) {
|
||||||
switch ($action) {
|
switch ($action) {
|
||||||
case USR_ACTION:
|
case USR_ACTION:
|
||||||
$_action = $lng['admin']['customer'];
|
$_action = $lng['admin']['customer'];
|
||||||
break;
|
break;
|
||||||
case RES_ACTION:
|
case RES_ACTION:
|
||||||
$_action = $lng['logger']['reseller'];
|
$_action = $lng['logger']['reseller'];
|
||||||
break;
|
break;
|
||||||
case ADM_ACTION:
|
case ADM_ACTION:
|
||||||
$_action = $lng['logger']['admin'];
|
$_action = $lng['logger']['admin'];
|
||||||
break;
|
break;
|
||||||
case CRON_ACTION:
|
case CRON_ACTION:
|
||||||
$_action = $lng['logger']['cron'];
|
$_action = $lng['logger']['cron'];
|
||||||
break;
|
break;
|
||||||
case LOGIN_ACTION:
|
case LOGIN_ACTION:
|
||||||
$_action = $lng['logger']['login'];
|
$_action = $lng['logger']['login'];
|
||||||
break;
|
break;
|
||||||
case LOG_ERROR:
|
case LOG_ERROR:
|
||||||
$_action = $lng['logger']['intern'];
|
$_action = $lng['logger']['intern'];
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
$_action = $lng['logger']['unknown'];
|
$_action = $lng['logger']['unknown'];
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
$row['action'] = $_action;
|
|
||||||
eval("\$log.=\"" . getTemplate('logger/logger_action') . "\";");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$log_count++;
|
$row['action'] = $_action;
|
||||||
$row['type'] = getLogLevelDesc($row['type']);
|
eval("\$log.=\"" . getTemplate('logger/logger_action') . "\";");
|
||||||
eval("\$log.=\"" . getTemplate('logger/logger_log') . "\";");
|
|
||||||
$count++;
|
|
||||||
$_action = $action;
|
|
||||||
}
|
}
|
||||||
$i++;
|
|
||||||
|
$log_count ++;
|
||||||
|
$row['type'] = getLogLevelDesc($row['type']);
|
||||||
|
eval("\$log.=\"" . getTemplate('logger/logger_log') . "\";");
|
||||||
|
$count ++;
|
||||||
|
$_action = $action;
|
||||||
|
// }
|
||||||
|
$i ++;
|
||||||
}
|
}
|
||||||
$i++;
|
$i ++;
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("echo \"" . getTemplate('logger/logger') . "\";");
|
eval("echo \"" . getTemplate('logger/logger') . "\";");
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,10 +20,6 @@
|
|||||||
define('AREA', 'customer');
|
define('AREA', 'customer');
|
||||||
require './lib/init.php';
|
require './lib/init.php';
|
||||||
|
|
||||||
// redirect if this customer page is hidden via settings
|
|
||||||
if (Settings::IsInList('panel.customer_hide_options','domains')) {
|
|
||||||
redirectTo('customer_index.php');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($_POST['id'])) {
|
if (isset($_POST['id'])) {
|
||||||
|
|
||||||
@@ -242,7 +238,11 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
} elseif ($action == 'answer' && $id != 0) {
|
} elseif ($action == 'answer' && $id != 0) {
|
||||||
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
$replyticket = ticket::getInstanceOf($userinfo, -1);
|
try {
|
||||||
|
$replyticket = ticket::getInstanceOf($userinfo, -1);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
standard_error($e->getMessage());
|
||||||
|
}
|
||||||
$replyticket->Set('subject', validate($_POST['subject'], 'subject'), true, false);
|
$replyticket->Set('subject', validate($_POST['subject'], 'subject'), true, false);
|
||||||
$replyticket->Set('priority', validate($_POST['priority'], 'priority'), true, false);
|
$replyticket->Set('priority', validate($_POST['priority'], 'priority'), true, false);
|
||||||
$replyticket->Set('message', validate(str_replace("\r\n", "\n", $_POST['message']), 'message', '/^[^\0]*$/'), true, false);
|
$replyticket->Set('message', validate(str_replace("\r\n", "\n", $_POST['message']), 'message', '/^[^\0]*$/'), true, false);
|
||||||
@@ -250,6 +250,11 @@ if ($page == 'overview') {
|
|||||||
if ($replyticket->Get('message') == null) {
|
if ($replyticket->Get('message') == null) {
|
||||||
standard_error(array('stringisempty', 'mymessage'));
|
standard_error(array('stringisempty', 'mymessage'));
|
||||||
} else {
|
} else {
|
||||||
|
try {
|
||||||
|
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
standard_error($e->getMessage());
|
||||||
|
}
|
||||||
$now = time();
|
$now = time();
|
||||||
$replyticket->Set('customer', (int)$userinfo['customerid'], true, true);
|
$replyticket->Set('customer', (int)$userinfo['customerid'], true, true);
|
||||||
$replyticket->Set('lastchange', $now, true, true);
|
$replyticket->Set('lastchange', $now, true, true);
|
||||||
@@ -260,8 +265,6 @@ if ($page == 'overview') {
|
|||||||
$replyticket->Insert();
|
$replyticket->Insert();
|
||||||
|
|
||||||
// Update priority if changed
|
// Update priority if changed
|
||||||
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
|
||||||
|
|
||||||
if ($replyticket->Get('priority') != $mainticket->Get('priority')) {
|
if ($replyticket->Get('priority') != $mainticket->Get('priority')) {
|
||||||
$mainticket->Set('priority', $replyticket->Get('priority'), true);
|
$mainticket->Set('priority', $replyticket->Get('priority'), true);
|
||||||
}
|
}
|
||||||
@@ -276,7 +279,11 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$ticket_replies = '';
|
$ticket_replies = '';
|
||||||
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
try {
|
||||||
|
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
standard_error($e->getMessage());
|
||||||
|
}
|
||||||
$dt = date("d.m.Y H:i\h", $mainticket->Get('dt'));
|
$dt = date("d.m.Y H:i\h", $mainticket->Get('dt'));
|
||||||
$status = ticket::getStatusText($lng, $mainticket->Get('status'));
|
$status = ticket::getStatusText($lng, $mainticket->Get('status'));
|
||||||
|
|
||||||
@@ -355,7 +362,11 @@ if ($page == 'overview') {
|
|||||||
} elseif ($action == 'close' && $id != 0) {
|
} elseif ($action == 'close' && $id != 0) {
|
||||||
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
if (isset($_POST['send']) && $_POST['send'] == 'send') {
|
||||||
$now = time();
|
$now = time();
|
||||||
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
try {
|
||||||
|
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
standard_error($e->getMessage());
|
||||||
|
}
|
||||||
$mainticket->Set('lastchange', $now, true, true);
|
$mainticket->Set('lastchange', $now, true, true);
|
||||||
$mainticket->Set('lastreplier', '0', true, true);
|
$mainticket->Set('lastreplier', '0', true, true);
|
||||||
$mainticket->Set('status', '3', true, true);
|
$mainticket->Set('status', '3', true, true);
|
||||||
@@ -363,7 +374,11 @@ if ($page == 'overview') {
|
|||||||
$log->logAction(USR_ACTION, LOG_NOTICE, "closed support-ticket '" . $mainticket->Get('subject') . "'");
|
$log->logAction(USR_ACTION, LOG_NOTICE, "closed support-ticket '" . $mainticket->Get('subject') . "'");
|
||||||
redirectTo($filename, array('page' => $page, 's' => $s));
|
redirectTo($filename, array('page' => $page, 's' => $s));
|
||||||
} else {
|
} else {
|
||||||
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
try {
|
||||||
|
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
standard_error($e->getMessage());
|
||||||
|
}
|
||||||
ask_yesno('ticket_reallyclose', $filename, array('id' => $id, 'page' => $page, 'action' => $action), $mainticket->Get('subject'));
|
ask_yesno('ticket_reallyclose', $filename, array('id' => $id, 'page' => $page, 'action' => $action), $mainticket->Get('subject'));
|
||||||
}
|
}
|
||||||
} elseif ($action == 'reopen' && $id != 0) {
|
} elseif ($action == 'reopen' && $id != 0) {
|
||||||
@@ -381,7 +396,11 @@ if ($page == 'overview') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$now = time();
|
$now = time();
|
||||||
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
try {
|
||||||
|
$mainticket = ticket::getInstanceOf($userinfo, (int)$id);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
standard_error($e->getMessage());
|
||||||
|
}
|
||||||
$mainticket->Set('lastchange', $now, true, true);
|
$mainticket->Set('lastchange', $now, true, true);
|
||||||
$mainticket->Set('lastreplier', '0', true, true);
|
$mainticket->Set('lastreplier', '0', true, true);
|
||||||
$mainticket->Set('status', '0', true, true);
|
$mainticket->Set('status', '0', true, true);
|
||||||
|
|||||||
@@ -56,13 +56,29 @@ if ($action == 'add_record' && ! empty($_POST)) {
|
|||||||
if (strpos($record, '--') !== false) {
|
if (strpos($record, '--') !== false) {
|
||||||
$errors[] = $lng['error']['domain_nopunycode'];
|
$errors[] = $lng['error']['domain_nopunycode'];
|
||||||
} else {
|
} else {
|
||||||
|
// check for wildcard-record
|
||||||
|
$add_wildcard_again = false;
|
||||||
|
if (substr($record, 0, 2) == '*.') {
|
||||||
|
$record = substr($record, 2);
|
||||||
|
$add_wildcard_again = true;
|
||||||
|
}
|
||||||
|
// convert entry
|
||||||
$record = $idna_convert->encode($record);
|
$record = $idna_convert->encode($record);
|
||||||
|
|
||||||
|
if ($add_wildcard_again) {
|
||||||
|
$record = '*.'.$record;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* see https://redmine.froxlor.org/issues/1697
|
||||||
|
*
|
||||||
if ($type != 'SRV' && $type != 'TXT') {
|
if ($type != 'SRV' && $type != 'TXT') {
|
||||||
$check_dom = $record . '.example.com';
|
$check_dom = $record . '.example.com';
|
||||||
if (! validateDomain($check_dom)) {
|
if (! validateDomain($check_dom)) {
|
||||||
$errors[] = sprintf($lng['error']['subdomainiswrong'], $idna_convert->decode($record));
|
$errors[] = sprintf($lng['error']['subdomainiswrong'], $idna_convert->decode($record));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
if (strlen($record) > 63) {
|
if (strlen($record) > 63) {
|
||||||
$errors[] = $lng['error']['dns_record_toolong'];
|
$errors[] = $lng['error']['dns_record_toolong'];
|
||||||
}
|
}
|
||||||
@@ -112,6 +128,9 @@ if ($action == 'add_record' && ! empty($_POST)) {
|
|||||||
if (substr($content, - 1) == '.') {
|
if (substr($content, - 1) == '.') {
|
||||||
// remove it for checks
|
// remove it for checks
|
||||||
$content = substr($content, 0, - 1);
|
$content = substr($content, 0, - 1);
|
||||||
|
} else {
|
||||||
|
// add domain name
|
||||||
|
$content .= '.' . $domain;
|
||||||
}
|
}
|
||||||
if (! validateDomain($content)) {
|
if (! validateDomain($content)) {
|
||||||
$errors[] = $lng['error']['dns_cname_invaliddom'];
|
$errors[] = $lng['error']['dns_cname_invaliddom'];
|
||||||
@@ -171,8 +190,8 @@ if ($action == 'add_record' && ! empty($_POST)) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// append trailing dot (again)
|
// append trailing dot if there's none
|
||||||
if ($target != '.') {
|
if (substr($content, - 1) != '.') {
|
||||||
$content .= '.';
|
$content .= '.';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -189,7 +208,7 @@ if ($action == 'add_record' && ! empty($_POST)) {
|
|||||||
|
|
||||||
// check for duplicate
|
// check for duplicate
|
||||||
foreach ($dom_entries as $existing_entry) {
|
foreach ($dom_entries as $existing_entry) {
|
||||||
// compare serialized string of array
|
// compare json-encoded string of array
|
||||||
$check_entry = $existing_entry;
|
$check_entry = $existing_entry;
|
||||||
// new entry has no ID yet
|
// new entry has no ID yet
|
||||||
unset($check_entry['id']);
|
unset($check_entry['id']);
|
||||||
@@ -199,9 +218,9 @@ if ($action == 'add_record' && ! empty($_POST)) {
|
|||||||
$check_entry['prio'] = (int) $check_entry['prio'];
|
$check_entry['prio'] = (int) $check_entry['prio'];
|
||||||
$check_entry['ttl'] = (int) $check_entry['ttl'];
|
$check_entry['ttl'] = (int) $check_entry['ttl'];
|
||||||
$check_entry['domain_id'] = (int) $check_entry['domain_id'];
|
$check_entry['domain_id'] = (int) $check_entry['domain_id'];
|
||||||
// serialize both
|
// encode both
|
||||||
$check_entry = serialize($check_entry);
|
$check_entry = json_encode($check_entry);
|
||||||
$new = serialize($new_entry);
|
$new = json_encode($new_entry);
|
||||||
// compare
|
// compare
|
||||||
if ($check_entry === $new) {
|
if ($check_entry === $new) {
|
||||||
$errors[] = $lng['error']['dns_duplicate_entry'];
|
$errors[] = $lng['error']['dns_duplicate_entry'];
|
||||||
|
|||||||
@@ -250,7 +250,7 @@ if ($action == 'login') {
|
|||||||
$language_options = '';
|
$language_options = '';
|
||||||
$language_options .= makeoption($lng['login']['profile_lng'], 'profile', 'profile', true, true);
|
$language_options .= makeoption($lng['login']['profile_lng'], 'profile', 'profile', true, true);
|
||||||
|
|
||||||
while (list($language_file, $language_name) = each($languages)) {
|
foreach ($languages as $language_file => $language_name) {
|
||||||
$language_options .= makeoption($language_name, $language_file, 'profile', true);
|
$language_options .= makeoption($language_name, $language_file, 'profile', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -66,7 +66,7 @@ CREATE TABLE `mail_virtual` (
|
|||||||
`id` int(11) NOT NULL auto_increment,
|
`id` int(11) NOT NULL auto_increment,
|
||||||
`email` varchar(255) NOT NULL default '',
|
`email` varchar(255) NOT NULL default '',
|
||||||
`email_full` varchar(255) NOT NULL default '',
|
`email_full` varchar(255) NOT NULL default '',
|
||||||
`destination` text NOT NULL default '',
|
`destination` text,
|
||||||
`domainid` int(11) NOT NULL default '0',
|
`domainid` int(11) NOT NULL default '0',
|
||||||
`customerid` int(11) NOT NULL default '0',
|
`customerid` int(11) NOT NULL default '0',
|
||||||
`popaccountid` int(11) NOT NULL default '0',
|
`popaccountid` int(11) NOT NULL default '0',
|
||||||
@@ -198,6 +198,8 @@ CREATE TABLE `panel_customers` (
|
|||||||
`lepublickey` mediumtext default NULL,
|
`lepublickey` mediumtext default NULL,
|
||||||
`leprivatekey` mediumtext default NULL,
|
`leprivatekey` mediumtext default NULL,
|
||||||
`leregistered` tinyint(1) NOT NULL default '0',
|
`leregistered` tinyint(1) NOT NULL default '0',
|
||||||
|
`leaccount` varchar(255) default '',
|
||||||
|
`allowed_phpconfigs` varchar(500) NOT NULL default '',
|
||||||
PRIMARY KEY (`customerid`),
|
PRIMARY KEY (`customerid`),
|
||||||
UNIQUE KEY `loginname` (`loginname`)
|
UNIQUE KEY `loginname` (`loginname`)
|
||||||
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
@@ -257,6 +259,9 @@ CREATE TABLE `panel_domains` (
|
|||||||
`hsts` varchar(10) NOT NULL default '0',
|
`hsts` varchar(10) NOT NULL default '0',
|
||||||
`hsts_sub` tinyint(1) NOT NULL default '0',
|
`hsts_sub` tinyint(1) NOT NULL default '0',
|
||||||
`hsts_preload` tinyint(1) NOT NULL default '0',
|
`hsts_preload` tinyint(1) NOT NULL default '0',
|
||||||
|
`ocsp_stapling` tinyint(1) DEFAULT '0',
|
||||||
|
`http2` tinyint(1) DEFAULT '0',
|
||||||
|
`notryfiles` tinyint(1) DEFAULT '0',
|
||||||
PRIMARY KEY (`id`),
|
PRIMARY KEY (`id`),
|
||||||
KEY `customerid` (`customerid`),
|
KEY `customerid` (`customerid`),
|
||||||
KEY `parentdomain` (`parentdomainid`),
|
KEY `parentdomain` (`parentdomainid`),
|
||||||
@@ -276,11 +281,11 @@ CREATE TABLE `panel_ipsandports` (
|
|||||||
`vhostcontainer_servername_statement` tinyint(1) NOT NULL default '0',
|
`vhostcontainer_servername_statement` tinyint(1) NOT NULL default '0',
|
||||||
`specialsettings` text,
|
`specialsettings` text,
|
||||||
`ssl` tinyint(4) NOT NULL default '0',
|
`ssl` tinyint(4) NOT NULL default '0',
|
||||||
`ssl_cert_file` varchar(255) NOT NULL,
|
`ssl_cert_file` varchar(255) NOT NULL default '',
|
||||||
`ssl_key_file` varchar(255) NOT NULL,
|
`ssl_key_file` varchar(255) NOT NULL default '',
|
||||||
`ssl_ca_file` varchar(255) NOT NULL,
|
`ssl_ca_file` varchar(255) NOT NULL default '',
|
||||||
`default_vhostconf_domain` text,
|
`default_vhostconf_domain` text,
|
||||||
`ssl_cert_chainfile` varchar(255) NOT NULL,
|
`ssl_cert_chainfile` varchar(255) NOT NULL default '',
|
||||||
`docroot` varchar(255) NOT NULL default '',
|
`docroot` varchar(255) NOT NULL default '',
|
||||||
PRIMARY KEY (`id`),
|
PRIMARY KEY (`id`),
|
||||||
UNIQUE KEY `ip_port` (`ip`,`port`)
|
UNIQUE KEY `ip_port` (`ip`,`port`)
|
||||||
@@ -401,25 +406,113 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES
|
|||||||
('login', 'maxloginattempts', '3'),
|
('login', 'maxloginattempts', '3'),
|
||||||
('login', 'deactivatetime', '900'),
|
('login', 'deactivatetime', '900'),
|
||||||
('phpfpm', 'enabled', '0'),
|
('phpfpm', 'enabled', '0'),
|
||||||
('phpfpm', 'configdir', '/etc/php-fpm.d/'),
|
|
||||||
('phpfpm', 'reload', '/etc/init.d/php-fpm restart'),
|
|
||||||
('phpfpm', 'pm', 'static'),
|
|
||||||
('phpfpm', 'max_children', '1'),
|
|
||||||
('phpfpm', 'start_servers', '20'),
|
|
||||||
('phpfpm', 'min_spare_servers', '5'),
|
|
||||||
('phpfpm', 'max_spare_servers', '35'),
|
|
||||||
('phpfpm', 'max_requests', '0'),
|
|
||||||
('phpfpm', 'tmpdir', '/var/customers/tmp/'),
|
('phpfpm', 'tmpdir', '/var/customers/tmp/'),
|
||||||
('phpfpm', 'peardir', '/usr/share/php/:/usr/share/php5/'),
|
('phpfpm', 'peardir', '/usr/share/php/:/usr/share/php5/'),
|
||||||
|
('phpfpm', 'envpath', '/usr/local/bin:/usr/bin:/bin'),
|
||||||
('phpfpm', 'enabled_ownvhost', '0'),
|
('phpfpm', 'enabled_ownvhost', '0'),
|
||||||
('phpfpm', 'vhost_httpuser', 'froxlorlocal'),
|
('phpfpm', 'vhost_httpuser', 'froxlorlocal'),
|
||||||
('phpfpm', 'vhost_httpgroup', 'froxlorlocal'),
|
('phpfpm', 'vhost_httpgroup', 'froxlorlocal'),
|
||||||
('phpfpm', 'idle_timeout', '30'),
|
|
||||||
('phpfpm', 'aliasconfigdir', '/var/www/php-fpm/'),
|
('phpfpm', 'aliasconfigdir', '/var/www/php-fpm/'),
|
||||||
('phpfpm', 'defaultini', '1'),
|
('phpfpm', 'defaultini', '1'),
|
||||||
('phpfpm', 'vhost_defaultini', '2'),
|
('phpfpm', 'vhost_defaultini', '2'),
|
||||||
('phpfpm', 'fastcgi_ipcdir', '/var/lib/apache2/fastcgi/'),
|
('phpfpm', 'fastcgi_ipcdir', '/var/lib/apache2/fastcgi/'),
|
||||||
('phpfpm', 'use_mod_proxy', '0'),
|
('phpfpm', 'use_mod_proxy', '0'),
|
||||||
|
('phpfpm', 'ini_flags', 'asp_tags
|
||||||
|
display_errors
|
||||||
|
display_startup_errors
|
||||||
|
html_errors
|
||||||
|
log_errors
|
||||||
|
magic_quotes_gpc
|
||||||
|
magic_quotes_runtime
|
||||||
|
magic_quotes_sybase
|
||||||
|
mail.add_x_header
|
||||||
|
session.cookie_secure
|
||||||
|
session.use_cookies
|
||||||
|
short_open_tag
|
||||||
|
track_errors
|
||||||
|
xmlrpc_errors
|
||||||
|
suhosin.simulation
|
||||||
|
suhosin.session.encrypt
|
||||||
|
suhosin.session.cryptua
|
||||||
|
suhosin.session.cryptdocroot
|
||||||
|
suhosin.cookie.encrypt
|
||||||
|
suhosin.cookie.cryptua
|
||||||
|
suhosin.cookie.cryptdocroot
|
||||||
|
suhosin.executor.disable_eval
|
||||||
|
mbstring.func_overload'),
|
||||||
|
('phpfpm', 'ini_values', 'auto_append_file
|
||||||
|
auto_prepend_file
|
||||||
|
date.timezone
|
||||||
|
default_charset
|
||||||
|
error_reporting
|
||||||
|
include_path
|
||||||
|
log_errors_max_len
|
||||||
|
mail.log
|
||||||
|
max_execution_time
|
||||||
|
session.cookie_domain
|
||||||
|
session.cookie_lifetime
|
||||||
|
session.cookie_path
|
||||||
|
session.name
|
||||||
|
session.serialize_handler
|
||||||
|
upload_max_filesize
|
||||||
|
xmlrpc_error_number
|
||||||
|
session.auto_start
|
||||||
|
always_populate_raw_post_data
|
||||||
|
suhosin.session.cryptkey
|
||||||
|
suhosin.session.cryptraddr
|
||||||
|
suhosin.session.checkraddr
|
||||||
|
suhosin.cookie.cryptkey
|
||||||
|
suhosin.cookie.plainlist
|
||||||
|
suhosin.cookie.cryptraddr
|
||||||
|
suhosin.cookie.checkraddr
|
||||||
|
suhosin.executor.func.blacklist
|
||||||
|
suhosin.executor.eval.whitelist'),
|
||||||
|
('phpfpm', 'ini_admin_flags', 'allow_call_time_pass_reference
|
||||||
|
allow_url_fopen
|
||||||
|
allow_url_include
|
||||||
|
auto_detect_line_endings
|
||||||
|
cgi.fix_pathinfo
|
||||||
|
cgi.force_redirect
|
||||||
|
enable_dl
|
||||||
|
expose_php
|
||||||
|
file_uploads
|
||||||
|
ignore_repeated_errors
|
||||||
|
ignore_repeated_source
|
||||||
|
log_errors
|
||||||
|
register_argc_argv
|
||||||
|
report_memleaks
|
||||||
|
opcache.enable
|
||||||
|
opcache.consistency_checks
|
||||||
|
opcache.dups_fix
|
||||||
|
opcache.load_comments
|
||||||
|
opcache.revalidate_path
|
||||||
|
opcache.save_comments
|
||||||
|
opcache.use_cwd
|
||||||
|
opcache.validate_timestamps
|
||||||
|
opcache.fast_shutdown'),
|
||||||
|
('phpfpm', 'ini_admin_values', 'cgi.redirect_status_env
|
||||||
|
date.timezone
|
||||||
|
disable_classes
|
||||||
|
disable_functions
|
||||||
|
error_log
|
||||||
|
gpc_order
|
||||||
|
max_input_time
|
||||||
|
max_input_vars
|
||||||
|
memory_limit
|
||||||
|
open_basedir
|
||||||
|
output_buffering
|
||||||
|
post_max_size
|
||||||
|
precision
|
||||||
|
sendmail_path
|
||||||
|
session.gc_divisor
|
||||||
|
session.gc_probability
|
||||||
|
variables_order
|
||||||
|
opcache.log_verbosity_level
|
||||||
|
opcache.restrict_api
|
||||||
|
opcache.revalidate_freq
|
||||||
|
opcache.max_accelerated_files
|
||||||
|
opcache.memory_consumption
|
||||||
|
opcache.interned_strings_buffer'),
|
||||||
('nginx', 'fastcgiparams', '/etc/nginx/fastcgi_params'),
|
('nginx', 'fastcgiparams', '/etc/nginx/fastcgi_params'),
|
||||||
('system', 'lastaccountnumber', '0'),
|
('system', 'lastaccountnumber', '0'),
|
||||||
('system', 'lastguid', '9999'),
|
('system', 'lastguid', '9999'),
|
||||||
@@ -441,7 +534,7 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES
|
|||||||
('system', 'defaultip', '1'),
|
('system', 'defaultip', '1'),
|
||||||
('system', 'phpappendopenbasedir', '/tmp/'),
|
('system', 'phpappendopenbasedir', '/tmp/'),
|
||||||
('system', 'deactivateddocroot', ''),
|
('system', 'deactivateddocroot', ''),
|
||||||
('system', 'mailpwcleartext', '1'),
|
('system', 'mailpwcleartext', '0'),
|
||||||
('system', 'last_tasks_run', '000000'),
|
('system', 'last_tasks_run', '000000'),
|
||||||
('system', 'nameservers', ''),
|
('system', 'nameservers', ''),
|
||||||
('system', 'mxservers', ''),
|
('system', 'mxservers', ''),
|
||||||
@@ -499,10 +592,11 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES
|
|||||||
('system', 'ssl_cert_chainfile', ''),
|
('system', 'ssl_cert_chainfile', ''),
|
||||||
('system', 'ssl_cipher_list', 'ECDH+AESGCM:ECDH+AES256:!aNULL:!MD5:!DSS:!DH:!AES128'),
|
('system', 'ssl_cipher_list', 'ECDH+AESGCM:ECDH+AES256:!aNULL:!MD5:!DSS:!DH:!AES128'),
|
||||||
('system', 'nginx_php_backend', '127.0.0.1:8888'),
|
('system', 'nginx_php_backend', '127.0.0.1:8888'),
|
||||||
('system', 'nginx_http2_support', '0'),
|
('system', 'http2_support', '0'),
|
||||||
('system', 'perl_server', 'unix:/var/run/nginx/cgiwrap-dispatch.sock'),
|
('system', 'perl_server', 'unix:/var/run/nginx/cgiwrap-dispatch.sock'),
|
||||||
('system', 'phpreload_command', ''),
|
('system', 'phpreload_command', ''),
|
||||||
('system', 'apache24', '0'),
|
('system', 'apache24', '1'),
|
||||||
|
('system', 'apache24_ocsp_cache_path', 'shmcb:/var/run/apache2/ocsp-stapling.cache(131072)'),
|
||||||
('system', 'documentroot_use_default_value', '0'),
|
('system', 'documentroot_use_default_value', '0'),
|
||||||
('system', 'passwordcryptfunc', '3'),
|
('system', 'passwordcryptfunc', '3'),
|
||||||
('system', 'axfrservers', ''),
|
('system', 'axfrservers', ''),
|
||||||
@@ -530,6 +624,7 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES
|
|||||||
('system', 'letsencryptkeysize', '4096'),
|
('system', 'letsencryptkeysize', '4096'),
|
||||||
('system', 'letsencryptreuseold', 0),
|
('system', 'letsencryptreuseold', 0),
|
||||||
('system', 'leenabled', '0'),
|
('system', 'leenabled', '0'),
|
||||||
|
('system', 'leapiversion', '1'),
|
||||||
('system', 'backupenabled', '0'),
|
('system', 'backupenabled', '0'),
|
||||||
('system', 'dnsenabled', '0'),
|
('system', 'dnsenabled', '0'),
|
||||||
('system', 'dns_server', 'bind'),
|
('system', 'dns_server', 'bind'),
|
||||||
@@ -550,6 +645,14 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES
|
|||||||
('system', 'hsts_incsub', '0'),
|
('system', 'hsts_incsub', '0'),
|
||||||
('system', 'hsts_preload', '0'),
|
('system', 'hsts_preload', '0'),
|
||||||
('system', 'leregistered', '0'),
|
('system', 'leregistered', '0'),
|
||||||
|
('system', 'leaccount', ''),
|
||||||
|
('system', 'nssextrausers', '0'),
|
||||||
|
('system', 'disable_le_selfcheck', '0'),
|
||||||
|
('system', 'ssl_protocols', 'TLSv1,TLSv1.2'),
|
||||||
|
('system', 'logfiles_format', ''),
|
||||||
|
('system', 'logfiles_type', '1'),
|
||||||
|
('system', 'logfiles_piped', '0'),
|
||||||
|
('system', 'logfiles_script', ''),
|
||||||
('panel', 'decimal_places', '4'),
|
('panel', 'decimal_places', '4'),
|
||||||
('panel', 'adminmail', 'admin@SERVERNAME'),
|
('panel', 'adminmail', 'admin@SERVERNAME'),
|
||||||
('panel', 'phpmyadmin_url', ''),
|
('panel', 'phpmyadmin_url', ''),
|
||||||
@@ -581,8 +684,8 @@ INSERT INTO `panel_settings` (`settinggroup`, `varname`, `value`) VALUES
|
|||||||
('panel', 'password_special_char_required', '0'),
|
('panel', 'password_special_char_required', '0'),
|
||||||
('panel', 'password_special_char', '!?<>§$%+#=@'),
|
('panel', 'password_special_char', '!?<>§$%+#=@'),
|
||||||
('panel', 'customer_hide_options', ''),
|
('panel', 'customer_hide_options', ''),
|
||||||
('panel', 'version', '0.9.38.5'),
|
('panel', 'version', '0.9.40'),
|
||||||
('panel', 'db_version', '201612110');
|
('panel', 'db_version', '201809280');
|
||||||
|
|
||||||
|
|
||||||
DROP TABLE IF EXISTS `panel_tasks`;
|
DROP TABLE IF EXISTS `panel_tasks`;
|
||||||
@@ -748,6 +851,33 @@ CREATE TABLE IF NOT EXISTS `panel_syslog` (
|
|||||||
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
DROP TABLE IF EXISTS `panel_fpmdaemons`;
|
||||||
|
CREATE TABLE `panel_fpmdaemons` (
|
||||||
|
`id` int(11) unsigned NOT NULL auto_increment,
|
||||||
|
`description` varchar(50) NOT NULL,
|
||||||
|
`reload_cmd` varchar(255) NOT NULL,
|
||||||
|
`config_dir` varchar(255) NOT NULL,
|
||||||
|
`pm` varchar(15) NOT NULL DEFAULT 'static',
|
||||||
|
`max_children` int(4) NOT NULL DEFAULT '1',
|
||||||
|
`start_servers` int(4) NOT NULL DEFAULT '20',
|
||||||
|
`min_spare_servers` int(4) NOT NULL DEFAULT '5',
|
||||||
|
`max_spare_servers` int(4) NOT NULL DEFAULT '35',
|
||||||
|
`max_requests` int(4) NOT NULL DEFAULT '0',
|
||||||
|
`idle_timeout` int(4) NOT NULL DEFAULT '30',
|
||||||
|
`limit_extensions` varchar(255) NOT NULL default '.php',
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
UNIQUE KEY `reload` (`reload_cmd`),
|
||||||
|
UNIQUE KEY `config` (`config_dir`)
|
||||||
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `panel_fpmdaemons` (`id`, `description`, `reload_cmd`, `config_dir`) VALUES
|
||||||
|
(1, 'System default', 'service php7.0-fpm restart', '/etc/php/7.0/fpm/pool.d/');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
DROP TABLE IF EXISTS `panel_phpconfigs`;
|
DROP TABLE IF EXISTS `panel_phpconfigs`;
|
||||||
CREATE TABLE `panel_phpconfigs` (
|
CREATE TABLE `panel_phpconfigs` (
|
||||||
`id` int(11) unsigned NOT NULL auto_increment,
|
`id` int(11) unsigned NOT NULL auto_increment,
|
||||||
@@ -761,14 +891,26 @@ CREATE TABLE `panel_phpconfigs` (
|
|||||||
`fpm_reqterm` varchar(15) NOT NULL default '60s',
|
`fpm_reqterm` varchar(15) NOT NULL default '60s',
|
||||||
`fpm_reqslow` varchar(15) NOT NULL default '5s',
|
`fpm_reqslow` varchar(15) NOT NULL default '5s',
|
||||||
`phpsettings` text NOT NULL,
|
`phpsettings` text NOT NULL,
|
||||||
PRIMARY KEY (`id`)
|
`fpmsettingid` int(11) NOT NULL DEFAULT '1',
|
||||||
|
`pass_authorizationheader` tinyint(1) NOT NULL default '0',
|
||||||
|
`override_fpmconfig` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
|
`pm` varchar(15) NOT NULL DEFAULT 'static',
|
||||||
|
`max_children` int(4) NOT NULL DEFAULT '1',
|
||||||
|
`start_servers` int(4) NOT NULL DEFAULT '20',
|
||||||
|
`min_spare_servers` int(4) NOT NULL DEFAULT '5',
|
||||||
|
`max_spare_servers` int(4) NOT NULL DEFAULT '35',
|
||||||
|
`max_requests` int(4) NOT NULL DEFAULT '0',
|
||||||
|
`idle_timeout` int(4) NOT NULL DEFAULT '30',
|
||||||
|
`limit_extensions` varchar(255) NOT NULL default '.php',
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
KEY `fpmsettingid` (`fpmsettingid`)
|
||||||
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
INSERT INTO `panel_phpconfigs` (`id`, `description`, `binary`, `file_extensions`, `mod_fcgid_starter`, `mod_fcgid_maxrequests`, `phpsettings`) VALUES
|
INSERT INTO `panel_phpconfigs` (`id`, `description`, `binary`, `file_extensions`, `mod_fcgid_starter`, `mod_fcgid_maxrequests`, `phpsettings`) VALUES
|
||||||
(1, 'Default Config', '/usr/bin/php-cgi', 'php', '-1', '-1', 'allow_call_time_pass_reference = Off\r\nallow_url_fopen = Off\r\nasp_tags = Off\r\ndisable_classes =\r\ndisable_functions = curl_exec,curl_multi_exec,exec,parse_ini_file,passthru,popen,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,system\r\ndisplay_errors = Off\r\ndisplay_startup_errors = Off\r\nenable_dl = Off\r\nerror_reporting = E_ALL & ~E_NOTICE\r\nexpose_php = Off\r\nfile_uploads = On\r\ncgi.force_redirect = 1\r\ngpc_order = "GPC"\r\nhtml_errors = Off\r\nignore_repeated_errors = Off\r\nignore_repeated_source = Off\r\ninclude_path = ".:{PEAR_DIR}"\r\nlog_errors = On\r\nlog_errors_max_len = 1024\r\nmagic_quotes_gpc = Off\r\nmagic_quotes_runtime = Off\r\nmagic_quotes_sybase = Off\r\nmax_execution_time = 30\r\nmax_input_time = 60\r\nmemory_limit = 128M\r\n{OPEN_BASEDIR_C}open_basedir = "{OPEN_BASEDIR}"\r\noutput_buffering = 4096\r\npost_max_size = 16M\r\nprecision = 14\r\nregister_argc_argv = Off\r\nregister_globals = Off\r\nreport_memleaks = On\r\nsendmail_path = "/usr/sbin/sendmail -t -i -f {CUSTOMER_EMAIL}"\r\nsession.auto_start = 0\r\nsession.bug_compat_42 = 0\r\nsession.bug_compat_warn = 1\r\nsession.cache_expire = 180\r\nsession.cache_limiter = nocache\r\nsession.cookie_domain =\r\nsession.cookie_lifetime = 0\r\nsession.cookie_path = /\r\nsession.entropy_file = /dev/urandom\r\nsession.entropy_length = 16\r\nsession.gc_divisor = 1000\r\nsession.gc_maxlifetime = 1440\r\nsession.gc_probability = 1\r\nsession.name = PHPSESSID\r\nsession.referer_check =\r\nsession.save_handler = files\r\nsession.save_path = "{TMP_DIR}"\r\nsession.serialize_handler = php\r\nsession.use_cookies = 1\r\nsession.use_trans_sid = 0\r\nshort_open_tag = On\r\nsuhosin.mail.protect = 1\r\nsuhosin.simulation = Off\r\ntrack_errors = Off\r\nupload_max_filesize = 32M\r\nupload_tmp_dir = "{TMP_DIR}"\r\nvariables_order = "GPCS"\r\n;mail.add_x_header = On\r\n;mail.log = "/var/log/phpmail.log"\r\nopcache.restrict_api = "{DOCUMENT_ROOT}"\r\n'),
|
(1, 'Default Config', '/usr/bin/php-cgi', 'php', '-1', '-1', 'allow_call_time_pass_reference = Off\r\nallow_url_fopen = Off\r\nasp_tags = Off\r\ndisable_classes =\r\ndisable_functions = curl_exec,curl_multi_exec,exec,parse_ini_file,passthru,popen,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,system\r\ndisplay_errors = Off\r\ndisplay_startup_errors = Off\r\nenable_dl = Off\r\nerror_reporting = E_ALL & ~E_NOTICE\r\nexpose_php = Off\r\nfile_uploads = On\r\ncgi.force_redirect = 1\r\ngpc_order = "GPC"\r\nhtml_errors = Off\r\nignore_repeated_errors = Off\r\nignore_repeated_source = Off\r\ninclude_path = ".:{PEAR_DIR}"\r\nlog_errors = On\r\nlog_errors_max_len = 1024\r\nmagic_quotes_gpc = Off\r\nmagic_quotes_runtime = Off\r\nmagic_quotes_sybase = Off\r\nmax_execution_time = 30\r\nmax_input_time = 60\r\nmemory_limit = 128M\r\n{OPEN_BASEDIR_C}open_basedir = "{OPEN_BASEDIR}"\r\noutput_buffering = 4096\r\npost_max_size = 16M\r\nprecision = 14\r\nregister_argc_argv = Off\r\nregister_globals = Off\r\nreport_memleaks = On\r\nsendmail_path = "/usr/sbin/sendmail -t -i -f {CUSTOMER_EMAIL}"\r\nsession.auto_start = 0\r\nsession.bug_compat_42 = 0\r\nsession.bug_compat_warn = 1\r\nsession.cache_expire = 180\r\nsession.cache_limiter = nocache\r\nsession.cookie_domain =\r\nsession.cookie_lifetime = 0\r\nsession.cookie_path = /\r\nsession.entropy_file = /dev/urandom\r\nsession.entropy_length = 16\r\nsession.gc_divisor = 1000\r\nsession.gc_maxlifetime = 1440\r\nsession.gc_probability = 1\r\nsession.name = PHPSESSID\r\nsession.referer_check =\r\nsession.save_handler = files\r\nsession.save_path = "{TMP_DIR}"\r\nsession.serialize_handler = php\r\nsession.use_cookies = 1\r\nsession.use_trans_sid = 0\r\nshort_open_tag = On\r\nsuhosin.mail.protect = 1\r\nsuhosin.simulation = Off\r\ntrack_errors = Off\r\nupload_max_filesize = 32M\r\nupload_tmp_dir = "{TMP_DIR}"\r\nvariables_order = "GPCS"\r\n;mail.add_x_header = On\r\n;mail.log = "/var/log/phpmail.log"\r\nopcache.restrict_api = "{DOCUMENT_ROOT}"\r\n'),
|
||||||
(2, 'Froxlor Vhost Config', '/usr/bin/php-cgi', 'php', '-1', '-1', 'allow_call_time_pass_reference = Off\r\nallow_url_fopen = On\r\nasp_tags = Off\r\ndisable_classes =\r\ndisable_functions = curl_multi_exec,exec,parse_ini_file,passthru,popen,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,system\r\ndisplay_errors = Off\r\ndisplay_startup_errors = Off\r\nenable_dl = Off\r\nerror_reporting = E_ALL & ~E_NOTICE\r\nexpose_php = Off\r\nfile_uploads = On\r\ncgi.force_redirect = 1\r\ngpc_order = "GPC"\r\nhtml_errors = Off\r\nignore_repeated_errors = Off\r\nignore_repeated_source = Off\r\ninclude_path = ".:{PEAR_DIR}"\r\nlog_errors = On\r\nlog_errors_max_len = 1024\r\nmagic_quotes_gpc = Off\r\nmagic_quotes_runtime = Off\r\nmagic_quotes_sybase = Off\r\nmax_execution_time = 60\r\nmax_input_time = 60\r\nmemory_limit = 128M\r\nnoutput_buffering = 4096\r\npost_max_size = 16M\r\nprecision = 14\r\nregister_argc_argv = Off\r\nregister_globals = Off\r\nreport_memleaks = On\r\nsendmail_path = "/usr/sbin/sendmail -t -i -f {CUSTOMER_EMAIL}"\r\nsession.auto_start = 0\r\nsession.bug_compat_42 = 0\r\nsession.bug_compat_warn = 1\r\nsession.cache_expire = 180\r\nsession.cache_limiter = nocache\r\nsession.cookie_domain =\r\nsession.cookie_lifetime = 0\r\nsession.cookie_path = /\r\nsession.entropy_file = /dev/urandom\r\nsession.entropy_length = 16\r\nsession.gc_divisor = 1000\r\nsession.gc_maxlifetime = 1440\r\nsession.gc_probability = 1\r\nsession.name = PHPSESSID\r\nsession.referer_check =\r\nsession.save_handler = files\r\nsession.save_path = "{TMP_DIR}"\r\nsession.serialize_handler = php\r\nsession.use_cookies = 1\r\nsession.use_trans_sid = 0\r\nshort_open_tag = On\r\nsuhosin.mail.protect = 1\r\nsuhosin.simulation = Off\r\ntrack_errors = Off\r\nupload_max_filesize = 32M\r\nupload_tmp_dir = "{TMP_DIR}"\r\nvariables_order = "GPCS"\r\n;mail.add_x_header = On\r\n;mail.log = "/var/log/phpmail.log"\r\nopcache.restrict_api = ""\r\n');
|
(2, 'Froxlor Vhost Config', '/usr/bin/php-cgi', 'php', '-1', '-1', 'allow_call_time_pass_reference = Off\r\nallow_url_fopen = On\r\nasp_tags = Off\r\ndisable_classes =\r\ndisable_functions = curl_multi_exec,exec,parse_ini_file,passthru,popen,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,system\r\ndisplay_errors = Off\r\ndisplay_startup_errors = Off\r\nenable_dl = Off\r\nerror_reporting = E_ALL & ~E_NOTICE\r\nexpose_php = Off\r\nfile_uploads = On\r\ncgi.force_redirect = 1\r\ngpc_order = "GPC"\r\nhtml_errors = Off\r\nignore_repeated_errors = Off\r\nignore_repeated_source = Off\r\ninclude_path = ".:{PEAR_DIR}"\r\nlog_errors = On\r\nlog_errors_max_len = 1024\r\nmagic_quotes_gpc = Off\r\nmagic_quotes_runtime = Off\r\nmagic_quotes_sybase = Off\r\nmax_execution_time = 60\r\nmax_input_time = 60\r\nmemory_limit = 128M\r\noutput_buffering = 4096\r\npost_max_size = 16M\r\nprecision = 14\r\nregister_argc_argv = Off\r\nregister_globals = Off\r\nreport_memleaks = On\r\nsendmail_path = "/usr/sbin/sendmail -t -i -f {CUSTOMER_EMAIL}"\r\nsession.auto_start = 0\r\nsession.bug_compat_42 = 0\r\nsession.bug_compat_warn = 1\r\nsession.cache_expire = 180\r\nsession.cache_limiter = nocache\r\nsession.cookie_domain =\r\nsession.cookie_lifetime = 0\r\nsession.cookie_path = /\r\nsession.entropy_file = /dev/urandom\r\nsession.entropy_length = 16\r\nsession.gc_divisor = 1000\r\nsession.gc_maxlifetime = 1440\r\nsession.gc_probability = 1\r\nsession.name = PHPSESSID\r\nsession.referer_check =\r\nsession.save_handler = files\r\nsession.save_path = "{TMP_DIR}"\r\nsession.serialize_handler = php\r\nsession.use_cookies = 1\r\nsession.use_trans_sid = 0\r\nshort_open_tag = On\r\nsuhosin.mail.protect = 1\r\nsuhosin.simulation = Off\r\ntrack_errors = Off\r\nupload_max_filesize = 32M\r\nupload_tmp_dir = "{TMP_DIR}"\r\nvariables_order = "GPCS"\r\n;mail.add_x_header = On\r\n;mail.log = "/var/log/phpmail.log"\r\nopcache.restrict_api = ""\r\n');
|
||||||
|
|
||||||
|
|
||||||
DROP TABLE IF EXISTS `cronjobs_run`;
|
DROP TABLE IF EXISTS `cronjobs_run`;
|
||||||
@@ -863,11 +1005,12 @@ DROP TABLE IF EXISTS `domain_ssl_settings`;
|
|||||||
CREATE TABLE IF NOT EXISTS `domain_ssl_settings` (
|
CREATE TABLE IF NOT EXISTS `domain_ssl_settings` (
|
||||||
`id` int(5) NOT NULL auto_increment,
|
`id` int(5) NOT NULL auto_increment,
|
||||||
`domainid` int(11) NOT NULL,
|
`domainid` int(11) NOT NULL,
|
||||||
`ssl_cert_file` mediumtext NOT NULL,
|
`ssl_cert_file` mediumtext,
|
||||||
`ssl_key_file` mediumtext NOT NULL,
|
`ssl_key_file` mediumtext,
|
||||||
`ssl_ca_file` mediumtext,
|
`ssl_ca_file` mediumtext,
|
||||||
`ssl_cert_chainfile` mediumtext,
|
`ssl_cert_chainfile` mediumtext,
|
||||||
`ssl_csr_file` mediumtext,
|
`ssl_csr_file` mediumtext,
|
||||||
|
`ssl_fullchain_file` mediumtext,
|
||||||
`expirationdate` datetime DEFAULT NULL,
|
`expirationdate` datetime DEFAULT NULL,
|
||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`)
|
||||||
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
@@ -893,3 +1036,16 @@ CREATE TABLE `domain_dns_entries` (
|
|||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`)
|
||||||
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
|
|
||||||
|
|
||||||
|
DROP TABLE IF EXISTS `panel_plans`;
|
||||||
|
CREATE TABLE `panel_plans` (
|
||||||
|
`id` int(11) NOT NULL auto_increment,
|
||||||
|
`adminid` int(11) NOT NULL default '0',
|
||||||
|
`name` varchar(255) NOT NULL default '',
|
||||||
|
`description` text NOT NULL,
|
||||||
|
`value` longtext NOT NULL,
|
||||||
|
`ts` int(15) NOT NULL default '0',
|
||||||
|
PRIMARY KEY (id),
|
||||||
|
KEY adminid (adminid)
|
||||||
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,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
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
class FroxlorInstall
|
class FroxlorInstall
|
||||||
{
|
{
|
||||||
@@ -74,10 +74,17 @@ class FroxlorInstall
|
|||||||
/**
|
/**
|
||||||
* currently used language
|
* currently used language
|
||||||
*
|
*
|
||||||
* @var unknown
|
* @var string
|
||||||
*/
|
*/
|
||||||
private $_activelng = 'english';
|
private $_activelng = 'english';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* check whether to abort due to errors
|
||||||
|
*
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
private $_abort = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class constructor
|
* Class constructor
|
||||||
*/
|
*/
|
||||||
@@ -154,7 +161,7 @@ class FroxlorInstall
|
|||||||
$this->_guessServerName();
|
$this->_guessServerName();
|
||||||
$this->_guessServerIP();
|
$this->_guessServerIP();
|
||||||
$this->_guessWebserver();
|
$this->_guessWebserver();
|
||||||
|
|
||||||
$this->_getPostField('mysql_host', '127.0.0.1');
|
$this->_getPostField('mysql_host', '127.0.0.1');
|
||||||
$this->_getPostField('mysql_database', 'froxlor');
|
$this->_getPostField('mysql_database', 'froxlor');
|
||||||
$this->_getPostField('mysql_unpriv_user', 'froxlor');
|
$this->_getPostField('mysql_unpriv_user', 'froxlor');
|
||||||
@@ -169,22 +176,22 @@ class FroxlorInstall
|
|||||||
$this->_getPostField('httpuser', $posixusername['name']);
|
$this->_getPostField('httpuser', $posixusername['name']);
|
||||||
$posixgroup = posix_getgrgid(posix_getgid());
|
$posixgroup = posix_getgrgid(posix_getgid());
|
||||||
$this->_getPostField('httpgroup', $posixgroup['name']);
|
$this->_getPostField('httpgroup', $posixgroup['name']);
|
||||||
|
|
||||||
if ($this->_data['mysql_host'] == 'localhost' || $this->_data['mysql_host'] == '127.0.0.1') {
|
if ($this->_data['mysql_host'] == 'localhost' || $this->_data['mysql_host'] == '127.0.0.1') {
|
||||||
$this->_data['mysql_access_host'] = $this->_data['mysql_host'];
|
$this->_data['mysql_access_host'] = $this->_data['mysql_host'];
|
||||||
} else {
|
} else {
|
||||||
$this->_data['mysql_access_host'] = $this->_data['serverip'];
|
$this->_data['mysql_access_host'] = $this->_data['serverip'];
|
||||||
}
|
}
|
||||||
|
|
||||||
// check system-hostname to be a FQDN
|
// check system-hostname to be a FQDN
|
||||||
if ($this->_validate_ip($this->_data['servername']) !== false) {
|
if ($this->_validate_ip($this->_data['servername']) !== false) {
|
||||||
$this->_data['servername'] = '';
|
$this->_data['servername'] = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($this->_data['serverip'] || $this->_validate_ip($this->_data['serverip']) == false)) {
|
if (empty($this->_data['serverip']) || $this->_validate_ip($this->_data['serverip']) == false) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($_POST['installstep']) && $_POST['installstep'] == '1' && $this->_data['admin_pass1'] == $this->_data['admin_pass2'] && $this->_data['admin_pass1'] != '' && $this->_data['admin_pass2'] != '' && $this->_data['mysql_unpriv_pass'] != '' && $this->_data['mysql_root_pass'] != '' && $this->_data['servername'] != '' && $this->_data['serverip'] != '' && $this->_data['httpuser'] != '' && $this->_data['httpgroup'] != '' && $this->_data['mysql_unpriv_user'] != $this->_data['mysql_root_user']) {
|
if (isset($_POST['installstep']) && $_POST['installstep'] == '1' && $this->_data['admin_pass1'] == $this->_data['admin_pass2'] && $this->_data['admin_pass1'] != '' && $this->_data['admin_pass2'] != '' && $this->_data['mysql_unpriv_pass'] != '' && $this->_data['mysql_root_pass'] != '' && $this->_data['servername'] != '' && $this->_data['serverip'] != '' && $this->_data['httpuser'] != '' && $this->_data['httpgroup'] != '' && $this->_data['mysql_unpriv_user'] != $this->_data['mysql_root_user']) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -199,12 +206,12 @@ class FroxlorInstall
|
|||||||
private function _doInstall()
|
private function _doInstall()
|
||||||
{
|
{
|
||||||
$content = "<table class=\"noborder\">";
|
$content = "<table class=\"noborder\">";
|
||||||
|
|
||||||
// check for mysql-root-connection
|
// check for mysql-root-connection
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['testing_mysql']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['testing_mysql']);
|
||||||
|
|
||||||
$options = array(
|
$options = array(
|
||||||
'PDO::MYSQL_ATTR_INIT_COMMAND' => 'set names utf8'
|
'PDO::MYSQL_ATTR_INIT_COMMAND' => 'SET names utf8,sql_mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"'
|
||||||
);
|
);
|
||||||
$dsn = "mysql:host=" . $this->_data['mysql_host'] . ";";
|
$dsn = "mysql:host=" . $this->_data['mysql_host'] . ";";
|
||||||
$fatal_fail = false;
|
$fatal_fail = false;
|
||||||
@@ -227,9 +234,9 @@ class FroxlorInstall
|
|||||||
$fatal_fail = true;
|
$fatal_fail = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! $fatal_fail) {
|
if (! $fatal_fail) {
|
||||||
|
|
||||||
// ok, if we are here, the database connection is up and running
|
// ok, if we are here, the database connection is up and running
|
||||||
$content .= $this->_status_message('green', "OK");
|
$content .= $this->_status_message('green', "OK");
|
||||||
// check for existing db and create backup if so
|
// check for existing db and create backup if so
|
||||||
@@ -238,36 +245,37 @@ class FroxlorInstall
|
|||||||
$content .= $this->_createDatabaseAndUser($db_root);
|
$content .= $this->_createDatabaseAndUser($db_root);
|
||||||
// importing data to new database
|
// importing data to new database
|
||||||
$content .= $this->_importDatabaseData();
|
$content .= $this->_importDatabaseData();
|
||||||
// create DB object for new database
|
if (! $this->_abort) {
|
||||||
$options = array(
|
// create DB object for new database
|
||||||
'PDO::MYSQL_ATTR_INIT_COMMAND' => 'set names utf8'
|
$options = array(
|
||||||
);
|
'PDO::MYSQL_ATTR_INIT_COMMAND' => 'SET names utf8,sql_mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"'
|
||||||
$dsn = "mysql:host=" . $this->_data['mysql_host'] . ";dbname=" . $this->_data['mysql_database'] . ";";
|
);
|
||||||
$another_fail = false;
|
$dsn = "mysql:host=" . $this->_data['mysql_host'] . ";dbname=" . $this->_data['mysql_database'] . ";";
|
||||||
try {
|
$another_fail = false;
|
||||||
$db = new PDO($dsn, $this->_data['mysql_unpriv_user'], $this->_data['mysql_unpriv_pass'], $options);
|
try {
|
||||||
} catch (PDOException $e) {
|
$db = new PDO($dsn, $this->_data['mysql_unpriv_user'], $this->_data['mysql_unpriv_pass'], $options);
|
||||||
// dafuq? this should have happened in _importDatabaseData()
|
} catch (PDOException $e) {
|
||||||
$content .= $this->_status_message('red', $e->getMessage());
|
// dafuq? this should have happened in _importDatabaseData()
|
||||||
$another_fail = true;
|
$content .= $this->_status_message('red', $e->getMessage());
|
||||||
}
|
$another_fail = true;
|
||||||
;
|
}
|
||||||
|
|
||||||
if (! $another_fail) {
|
if (! $another_fail) {
|
||||||
// change settings accordingly
|
// change settings accordingly
|
||||||
$content .= $this->_doSettings($db);
|
$content .= $this->_doSettings($db);
|
||||||
// create entries
|
// create entries
|
||||||
$content .= $this->_doDataEntries($db);
|
$content .= $this->_doDataEntries($db);
|
||||||
$db = null;
|
$db = null;
|
||||||
// create config-file
|
// create config-file
|
||||||
$content .= $this->_createUserdataConf();
|
$content .= $this->_createUserdataConf();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$content .= "</table>";
|
$content .= "</table>";
|
||||||
|
|
||||||
// check if we have unrecoverable errors
|
// check if we have unrecoverable errors
|
||||||
if ($fatal_fail || $another_fail) {
|
if ($fatal_fail || $another_fail || $this->_abort) {
|
||||||
// D'oh
|
// D'oh
|
||||||
$navigation = '';
|
$navigation = '';
|
||||||
$msgcolor = 'red';
|
$msgcolor = 'red';
|
||||||
@@ -282,9 +290,9 @@ class FroxlorInstall
|
|||||||
$link = '../index.php';
|
$link = '../index.php';
|
||||||
$linktext = $this->_lng['click_here_to_login'];
|
$linktext = $this->_lng['click_here_to_login'];
|
||||||
}
|
}
|
||||||
|
|
||||||
eval("\$navigation .= \"" . $this->_getTemplate("pagebottom") . "\";");
|
eval("\$navigation .= \"" . $this->_getTemplate("pagebottom") . "\";");
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'pagecontent' => $content,
|
'pagecontent' => $content,
|
||||||
'pagenavigation' => $navigation
|
'pagenavigation' => $navigation
|
||||||
@@ -297,7 +305,7 @@ class FroxlorInstall
|
|||||||
private function _createUserdataConf()
|
private function _createUserdataConf()
|
||||||
{
|
{
|
||||||
$content = "";
|
$content = "";
|
||||||
|
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['creating_configfile']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['creating_configfile']);
|
||||||
$userdata = "<?php\n";
|
$userdata = "<?php\n";
|
||||||
$userdata .= "// automatically generated userdata.inc.php for Froxlor\n";
|
$userdata .= "// automatically generated userdata.inc.php for Froxlor\n";
|
||||||
@@ -312,13 +320,14 @@ class FroxlorInstall
|
|||||||
$userdata .= "// enable debugging to browser in case of SQL errors\n";
|
$userdata .= "// enable debugging to browser in case of SQL errors\n";
|
||||||
$userdata .= "\$sql['debug'] = false;\n";
|
$userdata .= "\$sql['debug'] = false;\n";
|
||||||
$userdata .= "?>";
|
$userdata .= "?>";
|
||||||
|
|
||||||
// test if we can store the userdata.inc.php in ../lib
|
// test if we can store the userdata.inc.php in ../lib
|
||||||
if ($fp = @fopen(dirname(dirname(dirname(__FILE__))) . '/lib/userdata.inc.php', 'w')) {
|
$userdata_file = dirname(dirname(dirname(__FILE__))) . '/lib/userdata.inc.php';
|
||||||
|
if ($fp = @fopen($userdata_file, 'w')) {
|
||||||
$result = @fputs($fp, $userdata, strlen($userdata));
|
$result = @fputs($fp, $userdata, strlen($userdata));
|
||||||
@fclose($fp);
|
@fclose($fp);
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
chmod('../lib/userdata.inc.php', 0440);
|
chmod($userdata_file, 0440);
|
||||||
} elseif ($fp = @fopen('/tmp/userdata.inc.php', 'w')) {
|
} elseif ($fp = @fopen('/tmp/userdata.inc.php', 'w')) {
|
||||||
$result = @fputs($fp, $userdata, strlen($userdata));
|
$result = @fputs($fp, $userdata, strlen($userdata));
|
||||||
@fclose($fp);
|
@fclose($fp);
|
||||||
@@ -329,7 +338,7 @@ class FroxlorInstall
|
|||||||
$escpduserdata = nl2br(htmlspecialchars($userdata));
|
$escpduserdata = nl2br(htmlspecialchars($userdata));
|
||||||
eval("\$content .= \"" . $this->_getTemplate("textarea") . "\";");
|
eval("\$content .= \"" . $this->_getTemplate("textarea") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -343,9 +352,9 @@ class FroxlorInstall
|
|||||||
private function _doDataEntries(&$db)
|
private function _doDataEntries(&$db)
|
||||||
{
|
{
|
||||||
$content = "";
|
$content = "";
|
||||||
|
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['creating_entries']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['creating_entries']);
|
||||||
|
|
||||||
// and lets insert the default ip and port
|
// and lets insert the default ip and port
|
||||||
$stmt = $db->prepare("
|
$stmt = $db->prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_IPSANDPORTS . "` SET
|
INSERT INTO `" . TABLE_PANEL_IPSANDPORTS . "` SET
|
||||||
@@ -359,7 +368,7 @@ class FroxlorInstall
|
|||||||
'serverip' => $this->_data['serverip']
|
'serverip' => $this->_data['serverip']
|
||||||
));
|
));
|
||||||
$defaultip = $db->lastInsertId();
|
$defaultip = $db->lastInsertId();
|
||||||
|
|
||||||
// insert the defaultip
|
// insert the defaultip
|
||||||
$upd_stmt = $db->prepare("
|
$upd_stmt = $db->prepare("
|
||||||
UPDATE `" . TABLE_PANEL_SETTINGS . "` SET
|
UPDATE `" . TABLE_PANEL_SETTINGS . "` SET
|
||||||
@@ -369,9 +378,9 @@ class FroxlorInstall
|
|||||||
$upd_stmt->execute(array(
|
$upd_stmt->execute(array(
|
||||||
'defaultip' => $defaultip
|
'defaultip' => $defaultip
|
||||||
));
|
));
|
||||||
|
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
|
||||||
// last but not least create the main admin
|
// last but not least create the main admin
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['adding_admin_user']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['adding_admin_user']);
|
||||||
$ins_data = array(
|
$ins_data = array(
|
||||||
@@ -406,11 +415,11 @@ class FroxlorInstall
|
|||||||
`subdomains` = -1,
|
`subdomains` = -1,
|
||||||
`traffic` = -1048576
|
`traffic` = -1048576
|
||||||
");
|
");
|
||||||
|
|
||||||
$ins_stmt->execute($ins_data);
|
$ins_stmt->execute($ins_data);
|
||||||
|
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -441,14 +450,14 @@ class FroxlorInstall
|
|||||||
private function _doSettings(&$db)
|
private function _doSettings(&$db)
|
||||||
{
|
{
|
||||||
$content = "";
|
$content = "";
|
||||||
|
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['changing_data']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['changing_data']);
|
||||||
$upd_stmt = $db->prepare("
|
$upd_stmt = $db->prepare("
|
||||||
UPDATE `" . TABLE_PANEL_SETTINGS . "` SET
|
UPDATE `" . TABLE_PANEL_SETTINGS . "` SET
|
||||||
`value` = :value
|
`value` = :value
|
||||||
WHERE `settinggroup` = :group AND `varname` = :varname
|
WHERE `settinggroup` = :group AND `varname` = :varname
|
||||||
");
|
");
|
||||||
|
|
||||||
$this->_updateSetting($upd_stmt, 'admin@' . $this->_data['servername'], 'panel', 'adminmail');
|
$this->_updateSetting($upd_stmt, 'admin@' . $this->_data['servername'], 'panel', 'adminmail');
|
||||||
$this->_updateSetting($upd_stmt, $this->_data['serverip'], 'system', 'ipaddress');
|
$this->_updateSetting($upd_stmt, $this->_data['serverip'], 'system', 'ipaddress');
|
||||||
$this->_updateSetting($upd_stmt, $this->_data['servername'], 'system', 'hostname');
|
$this->_updateSetting($upd_stmt, $this->_data['servername'], 'system', 'hostname');
|
||||||
@@ -457,7 +466,7 @@ class FroxlorInstall
|
|||||||
$this->_updateSetting($upd_stmt, $this->_data['webserver'], 'system', 'webserver');
|
$this->_updateSetting($upd_stmt, $this->_data['webserver'], 'system', 'webserver');
|
||||||
$this->_updateSetting($upd_stmt, $this->_data['httpuser'], 'system', 'httpuser');
|
$this->_updateSetting($upd_stmt, $this->_data['httpuser'], 'system', 'httpuser');
|
||||||
$this->_updateSetting($upd_stmt, $this->_data['httpgroup'], 'system', 'httpgroup');
|
$this->_updateSetting($upd_stmt, $this->_data['httpgroup'], 'system', 'httpgroup');
|
||||||
|
|
||||||
// necessary changes for webservers != apache2
|
// necessary changes for webservers != apache2
|
||||||
if ($this->_data['webserver'] == "apache24") {
|
if ($this->_data['webserver'] == "apache24") {
|
||||||
$this->_updateSetting($upd_stmt, 'apache2', 'system', 'webserver');
|
$this->_updateSetting($upd_stmt, 'apache2', 'system', 'webserver');
|
||||||
@@ -477,25 +486,25 @@ class FroxlorInstall
|
|||||||
$this->_updateSetting($upd_stmt, '/etc/nginx/nginx.pem', 'system', 'ssl_cert_file');
|
$this->_updateSetting($upd_stmt, '/etc/nginx/nginx.pem', 'system', 'ssl_cert_file');
|
||||||
$this->_updateSetting($upd_stmt, '/var/run/', 'phpfpm', 'fastcgi_ipcdir');
|
$this->_updateSetting($upd_stmt, '/var/run/', 'phpfpm', 'fastcgi_ipcdir');
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->_updateSetting($upd_stmt, $this->_data['activate_newsfeed'], 'admin', 'show_news_feed');
|
$this->_updateSetting($upd_stmt, $this->_data['activate_newsfeed'], 'admin', 'show_news_feed');
|
||||||
$this->_updateSetting($upd_stmt, dirname(dirname(dirname(__FILE__))), 'system', 'letsencryptchallengepath');
|
$this->_updateSetting($upd_stmt, dirname(dirname(dirname(__FILE__))), 'system', 'letsencryptchallengepath');
|
||||||
|
|
||||||
// insert the lastcronrun to be the installation date
|
// insert the lastcronrun to be the installation date
|
||||||
$this->_updateSetting($upd_stmt, time(), 'system', 'lastcronrun');
|
$this->_updateSetting($upd_stmt, time(), 'system', 'lastcronrun');
|
||||||
|
|
||||||
// set specific times for some crons (traffic only at night, etc.)
|
// set specific times for some crons (traffic only at night, etc.)
|
||||||
$ts = mktime(0, 0, 0, date('m', time()), date('d', time()), date('Y', time()));
|
$ts = mktime(0, 0, 0, date('m', time()), date('d', time()), date('Y', time()));
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_CRONRUNS . "` SET `lastrun` = '" . $ts . "' WHERE `cronfile` ='cron_traffic.php';");
|
$db->query("UPDATE `" . TABLE_PANEL_CRONRUNS . "` SET `lastrun` = '" . $ts . "' WHERE `cronfile` ='cron_traffic.php';");
|
||||||
$ts = mktime(1, 0, 0, date('m', time()), date('d', time()), date('Y', time()));
|
$ts = mktime(1, 0, 0, date('m', time()), date('d', time()), date('Y', time()));
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_CRONRUNS . "` SET `lastrun` = '" . $ts . "' WHERE `cronfile` ='cron_used_tickets_reset.php';");
|
$db->query("UPDATE `" . TABLE_PANEL_CRONRUNS . "` SET `lastrun` = '" . $ts . "' WHERE `cronfile` ='cron_used_tickets_reset.php';");
|
||||||
$db->query("UPDATE `" . TABLE_PANEL_CRONRUNS . "` SET `lastrun` = '" . $ts . "' WHERE `cronfile` ='cron_ticketarchive.php';");
|
$db->query("UPDATE `" . TABLE_PANEL_CRONRUNS . "` SET `lastrun` = '" . $ts . "' WHERE `cronfile` ='cron_ticketarchive.php';");
|
||||||
|
|
||||||
// insert task 99 to generate a correct cron.d-file automatically
|
// insert task 99 to generate a correct cron.d-file automatically
|
||||||
$db->query("INSERT INTO `" . TABLE_PANEL_TASKS . "` SET `type` = '99';");
|
$db->query("INSERT INTO `" . TABLE_PANEL_TASKS . "` SET `type` = '99';");
|
||||||
|
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -511,22 +520,28 @@ class FroxlorInstall
|
|||||||
$content = "";
|
$content = "";
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['testing_new_db']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['testing_new_db']);
|
||||||
$options = array(
|
$options = array(
|
||||||
'PDO::MYSQL_ATTR_INIT_COMMAND' => 'set names utf8'
|
'PDO::MYSQL_ATTR_INIT_COMMAND' => 'SET names utf8,sql_mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"'
|
||||||
);
|
);
|
||||||
$dsn = "mysql:host=" . $this->_data['mysql_host'] . ";dbname=" . $this->_data['mysql_database'] . ";";
|
$dsn = "mysql:host=" . $this->_data['mysql_host'] . ";dbname=" . $this->_data['mysql_database'] . ";";
|
||||||
$fatal_fail = false;
|
$fatal_fail = false;
|
||||||
try {
|
try {
|
||||||
$db = new PDO($dsn, $this->_data['mysql_unpriv_user'], $this->_data['mysql_unpriv_pass'], $options);
|
$db = new PDO($dsn, $this->_data['mysql_unpriv_user'], $this->_data['mysql_unpriv_pass'], $options);
|
||||||
|
$attributes = array(
|
||||||
|
'ATTR_ERRMODE' => 'ERRMODE_EXCEPTION'
|
||||||
|
);
|
||||||
|
// set attributes
|
||||||
|
foreach ($attributes as $k => $v) {
|
||||||
|
$db->setAttribute(constant("PDO::" . $k), constant("PDO::" . $v));
|
||||||
|
}
|
||||||
} catch (PDOException $e) {
|
} catch (PDOException $e) {
|
||||||
$content .= $this->_status_message('red', $e->getMessage());
|
$content .= $this->_status_message('red', $e->getMessage());
|
||||||
$fatal_fail = true;
|
$fatal_fail = true;
|
||||||
}
|
}
|
||||||
;
|
|
||||||
|
|
||||||
if (! $fatal_fail) {
|
if (! $fatal_fail) {
|
||||||
|
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['importing_data']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['importing_data']);
|
||||||
$db_schema = dirname(dirname(__FILE__)) . '/froxlor.sql';
|
$db_schema = dirname(dirname(__FILE__)) . '/froxlor.sql';
|
||||||
$sql_query = @file_get_contents($db_schema);
|
$sql_query = @file_get_contents($db_schema);
|
||||||
@@ -534,14 +549,23 @@ class FroxlorInstall
|
|||||||
$sql_query = $this->_split_sql_file($sql_query, ';');
|
$sql_query = $this->_split_sql_file($sql_query, ';');
|
||||||
for ($i = 0; $i < sizeof($sql_query); $i ++) {
|
for ($i = 0; $i < sizeof($sql_query); $i ++) {
|
||||||
if (trim($sql_query[$i]) != '') {
|
if (trim($sql_query[$i]) != '') {
|
||||||
$result = $db->query($sql_query[$i]);
|
try {
|
||||||
|
$result = $db->query($sql_query[$i]);
|
||||||
|
} catch (\PDOException $e) {
|
||||||
|
$content .= $this->_status_message('red', $e->getMessage());
|
||||||
|
$fatal_fail = true;
|
||||||
|
$this->_abort = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (! $fatal_fail) {
|
||||||
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
}
|
||||||
$db = null;
|
$db = null;
|
||||||
|
|
||||||
$content .= $this->_status_message('green', 'OK');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -555,56 +579,56 @@ class FroxlorInstall
|
|||||||
private function _createDatabaseAndUser(&$db_root)
|
private function _createDatabaseAndUser(&$db_root)
|
||||||
{
|
{
|
||||||
$content = "";
|
$content = "";
|
||||||
|
|
||||||
// so first we have to delete the database and
|
// so first we have to delete the database and
|
||||||
// the user given for the unpriv-user if they exit
|
// the user given for the unpriv-user if they exit
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['prepare_db']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['prepare_db']);
|
||||||
|
|
||||||
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`user` WHERE `User` = :user AND `Host` = :accesshost");
|
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`user` WHERE `User` = :user AND `Host` = :accesshost");
|
||||||
$del_stmt->execute(array(
|
$del_stmt->execute(array(
|
||||||
'user' => $this->_data['mysql_unpriv_user'],
|
'user' => $this->_data['mysql_unpriv_user'],
|
||||||
'accesshost' => $this->_data['mysql_access_host']
|
'accesshost' => $this->_data['mysql_access_host']
|
||||||
));
|
));
|
||||||
|
|
||||||
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`db` WHERE `User` = :user AND `Host` = :accesshost");
|
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`db` WHERE `User` = :user AND `Host` = :accesshost");
|
||||||
$del_stmt->execute(array(
|
$del_stmt->execute(array(
|
||||||
'user' => $this->_data['mysql_unpriv_user'],
|
'user' => $this->_data['mysql_unpriv_user'],
|
||||||
'accesshost' => $this->_data['mysql_access_host']
|
'accesshost' => $this->_data['mysql_access_host']
|
||||||
));
|
));
|
||||||
|
|
||||||
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`tables_priv` WHERE `User` = :user AND `Host` =:accesshost");
|
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`tables_priv` WHERE `User` = :user AND `Host` =:accesshost");
|
||||||
$del_stmt->execute(array(
|
$del_stmt->execute(array(
|
||||||
'user' => $this->_data['mysql_unpriv_user'],
|
'user' => $this->_data['mysql_unpriv_user'],
|
||||||
'accesshost' => $this->_data['mysql_access_host']
|
'accesshost' => $this->_data['mysql_access_host']
|
||||||
));
|
));
|
||||||
|
|
||||||
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`columns_priv` WHERE `User` = :user AND `Host` = :accesshost");
|
$del_stmt = $db_root->prepare("DELETE FROM `mysql`.`columns_priv` WHERE `User` = :user AND `Host` = :accesshost");
|
||||||
$del_stmt->execute(array(
|
$del_stmt->execute(array(
|
||||||
'user' => $this->_data['mysql_unpriv_user'],
|
'user' => $this->_data['mysql_unpriv_user'],
|
||||||
'accesshost' => $this->_data['mysql_access_host']
|
'accesshost' => $this->_data['mysql_access_host']
|
||||||
));
|
));
|
||||||
|
|
||||||
$del_stmt = $db_root->prepare("DROP DATABASE IF EXISTS `" . str_replace('`', '', $this->_data['mysql_database']) . "`;");
|
$del_stmt = $db_root->prepare("DROP DATABASE IF EXISTS `" . str_replace('`', '', $this->_data['mysql_database']) . "`;");
|
||||||
$del_stmt->execute();
|
$del_stmt->execute();
|
||||||
|
|
||||||
$db_root->query("FLUSH PRIVILEGES;");
|
$db_root->query("FLUSH PRIVILEGES;");
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
|
||||||
// we have to create a new user and database for the froxlor unprivileged mysql access
|
// we have to create a new user and database for the froxlor unprivileged mysql access
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['create_mysqluser_and_db']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['create_mysqluser_and_db']);
|
||||||
$ins_stmt = $db_root->prepare("CREATE DATABASE `" . str_replace('`', '', $this->_data['mysql_database']) . "` CHARACTER SET=utf8 COLLATE=utf8_general_ci");
|
$ins_stmt = $db_root->prepare("CREATE DATABASE `" . str_replace('`', '', $this->_data['mysql_database']) . "` CHARACTER SET=utf8 COLLATE=utf8_general_ci");
|
||||||
$ins_stmt->execute();
|
$ins_stmt->execute();
|
||||||
|
|
||||||
$mysql_access_host_array = array_map('trim', explode(',', $this->_data['mysql_access_host']));
|
$mysql_access_host_array = array_map('trim', explode(',', $this->_data['mysql_access_host']));
|
||||||
|
|
||||||
if (in_array('127.0.0.1', $mysql_access_host_array) && ! in_array('localhost', $mysql_access_host_array)) {
|
if (in_array('127.0.0.1', $mysql_access_host_array) && ! in_array('localhost', $mysql_access_host_array)) {
|
||||||
$mysql_access_host_array[] = 'localhost';
|
$mysql_access_host_array[] = 'localhost';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! in_array('127.0.0.1', $mysql_access_host_array) && in_array('localhost', $mysql_access_host_array)) {
|
if (! in_array('127.0.0.1', $mysql_access_host_array) && in_array('localhost', $mysql_access_host_array)) {
|
||||||
$mysql_access_host_array[] = '127.0.0.1';
|
$mysql_access_host_array[] = '127.0.0.1';
|
||||||
}
|
}
|
||||||
|
|
||||||
$mysql_access_host_array[] = $this->_data['serverip'];
|
$mysql_access_host_array[] = $this->_data['serverip'];
|
||||||
foreach ($mysql_access_host_array as $mysql_access_host) {
|
foreach ($mysql_access_host_array as $mysql_access_host) {
|
||||||
$_db = str_replace('`', '', $this->_data['mysql_database']);
|
$_db = str_replace('`', '', $this->_data['mysql_database']);
|
||||||
@@ -623,11 +647,11 @@ class FroxlorInstall
|
|||||||
"password" => $this->_data['mysql_unpriv_pass']
|
"password" => $this->_data['mysql_unpriv_pass']
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
$db_root->query("FLUSH PRIVILEGES;");
|
$db_root->query("FLUSH PRIVILEGES;");
|
||||||
$this->_data['mysql_access_host'] = implode(',', $mysql_access_host_array);
|
$this->_data['mysql_access_host'] = implode(',', $mysql_access_host_array);
|
||||||
$content .= $this->_status_message('green', 'OK');
|
$content .= $this->_status_message('green', 'OK');
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -641,7 +665,7 @@ class FroxlorInstall
|
|||||||
private function _backupExistingDatabase(&$db_root)
|
private function _backupExistingDatabase(&$db_root)
|
||||||
{
|
{
|
||||||
$content = "";
|
$content = "";
|
||||||
|
|
||||||
// check for existing of former database
|
// check for existing of former database
|
||||||
$tables_exist = false;
|
$tables_exist = false;
|
||||||
$sql = "SELECT SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = :database";
|
$sql = "SELECT SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = :database";
|
||||||
@@ -650,19 +674,19 @@ class FroxlorInstall
|
|||||||
'database' => $this->_data['mysql_database']
|
'database' => $this->_data['mysql_database']
|
||||||
));
|
));
|
||||||
$rows = $db_root->query("SELECT FOUND_ROWS()")->fetchColumn();
|
$rows = $db_root->query("SELECT FOUND_ROWS()")->fetchColumn();
|
||||||
|
|
||||||
// check result
|
// check result
|
||||||
if ($result_stmt !== false && $rows > 0) {
|
if ($result_stmt !== false && $rows > 0) {
|
||||||
$tables_exist = true;
|
$tables_exist = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($tables_exist) {
|
if ($tables_exist) {
|
||||||
// tell whats going on
|
// tell whats going on
|
||||||
$content .= $this->_status_message('begin', $this->_lng['install']['backup_old_db']);
|
$content .= $this->_status_message('begin', $this->_lng['install']['backup_old_db']);
|
||||||
|
|
||||||
// create temporary backup-filename
|
// create temporary backup-filename
|
||||||
$filename = "/tmp/froxlor_backup_" . date('YmdHi') . ".sql";
|
$filename = "/tmp/froxlor_backup_" . date('YmdHi') . ".sql";
|
||||||
|
|
||||||
// look for mysqldump
|
// look for mysqldump
|
||||||
$do_backup = false;
|
$do_backup = false;
|
||||||
if (file_exists("/usr/bin/mysqldump")) {
|
if (file_exists("/usr/bin/mysqldump")) {
|
||||||
@@ -672,7 +696,7 @@ class FroxlorInstall
|
|||||||
$do_backup = true;
|
$do_backup = true;
|
||||||
$mysql_dump = '/usr/local/bin/mysqldump';
|
$mysql_dump = '/usr/local/bin/mysqldump';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($do_backup) {
|
if ($do_backup) {
|
||||||
$command = $mysql_dump . " " . $this->_data['mysql_database'] . " -u " . $this->_data['mysql_root_user'] . " --password='" . $this->_data['mysql_root_pass'] . "' --result-file=" . $filename;
|
$command = $mysql_dump . " " . $this->_data['mysql_database'] . " -u " . $this->_data['mysql_root_user'] . " --password='" . $this->_data['mysql_root_pass'] . "' --result-file=" . $filename;
|
||||||
$output = exec($command);
|
$output = exec($command);
|
||||||
@@ -685,7 +709,7 @@ class FroxlorInstall
|
|||||||
$content .= $this->_status_message('red', $this->_lng['install']['backup_binary_missing']);
|
$content .= $this->_status_message('red', $this->_lng['install']['backup_binary_missing']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -702,12 +726,12 @@ class FroxlorInstall
|
|||||||
}
|
}
|
||||||
// language selection
|
// language selection
|
||||||
$language_options = '';
|
$language_options = '';
|
||||||
while (list ($language_file, $language_name) = each($this->_languages)) {
|
foreach ($this->_languages as $language_name => $language_file) {
|
||||||
$language_options .= makeoption($language_name, $language_file, $this->_activelng, true, true);
|
$language_options .= makeoption($language_name, $language_file, $this->_activelng, true, true);
|
||||||
}
|
}
|
||||||
// get language-form-template
|
// get language-form-template
|
||||||
eval("\$content .= \"" . $this->_getTemplate("lngform") . "\";");
|
eval("\$content .= \"" . $this->_getTemplate("lngform") . "\";");
|
||||||
|
|
||||||
// form-data
|
// form-data
|
||||||
$formdata = "";
|
$formdata = "";
|
||||||
/**
|
/**
|
||||||
@@ -747,7 +771,7 @@ class FroxlorInstall
|
|||||||
$style = '';
|
$style = '';
|
||||||
}
|
}
|
||||||
$formdata .= $this->_getSectionItemString('mysql_root_pass', true, $style, 'password');
|
$formdata .= $this->_getSectionItemString('mysql_root_pass', true, $style, 'password');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* admin data
|
* admin data
|
||||||
*/
|
*/
|
||||||
@@ -771,7 +795,7 @@ class FroxlorInstall
|
|||||||
$formdata .= $this->_getSectionItemString('admin_pass2', true, $style, 'password');
|
$formdata .= $this->_getSectionItemString('admin_pass2', true, $style, 'password');
|
||||||
// activate newsfeed?
|
// activate newsfeed?
|
||||||
$formdata .= $this->_getSectionItemYesNo('activate_newsfeed', true);
|
$formdata .= $this->_getSectionItemYesNo('activate_newsfeed', true);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Server data
|
* Server data
|
||||||
*/
|
*/
|
||||||
@@ -818,11 +842,11 @@ class FroxlorInstall
|
|||||||
$style = '';
|
$style = '';
|
||||||
}
|
}
|
||||||
$formdata .= $this->_getSectionItemString('httpgroup', true, $style);
|
$formdata .= $this->_getSectionItemString('httpgroup', true, $style);
|
||||||
|
|
||||||
// get data-form-template
|
// get data-form-template
|
||||||
$language = htmlspecialchars($this->_activelng);
|
$language = htmlspecialchars($this->_activelng);
|
||||||
eval("\$content .= \"" . $this->_getTemplate("dataform2") . "\";");
|
eval("\$content .= \"" . $this->_getTemplate("dataform2") . "\";");
|
||||||
|
|
||||||
$navigation = '';
|
$navigation = '';
|
||||||
return array(
|
return array(
|
||||||
'pagecontent' => $content,
|
'pagecontent' => $content,
|
||||||
@@ -839,7 +863,7 @@ class FroxlorInstall
|
|||||||
* optional css
|
* optional css
|
||||||
* @param string $type
|
* @param string $type
|
||||||
* optional type of input-box (default: text)
|
* optional type of input-box (default: text)
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
private function _getSectionItemString($fieldname = null, $required = false, $style = "", $type = 'text')
|
private function _getSectionItemString($fieldname = null, $required = false, $style = "", $type = 'text')
|
||||||
@@ -899,26 +923,26 @@ class FroxlorInstall
|
|||||||
*/
|
*/
|
||||||
private function _requirementCheck()
|
private function _requirementCheck()
|
||||||
{
|
{
|
||||||
|
|
||||||
// indicator whether we need to abort or not
|
// indicator whether we need to abort or not
|
||||||
$_die = false;
|
$_die = false;
|
||||||
|
|
||||||
$content = "<table class=\"noborder\">";
|
$content = "<table class=\"noborder\">";
|
||||||
|
|
||||||
// check for correct php version
|
// check for correct php version
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpversion']);
|
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpversion']);
|
||||||
|
|
||||||
if (version_compare("5.3.0", PHP_VERSION, ">=")) {
|
if (version_compare("5.3.0", PHP_VERSION, ">=")) {
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notfound'] . ' (' . PHP_VERSION . ')');
|
$content .= $this->_status_message('red', $this->_lng['requirements']['notfound'] . ' (' . PHP_VERSION . ')');
|
||||||
$_die = true;
|
$_die = true;
|
||||||
} else {
|
} else {
|
||||||
if (version_compare("5.6.0", PHP_VERSION, ">=")) {
|
if (version_compare("5.6.0", PHP_VERSION, ">=")) {
|
||||||
$content .= $this->_status_message('orange', $this->_lng['requirements']['newerphpprefered'] . ' (' .PHP_VERSION . ')');
|
$content .= $this->_status_message('orange', $this->_lng['requirements']['newerphpprefered'] . ' (' . PHP_VERSION . ')');
|
||||||
} else {
|
} else {
|
||||||
$content .= $this->_status_message('green', PHP_VERSION);
|
$content .= $this->_status_message('green', PHP_VERSION);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if magic_quotes_runtime is active | get_magic_quotes_runtime() is always FALSE since 5.4
|
// Check if magic_quotes_runtime is active | get_magic_quotes_runtime() is always FALSE since 5.4
|
||||||
if (version_compare(PHP_VERSION, "5.4.0", "<")) {
|
if (version_compare(PHP_VERSION, "5.4.0", "<")) {
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpmagic_quotes_runtime']);
|
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpmagic_quotes_runtime']);
|
||||||
@@ -930,10 +954,10 @@ class FroxlorInstall
|
|||||||
$content .= $this->_status_message('green', 'off');
|
$content .= $this->_status_message('green', 'off');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for php_pdo and pdo_mysql
|
// check for php_pdo and pdo_mysql
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phppdo']);
|
$content .= $this->_status_message('begin', $this->_lng['requirements']['phppdo']);
|
||||||
|
|
||||||
if (! extension_loaded('pdo') || in_array("mysql", PDO::getAvailableDrivers()) == false) {
|
if (! extension_loaded('pdo') || in_array("mysql", PDO::getAvailableDrivers()) == false) {
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
||||||
$_die = true;
|
$_die = true;
|
||||||
@@ -941,73 +965,38 @@ class FroxlorInstall
|
|||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check for session-extension
|
||||||
|
$this->_requirementCheckFor($content, $_die, 'session', false, 'phpsession');
|
||||||
|
|
||||||
|
// check for ctype-extension
|
||||||
|
$this->_requirementCheckFor($content, $_die, 'ctype', false, 'phpctype');
|
||||||
|
|
||||||
|
// check for SimpleXML-extension
|
||||||
|
$this->_requirementCheckFor($content, $_die, 'simplexml', false, 'phpsimplexml');
|
||||||
|
|
||||||
// check for xml-extension
|
// check for xml-extension
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpxml']);
|
$this->_requirementCheckFor($content, $_die, 'xml', false, 'phpxml');
|
||||||
|
|
||||||
if (! extension_loaded('xml')) {
|
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
|
||||||
$_die = true;
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for filter-extension
|
// check for filter-extension
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpfilter']);
|
$this->_requirementCheckFor($content, $_die, 'filter', false, 'phpfilter');
|
||||||
|
|
||||||
if (! extension_loaded('filter')) {
|
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
|
||||||
$_die = true;
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for posix-extension
|
// check for posix-extension
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpposix']);
|
$this->_requirementCheckFor($content, $_die, 'posix', false, 'phpposix');
|
||||||
|
|
||||||
if (! extension_loaded('posix')) {
|
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
|
||||||
$_die = true;
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for bstring-extension
|
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpmbstring']);
|
|
||||||
|
|
||||||
if (! extension_loaded('mbstring')) {
|
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
|
||||||
$_die = true;
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
// check for mbstring-extension
|
||||||
|
$this->_requirementCheckFor($content, $_die, 'mbstring', false, 'phpmbstring');
|
||||||
|
|
||||||
// check for curl extension
|
// check for curl extension
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpcurl']);
|
$this->_requirementCheckFor($content, $_die, 'curl', false, 'phpcurl');
|
||||||
|
|
||||||
if (! extension_loaded('curl')) {
|
// check for json extension
|
||||||
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
$this->_requirementCheckFor($content, $_die, 'json', false, 'phpjson');
|
||||||
$_die = true;
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for bcmath extension
|
// check for bcmath extension
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpbcmath']);
|
$this->_requirementCheckFor($content, $_die, 'bcmath', true, 'phpbcmath', 'bcmathdescription');
|
||||||
|
|
||||||
if (! extension_loaded('bcmath')) {
|
|
||||||
$content .= $this->_status_message('orange', $this->_lng['requirements']['notinstalled'] . "<br />" . $this->_lng['requirements']['bcmathdescription']);
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for zip extension
|
// check for zip extension
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['phpzip']);
|
$this->_requirementCheckFor($content, $_die, 'zip', true, 'phpzip', 'zipdescription');
|
||||||
|
|
||||||
if (! extension_loaded('zip')) {
|
|
||||||
$content .= $this->_status_message('orange', $this->_lng['requirements']['notinstalled'] . "<br />" . $this->_lng['requirements']['zipdescription']);
|
|
||||||
} else {
|
|
||||||
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for open_basedir
|
// check for open_basedir
|
||||||
$content .= $this->_status_message('begin', $this->_lng['requirements']['openbasedir']);
|
$content .= $this->_status_message('begin', $this->_lng['requirements']['openbasedir']);
|
||||||
@@ -1017,8 +1006,18 @@ class FroxlorInstall
|
|||||||
} else {
|
} else {
|
||||||
$content .= $this->_status_message('green', 'off');
|
$content .= $this->_status_message('green', 'off');
|
||||||
}
|
}
|
||||||
$content .= "</table>";
|
|
||||||
|
// check for mysqldump binary in order to backup existing database
|
||||||
|
$content .= $this->_status_message('begin', $this->_lng['requirements']['mysqldump']);
|
||||||
|
|
||||||
|
if (file_exists("/usr/bin/mysqldump") || file_exists("/usr/local/bin/mysqldump")) {
|
||||||
|
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
||||||
|
} else {
|
||||||
|
$content .= $this->_status_message('orange', $this->_lng['requirements']['notinstalled'] . "<br />" . $this->_lng['requirements']['mysqldumpmissing']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$content .= "</table>";
|
||||||
|
|
||||||
// check if we have unrecoverable errors
|
// check if we have unrecoverable errors
|
||||||
$navigation = '';
|
$navigation = '';
|
||||||
if ($_die) {
|
if ($_die) {
|
||||||
@@ -1033,12 +1032,28 @@ class FroxlorInstall
|
|||||||
$linktext = $this->_lng['click_here_to_continue'];
|
$linktext = $this->_lng['click_here_to_continue'];
|
||||||
}
|
}
|
||||||
eval("\$navigation .= \"" . $this->_getTemplate("pagebottom") . "\";");
|
eval("\$navigation .= \"" . $this->_getTemplate("pagebottom") . "\";");
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'pagecontent' => $content,
|
'pagecontent' => $content,
|
||||||
'pagenavigation' => $navigation
|
'pagenavigation' => $navigation
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function _requirementCheckFor(&$content, &$_die, $ext = '', $optional = false, $lng_txt = "", $lng_desc = "")
|
||||||
|
{
|
||||||
|
$content .= $this->_status_message('begin', $this->_lng['requirements'][$lng_txt]);
|
||||||
|
|
||||||
|
if (! extension_loaded($ext)) {
|
||||||
|
if (!$optional) {
|
||||||
|
$content .= $this->_status_message('red', $this->_lng['requirements']['notinstalled']);
|
||||||
|
$_die = true;
|
||||||
|
} else {
|
||||||
|
$content .= $this->_status_message('orange', $this->_lng['requirements']['notinstalled'] . "<br />" . $this->_lng['requirements'][$lng_desc]);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$content .= $this->_status_message('green', $this->_lng['requirements']['installed']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* send no-caching headers and set the default timezone
|
* send no-caching headers and set the default timezone
|
||||||
@@ -1050,7 +1065,7 @@ class FroxlorInstall
|
|||||||
header("Pragma: no-cache");
|
header("Pragma: no-cache");
|
||||||
header('Last-Modified: ' . gmdate('D, d M Y H:i:s \G\M\T', time()));
|
header('Last-Modified: ' . gmdate('D, d M Y H:i:s \G\M\T', time()));
|
||||||
header('Expires: ' . gmdate('D, d M Y H:i:s \G\M\T', time()));
|
header('Expires: ' . gmdate('D, d M Y H:i:s \G\M\T', time()));
|
||||||
|
|
||||||
// ensure that default timezone is set
|
// ensure that default timezone is set
|
||||||
if (function_exists("date_default_timezone_set") && function_exists("date_default_timezone_get")) {
|
if (function_exists("date_default_timezone_set") && function_exists("date_default_timezone_get")) {
|
||||||
@date_default_timezone_set(@date_default_timezone_get());
|
@date_default_timezone_set(@date_default_timezone_get());
|
||||||
@@ -1068,7 +1083,7 @@ class FroxlorInstall
|
|||||||
// includes the usersettings (MySQL-Username/Passwort)
|
// includes the usersettings (MySQL-Username/Passwort)
|
||||||
// to test if Froxlor is already installed
|
// to test if Froxlor is already installed
|
||||||
require $this->_basepath . '/lib/userdata.inc.php';
|
require $this->_basepath . '/lib/userdata.inc.php';
|
||||||
|
|
||||||
if (isset($sql) && is_array($sql)) {
|
if (isset($sql) && is_array($sql)) {
|
||||||
// use sparkle theme for the notice
|
// use sparkle theme for the notice
|
||||||
$installed_hint = file_get_contents($this->_basepath . '/templates/Sparkle/misc/alreadyinstalledhint.tpl');
|
$installed_hint = file_get_contents($this->_basepath . '/templates/Sparkle/misc/alreadyinstalledhint.tpl');
|
||||||
@@ -1085,7 +1100,7 @@ class FroxlorInstall
|
|||||||
{
|
{
|
||||||
// set default
|
// set default
|
||||||
$standardlanguage = 'english';
|
$standardlanguage = 'english';
|
||||||
|
|
||||||
// check either _GET or _POST
|
// check either _GET or _POST
|
||||||
if (isset($_GET['language']) && isset($this->_languages[$_GET['language']])) {
|
if (isset($_GET['language']) && isset($this->_languages[$_GET['language']])) {
|
||||||
$this->_activelng = $_GET['language'];
|
$this->_activelng = $_GET['language'];
|
||||||
@@ -1106,13 +1121,25 @@ class FroxlorInstall
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$lngfile = $this->_basepath . '/install/lng/' . $this->_activelng . '.lng.php';
|
// require english base language as fallback
|
||||||
|
$lngfile = $this->_basepath . '/install/lng/' . $standardlanguage . '.lng.php';
|
||||||
if (file_exists($lngfile)) {
|
if (file_exists($lngfile)) {
|
||||||
// includes file /lng/$language.lng.php if it exists
|
// includes file /lng/$language.lng.php if it exists
|
||||||
require $lngfile;
|
require $lngfile;
|
||||||
$this->_lng = $lng;
|
$this->_lng = $lng;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// require chosen language if not english
|
||||||
|
if ($this->_activelng != $standardlanguage)
|
||||||
|
{
|
||||||
|
$lngfile = $this->_basepath . '/install/lng/' . $this->_activelng . '.lng.php';
|
||||||
|
if (file_exists($lngfile)) {
|
||||||
|
// includes file /lng/$language.lng.php if it exists
|
||||||
|
require $lngfile;
|
||||||
|
$this->_lng = $lng;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -1120,7 +1147,7 @@ class FroxlorInstall
|
|||||||
*
|
*
|
||||||
* @param string $template
|
* @param string $template
|
||||||
* name of the template including subdirectory
|
* name of the template including subdirectory
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
private function _getTemplate($template = null)
|
private function _getTemplate($template = null)
|
||||||
@@ -1137,7 +1164,7 @@ class FroxlorInstall
|
|||||||
} else {
|
} else {
|
||||||
$templatefile = 'TEMPLATE NOT FOUND: ' . $filename;
|
$templatefile = 'TEMPLATE NOT FOUND: ' . $filename;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $templatefile;
|
return $templatefile;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1168,14 +1195,13 @@ class FroxlorInstall
|
|||||||
$this->_data['servername'] = $_POST['servername'];
|
$this->_data['servername'] = $_POST['servername'];
|
||||||
return;
|
return;
|
||||||
// from $_SERVER
|
// from $_SERVER
|
||||||
} else
|
} else if (! empty($_SERVER['SERVER_NAME'])) {
|
||||||
if (! empty($_SERVER['SERVER_NAME'])) {
|
// no ips
|
||||||
// no ips
|
if ($this->_validate_ip($_SERVER['SERVER_NAME']) == false) {
|
||||||
if ($this->_validate_ip($_SERVER['SERVER_NAME']) == false) {
|
$this->_data['servername'] = $_SERVER['SERVER_NAME'];
|
||||||
$this->_data['servername'] = $_SERVER['SERVER_NAME'];
|
return;
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// empty
|
// empty
|
||||||
$this->_data['servername'] = '';
|
$this->_data['servername'] = '';
|
||||||
}
|
}
|
||||||
@@ -1208,7 +1234,7 @@ class FroxlorInstall
|
|||||||
$this->_data['webserver'] = $_POST['webserver'];
|
$this->_data['webserver'] = $_POST['webserver'];
|
||||||
} else {
|
} else {
|
||||||
if (strtoupper(@php_sapi_name()) == "APACHE2HANDLER" || stristr($_SERVER['SERVER_SOFTWARE'], "apache/2")) {
|
if (strtoupper(@php_sapi_name()) == "APACHE2HANDLER" || stristr($_SERVER['SERVER_SOFTWARE'], "apache/2")) {
|
||||||
$this->_data['webserver'] = 'apache2';
|
$this->_data['webserver'] = 'apache24';
|
||||||
} elseif (substr(strtoupper(@php_sapi_name()), 0, 8) == "LIGHTTPD" || stristr($_SERVER['SERVER_SOFTWARE'], "lighttpd")) {
|
} elseif (substr(strtoupper(@php_sapi_name()), 0, 8) == "LIGHTTPD" || stristr($_SERVER['SERVER_SOFTWARE'], "lighttpd")) {
|
||||||
$this->_data['webserver'] = 'lighttpd';
|
$this->_data['webserver'] = 'lighttpd';
|
||||||
} elseif (substr(strtoupper(@php_sapi_name()), 0, 8) == "NGINX" || stristr($_SERVER['SERVER_SOFTWARE'], "nginx")) {
|
} elseif (substr(strtoupper(@php_sapi_name()), 0, 8) == "NGINX" || stristr($_SERVER['SERVER_SOFTWARE'], "nginx")) {
|
||||||
@@ -1294,17 +1320,17 @@ class FroxlorInstall
|
|||||||
*/
|
*/
|
||||||
private function _split_sql_file($sql, $delimiter)
|
private function _split_sql_file($sql, $delimiter)
|
||||||
{
|
{
|
||||||
|
|
||||||
// Split up our string into "possible" SQL statements.
|
// Split up our string into "possible" SQL statements.
|
||||||
$tokens = explode($delimiter, $sql);
|
$tokens = explode($delimiter, $sql);
|
||||||
|
|
||||||
// try to save mem.
|
// try to save mem.
|
||||||
$sql = "";
|
$sql = "";
|
||||||
$output = array();
|
$output = array();
|
||||||
|
|
||||||
// we don't actually care about the matches preg gives us.
|
// we don't actually care about the matches preg gives us.
|
||||||
$matches = array();
|
$matches = array();
|
||||||
|
|
||||||
// this is faster than calling count($tokens) every time through the loop.
|
// this is faster than calling count($tokens) every time through the loop.
|
||||||
$token_count = count($tokens);
|
$token_count = count($tokens);
|
||||||
for ($i = 0; $i < $token_count; $i ++) {
|
for ($i = 0; $i < $token_count; $i ++) {
|
||||||
@@ -1312,12 +1338,12 @@ class FroxlorInstall
|
|||||||
if (($i != ($token_count - 1)) || (strlen($tokens[$i] > 0))) {
|
if (($i != ($token_count - 1)) || (strlen($tokens[$i] > 0))) {
|
||||||
// This is the total number of single quotes in the token.
|
// This is the total number of single quotes in the token.
|
||||||
$total_quotes = preg_match_all("/'/", $tokens[$i], $matches);
|
$total_quotes = preg_match_all("/'/", $tokens[$i], $matches);
|
||||||
|
|
||||||
// Counts single quotes that are preceded by an odd number of backslashes,
|
// Counts single quotes that are preceded by an odd number of backslashes,
|
||||||
// which means they're escaped quotes.
|
// which means they're escaped quotes.
|
||||||
$escaped_quotes = preg_match_all("/(?<!\\\\)(\\\\\\\\)*\\\\'/", $tokens[$i], $matches);
|
$escaped_quotes = preg_match_all("/(?<!\\\\)(\\\\\\\\)*\\\\'/", $tokens[$i], $matches);
|
||||||
$unescaped_quotes = $total_quotes - $escaped_quotes;
|
$unescaped_quotes = $total_quotes - $escaped_quotes;
|
||||||
|
|
||||||
// If the number of unescaped quotes is even, then the delimiter
|
// If the number of unescaped quotes is even, then the delimiter
|
||||||
// did NOT occur inside a string literal.
|
// did NOT occur inside a string literal.
|
||||||
if (($unescaped_quotes % 2) == 0) {
|
if (($unescaped_quotes % 2) == 0) {
|
||||||
@@ -1340,7 +1366,7 @@ class FroxlorInstall
|
|||||||
// which means they're escaped quotes.
|
// which means they're escaped quotes.
|
||||||
$escaped_quotes = preg_match_all("/(?<!\\\\)(\\\\\\\\)*\\\\'/", $tokens[$j], $matches);
|
$escaped_quotes = preg_match_all("/(?<!\\\\)(\\\\\\\\)*\\\\'/", $tokens[$j], $matches);
|
||||||
$unescaped_quotes = $total_quotes - $escaped_quotes;
|
$unescaped_quotes = $total_quotes - $escaped_quotes;
|
||||||
|
|
||||||
if (($unescaped_quotes % 2) == 1) {
|
if (($unescaped_quotes % 2) == 1) {
|
||||||
// odd number of unescaped quotes. In combination with the previous incomplete
|
// odd number of unescaped quotes. In combination with the previous incomplete
|
||||||
// statement(s), we now have a complete statement. (2 odds always make an even)
|
// statement(s), we now have a complete statement. (2 odds always make an even)
|
||||||
|
|||||||
@@ -28,6 +28,9 @@ $lng['requirements']['newerphpprefered'] = 'Good, but php-5.6 is prefered.';
|
|||||||
$lng['requirements']['phpmagic_quotes_runtime'] = 'magic_quotes_runtime...';
|
$lng['requirements']['phpmagic_quotes_runtime'] = 'magic_quotes_runtime...';
|
||||||
$lng['requirements']['phpmagic_quotes_runtime_description'] = 'PHP setting "magic_quotes_runtime" must be set to "Off". We have disabled it temporary for now please fix the coresponding php.ini.';
|
$lng['requirements']['phpmagic_quotes_runtime_description'] = 'PHP setting "magic_quotes_runtime" must be set to "Off". We have disabled it temporary for now please fix the coresponding php.ini.';
|
||||||
$lng['requirements']['phppdo'] = 'PHP PDO extension and PDO-MySQL driver...';
|
$lng['requirements']['phppdo'] = 'PHP PDO extension and PDO-MySQL driver...';
|
||||||
|
$lng['requirements']['phpsession'] = 'PHP session-extension...';
|
||||||
|
$lng['requirements']['phpctype'] = 'PHP ctype-extension...';
|
||||||
|
$lng['requirements']['phpsimplexml'] = 'PHP SimpleXML-extension...';
|
||||||
$lng['requirements']['phpxml'] = 'PHP XML-extension...';
|
$lng['requirements']['phpxml'] = 'PHP XML-extension...';
|
||||||
$lng['requirements']['phpfilter'] = 'PHP filter-extension...';
|
$lng['requirements']['phpfilter'] = 'PHP filter-extension...';
|
||||||
$lng['requirements']['phpposix'] = 'PHP posix-extension...';
|
$lng['requirements']['phpposix'] = 'PHP posix-extension...';
|
||||||
@@ -35,10 +38,13 @@ $lng['requirements']['phpbcmath'] = 'PHP bcmath-extension...';
|
|||||||
$lng['requirements']['phpcurl'] = 'PHP curl-extension...';
|
$lng['requirements']['phpcurl'] = 'PHP curl-extension...';
|
||||||
$lng['requirements']['phpmbstring'] = 'PHP mbstring-extension...';
|
$lng['requirements']['phpmbstring'] = 'PHP mbstring-extension...';
|
||||||
$lng['requirements']['phpzip'] = 'PHP zip-extension...';
|
$lng['requirements']['phpzip'] = 'PHP zip-extension...';
|
||||||
|
$lng['requirements']['phpjson'] = 'PHP json-extension...';
|
||||||
$lng['requirements']['bcmathdescription'] = 'Traffic-calculation related functions will not work correctly!';
|
$lng['requirements']['bcmathdescription'] = 'Traffic-calculation related functions will not work correctly!';
|
||||||
$lng['requirements']['zipdescription'] = 'The auto-update feature requires the zip extension.';
|
$lng['requirements']['zipdescription'] = 'The auto-update feature requires the zip extension.';
|
||||||
$lng['requirements']['openbasedir'] = 'open_basedir...';
|
$lng['requirements']['openbasedir'] = 'open_basedir...';
|
||||||
$lng['requirements']['openbasedirenabled'] = 'Froxlor will not work properly with open_basedir enabled. Please disable open_basedir for Froxlor in the coresponding php.ini';
|
$lng['requirements']['openbasedirenabled'] = 'Froxlor will not work properly with open_basedir enabled. Please disable open_basedir for Froxlor in the coresponding php.ini';
|
||||||
|
$lng['requirements']['mysqldump'] = 'MySQL dump tool';
|
||||||
|
$lng['requirements']['mysqldumpmissing'] = 'Automatic backup of possible existing database is not possible. Please install mysql-client tools';
|
||||||
$lng['requirements']['diedbecauseofrequirements'] = 'Cannot install Froxlor without these requirements! Try to fix them and retry.';
|
$lng['requirements']['diedbecauseofrequirements'] = 'Cannot install Froxlor without these requirements! Try to fix them and retry.';
|
||||||
$lng['requirements']['froxlor_succ_checks'] = 'All requirements are satisfied';
|
$lng['requirements']['froxlor_succ_checks'] = 'All requirements are satisfied';
|
||||||
|
|
||||||
@@ -63,7 +69,7 @@ $lng['install']['serversettings'] = 'Server settings';
|
|||||||
$lng['install']['servername'] = 'Server name (FQDN, no ip-address)';
|
$lng['install']['servername'] = 'Server name (FQDN, no ip-address)';
|
||||||
$lng['install']['serverip'] = 'Server IP';
|
$lng['install']['serverip'] = 'Server IP';
|
||||||
$lng['install']['webserver'] = 'Webserver';
|
$lng['install']['webserver'] = 'Webserver';
|
||||||
$lng['install']['apache2'] = 'Apache 2';
|
$lng['install']['apache2'] = 'Apache 2.2';
|
||||||
$lng['install']['apache24'] = 'Apache 2.4';
|
$lng['install']['apache24'] = 'Apache 2.4';
|
||||||
$lng['install']['lighttpd'] = 'LigHTTPd';
|
$lng['install']['lighttpd'] = 'LigHTTPd';
|
||||||
$lng['install']['nginx'] = 'NGINX';
|
$lng['install']['nginx'] = 'NGINX';
|
||||||
@@ -83,8 +89,8 @@ $lng['install']['changing_data'] = 'Adjusting settings...';
|
|||||||
$lng['install']['creating_entries'] = 'Inserting new values...';
|
$lng['install']['creating_entries'] = 'Inserting new values...';
|
||||||
$lng['install']['adding_admin_user'] = 'Creating admin-account...';
|
$lng['install']['adding_admin_user'] = 'Creating admin-account...';
|
||||||
$lng['install']['creating_configfile'] = 'Creating configfile...';
|
$lng['install']['creating_configfile'] = 'Creating configfile...';
|
||||||
$lng['install']['creating_configfile_temp'] = 'File was saved in /tmp/userdata.inc.php, please move to lib/.';
|
$lng['install']['creating_configfile_temp'] = 'File was saved in /tmp/userdata.inc.php, please move to '.dirname(dirname(__DIR__)).'/lib/.';
|
||||||
$lng['install']['creating_configfile_failed'] = 'Could not create lib/userdata.inc.php, please create it manually with the following content:';
|
$lng['install']['creating_configfile_failed'] = 'Could not create '.dirname(dirname(__DIR__)).'/lib/userdata.inc.php, please create it manually with the following content:';
|
||||||
$lng['install']['froxlor_succ_installed'] = 'Froxlor was installed successfully.';
|
$lng['install']['froxlor_succ_installed'] = 'Froxlor was installed successfully.';
|
||||||
|
|
||||||
$lng['click_here_to_refresh'] = 'Click here to check again';
|
$lng['click_here_to_refresh'] = 'Click here to check again';
|
||||||
|
|||||||
@@ -79,8 +79,8 @@ $lng['install']['changing_data'] = 'Ajustement des paramètres...';
|
|||||||
$lng['install']['creating_entries'] = 'Insertion des nouvelles valeurs...';
|
$lng['install']['creating_entries'] = 'Insertion des nouvelles valeurs...';
|
||||||
$lng['install']['adding_admin_user'] = 'Création du compte administrateur...';
|
$lng['install']['adding_admin_user'] = 'Création du compte administrateur...';
|
||||||
$lng['install']['creating_configfile'] = 'Création du fichier de configuration...';
|
$lng['install']['creating_configfile'] = 'Création du fichier de configuration...';
|
||||||
$lng['install']['creating_configfile_temp'] = 'Le fichier a été enregistré dans /tmp/userdata.inc.php, merci de le déplacer dans lib/.';
|
$lng['install']['creating_configfile_temp'] = 'Le fichier a été enregistré dans /tmp/userdata.inc.php, merci de le déplacer dans '.dirname(dirname(__DIR__)).'/lib/.';
|
||||||
$lng['install']['creating_configfile_failed'] = 'Impossible de créer lib/userdata.inc.php, merci de le créer manuellement avec le contenu suivant:';
|
$lng['install']['creating_configfile_failed'] = 'Impossible de créer '.dirname(dirname(__DIR__)).'/lib/userdata.inc.php, merci de le créer manuellement avec le contenu suivant:';
|
||||||
$lng['install']['froxlor_succ_installed'] = 'Froxlor a été installé avec succès.';
|
$lng['install']['froxlor_succ_installed'] = 'Froxlor a été installé avec succès.';
|
||||||
|
|
||||||
$lng['click_here_to_refresh'] = 'Cliquez ici pour vérifier à nouveau';
|
$lng['click_here_to_refresh'] = 'Cliquez ici pour vérifier à nouveau';
|
||||||
|
|||||||
@@ -28,6 +28,9 @@ $lng['requirements']['newerphpprefered'] = 'Passt, aber php-5.6 wird bevorzugt.'
|
|||||||
$lng['requirements']['phpmagic_quotes_runtime'] = 'magic_quotes_runtime';
|
$lng['requirements']['phpmagic_quotes_runtime'] = 'magic_quotes_runtime';
|
||||||
$lng['requirements']['phpmagic_quotes_runtime_description'] = 'Die PHP Einstellung "magic_quotes_runtime" muss deaktiviert sein ("Off"). Die Einstellung wurde temporär deaktiviert, bitte ändern Sie diese in der entsprechenden php.ini.';
|
$lng['requirements']['phpmagic_quotes_runtime_description'] = 'Die PHP Einstellung "magic_quotes_runtime" muss deaktiviert sein ("Off"). Die Einstellung wurde temporär deaktiviert, bitte ändern Sie diese in der entsprechenden php.ini.';
|
||||||
$lng['requirements']['phppdo'] = 'PHP PDO Erweiterung und PDO-MySQL Treiber...';
|
$lng['requirements']['phppdo'] = 'PHP PDO Erweiterung und PDO-MySQL Treiber...';
|
||||||
|
$lng['requirements']['phpsession'] = 'PHP session-Erweiterung...';
|
||||||
|
$lng['requirements']['phpctype'] = 'PHP ctype-Erweiterung...';
|
||||||
|
$lng['requirements']['phpsimplexml'] = 'PHP SimpleXML-Erweiterung...';
|
||||||
$lng['requirements']['phpxml'] = 'PHP XML-Erweiterung...';
|
$lng['requirements']['phpxml'] = 'PHP XML-Erweiterung...';
|
||||||
$lng['requirements']['phpfilter'] = 'PHP filter-Erweiterung...';
|
$lng['requirements']['phpfilter'] = 'PHP filter-Erweiterung...';
|
||||||
$lng['requirements']['phpposix'] = 'PHP posix-Erweiterung...';
|
$lng['requirements']['phpposix'] = 'PHP posix-Erweiterung...';
|
||||||
@@ -35,10 +38,13 @@ $lng['requirements']['phpbcmath'] = 'PHP bcmath-Erweiterung...';
|
|||||||
$lng['requirements']['phpcurl'] = 'PHP curl-Erweiterung...';
|
$lng['requirements']['phpcurl'] = 'PHP curl-Erweiterung...';
|
||||||
$lng['requirements']['phpmbstring'] = 'PHP mbstring-Erweiterung...';
|
$lng['requirements']['phpmbstring'] = 'PHP mbstring-Erweiterung...';
|
||||||
$lng['requirements']['phpzip'] = 'PHP zip-Erweiterung...';
|
$lng['requirements']['phpzip'] = 'PHP zip-Erweiterung...';
|
||||||
|
$lng['requirements']['phpjson'] = 'PHP json-Erweiterung...';
|
||||||
$lng['requirements']['bcmathdescription'] = 'Traffic-Berechnungs bezogene Funktionen stehen nicht vollständig zur Verfügung!';
|
$lng['requirements']['bcmathdescription'] = 'Traffic-Berechnungs bezogene Funktionen stehen nicht vollständig zur Verfügung!';
|
||||||
$lng['requirements']['zipdescription'] = 'Die Auto-Update Funktion benötigt die zip Erweiterung.';
|
$lng['requirements']['zipdescription'] = 'Die Auto-Update Funktion benötigt die zip Erweiterung.';
|
||||||
$lng['requirements']['openbasedir'] = 'open_basedir genutzt wird...';
|
$lng['requirements']['openbasedir'] = 'open_basedir genutzt wird...';
|
||||||
$lng['requirements']['openbasedirenabled'] = 'Froxlor wird mit aktiviertem open_basedir nicht vollständig funktionieren. Bitte deaktivieren Sie open_basedir für Froxlor in der entsprechenden php.ini';
|
$lng['requirements']['openbasedirenabled'] = 'Froxlor wird mit aktiviertem open_basedir nicht vollständig funktionieren. Bitte deaktivieren Sie open_basedir für Froxlor in der entsprechenden php.ini';
|
||||||
|
$lng['requirements']['mysqldump'] = 'MySQL dump Tool';
|
||||||
|
$lng['requirements']['mysqldumpmissing'] = 'Ein automatisches Backup einer möglicherweise schon existierenden Datenbank nicht möglich. Bitte mysql-client installieren';
|
||||||
$lng['requirements']['diedbecauseofrequirements'] = 'Kann Froxlor ohne diese Voraussetzungen nicht installieren! Beheben Sie die angezeigten Probleme und versuchen Sie es erneut.';
|
$lng['requirements']['diedbecauseofrequirements'] = 'Kann Froxlor ohne diese Voraussetzungen nicht installieren! Beheben Sie die angezeigten Probleme und versuchen Sie es erneut.';
|
||||||
$lng['requirements']['froxlor_succ_checks'] = 'Alle Vorraussetzungen sind erfüllt';
|
$lng['requirements']['froxlor_succ_checks'] = 'Alle Vorraussetzungen sind erfüllt';
|
||||||
|
|
||||||
@@ -83,8 +89,8 @@ $lng['install']['changing_data'] = 'Einstellungen anpassen...';
|
|||||||
$lng['install']['creating_entries'] = 'Trage neue Werte ein...';
|
$lng['install']['creating_entries'] = 'Trage neue Werte ein...';
|
||||||
$lng['install']['adding_admin_user'] = 'Erstelle Admin-Benutzer...';
|
$lng['install']['adding_admin_user'] = 'Erstelle Admin-Benutzer...';
|
||||||
$lng['install']['creating_configfile'] = 'Erstelle Konfigurationsdatei...';
|
$lng['install']['creating_configfile'] = 'Erstelle Konfigurationsdatei...';
|
||||||
$lng['install']['creating_configfile_temp'] = 'Datei wurde in /tmp/userdata.inc.php gespeichert, bitte nach lib/ verschieben.';
|
$lng['install']['creating_configfile_temp'] = 'Datei wurde in /tmp/userdata.inc.php gespeichert, bitte nach '.dirname(dirname(__DIR__)).'/lib/ verschieben.';
|
||||||
$lng['install']['creating_configfile_failed'] = 'Konnte lib/userdata.inc.php nicht erstellen, bitte manuell mit folgendem Inhalt anlegen:';
|
$lng['install']['creating_configfile_failed'] = 'Konnte '.dirname(dirname(__DIR__)).'/lib/userdata.inc.php nicht erstellen, bitte manuell mit folgendem Inhalt anlegen:';
|
||||||
$lng['install']['froxlor_succ_installed'] = 'Froxlor wurde erfolgreich installiert.';
|
$lng['install']['froxlor_succ_installed'] = 'Froxlor wurde erfolgreich installiert.';
|
||||||
|
|
||||||
$lng['click_here_to_refresh'] = 'Hier klicken, um erneut zu prüfen';
|
$lng['click_here_to_refresh'] = 'Hier klicken, um erneut zu prüfen';
|
||||||
|
|||||||
489
install/scripts/config-services.php
Executable file
489
install/scripts/config-services.php
Executable file
@@ -0,0 +1,489 @@
|
|||||||
|
#!/usr/bin/php
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2018 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> (2018-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Cron
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Check if we're in the CLI
|
||||||
|
if (@php_sapi_name() !== 'cli') {
|
||||||
|
die('This script will only work in the shell.');
|
||||||
|
}
|
||||||
|
|
||||||
|
require dirname(dirname(__DIR__)) . '/lib/classes/output/class.CmdLineHandler.php';
|
||||||
|
|
||||||
|
class ConfigServicesCmd extends CmdLineHandler
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list of valid switches
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public static $switches = array(
|
||||||
|
'h'
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list of valid parameters
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public static $params = array(
|
||||||
|
'create',
|
||||||
|
'apply',
|
||||||
|
'import-settings',
|
||||||
|
'daemon',
|
||||||
|
'list-daemons',
|
||||||
|
'froxlor-dir',
|
||||||
|
'help'
|
||||||
|
);
|
||||||
|
|
||||||
|
public static $action_class = 'Action';
|
||||||
|
|
||||||
|
public static function printHelp()
|
||||||
|
{
|
||||||
|
self::println("");
|
||||||
|
self::println("Help / command line parameters:");
|
||||||
|
self::println("");
|
||||||
|
// commands
|
||||||
|
self::println("--create\t\tlets you create a services list configuration for the 'apply' command");
|
||||||
|
self::println("");
|
||||||
|
self::println("--apply\t\t\tconfigure your services by given configuration file. To create one run the --create command");
|
||||||
|
self::println("\t\t\tExample: --apply=/path/to/my-config.json or --apply=http://domain.tld/my-config.json");
|
||||||
|
self::println("");
|
||||||
|
self::println("--list-daemons\t\tOutput the services that are going to be configured using a given config file. No services will be configured.");
|
||||||
|
self::println("\t\t\tExample: --apply=/path/to/my-config.json --list-daemons");
|
||||||
|
self::println("");
|
||||||
|
self::println("--daemon\t\tWhen running --apply you can specify a daemon. This will be the only service that gets configured");
|
||||||
|
self::println("\t\t\tExample: --apply=/path/to/my-config.json --daemon=apache24");
|
||||||
|
self::println("");
|
||||||
|
self::println("--import-settings\tImport settings from another froxlor installation. This should be done prior to running --apply or alternatively in the same command together.");
|
||||||
|
self::println("\t\t\tExample: --import-settings=/path/to/Froxlor_settings-[version]-[dbversion]-[date].json or --import-settings=http://domain.tld/Froxlor_settings-[version]-[dbversion]-[date].json");
|
||||||
|
self::println("");
|
||||||
|
self::println("--froxlor-dir\t\tpath to froxlor installation");
|
||||||
|
self::println("\t\t\tExample: --froxlor-dir=/var/www/froxlor/");
|
||||||
|
self::println("");
|
||||||
|
self::println("--help\t\t\tshow help screen (this)");
|
||||||
|
self::println("");
|
||||||
|
// switches
|
||||||
|
// self::println("-d\t\t\tenable debug output");
|
||||||
|
self::println("-h\t\t\tsame as --help");
|
||||||
|
self::println("");
|
||||||
|
|
||||||
|
die(); // end of execution
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Action
|
||||||
|
{
|
||||||
|
|
||||||
|
private $_args = null;
|
||||||
|
|
||||||
|
private $_name = null;
|
||||||
|
|
||||||
|
private $_db = null;
|
||||||
|
|
||||||
|
public function __construct($args)
|
||||||
|
{
|
||||||
|
$this->_args = $args;
|
||||||
|
$this->_validate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getActionName()
|
||||||
|
{
|
||||||
|
return $this->_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* validates the parsed command line parameters
|
||||||
|
*
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
private function _validate()
|
||||||
|
{
|
||||||
|
$this->_checkConfigParam(true);
|
||||||
|
$this->_parseConfig();
|
||||||
|
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/tables.inc.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/functions.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/classes/settings/class.Settings.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/classes/settings/class.SImExporter.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/classes/config/class.ConfigParser.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/classes/config/class.ConfigService.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/classes/config/class.ConfigDaemon.php';
|
||||||
|
|
||||||
|
if (array_key_exists("import-settings", $this->_args)) {
|
||||||
|
$this->_importSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (array_key_exists("create", $this->_args)) {
|
||||||
|
$this->_createConfig();
|
||||||
|
} elseif (array_key_exists("apply", $this->_args)) {
|
||||||
|
$this->_applyConfig();
|
||||||
|
} elseif (array_key_exists("list-daemons", $this->_args) || array_key_exists("daemon", $this->_args)) {
|
||||||
|
CmdLineHandler::printwarn("--list-daemons and --daemon only work together with --apply");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _importSettings()
|
||||||
|
{
|
||||||
|
if (strtoupper(substr($this->_args["import-settings"], 0, 4)) == 'HTTP') {
|
||||||
|
echo "Settings file seems to be an URL, trying to download" . PHP_EOL;
|
||||||
|
$target = "/tmp/froxlor-import-settings-" . time() . ".json";
|
||||||
|
if (@file_exists($target)) {
|
||||||
|
@unlink($target);
|
||||||
|
}
|
||||||
|
$this->downloadFile($this->_args["import-settings"], $target);
|
||||||
|
$this->_args["import-settings"] = $target;
|
||||||
|
}
|
||||||
|
if (! is_file($this->_args["import-settings"])) {
|
||||||
|
throw new Exception("Given settings file is not a file");
|
||||||
|
} elseif (! file_exists($this->_args["import-settings"])) {
|
||||||
|
throw new Exception("Given settings file cannot be found ('" . $this->_args["import-settings"] . "')");
|
||||||
|
} elseif (! is_readable($this->_args["import-settings"])) {
|
||||||
|
throw new Exception("Given settings file cannot be read ('" . $this->_args["import-settings"] . "')");
|
||||||
|
}
|
||||||
|
$imp_content = file_get_contents($this->_args["import-settings"]);
|
||||||
|
SImExporter::import($imp_content);
|
||||||
|
CmdLineHandler::printsucc("Successfully imported settings from '" . $this->_args["import-settings"] . "'");
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _createConfig()
|
||||||
|
{
|
||||||
|
$_daemons_config = array(
|
||||||
|
'distro' => ""
|
||||||
|
);
|
||||||
|
|
||||||
|
$config_dir = FROXLOR_INSTALL_DIR . '/lib/configfiles/';
|
||||||
|
// show list of available distro's
|
||||||
|
$distros = glob($config_dir . '*.xml');
|
||||||
|
// tmp array
|
||||||
|
$distributions_select_data = array();
|
||||||
|
// read in all the distros
|
||||||
|
foreach ($distros as $_distribution) {
|
||||||
|
// get configparser object
|
||||||
|
$dist = new ConfigParser($_distribution);
|
||||||
|
// get distro-info
|
||||||
|
$dist_display = $this->getCompleteDistroName($dist);
|
||||||
|
// store in tmp array
|
||||||
|
$distributions_select_data[$dist_display] = str_replace(".xml", "", strtolower(basename($_distribution)));
|
||||||
|
}
|
||||||
|
|
||||||
|
// sort by distribution name
|
||||||
|
ksort($distributions_select_data);
|
||||||
|
|
||||||
|
// list all distributions
|
||||||
|
$mask = "|%-50.50s |%-50.50s |\n";
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
printf($mask, 'dist', 'name');
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
foreach ($distributions_select_data as $name => $filename) {
|
||||||
|
printf($mask, $filename, $name);
|
||||||
|
}
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
echo PHP_EOL;
|
||||||
|
|
||||||
|
while (! in_array($_daemons_config['distro'], $distributions_select_data)) {
|
||||||
|
$_daemons_config['distro'] = CmdLineHandler::getInput("choose distribution", "stretch");
|
||||||
|
}
|
||||||
|
|
||||||
|
// go through all services and let user check whether to include it or not
|
||||||
|
$configfiles = new ConfigParser($config_dir . '/' . $_daemons_config['distro'] . ".xml");
|
||||||
|
$services = $configfiles->getServices();
|
||||||
|
|
||||||
|
foreach ($services as $si => $service) {
|
||||||
|
echo PHP_EOL . "--- " . strtoupper($si) . " ---" . PHP_EOL . PHP_EOL;
|
||||||
|
$_daemons_config[$si] = "";
|
||||||
|
|
||||||
|
$daemons = $service->getDaemons();
|
||||||
|
$mask = "|%-50.50s |%-50.50s |\n";
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
printf($mask, 'value', 'name');
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
$default_daemon = "";
|
||||||
|
foreach ($daemons as $di => $dd) {
|
||||||
|
$title = $dd->title;
|
||||||
|
if ($dd->default) {
|
||||||
|
$default_daemon = $di;
|
||||||
|
$title = $title . " (default)";
|
||||||
|
}
|
||||||
|
printf($mask, $di, $title);
|
||||||
|
}
|
||||||
|
printf($mask, "x", "No " . $si);
|
||||||
|
$daemons['x'] = 'x';
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
echo PHP_EOL;
|
||||||
|
if ($si == 'system') {
|
||||||
|
$_daemons_config[$si] = array();
|
||||||
|
// for the system/other services we need a multiple choice possibility
|
||||||
|
CmdLineHandler::println("Select every service you need. Enter empty value when done");
|
||||||
|
$sysservice = "";
|
||||||
|
do {
|
||||||
|
$sysservice = CmdLineHandler::getInput("choose service");
|
||||||
|
if (! empty($sysservice)) {
|
||||||
|
$_daemons_config[$si][] = $sysservice;
|
||||||
|
}
|
||||||
|
} while (! empty($sysservice));
|
||||||
|
} else {
|
||||||
|
// for all others -> only one value
|
||||||
|
while (! array_key_exists($_daemons_config[$si], $daemons)) {
|
||||||
|
$_daemons_config[$si] = CmdLineHandler::getInput("choose service", $default_daemon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
echo PHP_EOL . PHP_EOL;
|
||||||
|
$daemons_config = json_encode($_daemons_config);
|
||||||
|
$output = CmdLineHandler::getInput("choose output-filename", "/tmp/froxlor-config-" . date('Ymd') . ".json");
|
||||||
|
file_put_contents($output, $daemons_config);
|
||||||
|
CmdLineHandler::printsucc("Successfully generated service-configfile '" . $output . "'");
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getCompleteDistroName($cparser)
|
||||||
|
{
|
||||||
|
// get distro-info
|
||||||
|
$dist_display = $cparser->distributionName;
|
||||||
|
if ($cparser->distributionCodename != '') {
|
||||||
|
$dist_display .= " " . $cparser->distributionCodename;
|
||||||
|
}
|
||||||
|
if ($cparser->distributionVersion != '') {
|
||||||
|
$dist_display .= " (" . $cparser->distributionVersion . ")";
|
||||||
|
}
|
||||||
|
if ($cparser->deprecated) {
|
||||||
|
$dist_display .= " [deprecated]";
|
||||||
|
}
|
||||||
|
return $dist_display;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _applyConfig()
|
||||||
|
{
|
||||||
|
if (strtoupper(substr($this->_args["apply"], 0, 4)) == 'HTTP') {
|
||||||
|
echo "Config file seems to be an URL, trying to download" . PHP_EOL;
|
||||||
|
$target = "/tmp/froxlor-config-" . time() . ".json";
|
||||||
|
if (@file_exists($target)) {
|
||||||
|
@unlink($target);
|
||||||
|
}
|
||||||
|
$this->downloadFile($this->_args["apply"], $target);
|
||||||
|
$this->_args["apply"] = $target;
|
||||||
|
}
|
||||||
|
if (! is_file($this->_args["apply"])) {
|
||||||
|
throw new Exception("Given config file is not a file");
|
||||||
|
} elseif (! file_exists($this->_args["apply"])) {
|
||||||
|
throw new Exception("Given config file cannot be found ('" . $this->_args["apply"] . "')");
|
||||||
|
} elseif (! is_readable($this->_args["apply"])) {
|
||||||
|
throw new Exception("Given config file cannot be read ('" . $this->_args["apply"] . "')");
|
||||||
|
}
|
||||||
|
|
||||||
|
$config = file_get_contents($this->_args["apply"]);
|
||||||
|
$decoded_config = json_decode($config, true);
|
||||||
|
|
||||||
|
if (array_key_exists("list-daemons", $this->_args)) {
|
||||||
|
$mask = "|%-50.50s |%-50.50s |\n";
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
printf($mask, 'service', 'daemon');
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
foreach ($decoded_config as $service => $daemon) {
|
||||||
|
if (is_array($daemon) && count($daemon) > 0) {
|
||||||
|
foreach ($daemon as $sysdaemon) {
|
||||||
|
printf($mask, $service, $sysdaemon);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if ($daemon == 'x') {
|
||||||
|
$daemon = '--- skipped ---';
|
||||||
|
}
|
||||||
|
printf($mask, $service, $daemon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
printf($mask, str_repeat("-", 50), str_repeat("-", 50));
|
||||||
|
echo PHP_EOL;
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
$only_daemon = null;
|
||||||
|
if (array_key_exists("daemon", $this->_args)) {
|
||||||
|
$only_daemon = $this->_args['daemon'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! empty($decoded_config)) {
|
||||||
|
$config_dir = FROXLOR_INSTALL_DIR . '/lib/configfiles/';
|
||||||
|
$configfiles = new ConfigParser($config_dir . '/' . $decoded_config['distro'] . ".xml");
|
||||||
|
$services = $configfiles->getServices();
|
||||||
|
$replace_arr = $this->_getReplacerArray();
|
||||||
|
|
||||||
|
foreach ($services as $si => $service) {
|
||||||
|
echo PHP_EOL . "--- Configuring: " . strtoupper($si) . " ---" . PHP_EOL . PHP_EOL;
|
||||||
|
if (! isset($decoded_config[$si]) || $decoded_config[$si] == 'x') {
|
||||||
|
CmdLineHandler::printwarn("Skipping " . strtoupper($si) . " configuration as desired");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$daemons = $service->getDaemons();
|
||||||
|
foreach ($daemons as $di => $dd) {
|
||||||
|
// check for desired service
|
||||||
|
if (($si != 'system' && $decoded_config[$si] != $di) || (is_array($decoded_config[$si]) && ! in_array($di, $decoded_config[$si]))) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
CmdLineHandler::println("Configuring '" . $di . "'");
|
||||||
|
|
||||||
|
if (! empty($only_daemon) && $only_daemon != $di) {
|
||||||
|
CmdLineHandler::printwarn("Skipping " . $di . " configuration as desired");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// run all cmds
|
||||||
|
$confarr = $dd->getConfig();
|
||||||
|
foreach ($confarr as $idx => $action) {
|
||||||
|
switch ($action['type']) {
|
||||||
|
case "install":
|
||||||
|
CmdLineHandler::println("Installing required packages");
|
||||||
|
passthru(strtr($action['content'], $replace_arr), $result);
|
||||||
|
if (strlen($result) > 1) {
|
||||||
|
echo $result;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "command":
|
||||||
|
exec(strtr($action['content'], $replace_arr));
|
||||||
|
break;
|
||||||
|
case "file":
|
||||||
|
if (array_key_exists('content', $action)) {
|
||||||
|
CmdLineHandler::printwarn("Creating file '" . $action['name'] . "'");
|
||||||
|
file_put_contents($action['name'], trim(strtr($action['content'], $replace_arr)));
|
||||||
|
} elseif (array_key_exists('subcommands', $action)) {
|
||||||
|
foreach ($action['subcommands'] as $fileaction) {
|
||||||
|
if (array_key_exists('execute', $fileaction) && $fileaction['execute'] == "pre") {
|
||||||
|
exec(strtr($fileaction['content'], $replace_arr));
|
||||||
|
} elseif (array_key_exists('execute', $fileaction) && $fileaction['execute'] == "post") {
|
||||||
|
exec(strtr($fileaction['content'], $replace_arr));
|
||||||
|
} elseif ($fileaction['type'] == 'file') {
|
||||||
|
CmdLineHandler::printwarn("Creating file '" . $fileaction['name'] . "'");
|
||||||
|
file_put_contents($fileaction['name'], trim(strtr($fileaction['content'], $replace_arr)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// run cronjob at the end to ensure configs are all up to date
|
||||||
|
exec('php ' . FROXLOR_INSTALL_DIR . '/scripts/froxlor_master_cronjob.php --force');
|
||||||
|
// and done
|
||||||
|
CmdLineHandler::printsucc("All services have been configured");
|
||||||
|
} else {
|
||||||
|
CmdLineHandler::printerr("Unable to decode given JSON file");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _getReplacerArray()
|
||||||
|
{
|
||||||
|
$customer_tmpdir = '/tmp/';
|
||||||
|
if (Settings::Get('system.mod_fcgid') == '1' && Settings::Get('system.mod_fcgid_tmpdir') != '') {
|
||||||
|
$customer_tmpdir = Settings::Get('system.mod_fcgid_tmpdir');
|
||||||
|
} elseif (Settings::Get('phpfpm.enabled') == '1' && Settings::Get('phpfpm.tmpdir') != '') {
|
||||||
|
$customer_tmpdir = Settings::Get('phpfpm.tmpdir');
|
||||||
|
}
|
||||||
|
|
||||||
|
// try to convert namserver hosts to ip's
|
||||||
|
$ns_ips = "";
|
||||||
|
if (Settings::Get('system.nameservers') != '') {
|
||||||
|
$nameservers = explode(',', Settings::Get('system.nameservers'));
|
||||||
|
foreach ($nameservers as $nameserver) {
|
||||||
|
$nameserver = trim($nameserver);
|
||||||
|
$nameserver_ips = gethostbynamel($nameserver);
|
||||||
|
if (is_array($nameserver_ips) && count($nameserver_ips) > 0) {
|
||||||
|
$ns_ips .= implode(",", $nameserver_ips);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Database::needSqlData();
|
||||||
|
$sql = Database::getSqlData();
|
||||||
|
|
||||||
|
$replace_arr = array(
|
||||||
|
'<SQL_UNPRIVILEGED_USER>' => $sql['user'],
|
||||||
|
'<SQL_UNPRIVILEGED_PASSWORD>' => $sql['passwd'],
|
||||||
|
'<SQL_DB>' => $sql['db'],
|
||||||
|
'<SQL_HOST>' => $sql['host'],
|
||||||
|
'<SQL_SOCKET>' => isset($sql['socket']) ? $sql['socket'] : null,
|
||||||
|
'<SERVERNAME>' => Settings::Get('system.hostname'),
|
||||||
|
'<SERVERIP>' => Settings::Get('system.ipaddress'),
|
||||||
|
'<NAMESERVERS>' => Settings::Get('system.nameservers'),
|
||||||
|
'<NAMESERVERS_IP>' => $ns_ips,
|
||||||
|
'<AXFRSERVERS>' => Settings::Get('system.axfrservers'),
|
||||||
|
'<VIRTUAL_MAILBOX_BASE>' => Settings::Get('system.vmail_homedir'),
|
||||||
|
'<VIRTUAL_UID_MAPS>' => Settings::Get('system.vmail_uid'),
|
||||||
|
'<VIRTUAL_GID_MAPS>' => Settings::Get('system.vmail_gid'),
|
||||||
|
'<SSLPROTOCOLS>' => (Settings::Get('system.use_ssl') == '1') ? 'imaps pop3s' : '',
|
||||||
|
'<CUSTOMER_TMP>' => makeCorrectDir($customer_tmpdir),
|
||||||
|
'<BASE_PATH>' => makeCorrectDir(FROXLOR_INSTALL_DIR),
|
||||||
|
'<BIND_CONFIG_PATH>' => makeCorrectDir(Settings::Get('system.bindconf_directory')),
|
||||||
|
'<WEBSERVER_RELOAD_CMD>' => Settings::Get('system.apachereload_command'),
|
||||||
|
'<CUSTOMER_LOGS>' => makeCorrectDir(Settings::Get('system.logfiles_directory')),
|
||||||
|
'<FPM_IPCDIR>' => makeCorrectDir(Settings::Get('phpfpm.fastcgi_ipcdir')),
|
||||||
|
'<WEBSERVER_GROUP>' => Settings::Get('system.httpgroup')
|
||||||
|
);
|
||||||
|
return $replace_arr;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _parseConfig()
|
||||||
|
{
|
||||||
|
define('FROXLOR_INSTALL_DIR', $this->_args['froxlor-dir']);
|
||||||
|
if (! file_exists(FROXLOR_INSTALL_DIR . '/lib/classes/database/class.Database.php')) {
|
||||||
|
throw new Exception("Could not find froxlor's Database class. Is froxlor really installed to '" . FROXLOR_INSTALL_DIR . "'?");
|
||||||
|
}
|
||||||
|
if (! file_exists(FROXLOR_INSTALL_DIR . '/lib/userdata.inc.php')) {
|
||||||
|
throw new Exception("Could not find froxlor's userdata.inc.php file. You should use this script only with a fully installed and setup froxlor system.");
|
||||||
|
}
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/classes/database/class.Database.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _checkConfigParam($needed = false)
|
||||||
|
{
|
||||||
|
if ($needed) {
|
||||||
|
if (! isset($this->_args["froxlor-dir"])) {
|
||||||
|
throw new Exception("No configuration given (missing --froxlor-dir parameter?)");
|
||||||
|
} elseif (! is_dir($this->_args["froxlor-dir"])) {
|
||||||
|
throw new Exception("Given --froxlor-dir parameter is not a directory");
|
||||||
|
} elseif (! file_exists($this->_args["froxlor-dir"])) {
|
||||||
|
throw new Exception("Given froxlor directory cannot be found ('" . $this->_args["froxlor-dir"] . "')");
|
||||||
|
} elseif (! is_readable($this->_args["froxlor-dir"])) {
|
||||||
|
throw new Exception("Given froxlor direcotry cannot be read ('" . $this->_args["froxlor-dir"] . "')");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function downloadFile($src, $dest)
|
||||||
|
{
|
||||||
|
set_time_limit(0);
|
||||||
|
// This is the file where we save the information
|
||||||
|
$fp = fopen($dest, 'w+');
|
||||||
|
// Here is the file we are downloading, replace spaces with %20
|
||||||
|
$ch = curl_init(str_replace(" ", "%20", $src));
|
||||||
|
curl_setopt($ch, CURLOPT_TIMEOUT, 50);
|
||||||
|
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
|
||||||
|
// write curl response to file
|
||||||
|
curl_setopt($ch, CURLOPT_FILE, $fp);
|
||||||
|
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
|
||||||
|
// get curl response
|
||||||
|
curl_exec($ch);
|
||||||
|
curl_close($ch);
|
||||||
|
fclose($fp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// give control to command line handler
|
||||||
|
try {
|
||||||
|
ConfigServicesCmd::processParameters($argc, $argv);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
ConfigServicesCmd::printerr($e->getMessage());
|
||||||
|
}
|
||||||
242
install/scripts/switch-server-ip.php
Normal file → Executable file
242
install/scripts/switch-server-ip.php
Normal file → Executable file
@@ -13,46 +13,33 @@
|
|||||||
* @author Froxlor team <team@froxlor.org> (2016-)
|
* @author Froxlor team <team@froxlor.org> (2016-)
|
||||||
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
* @package Cron
|
* @package Cron
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Check if we're in the CLI
|
// Check if we're in the CLI
|
||||||
if(@php_sapi_name() !== 'cli') {
|
if (@php_sapi_name() !== 'cli') {
|
||||||
die('This script will only work in the shell.');
|
die('This script will only work in the shell.');
|
||||||
}
|
}
|
||||||
|
|
||||||
// give control to command line handler
|
require dirname(dirname(__DIR__)) . '/lib/classes/output/class.CmdLineHandler.php';
|
||||||
try {
|
|
||||||
CmdLineHandler::processParameters($argc, $argv);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
CmdLineHandler::printerr($e->getMessage());
|
|
||||||
}
|
|
||||||
|
|
||||||
class CmdLineHandler
|
class SwitchServerIp extends CmdLineHandler
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* internal variable for passed arguments
|
* list of valid switches
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private static $args = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Action object read from commandline/config
|
|
||||||
*
|
|
||||||
* @var Action
|
|
||||||
*/
|
|
||||||
private $_action = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* list of valid parameters/switches
|
|
||||||
*/
|
|
||||||
public static $switches = array(
|
public static $switches = array(
|
||||||
/* 'd', // debug / output information for everything */
|
|
||||||
'h'
|
'h'
|
||||||
);
|
);
|
||||||
// same as --help
|
|
||||||
|
/**
|
||||||
|
* list of valid parameters
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
public static $params = array(
|
public static $params = array(
|
||||||
'switch',
|
'switch',
|
||||||
'list',
|
'list',
|
||||||
@@ -60,131 +47,7 @@ class CmdLineHandler
|
|||||||
'help'
|
'help'
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
public static $action_class = 'Action';
|
||||||
* Returns a CmdLineHandler object with given
|
|
||||||
* arguments from command line
|
|
||||||
*
|
|
||||||
* @param int $argc
|
|
||||||
* @param array $argv
|
|
||||||
*
|
|
||||||
* @return CmdLineHandler
|
|
||||||
*/
|
|
||||||
public static function processParameters($argc, $argv)
|
|
||||||
{
|
|
||||||
return new CmdLineHandler($argc, $argv);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* returns the Action object generated in
|
|
||||||
* the class constructor
|
|
||||||
*
|
|
||||||
* @return Action
|
|
||||||
*/
|
|
||||||
public function getAction()
|
|
||||||
{
|
|
||||||
return $this->_action;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* class constructor, validates the command line parameters
|
|
||||||
* and sets the Action-object if valid
|
|
||||||
*
|
|
||||||
* @param int $argc
|
|
||||||
* @param string[] $argv
|
|
||||||
*
|
|
||||||
* @return null
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
private function __construct($argc, $argv)
|
|
||||||
{
|
|
||||||
self::$args = $this->_parseArgs($argv);
|
|
||||||
$this->_action = $this->_createAction();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parses the arguments given via the command line;
|
|
||||||
* three types are supported:
|
|
||||||
* 1.
|
|
||||||
* --parm1 or --parm2=value
|
|
||||||
* 2. -xyz (multiple switches in one) or -a=value
|
|
||||||
* 3. parm1 parm2
|
|
||||||
*
|
|
||||||
* The 1. will be mapped as
|
|
||||||
* ["parm1"] => true, ["parm2"] => "value"
|
|
||||||
* The 2. as
|
|
||||||
* ["x"] => true, ["y"] => true, ["z"] => true, ["a"] => "value"
|
|
||||||
* And the 3. as
|
|
||||||
* [0] => "parm1", [1] => "parm2"
|
|
||||||
*
|
|
||||||
* @param array $argv
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
private function _parseArgs($argv)
|
|
||||||
{
|
|
||||||
array_shift($argv);
|
|
||||||
$o = array();
|
|
||||||
foreach ($argv as $a) {
|
|
||||||
if (substr($a, 0, 2) == '--') {
|
|
||||||
$eq = strpos($a, '=');
|
|
||||||
if ($eq !== false) {
|
|
||||||
$o[substr($a, 2, $eq - 2)] = substr($a, $eq + 1);
|
|
||||||
} else {
|
|
||||||
$k = substr($a, 2);
|
|
||||||
if (! isset($o[$k])) {
|
|
||||||
$o[$k] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
if (substr($a, 0, 1) == '-') {
|
|
||||||
if (substr($a, 2, 1) == '=') {
|
|
||||||
$o[substr($a, 1, 1)] = substr($a, 3);
|
|
||||||
} else {
|
|
||||||
foreach (str_split(substr($a, 1)) as $k) {
|
|
||||||
if (! isset($o[$k])) {
|
|
||||||
$o[$k] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$o[] = $a;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $o;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates an Action-Object for the Action-Handler
|
|
||||||
*
|
|
||||||
* @return Action
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
private function _createAction()
|
|
||||||
{
|
|
||||||
|
|
||||||
// Test for help-switch
|
|
||||||
if (empty(self::$args) || array_key_exists("help", self::$args) || array_key_exists("h", self::$args)) {
|
|
||||||
self::printHelp();
|
|
||||||
// end of execution
|
|
||||||
}
|
|
||||||
// check if no unknown parameters are present
|
|
||||||
foreach (self::$args as $arg => $value) {
|
|
||||||
|
|
||||||
if (is_numeric($arg)) {
|
|
||||||
throw new Exception("Unknown parameter '" . $value . "' in argument list");
|
|
||||||
} elseif (! in_array($arg, self::$params) && ! in_array($arg, self::$switches)) {
|
|
||||||
throw new Exception("Unknown parameter '" . $arg . "' in argument list");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// set debugger switch
|
|
||||||
if (isset(self::$args["d"]) && self::$args["d"] == true) {
|
|
||||||
// Debugger::getInstance()->setEnabled(true);
|
|
||||||
// Debugger::getInstance()->debug("debug output enabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Action(self::$args);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function printHelp()
|
public static function printHelp()
|
||||||
{
|
{
|
||||||
@@ -207,34 +70,9 @@ class CmdLineHandler
|
|||||||
// self::println("-d\t\t\tenable debug output");
|
// self::println("-d\t\t\tenable debug output");
|
||||||
self::println("-h\t\t\tsame as --help");
|
self::println("-h\t\t\tsame as --help");
|
||||||
self::println("");
|
self::println("");
|
||||||
|
|
||||||
die(); // end of execution
|
die(); // end of execution
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function println($msg = "")
|
|
||||||
{
|
|
||||||
print $msg . PHP_EOL;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static function _printcolor($msg = "", $color = "0")
|
|
||||||
{
|
|
||||||
print "\033[" . $color . "m" . $msg . "\033[0m" . PHP_EOL;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function printerr($msg = "")
|
|
||||||
{
|
|
||||||
self::_printcolor($msg, "31");
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function printsucc($msg = "")
|
|
||||||
{
|
|
||||||
self::_printcolor($msg, "32");
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function printwarn($msg = "")
|
|
||||||
{
|
|
||||||
self::_printcolor($msg, "33");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class Action
|
class Action
|
||||||
@@ -268,11 +106,11 @@ class Action
|
|||||||
if (array_key_exists("list", $this->_args) || array_key_exists("switch", $this->_args)) {
|
if (array_key_exists("list", $this->_args) || array_key_exists("switch", $this->_args)) {
|
||||||
$need_config = true;
|
$need_config = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->_checkConfigParam($need_config);
|
$this->_checkConfigParam($need_config);
|
||||||
|
|
||||||
$this->_parseConfig();
|
$this->_parseConfig();
|
||||||
|
|
||||||
if (array_key_exists("list", $this->_args)) {
|
if (array_key_exists("list", $this->_args)) {
|
||||||
$this->_listIPs();
|
$this->_listIPs();
|
||||||
}
|
}
|
||||||
@@ -300,11 +138,11 @@ class Action
|
|||||||
private function _switchIPs()
|
private function _switchIPs()
|
||||||
{
|
{
|
||||||
$ip_list = $this->_args['switch'];
|
$ip_list = $this->_args['switch'];
|
||||||
|
|
||||||
if (empty($ip_list) || is_bool($ip_list)) {
|
if (empty($ip_list) || is_bool($ip_list)) {
|
||||||
throw new Exception("No paramters given for --switch action.");
|
throw new Exception("No paramters given for --switch action.");
|
||||||
}
|
}
|
||||||
|
|
||||||
$ips_to_switch = array();
|
$ips_to_switch = array();
|
||||||
$ip_list = explode(" ", $ip_list);
|
$ip_list = explode(" ", $ip_list);
|
||||||
foreach ($ip_list as $ips_combo) {
|
foreach ($ip_list as $ips_combo) {
|
||||||
@@ -324,34 +162,42 @@ class Action
|
|||||||
}
|
}
|
||||||
$ips_to_switch[] = $ip_pair;
|
$ips_to_switch[] = $ip_pair;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count($ips_to_switch) > 0) {
|
if (count($ips_to_switch) > 0) {
|
||||||
|
$check_stmt = Database::prepare("SELECT `id` FROM panel_ipsandports WHERE `ip` = :newip");
|
||||||
$upd_stmt = Database::prepare("UPDATE panel_ipsandports SET `ip` = :newip WHERE `ip` = :oldip");
|
$upd_stmt = Database::prepare("UPDATE panel_ipsandports SET `ip` = :newip WHERE `ip` = :oldip");
|
||||||
|
|
||||||
// system.ipaddress
|
// system.ipaddress
|
||||||
$check_sysip_stmt = Database::prepare("SELECT `value` FROM `panel_settings` WHERE `settinggroup` = 'system' and `varname` = 'ipaddress'");
|
$check_sysip_stmt = Database::prepare("SELECT `value` FROM `panel_settings` WHERE `settinggroup` = 'system' and `varname` = 'ipaddress'");
|
||||||
$check_sysip = Database::pexecute_first($check_sysip_stmt);
|
$check_sysip = Database::pexecute_first($check_sysip_stmt);
|
||||||
|
|
||||||
// system.mysql_access_host
|
// system.mysql_access_host
|
||||||
$check_mysqlip_stmt = Database::prepare("SELECT `value` FROM `panel_settings` WHERE `settinggroup` = 'system' and `varname` = 'mysql_access_host'");
|
$check_mysqlip_stmt = Database::prepare("SELECT `value` FROM `panel_settings` WHERE `settinggroup` = 'system' and `varname` = 'mysql_access_host'");
|
||||||
$check_mysqlip = Database::pexecute_first($check_mysqlip_stmt);
|
$check_mysqlip = Database::pexecute_first($check_mysqlip_stmt);
|
||||||
|
|
||||||
// system.axfrservers
|
// system.axfrservers
|
||||||
$check_axfrip_stmt = Database::prepare("SELECT `value` FROM `panel_settings` WHERE `settinggroup` = 'system' and `varname` = 'axfrservers'");
|
$check_axfrip_stmt = Database::prepare("SELECT `value` FROM `panel_settings` WHERE `settinggroup` = 'system' and `varname` = 'axfrservers'");
|
||||||
$check_axfrip = Database::pexecute_first($check_axfrip_stmt);
|
$check_axfrip = Database::pexecute_first($check_axfrip_stmt);
|
||||||
|
|
||||||
foreach ($ips_to_switch as $ip_pair) {
|
foreach ($ips_to_switch as $ip_pair) {
|
||||||
echo "Switching IP \033[1m" . $ip_pair[0] . "\033[0m to IP \033[1m" . $ip_pair[1] . "\033[0m" . PHP_EOL;
|
echo "Switching IP \033[1m" . $ip_pair[0] . "\033[0m to IP \033[1m" . $ip_pair[1] . "\033[0m" . PHP_EOL;
|
||||||
|
|
||||||
|
$ip_check = Database::pexecute_first($check_stmt, array('newip' => $ip_pair[1]));
|
||||||
|
if ($ip_check) {
|
||||||
|
CmdLineHandler::printwarn("Note: " . $ip_pair[0] . " not updated to " . $ip_pair[1] . " - IP already exists in froxlor's database");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
Database::pexecute($upd_stmt, array(
|
Database::pexecute($upd_stmt, array(
|
||||||
'newip' => $ip_pair[1],
|
'newip' => $ip_pair[1],
|
||||||
'oldip' => $ip_pair[0]
|
'oldip' => $ip_pair[0]
|
||||||
));
|
));
|
||||||
$rows_updated = $upd_stmt->rowCount();
|
$rows_updated = $upd_stmt->rowCount();
|
||||||
|
|
||||||
if ($rows_updated == 0) {
|
if ($rows_updated == 0) {
|
||||||
CmdLineHandler::printwarn("Note: " . $ip_pair[0] . " not updated to " . $ip_pair[1] . " (possibly no entry found in froxlor database. Use --list to see what IP addresses are added in froxlor");
|
CmdLineHandler::printwarn("Note: " . $ip_pair[0] . " not updated to " . $ip_pair[1] . " (possibly no entry found in froxlor database. Use --list to see what IP addresses are added in froxlor");
|
||||||
}
|
}
|
||||||
|
|
||||||
// check whether the system.ipaddress needs updating
|
// check whether the system.ipaddress needs updating
|
||||||
if ($check_sysip['value'] == $ip_pair[0]) {
|
if ($check_sysip['value'] == $ip_pair[0]) {
|
||||||
$upd2_stmt = Database::prepare("UPDATE `panel_settings` SET `value` = :newip WHERE `settinggroup` = 'system' and `varname` = 'ipaddress'");
|
$upd2_stmt = Database::prepare("UPDATE `panel_settings` SET `value` = :newip WHERE `settinggroup` = 'system' and `varname` = 'ipaddress'");
|
||||||
@@ -360,7 +206,7 @@ class Action
|
|||||||
));
|
));
|
||||||
CmdLineHandler::printsucc("Updated system-ipaddress from '" . $ip_pair[0] . "' to '" . $ip_pair[1] . "'");
|
CmdLineHandler::printsucc("Updated system-ipaddress from '" . $ip_pair[0] . "' to '" . $ip_pair[1] . "'");
|
||||||
}
|
}
|
||||||
|
|
||||||
// check whether the system.mysql_access_host needs updating
|
// check whether the system.mysql_access_host needs updating
|
||||||
if (strstr($check_mysqlip['value'], $ip_pair[0]) !== false) {
|
if (strstr($check_mysqlip['value'], $ip_pair[0]) !== false) {
|
||||||
$new_mysqlip = str_replace($ip_pair[0], $ip_pair[1], $check_mysqlip['value']);
|
$new_mysqlip = str_replace($ip_pair[0], $ip_pair[1], $check_mysqlip['value']);
|
||||||
@@ -370,7 +216,7 @@ class Action
|
|||||||
));
|
));
|
||||||
CmdLineHandler::printsucc("Updated mysql_access_host from '" . $check_mysqlip['value'] . "' to '" . $new_mysqlip . "'");
|
CmdLineHandler::printsucc("Updated mysql_access_host from '" . $check_mysqlip['value'] . "' to '" . $new_mysqlip . "'");
|
||||||
}
|
}
|
||||||
|
|
||||||
// check whether the system.axfrservers needs updating
|
// check whether the system.axfrservers needs updating
|
||||||
if (strstr($check_axfrip['value'], $ip_pair[0]) !== false) {
|
if (strstr($check_axfrip['value'], $ip_pair[0]) !== false) {
|
||||||
$new_axfrip = str_replace($ip_pair[0], $ip_pair[1], $check_axfrip['value']);
|
$new_axfrip = str_replace($ip_pair[0], $ip_pair[1], $check_axfrip['value']);
|
||||||
@@ -382,7 +228,7 @@ class Action
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
echo PHP_EOL;
|
echo PHP_EOL;
|
||||||
CmdLineHandler::printwarn("*** ATTENTION *** Remember to replace IP addresses in configuration files if used anywhere.");
|
CmdLineHandler::printwarn("*** ATTENTION *** Remember to replace IP addresses in configuration files if used anywhere.");
|
||||||
CmdLineHandler::printsucc("IP addresses updated");
|
CmdLineHandler::printsucc("IP addresses updated");
|
||||||
@@ -391,12 +237,15 @@ class Action
|
|||||||
private function _parseConfig()
|
private function _parseConfig()
|
||||||
{
|
{
|
||||||
define('FROXLOR_INSTALL_DIR', $this->_args['froxlor-dir']);
|
define('FROXLOR_INSTALL_DIR', $this->_args['froxlor-dir']);
|
||||||
if (!file_exists(FROXLOR_INSTALL_DIR . '/lib/classes/database/class.Database.php')) {
|
if (! file_exists(FROXLOR_INSTALL_DIR . '/lib/classes/database/class.Database.php')) {
|
||||||
throw new Exception("Could not find froxlor's Database class. Is froxlor really installed to '".FROXLOR_INSTALL_DIR."'?");
|
throw new Exception("Could not find froxlor's Database class. Is froxlor really installed to '" . FROXLOR_INSTALL_DIR . "'?");
|
||||||
}
|
}
|
||||||
if (!file_exists(FROXLOR_INSTALL_DIR . '/lib/userdata.inc.php')) {
|
if (! file_exists(FROXLOR_INSTALL_DIR . '/lib/userdata.inc.php')) {
|
||||||
throw new Exception("Could not find froxlor's userdata.inc.php file. You should use this script only with a fully installed and setup froxlor system.");
|
throw new Exception("Could not find froxlor's userdata.inc.php file. You should use this script only with a fully installed and setup froxlor system.");
|
||||||
}
|
}
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/functions/filedir/function.makeSecurePath.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/functions/filedir/function.makeCorrectDir.php';
|
||||||
|
require FROXLOR_INSTALL_DIR . '/lib/functions/filedir/function.makeCorrectFile.php';
|
||||||
require FROXLOR_INSTALL_DIR . '/lib/classes/database/class.Database.php';
|
require FROXLOR_INSTALL_DIR . '/lib/classes/database/class.Database.php';
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -415,3 +264,10 @@ class Action
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// give control to command line handler
|
||||||
|
try {
|
||||||
|
SwitchServerIp::processParameters($argc, $argv);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
SwitchServerIp::printerr($e->getMessage());
|
||||||
|
}
|
||||||
|
|||||||
@@ -14,9 +14,11 @@
|
|||||||
* @package Install
|
* @package Install
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
if (! defined('AREA') || (defined('AREA') && AREA != 'admin') || ! isset($userinfo['loginname']) || (isset($userinfo['loginname']) && $userinfo['loginname'] == '')) {
|
if (!defined('_CRON_UPDATE')) {
|
||||||
header('Location: ../../../../index.php');
|
if (! defined('AREA') || (defined('AREA') && AREA != 'admin') || ! isset($userinfo['loginname']) || (isset($userinfo['loginname']) && $userinfo['loginname'] == '')) {
|
||||||
exit();
|
header('Location: ../../../../index.php');
|
||||||
|
exit();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isFroxlorVersion('0.9-r0')) {
|
if (isFroxlorVersion('0.9-r0')) {
|
||||||
@@ -3579,3 +3581,488 @@ if (isFroxlorVersion('0.9.38.4')) {
|
|||||||
showUpdateStep("Updating from 0.9.38.4 to 0.9.38.5", false);
|
showUpdateStep("Updating from 0.9.38.4 to 0.9.38.5", false);
|
||||||
updateToVersion('0.9.38.5');
|
updateToVersion('0.9.38.5');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.38.5')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.38.5 to 0.9.38.6", false);
|
||||||
|
updateToVersion('0.9.38.6');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.38.6')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.38.6 to 0.9.38.7", false);
|
||||||
|
updateToVersion('0.9.38.7');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201612110')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding field for OCSP stapling");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_DOMAINS .
|
||||||
|
"` ADD `ocsp_stapling` TINYINT(1) NOT NULL DEFAULT '0';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Adding default setting for Apache 2.4 OCSP cache path");
|
||||||
|
Settings::AddNew('system.apache24_ocsp_cache_path', 'shmcb:/var/run/apache2/ocsp-stapling.cache(131072)');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201704100');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201704100')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding new setting for libnss-extrausers");
|
||||||
|
$system_nssextrausers= isset($_POST['system_nssextrausers']) ? (int) $_POST['system_nssextrausers'] : 0;
|
||||||
|
Settings::AddNew('system.nssextrausers', $system_nssextrausers);
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201705050');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201705050')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating HTTP2 setting");
|
||||||
|
if (Settings::Get('system.nginx_http2_support') != null) {
|
||||||
|
Database::query("UPDATE `" . TABLE_PANEL_SETTINGS . "` SET `varname` = 'http2_support' WHERE `varname` = 'nginx_http2_support';");
|
||||||
|
} else {
|
||||||
|
Settings::AddNew('system.http2_support', 0);
|
||||||
|
}
|
||||||
|
lastStepStatus(0);
|
||||||
|
showUpdateStep("Adding domain field for HTTP2 stapling");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_DOMAINS . "` ADD `http2` TINYINT(1) NOT NULL DEFAULT '0';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201708240');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201708240')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding new 'disable LE self-check' setting");
|
||||||
|
$system_disable_le_selfcheck = isset($_POST['system_disable_le_selfcheck']) ? (int) $_POST['system_disable_le_selfcheck'] : 0;
|
||||||
|
Settings::AddNew('system.disable_le_selfcheck', $system_disable_le_selfcheck);
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201712310');
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.38.7 to 0.9.38.8", false);
|
||||||
|
updateToVersion('0.9.38.8');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201712310')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding field for fpm-daemon configs");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `fpmsettingid` int(11) NOT NULL DEFAULT '1';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Adding new fpm-daemons table");
|
||||||
|
Database::query("DROP TABLE IF EXISTS `panel_fpmdaemons`;");
|
||||||
|
$sql = "CREATE TABLE `panel_fpmdaemons` (
|
||||||
|
`id` int(11) unsigned NOT NULL auto_increment,
|
||||||
|
`description` varchar(50) NOT NULL,
|
||||||
|
`reload_cmd` varchar(255) NOT NULL,
|
||||||
|
`config_dir` varchar(255) NOT NULL,
|
||||||
|
`pm` varchar(15) NOT NULL DEFAULT 'static',
|
||||||
|
`max_children` int(4) NOT NULL DEFAULT '1',
|
||||||
|
`start_servers` int(4) NOT NULL DEFAULT '20',
|
||||||
|
`min_spare_servers` int(4) NOT NULL DEFAULT '5',
|
||||||
|
`max_spare_servers` int(4) NOT NULL DEFAULT '35',
|
||||||
|
`max_requests` int(4) NOT NULL DEFAULT '0',
|
||||||
|
`idle_timeout` int(4) NOT NULL DEFAULT '30',
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
UNIQUE KEY `reload` (`reload_cmd`),
|
||||||
|
UNIQUE KEY `config` (`config_dir`)
|
||||||
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;";
|
||||||
|
Database::query($sql);
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Converting php-fpm settings to new layout");
|
||||||
|
$ins_stmt = Database::prepare("
|
||||||
|
INSERT INTO `panel_fpmdaemons` SET
|
||||||
|
`id` = 1,
|
||||||
|
`description` = 'System default',
|
||||||
|
`reload_cmd` = :reloadcmd,
|
||||||
|
`config_dir` = :confdir,
|
||||||
|
`pm` = :pm,
|
||||||
|
`max_children` = :maxc,
|
||||||
|
`start_servers` = :starts,
|
||||||
|
`min_spare_servers` = :minss,
|
||||||
|
`max_spare_servers` = :maxss,
|
||||||
|
`max_requests` = :maxr,
|
||||||
|
`idle_timeout` = :it
|
||||||
|
");
|
||||||
|
Database::pexecute($ins_stmt, array(
|
||||||
|
'reloadcmd' => Settings::Get('phpfpm.reload'),
|
||||||
|
'confdir' => Settings::Get('phpfpm.configdir'),
|
||||||
|
'pm' => Settings::Get('phpfpm.pm'),
|
||||||
|
'maxc' => Settings::Get('phpfpm.max_children'),
|
||||||
|
'starts' => Settings::Get('phpfpm.start_servers'),
|
||||||
|
'minss' => Settings::Get('phpfpm.min_spare_servers'),
|
||||||
|
'maxss' => Settings::Get('phpfpm.max_spare_servers'),
|
||||||
|
'maxr' => Settings::Get('phpfpm.max_requests'),
|
||||||
|
'it' => Settings::Get('phpfpm.idle_timeout')
|
||||||
|
));
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Deleting unneeded settings");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'reload'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'configdir'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'pm'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'max_children'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'start_servers'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'min_spare_servers'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'max_spare_servers'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'max_requests'");
|
||||||
|
Database::query("DELETE FROM `".TABLE_PANEL_SETTINGS."` WHERE `settinggroup` = 'phpfpm' AND `varname` = 'idle_timeout'");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801070');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801070')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding field allowed_phpconfigs for customers");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_CUSTOMERS . "` ADD `allowed_phpconfigs` varchar(500) NOT NULL default '';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801080');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801080')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding new setting for Let's Encrypt ACME version");
|
||||||
|
Settings::AddNew('system.leapiversion', '1');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801090');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801090')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding field pass_authorizationheader for php-configs");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `pass_authorizationheader` tinyint(1) NOT NULL default '0';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801091');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801091')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding new setting for SSL protocols");
|
||||||
|
Settings::AddNew('system.ssl_protocols', 'TLSv1,TLSv1.2');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801100');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801100')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding field for security.limit_extensions fpm-setting");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_FPMDAEMONS . "` ADD `limit_extensions` varchar(255) NOT NULL default '.php';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801101');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801101')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding dynamic php-fpm php.ini settings");
|
||||||
|
Settings::AddNew('phpfpm.ini_flags', 'asp_tags
|
||||||
|
display_errors
|
||||||
|
display_startup_errors
|
||||||
|
html_errors
|
||||||
|
log_errors
|
||||||
|
magic_quotes_gpc
|
||||||
|
magic_quotes_runtime
|
||||||
|
magic_quotes_sybase
|
||||||
|
mail.add_x_header
|
||||||
|
session.cookie_secure
|
||||||
|
session.use_cookies
|
||||||
|
short_open_tag
|
||||||
|
track_errors
|
||||||
|
xmlrpc_errors
|
||||||
|
suhosin.simulation
|
||||||
|
suhosin.session.encrypt
|
||||||
|
suhosin.session.cryptua
|
||||||
|
suhosin.session.cryptdocroot
|
||||||
|
suhosin.cookie.encrypt
|
||||||
|
suhosin.cookie.cryptua
|
||||||
|
suhosin.cookie.cryptdocroot
|
||||||
|
suhosin.executor.disable_eval
|
||||||
|
mbstring.func_overload');
|
||||||
|
Settings::AddNew('phpfpm.ini_values', 'auto_append_file
|
||||||
|
auto_prepend_file
|
||||||
|
date.timezone
|
||||||
|
default_charset
|
||||||
|
error_reporting
|
||||||
|
include_path
|
||||||
|
log_errors_max_len
|
||||||
|
mail.log
|
||||||
|
max_execution_time
|
||||||
|
session.cookie_domain
|
||||||
|
session.cookie_lifetime
|
||||||
|
session.cookie_path
|
||||||
|
session.name
|
||||||
|
session.serialize_handler
|
||||||
|
upload_max_filesize
|
||||||
|
xmlrpc_error_number
|
||||||
|
session.auto_start
|
||||||
|
always_populate_raw_post_data
|
||||||
|
suhosin.session.cryptkey
|
||||||
|
suhosin.session.cryptraddr
|
||||||
|
suhosin.session.checkraddr
|
||||||
|
suhosin.cookie.cryptkey
|
||||||
|
suhosin.cookie.plainlist
|
||||||
|
suhosin.cookie.cryptraddr
|
||||||
|
suhosin.cookie.checkraddr
|
||||||
|
suhosin.executor.func.blacklist
|
||||||
|
suhosin.executor.eval.whitelist');
|
||||||
|
Settings::AddNew('phpfpm.ini_admin_flags', 'allow_call_time_pass_reference
|
||||||
|
allow_url_fopen
|
||||||
|
allow_url_include
|
||||||
|
auto_detect_line_endings
|
||||||
|
cgi.fix_pathinfo
|
||||||
|
cgi.force_redirect
|
||||||
|
enable_dl
|
||||||
|
expose_php
|
||||||
|
file_uploads
|
||||||
|
ignore_repeated_errors
|
||||||
|
ignore_repeated_source
|
||||||
|
log_errors
|
||||||
|
register_argc_argv
|
||||||
|
report_memleaks
|
||||||
|
opcache.enable
|
||||||
|
opcache.consistency_checks
|
||||||
|
opcache.dups_fix
|
||||||
|
opcache.load_comments
|
||||||
|
opcache.revalidate_path
|
||||||
|
opcache.save_comments
|
||||||
|
opcache.use_cwd
|
||||||
|
opcache.validate_timestamps
|
||||||
|
opcache.fast_shutdown');
|
||||||
|
Settings::AddNew('phpfpm.ini_admin_values', 'cgi.redirect_status_env
|
||||||
|
date.timezone
|
||||||
|
disable_classes
|
||||||
|
disable_functions
|
||||||
|
error_log
|
||||||
|
gpc_order
|
||||||
|
max_input_time
|
||||||
|
max_input_vars
|
||||||
|
memory_limit
|
||||||
|
open_basedir
|
||||||
|
output_buffering
|
||||||
|
post_max_size
|
||||||
|
precision
|
||||||
|
sendmail_path
|
||||||
|
session.gc_divisor
|
||||||
|
session.gc_probability
|
||||||
|
variables_order
|
||||||
|
opcache.log_verbosity_level
|
||||||
|
opcache.restrict_api
|
||||||
|
opcache.revalidate_freq
|
||||||
|
opcache.max_accelerated_files
|
||||||
|
opcache.memory_consumption
|
||||||
|
opcache.interned_strings_buffer');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801110');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801110')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding php-fpm php PATH setting for envrironment");
|
||||||
|
Settings::AddNew("phpfpm.envpath", '/usr/local/bin:/usr/bin:/bin');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201801260');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.38.8')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.38.8 to 0.9.39 final", false);
|
||||||
|
updateToVersion('0.9.39');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.39')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.39 to 0.9.39.1", false);
|
||||||
|
updateToVersion('0.9.39.1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.39.1')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.39.1 to 0.9.39.2", false);
|
||||||
|
updateToVersion('0.9.39.2');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201801260')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding new plans table");
|
||||||
|
Database::query("DROP TABLE IF EXISTS `panel_plans`;");
|
||||||
|
$sql = "CREATE TABLE `panel_plans` (
|
||||||
|
`id` int(11) NOT NULL auto_increment,
|
||||||
|
`adminid` int(11) NOT NULL default '0',
|
||||||
|
`name` varchar(255) NOT NULL default '',
|
||||||
|
`description` text NOT NULL,
|
||||||
|
`value` longtext NOT NULL,
|
||||||
|
`ts` int(15) NOT NULL default '0',
|
||||||
|
PRIMARY KEY (id),
|
||||||
|
KEY adminid (adminid)
|
||||||
|
) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;";
|
||||||
|
Database::query($sql);
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201802120');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201802120')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding domain field for try_files flag");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_DOMAINS . "` ADD `notryfiles` tinyint(1) DEFAULT '0';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201802130');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.39.2')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.39.2 to 0.9.39.3", false);
|
||||||
|
updateToVersion('0.9.39.3');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.39.3')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.39.3 to 0.9.39.4", false);
|
||||||
|
updateToVersion('0.9.39.4');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.39.4')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.39.4 to 0.9.39.5", false);
|
||||||
|
updateToVersion('0.9.39.5');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201802130')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding fullchain field to ssl certificates");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_DOMAIN_SSL_SETTINGS . "` ADD `ssl_fullchain_file` mediumtext AFTER `ssl_csr_file`;");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201802250');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201802250')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding webserver logfile settings");
|
||||||
|
Settings::AddNew("system.logfiles_format", '');
|
||||||
|
Settings::AddNew("system.logfiles_type", '1');
|
||||||
|
Settings::AddNew("system.logfiles_piped", '0');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201805240');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201805240')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding webserver logfile-script settings");
|
||||||
|
Settings::AddNew("system.logfiles_script", '');
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201805241');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201805241')) {
|
||||||
|
|
||||||
|
$do_update = true;
|
||||||
|
showUpdateStep("Checking for required PHP json-extension");
|
||||||
|
if (! extension_loaded('json')) {
|
||||||
|
$do_update = false;
|
||||||
|
lastStepStatus(2, 'not installed');
|
||||||
|
} else {
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Checking for current cronjobs that need converting");
|
||||||
|
$result_tasks_stmt = Database::query("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_TASKS . "` ORDER BY `id` ASC
|
||||||
|
");
|
||||||
|
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_TASKS . "` SET `data` = :data WHERE `id` = :taskid");
|
||||||
|
while ($row = $result_tasks_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
if (! empty($row['data'])) {
|
||||||
|
$data = unserialize($row['data']);
|
||||||
|
Database::pexecute($upd_stmt, array(
|
||||||
|
'data' => json_encode($data),
|
||||||
|
'taskid' => $row['id']
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201805290');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201805290')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding leaccount field to panel customers");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_CUSTOMERS . "` ADD COLUMN `leaccount` varchar(255) default '' AFTER `leregistered`;");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Adding system setting for let's-encrypt account");
|
||||||
|
Settings::AddNew('system.leaccount', "");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201809180');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isDatabaseVersion('201809180')) {
|
||||||
|
|
||||||
|
showUpdateStep("Adding new fields for php configs");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `override_fpmconfig` tinyint(1) NOT NULL DEFAULT '0';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `pm` varchar(15) NOT NULL DEFAULT 'static';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `max_children` int(4) NOT NULL DEFAULT '1';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `start_servers` int(4) NOT NULL DEFAULT '20';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `min_spare_servers` int(4) NOT NULL DEFAULT '5';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `max_spare_servers` int(4) NOT NULL DEFAULT '35';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `max_requests` int(4) NOT NULL DEFAULT '0';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `idle_timeout` int(4) NOT NULL DEFAULT '30';");
|
||||||
|
Database::query("ALTER TABLE `" . TABLE_PANEL_PHPCONFIGS . "` ADD `limit_extensions` varchar(255) NOT NULL default '.php';");
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
showUpdateStep("Synchronize fpm-daemon process manager settings with php-configs");
|
||||||
|
// get all fpm-daemons
|
||||||
|
$sel_stmt = Database::prepare("SELECT * FROM `panel_fpmdaemons`;");
|
||||||
|
Database::pexecute($sel_stmt);
|
||||||
|
$fpm_daemons = $sel_stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_PHPCONFIGS . "` SET
|
||||||
|
`pm` = :pm,
|
||||||
|
`max_children` = :maxc,
|
||||||
|
`start_servers` = :starts,
|
||||||
|
`min_spare_servers` = :minss,
|
||||||
|
`max_spare_servers` = :maxss,
|
||||||
|
`max_requests` = :maxr,
|
||||||
|
`idle_timeout` = :it,
|
||||||
|
`limit_extensions` = :le
|
||||||
|
WHERE `fpmsettingid` = :fpmid
|
||||||
|
");
|
||||||
|
// update all php-configs with the pm data from the fpm-daemon
|
||||||
|
foreach ($fpm_daemons as $fpm_daemon) {
|
||||||
|
Database::pexecute($upd_stmt, array(
|
||||||
|
'pm' => $fpm_daemon['pm'],
|
||||||
|
'maxc' => $fpm_daemon['max_children'],
|
||||||
|
'starts' => $fpm_daemon['start_servers'],
|
||||||
|
'minss' => $fpm_daemon['min_spare_servers'],
|
||||||
|
'maxss' => $fpm_daemon['max_spare_servers'],
|
||||||
|
'maxr' => $fpm_daemon['max_requests'],
|
||||||
|
'it' => $fpm_daemon['idle_timeout'],
|
||||||
|
'le' => $fpm_daemon['limit_extensions'],
|
||||||
|
'fpmid' => $fpm_daemon['id']
|
||||||
|
));
|
||||||
|
}
|
||||||
|
lastStepStatus(0);
|
||||||
|
|
||||||
|
updateToDbVersion('201809280');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isFroxlorVersion('0.9.39.5')) {
|
||||||
|
|
||||||
|
showUpdateStep("Updating from 0.9.39.5 to 0.9.40", false);
|
||||||
|
updateToVersion('0.9.40');
|
||||||
|
}
|
||||||
|
|||||||
@@ -709,4 +709,22 @@ function parseAndOutputPreconfig(&$has_preconfig, &$return, $current_version, $c
|
|||||||
$question .= '<input type="password" class="text" name="smtp_passwd" value="" /><br />';
|
$question .= '<input type="password" class="text" name="smtp_passwd" value="" /><br />';
|
||||||
eval("\$return.=\"" . getTemplate("update/preconfigitem") . "\";");
|
eval("\$return.=\"" . getTemplate("update/preconfigitem") . "\";");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (versionInUpdate($current_db_version, '201705050')) {
|
||||||
|
$has_preconfig = true;
|
||||||
|
$description = 'DEBIAN/UBUNTU ONLY: Enable usage of libnss-extrausers as alternative to libnss-mysql (NOTE: if enabled, go through the configuration steps right after the update!!!)<br /><br />';
|
||||||
|
$question = '<strong>Enable usage of libnss-extrausers?</strong><br />';
|
||||||
|
$question .= makeyesno('system_nssextrausers', '1', '0', '0') . '<br />';
|
||||||
|
eval("\$return.=\"" . getTemplate("update/preconfigitem") . "\";");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (versionInUpdate($current_db_version, '201712310')) {
|
||||||
|
if (Settings::Get('system.leenabled') == 1) {
|
||||||
|
$has_preconfig = true;
|
||||||
|
$description = 'Chose whether you want to disable the Let\'s Encrypt selfcheck as it causes false positives for some configurations.<br /><br />';
|
||||||
|
$question = '<strong>Disable Let\'s Encrypt self-check?</strong><br />';
|
||||||
|
$question .= makeyesno('system_disable_le_selfcheck', '1', '0', '0') . '<br />';
|
||||||
|
eval("\$return.=\"" . getTemplate("update/preconfigitem") . "\";");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,13 +17,15 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!defined('AREA')
|
if (!defined('_CRON_UPDATE')) {
|
||||||
|| (defined('AREA') && AREA != 'admin')
|
if (!defined('AREA')
|
||||||
|| !isset($userinfo['loginname'])
|
|| (defined('AREA') && AREA != 'admin')
|
||||||
|| (isset($userinfo['loginname']) && $userinfo['loginname'] == '')
|
|| !isset($userinfo['loginname'])
|
||||||
) {
|
|| (isset($userinfo['loginname']) && $userinfo['loginname'] == '')
|
||||||
header('Location: ../index.php');
|
) {
|
||||||
exit;
|
header('Location: ../index.php');
|
||||||
|
exit;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$updatelog = FroxlorLogger::getInstanceOf(array('loginname' => 'updater'));
|
$updatelog = FroxlorLogger::getInstanceOf(array('loginname' => 'updater'));
|
||||||
|
|||||||
82
lib/ajax.php
82
lib/ajax.php
@@ -18,7 +18,7 @@
|
|||||||
|
|
||||||
// Load the user settings
|
// Load the user settings
|
||||||
define('FROXLOR_INSTALL_DIR', dirname(dirname(__FILE__)));
|
define('FROXLOR_INSTALL_DIR', dirname(dirname(__FILE__)));
|
||||||
if (!file_exists('./userdata.inc.php')) {
|
if (! file_exists('./userdata.inc.php')) {
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
require './userdata.inc.php';
|
require './userdata.inc.php';
|
||||||
@@ -27,10 +27,11 @@ require './classes/database/class.Database.php';
|
|||||||
require './classes/settings/class.Settings.php';
|
require './classes/settings/class.Settings.php';
|
||||||
require './functions/validate/function.validate_ip.php';
|
require './functions/validate/function.validate_ip.php';
|
||||||
require './functions/validate/function.validateDomain.php';
|
require './functions/validate/function.validateDomain.php';
|
||||||
|
require './classes/cURL/class.HttpClient.php';
|
||||||
|
|
||||||
if(isset($_POST['action'])) {
|
if (isset($_POST['action'])) {
|
||||||
$action = $_POST['action'];
|
$action = $_POST['action'];
|
||||||
} elseif(isset($_GET['action'])) {
|
} elseif (isset($_GET['action'])) {
|
||||||
$action = $_GET['action'];
|
$action = $_GET['action'];
|
||||||
} else {
|
} else {
|
||||||
$action = "";
|
$action = "";
|
||||||
@@ -42,51 +43,31 @@ if ($action == "newsfeed") {
|
|||||||
} else {
|
} else {
|
||||||
$feed = "https://inside.froxlor.org/news/";
|
$feed = "https://inside.froxlor.org/news/";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (function_exists("simplexml_load_file") == false) {
|
if (function_exists("simplexml_load_file") == false) {
|
||||||
die();
|
outputItem("Newsfeed not available due to missing php-simplexml extension", "Please install the php-simplexml extension in order to view our newsfeed.");
|
||||||
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (function_exists('curl_version')) {
|
if (function_exists('curl_version')) {
|
||||||
$ch = curl_init();
|
$output = HttpClient::urlGet($feed);
|
||||||
curl_setopt($ch, CURLOPT_URL, $feed);
|
|
||||||
curl_setopt($ch, CURLOPT_USERAGENT, 'Froxlor/'.$version);
|
|
||||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
|
||||||
$output = curl_exec($ch);
|
|
||||||
curl_close($ch);
|
|
||||||
$news = simplexml_load_string(trim($output));
|
$news = simplexml_load_string(trim($output));
|
||||||
} else {
|
} else {
|
||||||
if (ini_get('allow_url_fopen')) {
|
outputItem("Newsfeed not available due to missing php-curl extension", "Please install the php-curl extension in order to view our newsfeed.");
|
||||||
ini_set('user_agent', 'Froxlor/'.$version);
|
exit();
|
||||||
$news = simplexml_load_file($feed, null, LIBXML_NOCDATA);
|
|
||||||
} else {
|
|
||||||
$news = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($news !== false) {
|
if ($news !== false) {
|
||||||
for ($i = 0; $i < 3; $i++) {
|
for ($i = 0; $i < 3; $i ++) {
|
||||||
$item = $news->channel->item[$i];
|
$item = $news->channel->item[$i];
|
||||||
|
|
||||||
$title = (string)$item->title;
|
$title = (string) $item->title;
|
||||||
$link = (string)$item->link;
|
$link = (string) $item->link;
|
||||||
$date = date("Y-m-d G:i", strtotime($item->pubDate));
|
$date = date("Y-m-d G:i", strtotime($item->pubDate));
|
||||||
$content = preg_replace("/[\r\n]+/", " ", strip_tags($item->description));
|
$content = preg_replace("/[\r\n]+/", " ", strip_tags($item->description));
|
||||||
$content = substr($content, 0, 150) . "...";
|
$content = substr($content, 0, 150) . "...";
|
||||||
|
|
||||||
echo "<li class=\"clearfix\">
|
outputItem($title, $content, $link, $date);
|
||||||
<div class=\"newsfeed-body clearfix\">
|
|
||||||
<div class=\"header\">
|
|
||||||
<strong class=\"primary-font\"><a href=\"{$link}\" target=\"_blank\">{$title}</a></strong>
|
|
||||||
<small class=\"pull-right text-muted\">
|
|
||||||
<i class=\"fa fa-clock-o fa-fw\"></i> {$date}
|
|
||||||
</small>
|
|
||||||
</div>
|
|
||||||
<p>
|
|
||||||
{$content}
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</li>";
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
echo "";
|
echo "";
|
||||||
@@ -94,3 +75,30 @@ if ($action == "newsfeed") {
|
|||||||
} else {
|
} else {
|
||||||
echo "No action set.";
|
echo "No action set.";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function outputItem($title, $content, $link = null, $date = null)
|
||||||
|
{
|
||||||
|
echo "<li class=\"clearfix\">
|
||||||
|
<div class=\"newsfeed-body clearfix\">
|
||||||
|
<div class=\"header\">
|
||||||
|
<strong class=\"primary-font\">";
|
||||||
|
if (! empty($link)) {
|
||||||
|
echo "<a href=\"{$link}\" target=\"_blank\">";
|
||||||
|
}
|
||||||
|
echo $title;
|
||||||
|
if (! empty($link)) {
|
||||||
|
echo "</a>";
|
||||||
|
}
|
||||||
|
echo "</strong>";
|
||||||
|
if (! empty($date)) {
|
||||||
|
echo "<small class=\"pull-right text-muted\">
|
||||||
|
<i class=\"fa fa-clock-o fa-fw\"></i> {$date}
|
||||||
|
</small>";
|
||||||
|
}
|
||||||
|
echo "</div>
|
||||||
|
<p>
|
||||||
|
{$content}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</li>";
|
||||||
|
}
|
||||||
|
|||||||
@@ -93,6 +93,13 @@ class DomainBulkAction
|
|||||||
/* 16 */ 'use_ssl',
|
/* 16 */ 'use_ssl',
|
||||||
/* 17 */ 'registration_date',
|
/* 17 */ 'registration_date',
|
||||||
/* 18 */ 'ips',
|
/* 18 */ 'ips',
|
||||||
|
/* 19 */ 'letsencrypt',
|
||||||
|
/* 20 */ 'hsts',
|
||||||
|
/* 21 */ 'hsts_sub',
|
||||||
|
/* 22 */ 'hsts_preload',
|
||||||
|
/* 23 */ 'ocsp_stapling',
|
||||||
|
/* 24 */ 'phpenabled',
|
||||||
|
/* 25 */ 'http2',
|
||||||
/* automatically added */
|
/* automatically added */
|
||||||
'adminid',
|
'adminid',
|
||||||
'customerid',
|
'customerid',
|
||||||
@@ -180,13 +187,14 @@ class DomainBulkAction
|
|||||||
}
|
}
|
||||||
|
|
||||||
// preapre insert statement as it is used a few times
|
// preapre insert statement as it is used a few times
|
||||||
|
// leave out aliasdomain for now, cause empty = NULL value which cannot be
|
||||||
|
// added this easily using prepared statements
|
||||||
$this->_ins_stmt = Database::prepare("
|
$this->_ins_stmt = Database::prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
INSERT INTO `" . TABLE_PANEL_DOMAINS . "` SET
|
||||||
`domain` = :domain,
|
`domain` = :domain,
|
||||||
`adminid` = :adminid,
|
`adminid` = :adminid,
|
||||||
`customerid` = :customerid,
|
`customerid` = :customerid,
|
||||||
`documentroot` = :documentroot,
|
`documentroot` = :documentroot,
|
||||||
`aliasdomain` = :aliasdomain,
|
|
||||||
`isbinddomain` = :isbinddomain,
|
`isbinddomain` = :isbinddomain,
|
||||||
`isemaildomain` = :isemaildomain,
|
`isemaildomain` = :isemaildomain,
|
||||||
`email_only` = :email_only,
|
`email_only` = :email_only,
|
||||||
@@ -200,7 +208,14 @@ class DomainBulkAction
|
|||||||
`specialsettings` = :specialsettings,
|
`specialsettings` = :specialsettings,
|
||||||
`ssl_redirect` = :ssl_redirect,
|
`ssl_redirect` = :ssl_redirect,
|
||||||
`registration_date` = :registration_date,
|
`registration_date` = :registration_date,
|
||||||
`add_date` = :add_date
|
`add_date` = :add_date,
|
||||||
|
`letsencrypt` = :letsencrypt,
|
||||||
|
`hsts` = :hsts,
|
||||||
|
`hsts_sub` = :hsts_sub,
|
||||||
|
`hsts_preload` = :hsts_preload,
|
||||||
|
`ocsp_stapling` = :ocsp_stapling,
|
||||||
|
`phpenabled` = :phpenabled,
|
||||||
|
`http2` = :http2
|
||||||
");
|
");
|
||||||
|
|
||||||
// prepare insert statement for ip/port <> domain
|
// prepare insert statement for ip/port <> domain
|
||||||
@@ -293,6 +308,7 @@ class DomainBulkAction
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check for alias-domain
|
// check for alias-domain
|
||||||
|
$hasAlias = false;
|
||||||
if (! empty($domain_data['aliasdomain'])) {
|
if (! empty($domain_data['aliasdomain'])) {
|
||||||
// format
|
// format
|
||||||
$domain_data['aliasdomain'] = $idna_convert->encode(preg_replace(array(
|
$domain_data['aliasdomain'] = $idna_convert->encode(preg_replace(array(
|
||||||
@@ -311,6 +327,7 @@ class DomainBulkAction
|
|||||||
// - we'd better skip
|
// - we'd better skip
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
$hasAlias = $domain_data['aliasdomain'];
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for use_ssl and ssl_redirect
|
// check for use_ssl and ssl_redirect
|
||||||
@@ -335,6 +352,38 @@ class DomainBulkAction
|
|||||||
$domain_data['ssl_redirect'] = 0;
|
$domain_data['ssl_redirect'] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// only check for letsencrypt, hsts and oscp-stapling if ssl is enabled
|
||||||
|
if ($domain_data['use_ssl'] == 1) {
|
||||||
|
//lets encrypt
|
||||||
|
if ($domain_data['letsencrypt'] != 1 || $domain_data['iswildcarddomain'] == 1) {
|
||||||
|
$domain_data['letsencrypt'] = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$domain_data['letsencrypt'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// hsts
|
||||||
|
if ($domain_data['hsts'] != 1) {
|
||||||
|
$domain_data['hsts'] = 0;
|
||||||
|
}
|
||||||
|
if ($domain_data['hsts_sub'] != 1) {
|
||||||
|
$domain_data['hsts_sub'] = 0;
|
||||||
|
}
|
||||||
|
if ($domain_data['hsts_preload'] != 1) {
|
||||||
|
$domain_data['hsts_preload'] = 0;
|
||||||
|
}
|
||||||
|
if ($domain_data['ocsp_stapling'] != 1) {
|
||||||
|
$domain_data['ocsp_stapling'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($domain_data['phpenabled'] != 1) {
|
||||||
|
$domain_data['phpenabled'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($domain_data['http2'] != 1) {
|
||||||
|
$domain_data['http2'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// add to known domains
|
// add to known domains
|
||||||
$this->_knownDomains[] = $domain_data['domain'];
|
$this->_knownDomains[] = $domain_data['domain'];
|
||||||
|
|
||||||
@@ -416,13 +465,21 @@ class DomainBulkAction
|
|||||||
$use_ssl = (bool)$domain_data['use_ssl'];
|
$use_ssl = (bool)$domain_data['use_ssl'];
|
||||||
// don't need that for the domain-insert-statement
|
// don't need that for the domain-insert-statement
|
||||||
unset($domain_data['use_ssl']);
|
unset($domain_data['use_ssl']);
|
||||||
|
// don't need alias
|
||||||
|
unset($domain_data['aliasdomain']);
|
||||||
|
|
||||||
// finally ADD the domain to panel_domains
|
// finally ADD the domain to panel_domains
|
||||||
Database::pexecute($this->_ins_stmt, $domain_data);
|
Database::pexecute($this->_ins_stmt, $domain_data);
|
||||||
|
|
||||||
// get the newly inserted domain-id
|
// get the newly inserted domain-id
|
||||||
$domain_id = Database::lastInsertId();
|
$domain_id = Database::lastInsertId();
|
||||||
|
|
||||||
|
// add alias if any
|
||||||
|
if ($hasAlias != false) {
|
||||||
|
$alias_stmt = Database::prepare("UPDATE `".TABLE_PANEL_DOMAINS."` SET `aliasdomain` = :aliasdomain WHERE `id` = :did");
|
||||||
|
Database::pexecute($alias_stmt, array('aliasdomain' => $hasAlias, 'did' => $domain_id));
|
||||||
|
}
|
||||||
|
|
||||||
// insert domain <-> ip/port reference
|
// insert domain <-> ip/port reference
|
||||||
if (empty($iplist)) {
|
if (empty($iplist)) {
|
||||||
$iplist = Settings::Get('system.ipaddress');
|
$iplist = Settings::Get('system.ipaddress');
|
||||||
|
|||||||
62
lib/classes/cURL/class.HttpClient.php
Normal file
62
lib/classes/cURL/class.HttpClient.php
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class HttpClient
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Executes simple GET request
|
||||||
|
*
|
||||||
|
* @param string $url
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function urlGet($url, $follow_location = true)
|
||||||
|
{
|
||||||
|
include FROXLOR_INSTALL_DIR . '/lib/version.inc.php';
|
||||||
|
$ch = curl_init();
|
||||||
|
curl_setopt($ch, CURLOPT_URL, $url);
|
||||||
|
curl_setopt($ch, CURLOPT_USERAGENT, 'Froxlor/' . $version);
|
||||||
|
if ($follow_location) {
|
||||||
|
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
|
||||||
|
}
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
$output = curl_exec($ch);
|
||||||
|
if ($output === false) {
|
||||||
|
$e = curl_error($ch);
|
||||||
|
curl_close($ch);
|
||||||
|
throw new \Exception("Curl error: " . $e);
|
||||||
|
}
|
||||||
|
curl_close($ch);
|
||||||
|
return $output;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Downloads and stores a file from an url
|
||||||
|
*
|
||||||
|
* @param string $url
|
||||||
|
* @param string $target
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function fileGet($url, $target)
|
||||||
|
{
|
||||||
|
include FROXLOR_INSTALL_DIR . '/lib/version.inc.php';
|
||||||
|
$fh = fopen($target, 'w');
|
||||||
|
$ch = curl_init();
|
||||||
|
curl_setopt($ch, CURLOPT_URL, $url);
|
||||||
|
curl_setopt($ch, CURLOPT_USERAGENT, 'Froxlor/' . $version);
|
||||||
|
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
|
||||||
|
curl_setopt($ch, CURLOPT_TIMEOUT, 50);
|
||||||
|
//give curl the file pointer so that it can write to it
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_FILE, $fh);
|
||||||
|
$output = curl_exec($ch);
|
||||||
|
if ($output === false) {
|
||||||
|
$e = curl_error($ch);
|
||||||
|
curl_close($ch);
|
||||||
|
throw new \Exception("Curl error: " . $e);
|
||||||
|
}
|
||||||
|
curl_close($ch);
|
||||||
|
return $output;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -28,6 +28,11 @@
|
|||||||
* @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 Classes
|
* @package Classes
|
||||||
|
*
|
||||||
|
* @method static \PDOStatement prepare($statement, array $driver_options = null) Prepares a statement for execution and returns a statement object
|
||||||
|
* @method static \PDOStatement query ($statement) Executes an SQL statement, returning a result set as a PDOStatement object
|
||||||
|
* @method static string lastInsertId ($name = null) Returns the ID of the last inserted row or sequence value
|
||||||
|
* @method static string quote ($string, $parameter_type = null) Quotes a string for use in a query.
|
||||||
*/
|
*/
|
||||||
class Database {
|
class Database {
|
||||||
|
|
||||||
@@ -262,7 +267,7 @@ class Database {
|
|||||||
// build up connection string
|
// build up connection string
|
||||||
$driver = 'mysql';
|
$driver = 'mysql';
|
||||||
$dsn = $driver.":";
|
$dsn = $driver.":";
|
||||||
$options = array(PDO::MYSQL_ATTR_INIT_COMMAND => 'set names utf8');
|
$options = array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET names utf8,sql_mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"');
|
||||||
$attributes = array('ATTR_ERRMODE' => 'ERRMODE_EXCEPTION');
|
$attributes = array('ATTR_ERRMODE' => 'ERRMODE_EXCEPTION');
|
||||||
|
|
||||||
$dbconf["dsn"] = array(
|
$dbconf["dsn"] = array(
|
||||||
|
|||||||
@@ -134,7 +134,7 @@ class DbManagerMySQL {
|
|||||||
* @param string $host (unused in mysql)
|
* @param string $host (unused in mysql)
|
||||||
*/
|
*/
|
||||||
public function disableUser($username = null, $host = null) {
|
public function disableUser($username = null, $host = null) {
|
||||||
$stmt = Database::prepare("REVOKE ALL PRIVILEGES, GRANT OPTION FROM `".$row_database['databasename']."`");
|
$stmt = Database::prepare('REVOKE ALL PRIVILEGES, GRANT OPTION FROM `' . $username . '`@`' . $host . '`');
|
||||||
Database::pexecute($stmt, array(), false);
|
Database::pexecute($stmt, array(), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -41,7 +41,31 @@ class DnsEntry
|
|||||||
|
|
||||||
public function __toString()
|
public function __toString()
|
||||||
{
|
{
|
||||||
$result = $this->record . "\t" . $this->ttl . "\t" . $this->class . "\t" . $this->type . "\t" . (($this->priority >= 0 && ($this->type == 'MX' || $this->type == 'SRV')) ? $this->priority . "\t" : "") . $this->content . PHP_EOL;
|
$_content = $this->content;
|
||||||
|
// check content length for txt records for bind9 (multiline)
|
||||||
|
if (Settings::Get('system.dns_server') != 'pdns' && $this->type == 'TXT' && strlen($_content) >= 255) {
|
||||||
|
// split string
|
||||||
|
$_contentlines = str_split($_content, 254);
|
||||||
|
// first line
|
||||||
|
$_l = array_shift($_contentlines);
|
||||||
|
// check for starting quote
|
||||||
|
if (substr($_l, 0, 1) == '"') {
|
||||||
|
$_l = substr($_l, 1);
|
||||||
|
}
|
||||||
|
$_content = '("' . $_l . '"' . PHP_EOL;
|
||||||
|
$_l = array_pop($_contentlines);
|
||||||
|
// check for ending quote
|
||||||
|
if (substr($_l, - 1) == '"') {
|
||||||
|
$_l = substr($_l, 0, - 1);
|
||||||
|
}
|
||||||
|
foreach ($_contentlines as $_cl) {
|
||||||
|
// lines in between
|
||||||
|
$_content .= "\t\t\t\t" . '"' . $_cl . '"' . PHP_EOL;
|
||||||
|
}
|
||||||
|
// last line
|
||||||
|
$_content .= "\t\t\t\t" . '"' . $_l . '")';
|
||||||
|
}
|
||||||
|
$result = $this->record . "\t" . $this->ttl . "\t" . $this->class . "\t" . $this->type . "\t" . (($this->priority >= 0 && ($this->type == 'MX' || $this->type == 'SRV')) ? $this->priority . "\t" : "") . $_content . PHP_EOL;
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -85,11 +85,10 @@ class IntegrityCheck {
|
|||||||
// fix database
|
// fix database
|
||||||
Database::query('ALTER DATABASE `' . Database::getDbName() . '` CHARACTER SET utf8 COLLATE utf8_general_ci');
|
Database::query('ALTER DATABASE `' . Database::getDbName() . '` CHARACTER SET utf8 COLLATE utf8_general_ci');
|
||||||
// fix all tables
|
// fix all tables
|
||||||
$handle = Database::query('SHOW TABLES');
|
$handle = Database::query('SHOW FULL TABLES WHERE Table_type != "VIEW"');
|
||||||
while ($row = $handle->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $handle->fetch(PDO::FETCH_BOTH)) {
|
||||||
foreach ($row as $table) {
|
$table = $row[0];
|
||||||
Database::query('ALTER TABLE `' . $table . '` CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;');
|
Database::query('ALTER TABLE `' . $table . '` CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;');
|
||||||
}
|
|
||||||
}
|
}
|
||||||
$this->_log->logAction(ADM_ACTION, LOG_WARNING, "database charset was different from UTF-8, integrity-check fixed that");
|
$this->_log->logAction(ADM_ACTION, LOG_WARNING, "database charset was different from UTF-8, integrity-check fixed that");
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
196
lib/classes/output/class.CmdLineHandler.php
Normal file
196
lib/classes/output/class.CmdLineHandler.php
Normal file
@@ -0,0 +1,196 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2018 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> (2018-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Cron
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
abstract class CmdLineHandler
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* internal variable for passed arguments
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private static $args = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Action object read from commandline/config
|
||||||
|
*
|
||||||
|
* @var Action
|
||||||
|
*/
|
||||||
|
private $_action = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a CmdLineHandler object with given
|
||||||
|
* arguments from command line
|
||||||
|
*
|
||||||
|
* @param int $argc
|
||||||
|
* @param array $argv
|
||||||
|
*
|
||||||
|
* @return CmdLineHandler
|
||||||
|
*/
|
||||||
|
public static function processParameters($argc, $argv)
|
||||||
|
{
|
||||||
|
$me = get_called_class();
|
||||||
|
return new $me($argc, $argv);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the Action object generated in
|
||||||
|
* the class constructor
|
||||||
|
*
|
||||||
|
* @return Action
|
||||||
|
*/
|
||||||
|
public function getAction()
|
||||||
|
{
|
||||||
|
return $this->_action;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* class constructor, validates the command line parameters
|
||||||
|
* and sets the Action-object if valid
|
||||||
|
*
|
||||||
|
* @param int $argc
|
||||||
|
* @param string[] $argv
|
||||||
|
*
|
||||||
|
* @return null
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
private function __construct($argc, $argv)
|
||||||
|
{
|
||||||
|
self::$args = $this->_parseArgs($argv);
|
||||||
|
$this->_action = $this->_createAction();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses the arguments given via the command line;
|
||||||
|
* three types are supported:
|
||||||
|
* 1.
|
||||||
|
* --parm1 or --parm2=value
|
||||||
|
* 2. -xyz (multiple switches in one) or -a=value
|
||||||
|
* 3. parm1 parm2
|
||||||
|
*
|
||||||
|
* The 1. will be mapped as
|
||||||
|
* ["parm1"] => true, ["parm2"] => "value"
|
||||||
|
* The 2. as
|
||||||
|
* ["x"] => true, ["y"] => true, ["z"] => true, ["a"] => "value"
|
||||||
|
* And the 3. as
|
||||||
|
* [0] => "parm1", [1] => "parm2"
|
||||||
|
*
|
||||||
|
* @param array $argv
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
private function _parseArgs($argv)
|
||||||
|
{
|
||||||
|
array_shift($argv);
|
||||||
|
$o = array();
|
||||||
|
foreach ($argv as $a) {
|
||||||
|
if (substr($a, 0, 2) == '--') {
|
||||||
|
$eq = strpos($a, '=');
|
||||||
|
if ($eq !== false) {
|
||||||
|
$o[substr($a, 2, $eq - 2)] = substr($a, $eq + 1);
|
||||||
|
} else {
|
||||||
|
$k = substr($a, 2);
|
||||||
|
if (! isset($o[$k])) {
|
||||||
|
$o[$k] = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (substr($a, 0, 1) == '-') {
|
||||||
|
if (substr($a, 2, 1) == '=') {
|
||||||
|
$o[substr($a, 1, 1)] = substr($a, 3);
|
||||||
|
} else {
|
||||||
|
foreach (str_split(substr($a, 1)) as $k) {
|
||||||
|
if (! isset($o[$k])) {
|
||||||
|
$o[$k] = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$o[] = $a;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $o;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an Action-Object for the Action-Handler
|
||||||
|
*
|
||||||
|
* @return Action
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
private function _createAction()
|
||||||
|
{
|
||||||
|
|
||||||
|
// Test for help-switch
|
||||||
|
if (empty(self::$args) || array_key_exists("help", self::$args) || array_key_exists("h", self::$args)) {
|
||||||
|
static::printHelp();
|
||||||
|
// end of execution
|
||||||
|
}
|
||||||
|
// check if no unknown parameters are present
|
||||||
|
foreach (self::$args as $arg => $value) {
|
||||||
|
|
||||||
|
if (is_numeric($arg)) {
|
||||||
|
throw new Exception("Unknown parameter '" . $value . "' in argument list");
|
||||||
|
} elseif (! in_array($arg, static::$params) && ! in_array($arg, static::$switches)) {
|
||||||
|
throw new Exception("Unknown parameter '" . $arg . "' in argument list");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// set debugger switch
|
||||||
|
if (isset(self::$args["d"]) && self::$args["d"] == true) {
|
||||||
|
// Debugger::getInstance()->setEnabled(true);
|
||||||
|
// Debugger::getInstance()->debug("debug output enabled");
|
||||||
|
}
|
||||||
|
|
||||||
|
return new static::$action_class(self::$args);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getInput($prompt = "#", $default = "")
|
||||||
|
{
|
||||||
|
if (! empty($default)) {
|
||||||
|
$prompt .= " [" . $default . "]";
|
||||||
|
}
|
||||||
|
$result = readline($prompt . ":");
|
||||||
|
if (empty($result) && ! empty($default)) {
|
||||||
|
$result = $default;
|
||||||
|
}
|
||||||
|
return mb_strtolower($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function println($msg = "")
|
||||||
|
{
|
||||||
|
print $msg . PHP_EOL;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function _printcolor($msg = "", $color = "0")
|
||||||
|
{
|
||||||
|
print "\033[" . $color . "m" . $msg . "\033[0m" . PHP_EOL;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function printerr($msg = "")
|
||||||
|
{
|
||||||
|
self::_printcolor($msg, "31");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function printsucc($msg = "")
|
||||||
|
{
|
||||||
|
self::_printcolor($msg, "32");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function printwarn($msg = "")
|
||||||
|
{
|
||||||
|
self::_printcolor($msg, "33");
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -88,6 +88,8 @@ class paging {
|
|||||||
* @var bool
|
* @var bool
|
||||||
*/
|
*/
|
||||||
private $natSorting = false;
|
private $natSorting = false;
|
||||||
|
|
||||||
|
private $_limit = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class constructor. Loads settings from request or from userdata and saves them to session.
|
* Class constructor. Loads settings from request or from userdata and saves them to session.
|
||||||
@@ -101,7 +103,7 @@ class paging {
|
|||||||
* @param string $default_order default sorting order 'asc' or 'desc'
|
* @param string $default_order default sorting order 'asc' or 'desc'
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public function __construct($userinfo, $table, $fields, $entriesperpage = 0, $natSorting = false, $default_field = 0, $default_order = 'asc') {
|
public function __construct($userinfo, $table, $fields, $entriesperpage = 0, $natSorting = false, $default_field = 0, $default_order = 'asc', $limit = 0) {
|
||||||
|
|
||||||
// entries per page and natsorting-flag are not
|
// entries per page and natsorting-flag are not
|
||||||
// passed as parameter anymore, because these are
|
// passed as parameter anymore, because these are
|
||||||
@@ -112,7 +114,7 @@ class paging {
|
|||||||
$this->userinfo = $userinfo;
|
$this->userinfo = $userinfo;
|
||||||
|
|
||||||
if (!is_array($this->userinfo['lastpaging'])) {
|
if (!is_array($this->userinfo['lastpaging'])) {
|
||||||
$this->userinfo['lastpaging'] = unserialize($this->userinfo['lastpaging']);
|
$this->userinfo['lastpaging'] = json_decode($this->userinfo['lastpaging'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->table = $table;
|
$this->table = $table;
|
||||||
@@ -222,7 +224,7 @@ class paging {
|
|||||||
AND `adminsession` = :adminsession
|
AND `adminsession` = :adminsession
|
||||||
");
|
");
|
||||||
$upd_data = array(
|
$upd_data = array(
|
||||||
'lastpaging' => serialize($this->userinfo['lastpaging']),
|
'lastpaging' => json_encode($this->userinfo['lastpaging']),
|
||||||
'hash' => $userinfo['hash'],
|
'hash' => $userinfo['hash'],
|
||||||
'userid' => $userinfo['userid'],
|
'userid' => $userinfo['userid'],
|
||||||
'ipaddr' => $userinfo['ipaddress'],
|
'ipaddr' => $userinfo['ipaddress'],
|
||||||
@@ -230,6 +232,8 @@ class paging {
|
|||||||
'adminsession' => $userinfo['adminsession']
|
'adminsession' => $userinfo['adminsession']
|
||||||
);
|
);
|
||||||
Database::pexecute($upd_stmt, $upd_data);
|
Database::pexecute($upd_stmt, $upd_data);
|
||||||
|
|
||||||
|
$this->_limit = $limit;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -378,6 +382,11 @@ class paging {
|
|||||||
* @return string always empty
|
* @return string always empty
|
||||||
*/
|
*/
|
||||||
public function getSqlLimit() {
|
public function getSqlLimit() {
|
||||||
|
|
||||||
|
if ($this->_limit > 0) {
|
||||||
|
$_offset = ($this->pageno - 1) * $this->_limit;
|
||||||
|
return ' LIMIT '.$_offset.','.$this->_limit;
|
||||||
|
}
|
||||||
/**
|
/**
|
||||||
* currently not in use
|
* currently not in use
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -91,6 +91,12 @@ class phpinterface {
|
|||||||
SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id"
|
SELECT * FROM `" . TABLE_PANEL_PHPCONFIGS . "` WHERE `id` = :id"
|
||||||
);
|
);
|
||||||
$this->_php_configs_cache[$php_config_id] = Database::pexecute_first($stmt, array('id' => $php_config_id));
|
$this->_php_configs_cache[$php_config_id] = Database::pexecute_first($stmt, array('id' => $php_config_id));
|
||||||
|
if ((int)Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
$stmt = Database::prepare("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id"
|
||||||
|
);
|
||||||
|
$this->_php_configs_cache[$php_config_id]['fpm_settings'] = Database::pexecute_first($stmt, array('id' => $this->_php_configs_cache[$php_config_id]['fpmsettingid']));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->_php_configs_cache[$php_config_id];
|
return $this->_php_configs_cache[$php_config_id];
|
||||||
|
|||||||
@@ -18,19 +18,28 @@
|
|||||||
* @since 0.9.16
|
* @since 0.9.16
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
class phpinterface_fpm
|
||||||
class phpinterface_fpm {
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Domain-Data array
|
* Domain-Data array
|
||||||
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private $_domain = array();
|
private $_domain = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Admin-Date cache array
|
* fpm config
|
||||||
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
|
private $_fpm_cfg = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Admin-Date cache array
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
private $_admin_cache = array();
|
private $_admin_cache = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -38,119 +47,38 @@ class phpinterface_fpm {
|
|||||||
* Mostly taken from http://php.net/manual/en/ini.list.php
|
* Mostly taken from http://php.net/manual/en/ini.list.php
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private $_ini = array(
|
private $_ini = array();
|
||||||
'php_value' => array(
|
|
||||||
'auto_append_file',
|
|
||||||
'auto_prepend_file',
|
|
||||||
'date.timezone',
|
|
||||||
'default_charset',
|
|
||||||
'error_reporting',
|
|
||||||
'include_path',
|
|
||||||
'log_errors_max_len',
|
|
||||||
'mail.log',
|
|
||||||
'max_execution_time',
|
|
||||||
'session.cookie_domain',
|
|
||||||
'session.cookie_lifetime',
|
|
||||||
'session.cookie_path',
|
|
||||||
'session.name',
|
|
||||||
'session.serialize_handler',
|
|
||||||
'upload_max_filesize',
|
|
||||||
'xmlrpc_error_number',
|
|
||||||
'session.auto_start',
|
|
||||||
'always_populate_raw_post_data',
|
|
||||||
'suhosin.session.cryptkey',
|
|
||||||
'suhosin.session.cryptraddr',
|
|
||||||
'suhosin.session.checkraddr',
|
|
||||||
'suhosin.cookie.cryptkey',
|
|
||||||
'suhosin.cookie.plainlist',
|
|
||||||
'suhosin.cookie.cryptraddr',
|
|
||||||
'suhosin.cookie.checkraddr',
|
|
||||||
'suhosin.executor.func.blacklist',
|
|
||||||
'suhosin.executor.eval.whitelist'
|
|
||||||
),
|
|
||||||
'php_flag' => array(
|
|
||||||
'asp_tags',
|
|
||||||
'display_errors',
|
|
||||||
'display_startup_errors',
|
|
||||||
'html_errors',
|
|
||||||
'log_errors',
|
|
||||||
'magic_quotes_gpc',
|
|
||||||
'magic_quotes_runtime',
|
|
||||||
'magic_quotes_sybase',
|
|
||||||
'mail.add_x_header',
|
|
||||||
'session.cookie_secure',
|
|
||||||
'session.use_cookies',
|
|
||||||
'short_open_tag',
|
|
||||||
'track_errors',
|
|
||||||
'xmlrpc_errors',
|
|
||||||
'suhosin.simulation',
|
|
||||||
'suhosin.session.encrypt',
|
|
||||||
'suhosin.session.cryptua',
|
|
||||||
'suhosin.session.cryptdocroot',
|
|
||||||
'suhosin.cookie.encrypt',
|
|
||||||
'suhosin.cookie.cryptua',
|
|
||||||
'suhosin.cookie.cryptdocroot',
|
|
||||||
'suhosin.executor.disable_eval',
|
|
||||||
'mbstring.func_overload'
|
|
||||||
),
|
|
||||||
'php_admin_value' => array(
|
|
||||||
'cgi.redirect_status_env',
|
|
||||||
'date.timezone',
|
|
||||||
'disable_classes',
|
|
||||||
'disable_functions',
|
|
||||||
'error_log',
|
|
||||||
'gpc_order',
|
|
||||||
'max_input_time',
|
|
||||||
'max_input_vars',
|
|
||||||
'memory_limit',
|
|
||||||
'open_basedir',
|
|
||||||
'output_buffering',
|
|
||||||
'post_max_size',
|
|
||||||
'precision',
|
|
||||||
'sendmail_path',
|
|
||||||
'session.gc_divisor',
|
|
||||||
'session.gc_probability',
|
|
||||||
'variables_order',
|
|
||||||
'opcache.log_verbosity_level',
|
|
||||||
'opcache.restrict_api',
|
|
||||||
'opcache.revalidate_freq',
|
|
||||||
'opcache.max_accelerated_files',
|
|
||||||
'opcache.memory_consumption',
|
|
||||||
'opcache.interned_strings_buffer'
|
|
||||||
),
|
|
||||||
'php_admin_flag' => array(
|
|
||||||
'allow_call_time_pass_reference',
|
|
||||||
'allow_url_fopen',
|
|
||||||
'allow_url_include',
|
|
||||||
'auto_detect_line_endings',
|
|
||||||
'cgi.fix_pathinfo',
|
|
||||||
'cgi.force_redirect',
|
|
||||||
'enable_dl',
|
|
||||||
'expose_php',
|
|
||||||
'file_uploads',
|
|
||||||
'ignore_repeated_errors',
|
|
||||||
'ignore_repeated_source',
|
|
||||||
'log_errors',
|
|
||||||
'register_argc_argv',
|
|
||||||
'report_memleaks',
|
|
||||||
'opcache.enable',
|
|
||||||
'opcache.consistency_checks',
|
|
||||||
'opcache.dups_fix',
|
|
||||||
'opcache.load_comments',
|
|
||||||
'opcache.revalidate_path',
|
|
||||||
'opcache.save_comments',
|
|
||||||
'opcache.use_cwd',
|
|
||||||
'opcache.validate_timestamps',
|
|
||||||
'opcache.fast_shutdown'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* main constructor
|
* main constructor
|
||||||
*/
|
*/
|
||||||
public function __construct($domain) {
|
public function __construct($domain)
|
||||||
|
{
|
||||||
|
if (!isset($domain['fpm_config_id']) || empty($domain['fpm_config_id'])) {
|
||||||
|
$domain['fpm_config_id'] = 1;
|
||||||
|
}
|
||||||
$this->_domain = $domain;
|
$this->_domain = $domain;
|
||||||
|
$this->_readFpmConfig($domain['fpm_config_id']);
|
||||||
|
$this->_buildIniMapping();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _buildIniMapping()
|
||||||
|
{
|
||||||
|
$this->_ini = array(
|
||||||
|
'php_flag' => explode("\n", Settings::Get('phpfpm.ini_flags')),
|
||||||
|
'php_value' => explode("\n", Settings::Get('phpfpm.ini_values')),
|
||||||
|
'php_admin_flag' => explode("\n", Settings::Get('phpfpm.ini_admin_flags')),
|
||||||
|
'php_admin_value' => explode("\n", Settings::Get('phpfpm.ini_admin_values'))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function _readFpmConfig($fpm_config_id)
|
||||||
|
{
|
||||||
|
$stmt = Database::prepare("SELECT * FROM `" . TABLE_PANEL_FPMDAEMONS . "` WHERE `id` = :id");
|
||||||
|
$this->_fpm_cfg = Database::pexecute_first($stmt, array(
|
||||||
|
'id' => $fpm_config_id
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -158,47 +86,60 @@ class phpinterface_fpm {
|
|||||||
*
|
*
|
||||||
* @param array $phpconfig
|
* @param array $phpconfig
|
||||||
*/
|
*/
|
||||||
public function createConfig($phpconfig) {
|
public function createConfig($phpconfig)
|
||||||
|
{
|
||||||
$fh = @fopen($this->getConfigFile(), 'w');
|
$fh = @fopen($this->getConfigFile(), 'w');
|
||||||
|
|
||||||
if ($fh) {
|
if ($fh) {
|
||||||
$fpm_pm = Settings::Get('phpfpm.pm');
|
|
||||||
$fpm_children = (int)Settings::Get('phpfpm.max_children');
|
if ($phpconfig['override_fpmconfig'] == 1) {
|
||||||
$fpm_start_servers = (int)Settings::Get('phpfpm.start_servers');
|
$this->_fpm_cfg['pm'] = $phpconfig['pm'];
|
||||||
$fpm_min_spare_servers = (int)Settings::Get('phpfpm.min_spare_servers');
|
$this->_fpm_cfg['max_children'] = $phpconfig['max_children'];
|
||||||
$fpm_max_spare_servers = (int)Settings::Get('phpfpm.max_spare_servers');
|
$this->_fpm_cfg['start_servers'] = $phpconfig['start_servers'];
|
||||||
$fpm_requests = (int)Settings::Get('phpfpm.max_requests');
|
$this->_fpm_cfg['min_spare_servers'] = $phpconfig['min_spare_servers'];
|
||||||
$fpm_process_idle_timeout = (int)Settings::Get('phpfpm.idle_timeout');
|
$this->_fpm_cfg['max_spare_servers'] = $phpconfig['max_spare_servers'];
|
||||||
|
$this->_fpm_cfg['max_requests'] = $phpconfig['max_requests'];
|
||||||
|
$this->_fpm_cfg['idle_timeout'] = $phpconfig['idle_timeout'];
|
||||||
|
$this->_fpm_cfg['limit_extensions'] = $phpconfig['limit_extensions'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$fpm_pm = $this->_fpm_cfg['pm'];
|
||||||
|
$fpm_children = (int) $this->_fpm_cfg['max_children'];
|
||||||
|
$fpm_start_servers = (int) $this->_fpm_cfg['start_servers'];
|
||||||
|
$fpm_min_spare_servers = (int) $this->_fpm_cfg['min_spare_servers'];
|
||||||
|
$fpm_max_spare_servers = (int) $this->_fpm_cfg['max_spare_servers'];
|
||||||
|
$fpm_requests = (int) $this->_fpm_cfg['max_requests'];
|
||||||
|
$fpm_process_idle_timeout = (int) $this->_fpm_cfg['idle_timeout'];
|
||||||
|
$fpm_limit_extensions = $this->_fpm_cfg['limit_extensions'];
|
||||||
|
|
||||||
if ($fpm_children == 0) {
|
if ($fpm_children == 0) {
|
||||||
$fpm_children = 1;
|
$fpm_children = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$fpm_config = ';PHP-FPM configuration for "'.$this->_domain['domain'].'" created on ' . date("Y.m.d H:i:s") . "\n";
|
$fpm_config = ';PHP-FPM configuration for "' . $this->_domain['domain'] . '" created on ' . date("Y.m.d H:i:s") . "\n";
|
||||||
$fpm_config.= '['.$this->_domain['domain'].']'."\n";
|
$fpm_config .= '[' . $this->_domain['domain'] . ']' . "\n";
|
||||||
$fpm_config.= 'listen = '.$this->getSocketFile()."\n";
|
$fpm_config .= 'listen = ' . $this->getSocketFile() . "\n";
|
||||||
if ($this->_domain['loginname'] == 'froxlor.panel') {
|
if ($this->_domain['loginname'] == 'froxlor.panel') {
|
||||||
$fpm_config.= 'listen.owner = '.$this->_domain['guid']."\n";
|
$fpm_config .= 'listen.owner = ' . $this->_domain['guid'] . "\n";
|
||||||
$fpm_config.= 'listen.group = '.$this->_domain['guid']."\n";
|
$fpm_config .= 'listen.group = ' . $this->_domain['guid'] . "\n";
|
||||||
} else {
|
} else {
|
||||||
$fpm_config.= 'listen.owner = '.$this->_domain['loginname']."\n";
|
$fpm_config .= 'listen.owner = ' . $this->_domain['loginname'] . "\n";
|
||||||
$fpm_config.= 'listen.group = '.$this->_domain['loginname']."\n";
|
$fpm_config .= 'listen.group = ' . $this->_domain['loginname'] . "\n";
|
||||||
}
|
}
|
||||||
// see #1418 why this is 0660
|
// see #1418 why this is 0660
|
||||||
$fpm_config.= 'listen.mode = 0660'."\n";
|
$fpm_config .= 'listen.mode = 0660' . "\n";
|
||||||
|
|
||||||
if ($this->_domain['loginname'] == 'froxlor.panel') {
|
if ($this->_domain['loginname'] == 'froxlor.panel') {
|
||||||
$fpm_config.= 'user = '.$this->_domain['guid']."\n";
|
$fpm_config .= 'user = ' . $this->_domain['guid'] . "\n";
|
||||||
$fpm_config.= 'group = '.$this->_domain['guid']."\n";
|
$fpm_config .= 'group = ' . $this->_domain['guid'] . "\n";
|
||||||
} else {
|
} else {
|
||||||
$fpm_config.= 'user = '.$this->_domain['loginname']."\n";
|
$fpm_config .= 'user = ' . $this->_domain['loginname'] . "\n";
|
||||||
$fpm_config.= 'group = '.$this->_domain['loginname']."\n";
|
$fpm_config .= 'group = ' . $this->_domain['loginname'] . "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$fpm_config.= 'pm = '.$fpm_pm."\n";
|
$fpm_config .= 'pm = ' . $fpm_pm . "\n";
|
||||||
$fpm_config.= 'pm.max_children = '.$fpm_children."\n";
|
$fpm_config .= 'pm.max_children = ' . $fpm_children . "\n";
|
||||||
|
|
||||||
if ($fpm_pm == 'dynamic') {
|
if ($fpm_pm == 'dynamic') {
|
||||||
// honor max_children
|
// honor max_children
|
||||||
if ($fpm_children < $fpm_min_spare_servers) {
|
if ($fpm_children < $fpm_min_spare_servers) {
|
||||||
@@ -214,35 +155,40 @@ class phpinterface_fpm {
|
|||||||
if ($fpm_start_servers > $fpm_max_spare_servers) {
|
if ($fpm_start_servers > $fpm_max_spare_servers) {
|
||||||
$fpm_start_servers = $fpm_max_spare_servers;
|
$fpm_start_servers = $fpm_max_spare_servers;
|
||||||
}
|
}
|
||||||
$fpm_config.= 'pm.start_servers = '.$fpm_start_servers."\n";
|
$fpm_config .= 'pm.start_servers = ' . $fpm_start_servers . "\n";
|
||||||
$fpm_config.= 'pm.min_spare_servers = '.$fpm_min_spare_servers."\n";
|
$fpm_config .= 'pm.min_spare_servers = ' . $fpm_min_spare_servers . "\n";
|
||||||
$fpm_config.= 'pm.max_spare_servers = '.$fpm_max_spare_servers."\n";
|
$fpm_config .= 'pm.max_spare_servers = ' . $fpm_max_spare_servers . "\n";
|
||||||
} elseif ($fpm_pm == 'ondemand') {
|
} elseif ($fpm_pm == 'ondemand') {
|
||||||
$fpm_config.= 'pm.process_idle_timeout = '.$fpm_process_idle_timeout."\n";
|
$fpm_config .= 'pm.process_idle_timeout = ' . $fpm_process_idle_timeout . "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$fpm_config.= 'pm.max_requests = '.$fpm_requests."\n";
|
$fpm_config .= 'pm.max_requests = ' . $fpm_requests . "\n";
|
||||||
|
|
||||||
// possible slowlog configs
|
// possible slowlog configs
|
||||||
if ($phpconfig['fpm_slowlog'] == '1') {
|
if ($phpconfig['fpm_slowlog'] == '1') {
|
||||||
$fpm_config.= 'request_terminate_timeout = ' . $phpconfig['fpm_reqterm'] . "\n";
|
$fpm_config .= 'request_terminate_timeout = ' . $phpconfig['fpm_reqterm'] . "\n";
|
||||||
$fpm_config.= 'request_slowlog_timeout = ' . $phpconfig['fpm_reqslow'] . "\n";
|
$fpm_config .= 'request_slowlog_timeout = ' . $phpconfig['fpm_reqslow'] . "\n";
|
||||||
$slowlog = makeCorrectFile(Settings::Get('system.logfiles_directory') . '/' . $this->_domain['loginname'] . '-php-slow.log');
|
$slowlog = makeCorrectFile(Settings::Get('system.logfiles_directory') . '/' . $this->_domain['loginname'] . '-php-slow.log');
|
||||||
$fpm_config.= 'slowlog = ' . $slowlog . "\n";
|
$fpm_config .= 'slowlog = ' . $slowlog . "\n";
|
||||||
$fpm_config.= 'catch_workers_output = yes' . "\n";
|
$fpm_config .= 'catch_workers_output = yes' . "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$fpm_config.= ';chroot = '.makeCorrectDir($this->_domain['documentroot'])."\n";
|
$fpm_config .= ';chroot = ' . makeCorrectDir($this->_domain['documentroot']) . "\n";
|
||||||
|
$fpm_config .= 'security.limit_extensions = '.$fpm_limit_extensions . "\n";
|
||||||
|
|
||||||
$tmpdir = makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/');
|
$tmpdir = makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/');
|
||||||
if (!is_dir($tmpdir)) {
|
if (! is_dir($tmpdir)) {
|
||||||
$this->getTempDir();
|
$this->getTempDir();
|
||||||
}
|
}
|
||||||
|
|
||||||
$fpm_config.= 'env[TMP] = '.$tmpdir."\n";
|
$env_path = Settings::Get('phpfpm.envpath');
|
||||||
$fpm_config.= 'env[TMPDIR] = '.$tmpdir."\n";
|
if (!empty($env_path)) {
|
||||||
$fpm_config.= 'env[TEMP] = '.$tmpdir."\n";
|
$fpm_config .= 'env[PATH] = ' . $env_path . "\n";
|
||||||
|
}
|
||||||
|
$fpm_config .= 'env[TMP] = ' . $tmpdir . "\n";
|
||||||
|
$fpm_config .= 'env[TMPDIR] = ' . $tmpdir . "\n";
|
||||||
|
$fpm_config .= 'env[TEMP] = ' . $tmpdir . "\n";
|
||||||
|
|
||||||
$openbasedir = '';
|
$openbasedir = '';
|
||||||
if ($this->_domain['loginname'] != 'froxlor.panel') {
|
if ($this->_domain['loginname'] != 'froxlor.panel') {
|
||||||
if ($this->_domain['openbasedir'] == '1') {
|
if ($this->_domain['openbasedir'] == '1') {
|
||||||
@@ -251,47 +197,45 @@ class phpinterface_fpm {
|
|||||||
foreach ($_custom_openbasedir as $cobd) {
|
foreach ($_custom_openbasedir as $cobd) {
|
||||||
$_phpappendopenbasedir .= appendOpenBasedirPath($cobd);
|
$_phpappendopenbasedir .= appendOpenBasedirPath($cobd);
|
||||||
}
|
}
|
||||||
|
|
||||||
$_custom_openbasedir = explode(':', Settings::Get('system.phpappendopenbasedir'));
|
$_custom_openbasedir = explode(':', Settings::Get('system.phpappendopenbasedir'));
|
||||||
foreach ($_custom_openbasedir as $cobd) {
|
foreach ($_custom_openbasedir as $cobd) {
|
||||||
$_phpappendopenbasedir .= appendOpenBasedirPath($cobd);
|
$_phpappendopenbasedir .= appendOpenBasedirPath($cobd);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($this->_domain['openbasedir_path'] == '0'
|
if ($this->_domain['openbasedir_path'] == '0' && strstr($this->_domain['documentroot'], ":") === false) {
|
||||||
&& strstr($this->_domain['documentroot'], ":") === false
|
|
||||||
) {
|
|
||||||
$openbasedir = appendOpenBasedirPath($this->_domain['documentroot'], true);
|
$openbasedir = appendOpenBasedirPath($this->_domain['documentroot'], true);
|
||||||
} else {
|
} else {
|
||||||
$openbasedir = appendOpenBasedirPath($this->_domain['customerroot'], true);
|
$openbasedir = appendOpenBasedirPath($this->_domain['customerroot'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$openbasedir .= appendOpenBasedirPath($this->getTempDir());
|
$openbasedir .= appendOpenBasedirPath($this->getTempDir());
|
||||||
$openbasedir .= $_phpappendopenbasedir;
|
$openbasedir .= $_phpappendopenbasedir;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$fpm_config.= 'php_admin_value[session.save_path] = ' . makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/') . "\n";
|
$fpm_config .= 'php_admin_value[session.save_path] = ' . makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/') . "\n";
|
||||||
$fpm_config.= 'php_admin_value[upload_tmp_dir] = ' . makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/') . "\n";
|
$fpm_config .= 'php_admin_value[upload_tmp_dir] = ' . makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/') . "\n";
|
||||||
|
|
||||||
$admin = $this->_getAdminData($this->_domain['adminid']);
|
$admin = $this->_getAdminData($this->_domain['adminid']);
|
||||||
$php_ini_variables = array(
|
$php_ini_variables = array(
|
||||||
'SAFE_MODE' => 'Off', // keep this for compatibility, just in case
|
'SAFE_MODE' => 'Off', // keep this for compatibility, just in case
|
||||||
'PEAR_DIR' => Settings::Get('phpfpm.peardir'),
|
'PEAR_DIR' => Settings::Get('phpfpm.peardir'),
|
||||||
'TMP_DIR' => $this->getTempDir(),
|
'TMP_DIR' => $this->getTempDir(),
|
||||||
'CUSTOMER_EMAIL' => $this->_domain['email'],
|
'CUSTOMER_EMAIL' => $this->_domain['email'],
|
||||||
'ADMIN_EMAIL' => $admin['email'],
|
'ADMIN_EMAIL' => $admin['email'],
|
||||||
'DOMAIN' => $this->_domain['domain'],
|
'DOMAIN' => $this->_domain['domain'],
|
||||||
'CUSTOMER' => $this->_domain['loginname'],
|
'CUSTOMER' => $this->_domain['loginname'],
|
||||||
'ADMIN' => $admin['loginname'],
|
'ADMIN' => $admin['loginname'],
|
||||||
'OPEN_BASEDIR' => $openbasedir,
|
'OPEN_BASEDIR' => $openbasedir,
|
||||||
'OPEN_BASEDIR_C' => '',
|
'OPEN_BASEDIR_C' => '',
|
||||||
'OPEN_BASEDIR_GLOBAL' => Settings::Get('system.phpappendopenbasedir'),
|
'OPEN_BASEDIR_GLOBAL' => Settings::Get('system.phpappendopenbasedir'),
|
||||||
'DOCUMENT_ROOT' => makeCorrectDir($this->_domain['documentroot'])
|
'DOCUMENT_ROOT' => makeCorrectDir($this->_domain['documentroot'])
|
||||||
);
|
);
|
||||||
|
|
||||||
$phpini = replace_variables($phpconfig['phpsettings'], $php_ini_variables);
|
$phpini = replace_variables($phpconfig['phpsettings'], $php_ini_variables);
|
||||||
$phpini_array = explode("\n", $phpini);
|
$phpini_array = explode("\n", $phpini);
|
||||||
|
|
||||||
$fpm_config.= "\n\n";
|
$fpm_config .= "\n\n";
|
||||||
foreach ($phpini_array as $inisection) {
|
foreach ($phpini_array as $inisection) {
|
||||||
$is = explode("=", $inisection);
|
$is = explode("=", $inisection);
|
||||||
foreach ($this->_ini as $sec => $possibles) {
|
foreach ($this->_ini as $sec => $possibles) {
|
||||||
@@ -300,17 +244,17 @@ class phpinterface_fpm {
|
|||||||
if (trim($is[0]) == 'open_basedir' && $openbasedir == '') {
|
if (trim($is[0]) == 'open_basedir' && $openbasedir == '') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$fpm_config.= $sec.'['.trim($is[0]).'] = ' . trim($is[1]) . "\n";
|
$fpm_config .= $sec . '[' . trim($is[0]) . '] = ' . trim($is[1]) . "\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// now check if 'sendmail_path' has not beed set in the custom-php.ini
|
// now check if 'sendmail_path' has not beed set in the custom-php.ini
|
||||||
// if not we use our fallback-default as usual
|
// if not we use our fallback-default as usual
|
||||||
if (strpos($fpm_config, 'php_admin_value[sendmail_path]') === false) {
|
if (strpos($fpm_config, 'php_admin_value[sendmail_path]') === false) {
|
||||||
$fpm_config.= 'php_admin_value[sendmail_path] = /usr/sbin/sendmail -t -i -f '.$this->_domain['email']."\n";
|
$fpm_config .= 'php_admin_value[sendmail_path] = /usr/sbin/sendmail -t -i -f ' . $this->_domain['email'] . "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
fwrite($fh, $fpm_config, strlen($fpm_config));
|
fwrite($fh, $fpm_config, strlen($fpm_config));
|
||||||
fclose($fh);
|
fclose($fh);
|
||||||
}
|
}
|
||||||
@@ -322,108 +266,138 @@ class phpinterface_fpm {
|
|||||||
*
|
*
|
||||||
* @param string $phpconfig
|
* @param string $phpconfig
|
||||||
*/
|
*/
|
||||||
public function createIniFile($phpconfig) {
|
public function createIniFile($phpconfig)
|
||||||
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fpm-config file
|
* fpm-config file
|
||||||
*
|
*
|
||||||
* @param boolean $createifnotexists create the directory if it does not exist
|
* @param boolean $createifnotexists
|
||||||
*
|
* create the directory if it does not exist
|
||||||
|
*
|
||||||
* @return string the full path to the file
|
* @return string the full path to the file
|
||||||
*/
|
*/
|
||||||
public function getConfigFile($createifnotexists = true) {
|
public function getConfigFile($createifnotexists = true)
|
||||||
|
{
|
||||||
$configdir = makeCorrectDir(Settings::Get('phpfpm.configdir'));
|
$configdir = $this->_fpm_cfg['config_dir'];
|
||||||
$config = makeCorrectFile($configdir.'/'.$this->_domain['domain'].'.conf');
|
$config = makeCorrectFile($configdir . '/' . $this->_domain['domain'] . '.conf');
|
||||||
|
|
||||||
if (!is_dir($configdir) && $createifnotexists) {
|
if (! is_dir($configdir) && $createifnotexists) {
|
||||||
safe_exec('mkdir -p ' . escapeshellarg($configdir));
|
safe_exec('mkdir -p ' . escapeshellarg($configdir));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $config;
|
return $config;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* return path of fpm-socket file
|
* return path of fpm-socket file
|
||||||
*
|
*
|
||||||
* @param boolean $createifnotexists create the directory if it does not exist
|
* @param boolean $createifnotexists
|
||||||
*
|
* create the directory if it does not exist
|
||||||
|
*
|
||||||
* @return string the full path to the socket
|
* @return string the full path to the socket
|
||||||
*/
|
*/
|
||||||
public function getSocketFile($createifnotexists = true) {
|
public function getSocketFile($createifnotexists = true)
|
||||||
|
{
|
||||||
$socketdir = makeCorrectDir(Settings::Get('phpfpm.fastcgi_ipcdir'));
|
$socketdir = makeCorrectDir(Settings::Get('phpfpm.fastcgi_ipcdir'));
|
||||||
$socket = strtolower(makeCorrectFile($socketdir.'/'.$this->_domain['loginname'].'-'.$this->_domain['domain'].'-php-fpm.socket'));
|
// add fpm-config-id to filename so it's unique for the fpm-daemon and doesn't interfere with running configs when reuilding
|
||||||
|
$socket = strtolower(makeCorrectFile($socketdir . '/' . $this->_domain['fpm_config_id'] . '-' . $this->_domain['loginname'] . '-' . $this->_domain['domain'] . '-php-fpm.socket'));
|
||||||
if (!is_dir($socketdir) && $createifnotexists) {
|
|
||||||
safe_exec('mkdir -p '.escapeshellarg($socketdir));
|
if (! is_dir($socketdir) && $createifnotexists) {
|
||||||
safe_exec('chown -R '.Settings::Get('system.httpuser').':'.Settings::Get('system.httpgroup').' '.escapeshellarg($socketdir));
|
safe_exec('mkdir -p ' . escapeshellarg($socketdir));
|
||||||
|
safe_exec('chown -R ' . Settings::Get('system.httpuser') . ':' . Settings::Get('system.httpgroup') . ' ' . escapeshellarg($socketdir));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $socket;
|
return $socket;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fpm-temp directory
|
* fpm-temp directory
|
||||||
*
|
*
|
||||||
* @param boolean $createifnotexists create the directory if it does not exist
|
* @param boolean $createifnotexists
|
||||||
*
|
* create the directory if it does not exist
|
||||||
|
*
|
||||||
* @return string the directory
|
* @return string the directory
|
||||||
*/
|
*/
|
||||||
public function getTempDir($createifnotexists = true) {
|
public function getTempDir($createifnotexists = true)
|
||||||
|
{
|
||||||
$tmpdir = makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/');
|
$tmpdir = makeCorrectDir(Settings::Get('phpfpm.tmpdir') . '/' . $this->_domain['loginname'] . '/');
|
||||||
|
|
||||||
if (!is_dir($tmpdir) && $createifnotexists) {
|
if (! is_dir($tmpdir) && $createifnotexists) {
|
||||||
safe_exec('mkdir -p ' . escapeshellarg($tmpdir));
|
safe_exec('mkdir -p ' . escapeshellarg($tmpdir));
|
||||||
safe_exec('chown -R ' . $this->_domain['guid'] . ':' . $this->_domain['guid'] . ' ' . escapeshellarg($tmpdir));
|
safe_exec('chown -R ' . $this->_domain['guid'] . ':' . $this->_domain['guid'] . ' ' . escapeshellarg($tmpdir));
|
||||||
safe_exec('chmod 0750 ' . escapeshellarg($tmpdir));
|
safe_exec('chmod 0750 ' . escapeshellarg($tmpdir));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $tmpdir;
|
return $tmpdir;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fastcgi-fakedirectory directory
|
* fastcgi-fakedirectory directory
|
||||||
*
|
*
|
||||||
* @param boolean $createifnotexists create the directory if it does not exist
|
* @param boolean $createifnotexists
|
||||||
*
|
* create the directory if it does not exist
|
||||||
|
*
|
||||||
* @return string the directory
|
* @return string the directory
|
||||||
*/
|
*/
|
||||||
public function getAliasConfigDir($createifnotexists = true) {
|
public function getAliasConfigDir($createifnotexists = true)
|
||||||
|
{
|
||||||
|
|
||||||
// ensure default...
|
// ensure default...
|
||||||
if (Settings::Get('phpfpm.aliasconfigdir') == null) {
|
if (Settings::Get('phpfpm.aliasconfigdir') == null) {
|
||||||
Settings::Set('phpfpm.aliasconfigdir', '/var/www/php-fpm');
|
Settings::Set('phpfpm.aliasconfigdir', '/var/www/php-fpm');
|
||||||
}
|
}
|
||||||
|
|
||||||
$configdir = makeCorrectDir(Settings::Get('phpfpm.aliasconfigdir') . '/' . $this->_domain['loginname'] . '/' . $this->_domain['domain'] . '/');
|
$configdir = makeCorrectDir(Settings::Get('phpfpm.aliasconfigdir') . '/' . $this->_domain['loginname'] . '/' . $this->_domain['domain'] . '/');
|
||||||
if (!is_dir($configdir) && $createifnotexists) {
|
if (! is_dir($configdir) && $createifnotexists) {
|
||||||
safe_exec('mkdir -p ' . escapeshellarg($configdir));
|
safe_exec('mkdir -p ' . escapeshellarg($configdir));
|
||||||
safe_exec('chown ' . $this->_domain['guid'] . ':' . $this->_domain['guid'] . ' ' . escapeshellarg($configdir));
|
safe_exec('chown ' . $this->_domain['guid'] . ':' . $this->_domain['guid'] . ' ' . escapeshellarg($configdir));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $configdir;
|
return $configdir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* create a dummy fpm pool config with minimal configuration
|
||||||
|
* (this is used whenever a config directory is empty but needs at least one pool to startup/restart)
|
||||||
|
*
|
||||||
|
* @param string $configdir
|
||||||
|
*/
|
||||||
|
public static function createDummyPool($configdir)
|
||||||
|
{
|
||||||
|
if (! is_dir($configdir)) {
|
||||||
|
safe_exec('mkdir -p ' . escapeshellarg($configdir));
|
||||||
|
}
|
||||||
|
$config = makeCorrectFile($configdir . '/dummy.conf');
|
||||||
|
$dummy = "[dummy]
|
||||||
|
user = ".Settings::Get('system.httpuser')."
|
||||||
|
listen = /run/" . md5($configdir) . "-fpm.sock
|
||||||
|
pm = static
|
||||||
|
pm.max_children = 1
|
||||||
|
";
|
||||||
|
file_put_contents($config, $dummy);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* return the admin-data of a specific admin
|
* return the admin-data of a specific admin
|
||||||
*
|
*
|
||||||
* @param int $adminid id of the admin-user
|
* @param int $adminid
|
||||||
*
|
* id of the admin-user
|
||||||
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
private function _getAdminData($adminid) {
|
private function _getAdminData($adminid)
|
||||||
|
{
|
||||||
$adminid = intval($adminid);
|
$adminid = intval($adminid);
|
||||||
|
|
||||||
if (!isset($this->_admin_cache[$adminid])) {
|
if (! isset($this->_admin_cache[$adminid])) {
|
||||||
$stmt = Database::prepare("
|
$stmt = Database::prepare("
|
||||||
SELECT `email`, `loginname` FROM `" . TABLE_PANEL_ADMINS . "` WHERE `adminid` = :id"
|
SELECT `email`, `loginname` FROM `" . TABLE_PANEL_ADMINS . "` WHERE `adminid` = :id");
|
||||||
);
|
$this->_admin_cache[$adminid] = Database::pexecute_first($stmt, array(
|
||||||
$this->_admin_cache[$adminid] = Database::pexecute_first($stmt, array('id' => $adminid));
|
'id' => $adminid
|
||||||
|
));
|
||||||
}
|
}
|
||||||
return $this->_admin_cache[$adminid];
|
return $this->_admin_cache[$adminid];
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -1,88 +1,88 @@
|
|||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* PHPMailer RFC821 SMTP email transport class.
|
* PHPMailer RFC821 SMTP email transport class.
|
||||||
* PHP Version 5
|
* PHP Version 5
|
||||||
* @package PHPMailer
|
* @package PHPMailer
|
||||||
* @link https://github.com/PHPMailer/PHPMailer/ The PHPMailer GitHub project
|
* @link https://github.com/PHPMailer/PHPMailer/ The PHPMailer GitHub project
|
||||||
* @author Marcus Bointon (Synchro/coolbru) <phpmailer@synchromedia.co.uk>
|
* @author Marcus Bointon (Synchro/coolbru) <phpmailer@synchromedia.co.uk>
|
||||||
* @author Jim Jagielski (jimjag) <jimjag@gmail.com>
|
* @author Jim Jagielski (jimjag) <jimjag@gmail.com>
|
||||||
* @author Andy Prevost (codeworxtech) <codeworxtech@users.sourceforge.net>
|
* @author Andy Prevost (codeworxtech) <codeworxtech@users.sourceforge.net>
|
||||||
* @author Brent R. Matzelle (original founder)
|
* @author Brent R. Matzelle (original founder)
|
||||||
* @copyright 2014 Marcus Bointon
|
* @copyright 2014 Marcus Bointon
|
||||||
* @copyright 2010 - 2012 Jim Jagielski
|
* @copyright 2010 - 2012 Jim Jagielski
|
||||||
* @copyright 2004 - 2009 Andy Prevost
|
* @copyright 2004 - 2009 Andy Prevost
|
||||||
* @license http://www.gnu.org/copyleft/lesser.html GNU Lesser General Public License
|
* @license http://www.gnu.org/copyleft/lesser.html GNU Lesser General Public License
|
||||||
* @note This program is distributed in the hope that it will be useful - WITHOUT
|
* @note This program is distributed in the hope that it will be useful - WITHOUT
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE.
|
* FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* PHPMailer RFC821 SMTP email transport class.
|
* PHPMailer RFC821 SMTP email transport class.
|
||||||
* Implements RFC 821 SMTP commands and provides some utility methods for sending mail to an SMTP server.
|
* Implements RFC 821 SMTP commands and provides some utility methods for sending mail to an SMTP server.
|
||||||
* @package PHPMailer
|
* @package PHPMailer
|
||||||
* @author Chris Ryan
|
* @author Chris Ryan
|
||||||
* @author Marcus Bointon <phpmailer@synchromedia.co.uk>
|
* @author Marcus Bointon <phpmailer@synchromedia.co.uk>
|
||||||
*/
|
*/
|
||||||
class SMTP
|
class SMTP
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* The PHPMailer SMTP version number.
|
* The PHPMailer SMTP version number.
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
const VERSION = '5.2.21';
|
const VERSION = '5.2.26';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SMTP line break constant.
|
* SMTP line break constant.
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
const CRLF = "\r\n";
|
const CRLF = "\r\n";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The SMTP port to use if one is not specified.
|
* The SMTP port to use if one is not specified.
|
||||||
* @var integer
|
* @var integer
|
||||||
*/
|
*/
|
||||||
const DEFAULT_SMTP_PORT = 25;
|
const DEFAULT_SMTP_PORT = 25;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The maximum line length allowed by RFC 2822 section 2.1.1
|
* The maximum line length allowed by RFC 2822 section 2.1.1
|
||||||
* @var integer
|
* @var integer
|
||||||
*/
|
*/
|
||||||
const MAX_LINE_LENGTH = 998;
|
const MAX_LINE_LENGTH = 998;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug level for no output
|
* Debug level for no output
|
||||||
*/
|
*/
|
||||||
const DEBUG_OFF = 0;
|
const DEBUG_OFF = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug level to show client -> server messages
|
* Debug level to show client -> server messages
|
||||||
*/
|
*/
|
||||||
const DEBUG_CLIENT = 1;
|
const DEBUG_CLIENT = 1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug level to show client -> server and server -> client messages
|
* Debug level to show client -> server and server -> client messages
|
||||||
*/
|
*/
|
||||||
const DEBUG_SERVER = 2;
|
const DEBUG_SERVER = 2;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug level to show connection status, client -> server and server -> client messages
|
* Debug level to show connection status, client -> server and server -> client messages
|
||||||
*/
|
*/
|
||||||
const DEBUG_CONNECTION = 3;
|
const DEBUG_CONNECTION = 3;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug level to show all messages
|
* Debug level to show all messages
|
||||||
*/
|
*/
|
||||||
const DEBUG_LOWLEVEL = 4;
|
const DEBUG_LOWLEVEL = 4;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The PHPMailer SMTP Version number.
|
* The PHPMailer SMTP Version number.
|
||||||
* @var string
|
* @var string
|
||||||
* @deprecated Use the `VERSION` constant instead
|
* @deprecated Use the `VERSION` constant instead
|
||||||
* @see SMTP::VERSION
|
* @see SMTP::VERSION
|
||||||
*/
|
*/
|
||||||
public $Version = '5.2.21';
|
public $Version = '5.2.26';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SMTP server port number.
|
* SMTP server port number.
|
||||||
* @var integer
|
* @var integer
|
||||||
@@ -90,7 +90,7 @@ class SMTP
|
|||||||
* @see SMTP::DEFAULT_SMTP_PORT
|
* @see SMTP::DEFAULT_SMTP_PORT
|
||||||
*/
|
*/
|
||||||
public $SMTP_PORT = 25;
|
public $SMTP_PORT = 25;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SMTP reply line ending.
|
* SMTP reply line ending.
|
||||||
* @var string
|
* @var string
|
||||||
@@ -98,7 +98,7 @@ class SMTP
|
|||||||
* @see SMTP::CRLF
|
* @see SMTP::CRLF
|
||||||
*/
|
*/
|
||||||
public $CRLF = "\r\n";
|
public $CRLF = "\r\n";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Debug output level.
|
* Debug output level.
|
||||||
* Options:
|
* Options:
|
||||||
@@ -110,7 +110,7 @@ class SMTP
|
|||||||
* @var integer
|
* @var integer
|
||||||
*/
|
*/
|
||||||
public $do_debug = self::DEBUG_OFF;
|
public $do_debug = self::DEBUG_OFF;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* How to handle debug output.
|
* How to handle debug output.
|
||||||
* Options:
|
* Options:
|
||||||
@@ -125,7 +125,7 @@ class SMTP
|
|||||||
* @var string|callable
|
* @var string|callable
|
||||||
*/
|
*/
|
||||||
public $Debugoutput = 'echo';
|
public $Debugoutput = 'echo';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether to use VERP.
|
* Whether to use VERP.
|
||||||
* @link http://en.wikipedia.org/wiki/Variable_envelope_return_path
|
* @link http://en.wikipedia.org/wiki/Variable_envelope_return_path
|
||||||
@@ -133,7 +133,7 @@ class SMTP
|
|||||||
* @var boolean
|
* @var boolean
|
||||||
*/
|
*/
|
||||||
public $do_verp = false;
|
public $do_verp = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The timeout value for connection, in seconds.
|
* The timeout value for connection, in seconds.
|
||||||
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
|
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
|
||||||
@@ -142,31 +142,36 @@ class SMTP
|
|||||||
* @var integer
|
* @var integer
|
||||||
*/
|
*/
|
||||||
public $Timeout = 300;
|
public $Timeout = 300;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* How long to wait for commands to complete, in seconds.
|
* How long to wait for commands to complete, in seconds.
|
||||||
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
|
* Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
|
||||||
* @var integer
|
* @var integer
|
||||||
*/
|
*/
|
||||||
public $Timelimit = 300;
|
public $Timelimit = 300;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var array patterns to extract smtp transaction id from smtp reply
|
* @var array Patterns to extract an SMTP transaction id from reply to a DATA command.
|
||||||
* Only first capture group will be use, use non-capturing group to deal with it
|
* The first capture group in each regex will be used as the ID.
|
||||||
* Extend this class to override this property to fulfil your needs.
|
|
||||||
*/
|
*/
|
||||||
protected $smtp_transaction_id_patterns = array(
|
protected $smtp_transaction_id_patterns = array(
|
||||||
'exim' => '/[0-9]{3} OK id=(.*)/',
|
'exim' => '/[0-9]{3} OK id=(.*)/',
|
||||||
'sendmail' => '/[0-9]{3} 2.0.0 (.*) Message/',
|
'sendmail' => '/[0-9]{3} 2.0.0 (.*) Message/',
|
||||||
'postfix' => '/[0-9]{3} 2.0.0 Ok: queued as (.*)/'
|
'postfix' => '/[0-9]{3} 2.0.0 Ok: queued as (.*)/'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string The last transaction ID issued in response to a DATA command,
|
||||||
|
* if one was detected
|
||||||
|
*/
|
||||||
|
protected $last_smtp_transaction_id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The socket for the server connection.
|
* The socket for the server connection.
|
||||||
* @var resource
|
* @var resource
|
||||||
*/
|
*/
|
||||||
protected $smtp_conn;
|
protected $smtp_conn;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Error information, if any, for the last SMTP command.
|
* Error information, if any, for the last SMTP command.
|
||||||
* @var array
|
* @var array
|
||||||
@@ -177,14 +182,14 @@ class SMTP
|
|||||||
'smtp_code' => '',
|
'smtp_code' => '',
|
||||||
'smtp_code_ex' => ''
|
'smtp_code_ex' => ''
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The reply the server sent to us for HELO.
|
* The reply the server sent to us for HELO.
|
||||||
* If null, no HELO string has yet been received.
|
* If null, no HELO string has yet been received.
|
||||||
* @var string|null
|
* @var string|null
|
||||||
*/
|
*/
|
||||||
protected $helo_rply = null;
|
protected $helo_rply = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The set of SMTP extensions sent in reply to EHLO command.
|
* The set of SMTP extensions sent in reply to EHLO command.
|
||||||
* Indexes of the array are extension names.
|
* Indexes of the array are extension names.
|
||||||
@@ -195,13 +200,13 @@ class SMTP
|
|||||||
* @var array|null
|
* @var array|null
|
||||||
*/
|
*/
|
||||||
protected $server_caps = null;
|
protected $server_caps = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The most recent reply received from the server.
|
* The most recent reply received from the server.
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected $last_reply = '';
|
protected $last_reply = '';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output debugging info via a user-selected method.
|
* Output debugging info via a user-selected method.
|
||||||
* @see SMTP::$Debugoutput
|
* @see SMTP::$Debugoutput
|
||||||
@@ -227,12 +232,11 @@ class SMTP
|
|||||||
break;
|
break;
|
||||||
case 'html':
|
case 'html':
|
||||||
//Cleans up output a bit for a better looking, HTML-safe output
|
//Cleans up output a bit for a better looking, HTML-safe output
|
||||||
echo htmlentities(
|
echo gmdate('Y-m-d H:i:s') . ' ' . htmlentities(
|
||||||
preg_replace('/[\r\n]+/', '', $str),
|
preg_replace('/[\r\n]+/', '', $str),
|
||||||
ENT_QUOTES,
|
ENT_QUOTES,
|
||||||
'UTF-8'
|
'UTF-8'
|
||||||
)
|
) . "<br>\n";
|
||||||
. "<br>\n";
|
|
||||||
break;
|
break;
|
||||||
case 'echo':
|
case 'echo':
|
||||||
default:
|
default:
|
||||||
@@ -242,10 +246,10 @@ class SMTP
|
|||||||
"\n",
|
"\n",
|
||||||
"\n \t ",
|
"\n \t ",
|
||||||
trim($str)
|
trim($str)
|
||||||
)."\n";
|
) . "\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Connect to an SMTP server.
|
* Connect to an SMTP server.
|
||||||
* @param string $host SMTP server IP or host name
|
* @param string $host SMTP server IP or host name
|
||||||
@@ -276,7 +280,8 @@ class SMTP
|
|||||||
}
|
}
|
||||||
// Connect to the SMTP server
|
// Connect to the SMTP server
|
||||||
$this->edebug(
|
$this->edebug(
|
||||||
"Connection: opening to $host:$port, timeout=$timeout, options=".var_export($options, true),
|
"Connection: opening to $host:$port, timeout=$timeout, options=" .
|
||||||
|
var_export($options, true),
|
||||||
self::DEBUG_CONNECTION
|
self::DEBUG_CONNECTION
|
||||||
);
|
);
|
||||||
$errno = 0;
|
$errno = 0;
|
||||||
@@ -339,7 +344,7 @@ class SMTP
|
|||||||
$this->edebug('SERVER -> CLIENT: ' . $announce, self::DEBUG_SERVER);
|
$this->edebug('SERVER -> CLIENT: ' . $announce, self::DEBUG_SERVER);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initiate a TLS (encrypted) session.
|
* Initiate a TLS (encrypted) session.
|
||||||
* @access public
|
* @access public
|
||||||
@@ -350,28 +355,28 @@ class SMTP
|
|||||||
if (!$this->sendCommand('STARTTLS', 'STARTTLS', 220)) {
|
if (!$this->sendCommand('STARTTLS', 'STARTTLS', 220)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Allow the best TLS version(s) we can
|
//Allow the best TLS version(s) we can
|
||||||
$crypto_method = STREAM_CRYPTO_METHOD_TLS_CLIENT;
|
$crypto_method = STREAM_CRYPTO_METHOD_TLS_CLIENT;
|
||||||
|
|
||||||
//PHP 5.6.7 dropped inclusion of TLS 1.1 and 1.2 in STREAM_CRYPTO_METHOD_TLS_CLIENT
|
//PHP 5.6.7 dropped inclusion of TLS 1.1 and 1.2 in STREAM_CRYPTO_METHOD_TLS_CLIENT
|
||||||
//so add them back in manually if we can
|
//so add them back in manually if we can
|
||||||
if (defined('STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT')) {
|
if (defined('STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT')) {
|
||||||
$crypto_method |= STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT;
|
$crypto_method |= STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT;
|
||||||
$crypto_method |= STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT;
|
$crypto_method |= STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Begin encrypted connection
|
// Begin encrypted connection
|
||||||
if (!stream_socket_enable_crypto(
|
set_error_handler(array($this, 'errorHandler'));
|
||||||
|
$crypto_ok = stream_socket_enable_crypto(
|
||||||
$this->smtp_conn,
|
$this->smtp_conn,
|
||||||
true,
|
true,
|
||||||
$crypto_method
|
$crypto_method
|
||||||
)) {
|
);
|
||||||
return false;
|
restore_error_handler();
|
||||||
}
|
return $crypto_ok;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Perform SMTP authentication.
|
* Perform SMTP authentication.
|
||||||
* Must be run after hello().
|
* Must be run after hello().
|
||||||
@@ -396,23 +401,22 @@ class SMTP
|
|||||||
$this->setError('Authentication is not allowed before HELO/EHLO');
|
$this->setError('Authentication is not allowed before HELO/EHLO');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (array_key_exists('EHLO', $this->server_caps)) {
|
if (array_key_exists('EHLO', $this->server_caps)) {
|
||||||
// SMTP extensions are available. Let's try to find a proper authentication method
|
// SMTP extensions are available; try to find a proper authentication method
|
||||||
|
|
||||||
if (!array_key_exists('AUTH', $this->server_caps)) {
|
if (!array_key_exists('AUTH', $this->server_caps)) {
|
||||||
$this->setError('Authentication is not allowed at this stage');
|
$this->setError('Authentication is not allowed at this stage');
|
||||||
// 'at this stage' means that auth may be allowed after the stage changes
|
// 'at this stage' means that auth may be allowed after the stage changes
|
||||||
// e.g. after STARTTLS
|
// e.g. after STARTTLS
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
self::edebug('Auth method requested: ' . ($authtype ? $authtype : 'UNKNOWN'), self::DEBUG_LOWLEVEL);
|
self::edebug('Auth method requested: ' . ($authtype ? $authtype : 'UNKNOWN'), self::DEBUG_LOWLEVEL);
|
||||||
self::edebug(
|
self::edebug(
|
||||||
'Auth methods available on the server: ' . implode(',', $this->server_caps['AUTH']),
|
'Auth methods available on the server: ' . implode(',', $this->server_caps['AUTH']),
|
||||||
self::DEBUG_LOWLEVEL
|
self::DEBUG_LOWLEVEL
|
||||||
);
|
);
|
||||||
|
|
||||||
if (empty($authtype)) {
|
if (empty($authtype)) {
|
||||||
foreach (array('CRAM-MD5', 'LOGIN', 'PLAIN', 'NTLM', 'XOAUTH2') as $method) {
|
foreach (array('CRAM-MD5', 'LOGIN', 'PLAIN', 'NTLM', 'XOAUTH2') as $method) {
|
||||||
if (in_array($method, $this->server_caps['AUTH'])) {
|
if (in_array($method, $this->server_caps['AUTH'])) {
|
||||||
@@ -424,9 +428,9 @@ class SMTP
|
|||||||
$this->setError('No supported authentication methods found');
|
$this->setError('No supported authentication methods found');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
self::edebug('Auth method selected: '.$authtype, self::DEBUG_LOWLEVEL);
|
self::edebug('Auth method selected: ' . $authtype, self::DEBUG_LOWLEVEL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!in_array($authtype, $this->server_caps['AUTH'])) {
|
if (!in_array($authtype, $this->server_caps['AUTH'])) {
|
||||||
$this->setError("The requested authentication method \"$authtype\" is not supported by the server");
|
$this->setError("The requested authentication method \"$authtype\" is not supported by the server");
|
||||||
return false;
|
return false;
|
||||||
@@ -469,7 +473,7 @@ class SMTP
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$oauth = $OAuth->getOauth64();
|
$oauth = $OAuth->getOauth64();
|
||||||
|
|
||||||
// Start authentication
|
// Start authentication
|
||||||
if (!$this->sendCommand('AUTH', 'AUTH XOAUTH2 ' . $oauth, 235)) {
|
if (!$this->sendCommand('AUTH', 'AUTH XOAUTH2 ' . $oauth, 235)) {
|
||||||
return false;
|
return false;
|
||||||
@@ -499,7 +503,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
//msg1
|
//msg1
|
||||||
$msg1 = $ntlm_client->typeMsg1($realm, $workstation); //msg1
|
$msg1 = $ntlm_client->typeMsg1($realm, $workstation); //msg1
|
||||||
|
|
||||||
if (!$this->sendCommand(
|
if (!$this->sendCommand(
|
||||||
'AUTH NTLM',
|
'AUTH NTLM',
|
||||||
'AUTH NTLM ' . base64_encode($msg1),
|
'AUTH NTLM ' . base64_encode($msg1),
|
||||||
@@ -532,10 +536,10 @@ class SMTP
|
|||||||
}
|
}
|
||||||
// Get the challenge
|
// Get the challenge
|
||||||
$challenge = base64_decode(substr($this->last_reply, 4));
|
$challenge = base64_decode(substr($this->last_reply, 4));
|
||||||
|
|
||||||
// Build the response
|
// Build the response
|
||||||
$response = $username . ' ' . $this->hmac($challenge, $password);
|
$response = $username . ' ' . $this->hmac($challenge, $password);
|
||||||
|
|
||||||
// send encoded credentials
|
// send encoded credentials
|
||||||
return $this->sendCommand('Username', base64_encode($response), 235);
|
return $this->sendCommand('Username', base64_encode($response), 235);
|
||||||
default:
|
default:
|
||||||
@@ -544,13 +548,13 @@ class SMTP
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Calculate an MD5 HMAC hash.
|
* Calculate an MD5 HMAC hash.
|
||||||
* Works like hash_hmac('md5', $data, $key)
|
* Works like hash_hmac('md5', $data, $key)
|
||||||
* in case that function is not available
|
* in case that function is not available
|
||||||
* @param string $data The data to hash
|
* @param string $data The data to hash
|
||||||
* @param string $key The key to hash with
|
* @param string $key The key to hash with
|
||||||
* @access protected
|
* @access protected
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
@@ -559,15 +563,15 @@ class SMTP
|
|||||||
if (function_exists('hash_hmac')) {
|
if (function_exists('hash_hmac')) {
|
||||||
return hash_hmac('md5', $data, $key);
|
return hash_hmac('md5', $data, $key);
|
||||||
}
|
}
|
||||||
|
|
||||||
// The following borrowed from
|
// The following borrowed from
|
||||||
// http://php.net/manual/en/function.mhash.php#27225
|
// http://php.net/manual/en/function.mhash.php#27225
|
||||||
|
|
||||||
// RFC 2104 HMAC implementation for php.
|
// RFC 2104 HMAC implementation for php.
|
||||||
// Creates an md5 HMAC.
|
// Creates an md5 HMAC.
|
||||||
// Eliminates the need to install mhash to compute a HMAC
|
// Eliminates the need to install mhash to compute a HMAC
|
||||||
// by Lance Rushing
|
// by Lance Rushing
|
||||||
|
|
||||||
$bytelen = 64; // byte length for md5
|
$bytelen = 64; // byte length for md5
|
||||||
if (strlen($key) > $bytelen) {
|
if (strlen($key) > $bytelen) {
|
||||||
$key = pack('H*', md5($key));
|
$key = pack('H*', md5($key));
|
||||||
@@ -577,10 +581,10 @@ class SMTP
|
|||||||
$opad = str_pad('', $bytelen, chr(0x5c));
|
$opad = str_pad('', $bytelen, chr(0x5c));
|
||||||
$k_ipad = $key ^ $ipad;
|
$k_ipad = $key ^ $ipad;
|
||||||
$k_opad = $key ^ $opad;
|
$k_opad = $key ^ $opad;
|
||||||
|
|
||||||
return md5($k_opad . pack('H*', md5($k_ipad . $data)));
|
return md5($k_opad . pack('H*', md5($k_ipad . $data)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check connection state.
|
* Check connection state.
|
||||||
* @access public
|
* @access public
|
||||||
@@ -603,7 +607,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Close the socket and clean up the state of the class.
|
* Close the socket and clean up the state of the class.
|
||||||
* Don't use this function without first trying to use QUIT.
|
* Don't use this function without first trying to use QUIT.
|
||||||
@@ -623,7 +627,7 @@ class SMTP
|
|||||||
$this->edebug('Connection: closed', self::DEBUG_CONNECTION);
|
$this->edebug('Connection: closed', self::DEBUG_CONNECTION);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP DATA command.
|
* Send an SMTP DATA command.
|
||||||
* Issues a data command and sends the msg_data to the server,
|
* Issues a data command and sends the msg_data to the server,
|
||||||
@@ -642,7 +646,7 @@ class SMTP
|
|||||||
if (!$this->sendCommand('DATA', 'DATA', 354)) {
|
if (!$this->sendCommand('DATA', 'DATA', 354)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The server is ready to accept data!
|
/* The server is ready to accept data!
|
||||||
* According to rfc821 we should not send more than 1000 characters on a single line (including the CRLF)
|
* According to rfc821 we should not send more than 1000 characters on a single line (including the CRLF)
|
||||||
* so we will break the data up into lines by \r and/or \n then if needed we will break each of those into
|
* so we will break the data up into lines by \r and/or \n then if needed we will break each of those into
|
||||||
@@ -650,21 +654,21 @@ class SMTP
|
|||||||
* We will also look for lines that start with a '.' and prepend an additional '.'.
|
* We will also look for lines that start with a '.' and prepend an additional '.'.
|
||||||
* NOTE: this does not count towards line-length limit.
|
* NOTE: this does not count towards line-length limit.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Normalize line breaks before exploding
|
// Normalize line breaks before exploding
|
||||||
$lines = explode("\n", str_replace(array("\r\n", "\r"), "\n", $msg_data));
|
$lines = explode("\n", str_replace(array("\r\n", "\r"), "\n", $msg_data));
|
||||||
|
|
||||||
/* To distinguish between a complete RFC822 message and a plain message body, we check if the first field
|
/* To distinguish between a complete RFC822 message and a plain message body, we check if the first field
|
||||||
* of the first line (':' separated) does not contain a space then it _should_ be a header and we will
|
* of the first line (':' separated) does not contain a space then it _should_ be a header and we will
|
||||||
* process all lines before a blank line as headers.
|
* process all lines before a blank line as headers.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$field = substr($lines[0], 0, strpos($lines[0], ':'));
|
$field = substr($lines[0], 0, strpos($lines[0], ':'));
|
||||||
$in_headers = false;
|
$in_headers = false;
|
||||||
if (!empty($field) && strpos($field, ' ') === false) {
|
if (!empty($field) && strpos($field, ' ') === false) {
|
||||||
$in_headers = true;
|
$in_headers = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($lines as $line) {
|
foreach ($lines as $line) {
|
||||||
$lines_out = array();
|
$lines_out = array();
|
||||||
if ($in_headers and $line == '') {
|
if ($in_headers and $line == '') {
|
||||||
@@ -694,7 +698,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$lines_out[] = $line;
|
$lines_out[] = $line;
|
||||||
|
|
||||||
//Send the lines to the server
|
//Send the lines to the server
|
||||||
foreach ($lines_out as $line_out) {
|
foreach ($lines_out as $line_out) {
|
||||||
//RFC2821 section 4.5.2
|
//RFC2821 section 4.5.2
|
||||||
@@ -704,17 +708,18 @@ class SMTP
|
|||||||
$this->client_send($line_out . self::CRLF);
|
$this->client_send($line_out . self::CRLF);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Message data has been sent, complete the command
|
//Message data has been sent, complete the command
|
||||||
//Increase timelimit for end of DATA command
|
//Increase timelimit for end of DATA command
|
||||||
$savetimelimit = $this->Timelimit;
|
$savetimelimit = $this->Timelimit;
|
||||||
$this->Timelimit = $this->Timelimit * 2;
|
$this->Timelimit = $this->Timelimit * 2;
|
||||||
$result = $this->sendCommand('DATA END', '.', 250);
|
$result = $this->sendCommand('DATA END', '.', 250);
|
||||||
|
$this->recordLastTransactionID();
|
||||||
//Restore timelimit
|
//Restore timelimit
|
||||||
$this->Timelimit = $savetimelimit;
|
$this->Timelimit = $savetimelimit;
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP HELO or EHLO command.
|
* Send an SMTP HELO or EHLO command.
|
||||||
* Used to identify the sending server to the receiving server.
|
* Used to identify the sending server to the receiving server.
|
||||||
@@ -730,7 +735,7 @@ class SMTP
|
|||||||
//Try extended hello first (RFC 2821)
|
//Try extended hello first (RFC 2821)
|
||||||
return (boolean)($this->sendHello('EHLO', $host) or $this->sendHello('HELO', $host));
|
return (boolean)($this->sendHello('EHLO', $host) or $this->sendHello('HELO', $host));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP HELO or EHLO command.
|
* Send an SMTP HELO or EHLO command.
|
||||||
* Low-level implementation used by hello()
|
* Low-level implementation used by hello()
|
||||||
@@ -751,7 +756,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
return $noerror;
|
return $noerror;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parse a reply to HELO/EHLO command to discover server extensions.
|
* Parse a reply to HELO/EHLO command to discover server extensions.
|
||||||
* In case of HELO, the only parameter that can be discovered is a server name.
|
* In case of HELO, the only parameter that can be discovered is a server name.
|
||||||
@@ -762,7 +767,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
$this->server_caps = array();
|
$this->server_caps = array();
|
||||||
$lines = explode("\n", $this->helo_rply);
|
$lines = explode("\n", $this->helo_rply);
|
||||||
|
|
||||||
foreach ($lines as $n => $s) {
|
foreach ($lines as $n => $s) {
|
||||||
//First 4 chars contain response code followed by - or space
|
//First 4 chars contain response code followed by - or space
|
||||||
$s = trim(substr($s, 4));
|
$s = trim(substr($s, 4));
|
||||||
@@ -793,7 +798,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP MAIL command.
|
* Send an SMTP MAIL command.
|
||||||
* Starts a mail transaction from the email address specified in
|
* Starts a mail transaction from the email address specified in
|
||||||
@@ -814,7 +819,7 @@ class SMTP
|
|||||||
250
|
250
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP QUIT command.
|
* Send an SMTP QUIT command.
|
||||||
* Closes the socket if there is no error or the $close_on_error argument is true.
|
* Closes the socket if there is no error or the $close_on_error argument is true.
|
||||||
@@ -833,7 +838,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
return $noerror;
|
return $noerror;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP RCPT command.
|
* Send an SMTP RCPT command.
|
||||||
* Sets the TO argument to $toaddr.
|
* Sets the TO argument to $toaddr.
|
||||||
@@ -851,7 +856,7 @@ class SMTP
|
|||||||
array(250, 251)
|
array(250, 251)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP RSET command.
|
* Send an SMTP RSET command.
|
||||||
* Abort any transaction that is currently in progress.
|
* Abort any transaction that is currently in progress.
|
||||||
@@ -863,7 +868,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->sendCommand('RSET', 'RSET', 250);
|
return $this->sendCommand('RSET', 'RSET', 250);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send a command to an SMTP server and check its return code.
|
* Send a command to an SMTP server and check its return code.
|
||||||
* @param string $command The command name - not sent to the server
|
* @param string $command The command name - not sent to the server
|
||||||
@@ -884,7 +889,7 @@ class SMTP
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$this->client_send($commandstring . self::CRLF);
|
$this->client_send($commandstring . self::CRLF);
|
||||||
|
|
||||||
$this->last_reply = $this->get_lines();
|
$this->last_reply = $this->get_lines();
|
||||||
// Fetch SMTP code and possible error code explanation
|
// Fetch SMTP code and possible error code explanation
|
||||||
$matches = array();
|
$matches = array();
|
||||||
@@ -893,7 +898,8 @@ class SMTP
|
|||||||
$code_ex = (count($matches) > 2 ? $matches[2] : null);
|
$code_ex = (count($matches) > 2 ? $matches[2] : null);
|
||||||
// Cut off error code from each response line
|
// Cut off error code from each response line
|
||||||
$detail = preg_replace(
|
$detail = preg_replace(
|
||||||
"/{$code}[ -]".($code_ex ? str_replace('.', '\\.', $code_ex).' ' : '')."/m",
|
"/{$code}[ -]" .
|
||||||
|
($code_ex ? str_replace('.', '\\.', $code_ex) . ' ' : '') . "/m",
|
||||||
'',
|
'',
|
||||||
$this->last_reply
|
$this->last_reply
|
||||||
);
|
);
|
||||||
@@ -903,9 +909,9 @@ class SMTP
|
|||||||
$code_ex = null;
|
$code_ex = null;
|
||||||
$detail = substr($this->last_reply, 4);
|
$detail = substr($this->last_reply, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->edebug('SERVER -> CLIENT: ' . $this->last_reply, self::DEBUG_SERVER);
|
$this->edebug('SERVER -> CLIENT: ' . $this->last_reply, self::DEBUG_SERVER);
|
||||||
|
|
||||||
if (!in_array($code, (array)$expect)) {
|
if (!in_array($code, (array)$expect)) {
|
||||||
$this->setError(
|
$this->setError(
|
||||||
"$command command failed",
|
"$command command failed",
|
||||||
@@ -919,11 +925,11 @@ class SMTP
|
|||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->setError('');
|
$this->setError('');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP SAML command.
|
* Send an SMTP SAML command.
|
||||||
* Starts a mail transaction from the email address specified in $from.
|
* Starts a mail transaction from the email address specified in $from.
|
||||||
@@ -941,7 +947,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->sendCommand('SAML', "SAML FROM:$from", 250);
|
return $this->sendCommand('SAML', "SAML FROM:$from", 250);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP VRFY command.
|
* Send an SMTP VRFY command.
|
||||||
* @param string $name The name to verify
|
* @param string $name The name to verify
|
||||||
@@ -952,7 +958,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->sendCommand('VRFY', "VRFY $name", array(250, 251));
|
return $this->sendCommand('VRFY', "VRFY $name", array(250, 251));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP NOOP command.
|
* Send an SMTP NOOP command.
|
||||||
* Used to keep keep-alives alive, doesn't actually do anything
|
* Used to keep keep-alives alive, doesn't actually do anything
|
||||||
@@ -963,7 +969,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->sendCommand('NOOP', 'NOOP', 250);
|
return $this->sendCommand('NOOP', 'NOOP', 250);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send an SMTP TURN command.
|
* Send an SMTP TURN command.
|
||||||
* This is an optional command for SMTP that this class does not support.
|
* This is an optional command for SMTP that this class does not support.
|
||||||
@@ -979,7 +985,7 @@ class SMTP
|
|||||||
$this->edebug('SMTP NOTICE: ' . $this->error['error'], self::DEBUG_CLIENT);
|
$this->edebug('SMTP NOTICE: ' . $this->error['error'], self::DEBUG_CLIENT);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send raw data to the server.
|
* Send raw data to the server.
|
||||||
* @param string $data The data to send
|
* @param string $data The data to send
|
||||||
@@ -989,9 +995,12 @@ class SMTP
|
|||||||
public function client_send($data)
|
public function client_send($data)
|
||||||
{
|
{
|
||||||
$this->edebug("CLIENT -> SERVER: $data", self::DEBUG_CLIENT);
|
$this->edebug("CLIENT -> SERVER: $data", self::DEBUG_CLIENT);
|
||||||
return fwrite($this->smtp_conn, $data);
|
set_error_handler(array($this, 'errorHandler'));
|
||||||
|
$result = fwrite($this->smtp_conn, $data);
|
||||||
|
restore_error_handler();
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the latest error.
|
* Get the latest error.
|
||||||
* @access public
|
* @access public
|
||||||
@@ -1001,7 +1010,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->error;
|
return $this->error;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get SMTP extensions available on the server
|
* Get SMTP extensions available on the server
|
||||||
* @access public
|
* @access public
|
||||||
@@ -1011,7 +1020,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->server_caps;
|
return $this->server_caps;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A multipurpose method
|
* A multipurpose method
|
||||||
* The method works in three ways, dependent on argument value and current state
|
* The method works in three ways, dependent on argument value and current state
|
||||||
@@ -1037,7 +1046,7 @@ class SMTP
|
|||||||
$this->setError('No HELO/EHLO was sent');
|
$this->setError('No HELO/EHLO was sent');
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// the tight logic knot ;)
|
// the tight logic knot ;)
|
||||||
if (!array_key_exists($name, $this->server_caps)) {
|
if (!array_key_exists($name, $this->server_caps)) {
|
||||||
if ($name == 'HELO') {
|
if ($name == 'HELO') {
|
||||||
@@ -1049,10 +1058,10 @@ class SMTP
|
|||||||
$this->setError('HELO handshake was used. Client knows nothing about server extensions');
|
$this->setError('HELO handshake was used. Client knows nothing about server extensions');
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->server_caps[$name];
|
return $this->server_caps[$name];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the last reply from the server.
|
* Get the last reply from the server.
|
||||||
* @access public
|
* @access public
|
||||||
@@ -1062,7 +1071,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->last_reply;
|
return $this->last_reply;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read the SMTP server's response.
|
* Read the SMTP server's response.
|
||||||
* Either before eof or socket timeout occurs on the operation.
|
* Either before eof or socket timeout occurs on the operation.
|
||||||
@@ -1089,8 +1098,10 @@ class SMTP
|
|||||||
$this->edebug("SMTP -> get_lines(): \$data is \"$data\"", self::DEBUG_LOWLEVEL);
|
$this->edebug("SMTP -> get_lines(): \$data is \"$data\"", self::DEBUG_LOWLEVEL);
|
||||||
$this->edebug("SMTP -> get_lines(): \$str is \"$str\"", self::DEBUG_LOWLEVEL);
|
$this->edebug("SMTP -> get_lines(): \$str is \"$str\"", self::DEBUG_LOWLEVEL);
|
||||||
$data .= $str;
|
$data .= $str;
|
||||||
// If 4th character is a space, we are done reading, break the loop, micro-optimisation over strlen
|
// If response is only 3 chars (not valid, but RFC5321 S4.2 says it must be handled),
|
||||||
if ((isset($str[3]) and $str[3] == ' ')) {
|
// or 4th character is a space, we are done reading, break the loop,
|
||||||
|
// string array access is a micro-optimisation over strlen
|
||||||
|
if (!isset($str[3]) or (isset($str[3]) and $str[3] == ' ')) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// Timed-out? Log and break
|
// Timed-out? Log and break
|
||||||
@@ -1105,7 +1116,7 @@ class SMTP
|
|||||||
// Now check if reads took too long
|
// Now check if reads took too long
|
||||||
if ($endtime and time() > $endtime) {
|
if ($endtime and time() > $endtime) {
|
||||||
$this->edebug(
|
$this->edebug(
|
||||||
'SMTP -> get_lines(): timelimit reached ('.
|
'SMTP -> get_lines(): timelimit reached (' .
|
||||||
$this->Timelimit . ' sec)',
|
$this->Timelimit . ' sec)',
|
||||||
self::DEBUG_LOWLEVEL
|
self::DEBUG_LOWLEVEL
|
||||||
);
|
);
|
||||||
@@ -1114,7 +1125,7 @@ class SMTP
|
|||||||
}
|
}
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable or disable VERP address generation.
|
* Enable or disable VERP address generation.
|
||||||
* @param boolean $enabled
|
* @param boolean $enabled
|
||||||
@@ -1123,7 +1134,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
$this->do_verp = $enabled;
|
$this->do_verp = $enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get VERP address generation mode.
|
* Get VERP address generation mode.
|
||||||
* @return boolean
|
* @return boolean
|
||||||
@@ -1132,7 +1143,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->do_verp;
|
return $this->do_verp;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set error messages and codes.
|
* Set error messages and codes.
|
||||||
* @param string $message The error message
|
* @param string $message The error message
|
||||||
@@ -1149,7 +1160,7 @@ class SMTP
|
|||||||
'smtp_code_ex' => $smtp_code_ex
|
'smtp_code_ex' => $smtp_code_ex
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set debug output method.
|
* Set debug output method.
|
||||||
* @param string|callable $method The name of the mechanism to use for debugging output, or a callable to handle it.
|
* @param string|callable $method The name of the mechanism to use for debugging output, or a callable to handle it.
|
||||||
@@ -1158,7 +1169,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
$this->Debugoutput = $method;
|
$this->Debugoutput = $method;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get debug output method.
|
* Get debug output method.
|
||||||
* @return string
|
* @return string
|
||||||
@@ -1167,7 +1178,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->Debugoutput;
|
return $this->Debugoutput;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set debug output level.
|
* Set debug output level.
|
||||||
* @param integer $level
|
* @param integer $level
|
||||||
@@ -1176,7 +1187,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
$this->do_debug = $level;
|
$this->do_debug = $level;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get debug output level.
|
* Get debug output level.
|
||||||
* @return integer
|
* @return integer
|
||||||
@@ -1185,7 +1196,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->do_debug;
|
return $this->do_debug;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set SMTP timeout.
|
* Set SMTP timeout.
|
||||||
* @param integer $timeout
|
* @param integer $timeout
|
||||||
@@ -1194,7 +1205,7 @@ class SMTP
|
|||||||
{
|
{
|
||||||
$this->Timeout = $timeout;
|
$this->Timeout = $timeout;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get SMTP timeout.
|
* Get SMTP timeout.
|
||||||
* @return integer
|
* @return integer
|
||||||
@@ -1203,47 +1214,63 @@ class SMTP
|
|||||||
{
|
{
|
||||||
return $this->Timeout;
|
return $this->Timeout;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reports an error number and string.
|
* Reports an error number and string.
|
||||||
* @param integer $errno The error number returned by PHP.
|
* @param integer $errno The error number returned by PHP.
|
||||||
* @param string $errmsg The error message returned by PHP.
|
* @param string $errmsg The error message returned by PHP.
|
||||||
|
* @param string $errfile The file the error occurred in
|
||||||
|
* @param integer $errline The line number the error occurred on
|
||||||
*/
|
*/
|
||||||
protected function errorHandler($errno, $errmsg)
|
protected function errorHandler($errno, $errmsg, $errfile = '', $errline = 0)
|
||||||
{
|
{
|
||||||
$notice = 'Connection: Failed to connect to server.';
|
$notice = 'Connection failed.';
|
||||||
$this->setError(
|
$this->setError(
|
||||||
$notice,
|
$notice,
|
||||||
$errno,
|
$errno,
|
||||||
$errmsg
|
$errmsg
|
||||||
);
|
);
|
||||||
$this->edebug(
|
$this->edebug(
|
||||||
$notice . ' Error number ' . $errno . '. "Error notice: ' . $errmsg,
|
$notice . ' Error #' . $errno . ': ' . $errmsg . " [$errfile line $errline]",
|
||||||
self::DEBUG_CONNECTION
|
self::DEBUG_CONNECTION
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will return the ID of the last smtp transaction based on a list of patterns provided
|
* Extract and return the ID of the last SMTP transaction based on
|
||||||
* in SMTP::$smtp_transaction_id_patterns.
|
* a list of patterns provided in SMTP::$smtp_transaction_id_patterns.
|
||||||
|
* Relies on the host providing the ID in response to a DATA command.
|
||||||
* If no reply has been received yet, it will return null.
|
* If no reply has been received yet, it will return null.
|
||||||
* If no pattern has been matched, it will return false.
|
* If no pattern was matched, it will return false.
|
||||||
* @return bool|null|string
|
* @return bool|null|string
|
||||||
*/
|
*/
|
||||||
|
protected function recordLastTransactionID()
|
||||||
|
{
|
||||||
|
$reply = $this->getLastReply();
|
||||||
|
|
||||||
|
if (empty($reply)) {
|
||||||
|
$this->last_smtp_transaction_id = null;
|
||||||
|
} else {
|
||||||
|
$this->last_smtp_transaction_id = false;
|
||||||
|
foreach ($this->smtp_transaction_id_patterns as $smtp_transaction_id_pattern) {
|
||||||
|
if (preg_match($smtp_transaction_id_pattern, $reply, $matches)) {
|
||||||
|
$this->last_smtp_transaction_id = $matches[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->last_smtp_transaction_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the queue/transaction ID of the last SMTP transaction
|
||||||
|
* If no reply has been received yet, it will return null.
|
||||||
|
* If no pattern was matched, it will return false.
|
||||||
|
* @return bool|null|string
|
||||||
|
* @see recordLastTransactionID()
|
||||||
|
*/
|
||||||
public function getLastTransactionID()
|
public function getLastTransactionID()
|
||||||
{
|
{
|
||||||
$reply = $this->getLastReply();
|
return $this->last_smtp_transaction_id;
|
||||||
|
|
||||||
if (empty($reply)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach($this->smtp_transaction_id_patterns as $smtp_transaction_id_pattern) {
|
|
||||||
if(preg_match($smtp_transaction_id_pattern, $reply, $matches)) {
|
|
||||||
return $matches[1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
128
lib/classes/settings/class.SImExporter.php
Normal file
128
lib/classes/settings/class.SImExporter.php
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2018 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 Michael Kaufmann <d00p@froxlor.org>
|
||||||
|
* @author Froxlor team <team@froxlor.org> (2018-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Classes
|
||||||
|
*
|
||||||
|
* @since 0.9.39
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class SImExporter
|
||||||
|
*
|
||||||
|
* Import/Export settings to JSON
|
||||||
|
*
|
||||||
|
* @copyright (c) the authors
|
||||||
|
* @author Michael Kaufmann <d00p@froxlor.org>
|
||||||
|
* @author Froxlor team <team@froxlor.org> (2018-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Classes
|
||||||
|
*/
|
||||||
|
class SImExporter
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* settings which are not being exported
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private static $_no_export = [
|
||||||
|
'panel.adminmail',
|
||||||
|
'admin.show_news_feed',
|
||||||
|
'system.lastaccountnumber',
|
||||||
|
'system.lastguid',
|
||||||
|
'system.ipaddress',
|
||||||
|
'system.last_traffic_run',
|
||||||
|
'system.hostname',
|
||||||
|
'system.mysql_access_host',
|
||||||
|
'system.lastcronrun',
|
||||||
|
'system.defaultip',
|
||||||
|
'system.last_tasks_run',
|
||||||
|
'system.last_archive_run',
|
||||||
|
'system.leprivatekey',
|
||||||
|
'system.lepublickey'
|
||||||
|
];
|
||||||
|
|
||||||
|
public static function export()
|
||||||
|
{
|
||||||
|
$result_stmt = Database::query("
|
||||||
|
SELECT * FROM `" . TABLE_PANEL_SETTINGS . "` ORDER BY `settingid` ASC
|
||||||
|
");
|
||||||
|
$_data = array();
|
||||||
|
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$index = $row['settinggroup'] . "." . $row['varname'];
|
||||||
|
if (! in_array($index, self::$_no_export)) {
|
||||||
|
$_data[$index] = $row['value'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// add checksum for validation
|
||||||
|
$_data['_sha'] = sha1(var_export($_data, true));
|
||||||
|
$_export = json_encode($_data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
|
||||||
|
if (! $_export) {
|
||||||
|
throw new Exception("Error exporting settings: " . json_last_error_msg());
|
||||||
|
}
|
||||||
|
return $_export;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function import($json_str = null)
|
||||||
|
{
|
||||||
|
// decode data
|
||||||
|
$_data = json_decode($json_str, true);
|
||||||
|
if ($_data) {
|
||||||
|
// get validity check data
|
||||||
|
$_sha = isset($_data['_sha']) ? $_data['_sha'] : false;
|
||||||
|
$_version = isset($_data['panel.version']) ? $_data['panel.version'] : false;
|
||||||
|
$_dbversion = isset($_data['panel.db_version']) ? $_data['panel.db_version'] : false;
|
||||||
|
// check if we have everything we need
|
||||||
|
if (! $_sha || ! $_version || ! $_dbversion) {
|
||||||
|
throw new Exception("Invalid froxlor settings data. Unable to import.");
|
||||||
|
}
|
||||||
|
// validate import file
|
||||||
|
unset($_data['_sha']);
|
||||||
|
// compare
|
||||||
|
if ($_sha != sha1(var_export($_data, true))) {
|
||||||
|
throw new Exception("SHA check of import data failed. Unable to import.");
|
||||||
|
}
|
||||||
|
// do not import version info - but we need that to possibily update settings
|
||||||
|
// when there were changes in the variable-name or similar
|
||||||
|
unset($_data['panel.version']);
|
||||||
|
unset($_data['panel.db_version']);
|
||||||
|
// validate we got ssl enabled ips when ssl is enabled
|
||||||
|
// otherwise deactivate it
|
||||||
|
if ($_data['system.use_ssl'] == 1) {
|
||||||
|
$result_ssl_ipsandports_stmt = Database::prepare("
|
||||||
|
SELECT COUNT(*) as count_ssl_ip FROM `" . TABLE_PANEL_IPSANDPORTS . "` WHERE `ssl`='1'
|
||||||
|
");
|
||||||
|
$result = Database::pexecute_first($result_ssl_ipsandports_stmt);
|
||||||
|
if ($result['count_ssl_ip'] <= 0) {
|
||||||
|
// no ssl-ip -> deactivate
|
||||||
|
$_data['system.use_ssl'] = 0;
|
||||||
|
// deactivate other ssl-related settings
|
||||||
|
$_data['system.leenabled'] = 0;
|
||||||
|
$_data['system.le_froxlor_enabled'] = 0;
|
||||||
|
$_data['system.le_froxlor_redirect'] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// store new data
|
||||||
|
foreach ($_data as $index => $value) {
|
||||||
|
Settings::Set($index, $value);
|
||||||
|
}
|
||||||
|
// save to DB
|
||||||
|
Settings::Flush();
|
||||||
|
// all good
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
throw new Exception("Invalid JSON data: " . json_last_error_msg());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -30,7 +30,6 @@ class lescript
|
|||||||
{
|
{
|
||||||
|
|
||||||
// https://letsencrypt.org/repository/
|
// https://letsencrypt.org/repository/
|
||||||
public $license;
|
|
||||||
|
|
||||||
private $logger;
|
private $logger;
|
||||||
|
|
||||||
@@ -63,7 +62,7 @@ class lescript
|
|||||||
{
|
{
|
||||||
// Let's see if we have the private accountkey
|
// Let's see if we have the private accountkey
|
||||||
$this->accountKey = $certrow['leprivatekey'];
|
$this->accountKey = $certrow['leprivatekey'];
|
||||||
$this->customerId = $certrow['customerid'];
|
$this->customerId = (!$isFroxlorVhost ? $certrow['customerid'] : null);
|
||||||
$this->isFroxlorVhost = $isFroxlorVhost;
|
$this->isFroxlorVhost = $isFroxlorVhost;
|
||||||
$this->isLeProduction = (Settings::Get('system.letsencryptca') == 'production');
|
$this->isLeProduction = (Settings::Get('system.letsencryptca') == 'production');
|
||||||
|
|
||||||
@@ -83,7 +82,7 @@ class lescript
|
|||||||
Settings::Set('system.leprivatekey', $keys['private']);
|
Settings::Set('system.leprivatekey', $keys['private']);
|
||||||
Settings::Set('system.leregistered', 0); // key is not registered
|
Settings::Set('system.leregistered', 0); // key is not registered
|
||||||
} else {
|
} else {
|
||||||
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `lepublickey` = :public, `leprivatekey` = :private, `leregistered` = :registered " . "WHERE `customerid` = :customerid;");
|
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `lepublickey` = :public, `leprivatekey` = :private, `leregistered` = :registered WHERE `customerid` = :customerid;");
|
||||||
Database::pexecute($upd_stmt, array(
|
Database::pexecute($upd_stmt, array(
|
||||||
'public' => $keys['public'],
|
'public' => $keys['public'],
|
||||||
'private' => $keys['private'],
|
'private' => $keys['private'],
|
||||||
@@ -111,19 +110,7 @@ class lescript
|
|||||||
}
|
}
|
||||||
$accountUrl=$this->client->getLastLocation();
|
$accountUrl=$this->client->getLastLocation();
|
||||||
|
|
||||||
$this->log('Accepting lets encrypt Terms of Service');
|
$leregistered = 1;
|
||||||
|
|
||||||
$this->license = $this->client->getAgreementURL();
|
|
||||||
|
|
||||||
// Terms of Service are optional according to ACME specs; if no ToS are presented, no need to update registration
|
|
||||||
if (!empty($this->license)) {
|
|
||||||
$response = $this->postRegAgreement(parse_url($accountUrl, PHP_URL_PATH));
|
|
||||||
if ($this->client->getLastCode() != 202) {
|
|
||||||
throw new \RuntimeException("Terms of Service not accepted. Whole response: " . json_encode($response));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$leregistered=1;
|
|
||||||
$this->setLeRegisteredState($leregistered); // Account registered
|
$this->setLeRegisteredState($leregistered); // Account registered
|
||||||
$this->log('Lets encrypt Terms of Service accepted');
|
$this->log('Lets encrypt Terms of Service accepted');
|
||||||
}
|
}
|
||||||
@@ -227,17 +214,18 @@ class lescript
|
|||||||
$this->log("Token for $domain saved at $tokenPath and should be available at $uri");
|
$this->log("Token for $domain saved at $tokenPath and should be available at $uri");
|
||||||
|
|
||||||
// simple self check
|
// simple self check
|
||||||
$selfcheckContextOptions = array('http' => array('header' => "User-Agent: Froxlor/".$this->version));
|
if (Settings::Get('system.disable_le_selfcheck') == '0')
|
||||||
$selfcheckContext = stream_context_create($selfcheckContextOptions);
|
{
|
||||||
if ($payload !== trim(@file_get_contents($uri, false, $selfcheckContext))) {
|
$selfcheckpayload = HttpClient::urlGet($uri, false);
|
||||||
$errmsg = json_encode(error_get_last());
|
if ($payload !== trim($selfcheckpayload)) {
|
||||||
if ($errmsg != "null") {
|
$errmsg = json_encode(error_get_last());
|
||||||
$errmsg = "; PHP error: " . $errmsg;
|
if ($errmsg != "null") {
|
||||||
} else {
|
$errmsg = "; PHP error: " . $errmsg;
|
||||||
$errmsg = "";
|
} else {
|
||||||
|
$errmsg = "";
|
||||||
|
}
|
||||||
|
$this->logger->logAction(CRON_ACTION, LOG_WARNING, "[Lets Encrypt self-check] Please check $uri - token seems to be not available. This is just a simple self-check, it might be wrong but consider using this information when Let's Encrypt fails to issue a certificate" . $errmsg);
|
||||||
}
|
}
|
||||||
@unlink($tokenPath);
|
|
||||||
$this->logger->logAction(CRON_ACTION, LOG_ERR, "letsencrypt Please check $uri - token not available" . $errmsg);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->log("Sending request to challenge");
|
$this->log("Sending request to challenge");
|
||||||
@@ -354,7 +342,7 @@ class lescript
|
|||||||
if ($this->isFroxlorVhost) {
|
if ($this->isFroxlorVhost) {
|
||||||
Settings::Set('system.leregistered', $state);
|
Settings::Set('system.leregistered', $state);
|
||||||
} else {
|
} else {
|
||||||
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `leregistered` = :registered " . "WHERE `customerid` = :customerid;");
|
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `leregistered` = :registered WHERE `customerid` = :customerid;");
|
||||||
Database::pexecute($upd_stmt, array(
|
Database::pexecute($upd_stmt, array(
|
||||||
'registered' => $state,
|
'registered' => $state,
|
||||||
'customerid' => $this->customerId
|
'customerid' => $this->customerId
|
||||||
@@ -371,21 +359,16 @@ class lescript
|
|||||||
|
|
||||||
private function postNewReg()
|
private function postNewReg()
|
||||||
{
|
{
|
||||||
|
$this->log('Getting last terms of service URL');
|
||||||
|
$directory = $this->client->get('/directory');
|
||||||
|
if (!isset($directory['meta']) || !isset($directory['meta']['terms-of-service'])) {
|
||||||
|
throw new \RuntimeException("No terms of service link available!");
|
||||||
|
}
|
||||||
$this->log('Sending registration to letsencrypt server');
|
$this->log('Sending registration to letsencrypt server');
|
||||||
|
|
||||||
return $this->signedRequest('/acme/new-reg', array(
|
return $this->signedRequest('/acme/new-reg', array(
|
||||||
'resource' => 'new-reg',
|
'resource' => 'new-reg',
|
||||||
'agreement' => $this->license
|
'agreement' => $directory['meta']['terms-of-service']
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
private function postRegAgreement($uri)
|
|
||||||
{
|
|
||||||
$this->log('Accepting agreement at URL: ' . $this->license);
|
|
||||||
|
|
||||||
return $this->signedRequest($uri, array(
|
|
||||||
'resource' => 'reg',
|
|
||||||
'agreement' => $this->license
|
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -590,49 +573,6 @@ class Client
|
|||||||
preg_match_all('~Link: <(.+)>;rel="up"~', $this->lastHeader, $matches);
|
preg_match_all('~Link: <(.+)>;rel="up"~', $this->lastHeader, $matches);
|
||||||
return $matches[1];
|
return $matches[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getAgreementURLFromLastResponse()
|
|
||||||
{
|
|
||||||
if (preg_match_all('~Link: <(.+)>;rel="terms-of-service"~', $this->lastHeader, $matches)) {
|
|
||||||
return $matches[1][0];
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
public function getAgreementURLFromDirectory()
|
|
||||||
{
|
|
||||||
// FIXME: Current license should be found in /directory but LE does not implement this yet
|
|
||||||
// $this->curl('GET', '/directory');
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
public function getAgreementURLFromTermsUrl()
|
|
||||||
{
|
|
||||||
$this->curl('GET', '/terms');
|
|
||||||
if (preg_match_all('~Location: (.+)~', $this->lastHeader, $matches)) {
|
|
||||||
return trim($matches[1][0]);
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getAgreementURL()
|
|
||||||
{
|
|
||||||
// 1. check the header of the last response
|
|
||||||
$license=$this->getAgreementURLFromLastResponse();
|
|
||||||
if (!empty($license)) return $license;
|
|
||||||
|
|
||||||
// 2. query directory for license
|
|
||||||
$license=$this->getAgreementURLFromDirectory();
|
|
||||||
if (!empty($license)) return $license;
|
|
||||||
|
|
||||||
// 3. query /terms endpoint (not ACME standard but implemented by let's enrypt)
|
|
||||||
$license=$this->getAgreementURLFromTermsUrl();
|
|
||||||
if (!empty($license)) return $license;
|
|
||||||
|
|
||||||
// Fallback: use latest known license. This is only valid for let's encrypt and should be removed as soon as there is an official
|
|
||||||
// ACME-endpoint to get the current ToS
|
|
||||||
return "https://letsencrypt.org/documents/LE-SA-v1.1.1-August-1-2016.pdf";
|
|
||||||
// return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class Base64UrlSafeEncoder
|
class Base64UrlSafeEncoder
|
||||||
|
|||||||
609
lib/classes/ssl/class.lescript_v2.php
Normal file
609
lib/classes/ssl/class.lescript_v2.php
Normal file
@@ -0,0 +1,609 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// Copyright (c) 2015, Stanislav Humplik <sh@analogic.cz>
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without
|
||||||
|
// modification, are permitted provided that the following conditions are met:
|
||||||
|
// * Redistributions of source code must retain the above copyright
|
||||||
|
// notice, this list of conditions and the following disclaimer.
|
||||||
|
// * Redistributions in binary form must reproduce the above copyright
|
||||||
|
// notice, this list of conditions and the following disclaimer in the
|
||||||
|
// documentation and/or other materials provided with the distribution.
|
||||||
|
// * Neither the name of the <organization> nor the
|
||||||
|
// names of its contributors may be used to endorse or promote products
|
||||||
|
// derived from this software without specific prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
// DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
|
||||||
|
// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
// This file is copied from https://github.com/analogic/lescript
|
||||||
|
// and modified to work without files and integrate in Froxlor
|
||||||
|
class lescript_v2
|
||||||
|
{
|
||||||
|
|
||||||
|
// https://letsencrypt.org/repository/
|
||||||
|
private $logger;
|
||||||
|
|
||||||
|
private $client;
|
||||||
|
|
||||||
|
private $accountKey;
|
||||||
|
|
||||||
|
private $customerid;
|
||||||
|
|
||||||
|
private $isFroxlorVhost;
|
||||||
|
|
||||||
|
private $isLeProduction;
|
||||||
|
|
||||||
|
private $version;
|
||||||
|
|
||||||
|
private $_req_uris = array();
|
||||||
|
|
||||||
|
private $_acc_location = null;
|
||||||
|
|
||||||
|
public function __construct($logger, $version = '2')
|
||||||
|
{
|
||||||
|
$this->logger = $logger;
|
||||||
|
$this->version = $version;
|
||||||
|
if (Settings::Get('system.letsencryptca') == 'production') {
|
||||||
|
$ca = 'https://acme-v02.api.letsencrypt.org';
|
||||||
|
} else {
|
||||||
|
$ca = 'https://acme-staging-v02.api.letsencrypt.org';
|
||||||
|
}
|
||||||
|
$this->client = new Client($ca);
|
||||||
|
$this->log("Using '$ca' to generate certificate");
|
||||||
|
|
||||||
|
// get request-uris from /directory
|
||||||
|
$response = $this->client->get('/directory');
|
||||||
|
$this->_req_uris['newAccount'] = $response['newAccount'];
|
||||||
|
$this->_req_uris['newOrder'] = $response['newOrder'];
|
||||||
|
$this->_req_uris['newNonce'] = $response['newNonce'];
|
||||||
|
$this->_req_uris['revokeCert'] = $response['revokeCert'];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function initAccount($certrow, $isFroxlorVhost = false)
|
||||||
|
{
|
||||||
|
// Let's see if we have the private accountkey
|
||||||
|
$this->accountKey = $certrow['leprivatekey'];
|
||||||
|
$this->customerId = (! $isFroxlorVhost ? $certrow['customerid'] : null);
|
||||||
|
$this->isFroxlorVhost = $isFroxlorVhost;
|
||||||
|
$this->isLeProduction = (Settings::Get('system.letsencryptca') == 'production');
|
||||||
|
$this->_acc_location = $certrow['leaccount'];
|
||||||
|
|
||||||
|
$leregistered = $certrow['leregistered'];
|
||||||
|
|
||||||
|
if (! $this->accountKey || $this->accountKey == 'unset' || ! $this->isLeProduction) {
|
||||||
|
|
||||||
|
// generate and save new private key for account
|
||||||
|
// ---------------------------------------------
|
||||||
|
|
||||||
|
$this->log('Creating new account key');
|
||||||
|
$keys = $this->generateKey();
|
||||||
|
// Only store the accountkey in production, in staging always generate a new key
|
||||||
|
if ($this->isLeProduction) {
|
||||||
|
if ($isFroxlorVhost) {
|
||||||
|
Settings::Set('system.lepublickey', $keys['public']);
|
||||||
|
Settings::Set('system.leprivatekey', $keys['private']);
|
||||||
|
Settings::Set('system.leregistered', 0); // key is not registered
|
||||||
|
} else {
|
||||||
|
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `lepublickey` = :public, `leprivatekey` = :private, `leregistered` = :registered WHERE `customerid` = :customerid;");
|
||||||
|
Database::pexecute($upd_stmt, array(
|
||||||
|
'public' => $keys['public'],
|
||||||
|
'private' => $keys['private'],
|
||||||
|
'registered' => 0,
|
||||||
|
'customerid' => $this->customerId
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$leregistered = 0;
|
||||||
|
$this->accountKey = $keys['private'];
|
||||||
|
} else {
|
||||||
|
$this->log('Using existing account key');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($leregistered == 0) { // Account not registered
|
||||||
|
|
||||||
|
$this->log('Starting new account registration');
|
||||||
|
$response = $this->postNewReg();
|
||||||
|
if ($this->client->getLastCode() == 409) {
|
||||||
|
$this->log('The key was already registered. Using existing account.');
|
||||||
|
} else if ($this->client->getLastCode() == 201) {
|
||||||
|
$this->log('New account registered.');
|
||||||
|
} else {
|
||||||
|
throw new \RuntimeException("Account not initialized, probably due to rate limiting. Whole response: " . json_encode($response));
|
||||||
|
}
|
||||||
|
$this->_acc_location = $this->client->getLastLocation();
|
||||||
|
|
||||||
|
$leregistered = 1;
|
||||||
|
$this->setLeRegisteredState($leregistered);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param array $domains
|
||||||
|
* @param string $domainkey
|
||||||
|
* @param string $csr
|
||||||
|
* optional, same behavior as $reuseCsr from the original class, but we're passing the content of the csr already
|
||||||
|
*
|
||||||
|
* @throws \RuntimeException
|
||||||
|
* @return string[]
|
||||||
|
*/
|
||||||
|
public function signDomains(array $domains, $domainkey = null, $csr = null)
|
||||||
|
{
|
||||||
|
if (! $this->accountKey) {
|
||||||
|
throw new \RuntimeException("Account not initialized");
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->log('Starting certificate generation process for domains');
|
||||||
|
|
||||||
|
$privateAccountKey = openssl_pkey_get_private($this->accountKey);
|
||||||
|
$accountKeyDetails = openssl_pkey_get_details($privateAccountKey);
|
||||||
|
|
||||||
|
// start domains authentication
|
||||||
|
// ----------------------------
|
||||||
|
|
||||||
|
// Prepare order
|
||||||
|
$domains_in_order = array();
|
||||||
|
foreach ($domains as $domain) {
|
||||||
|
$domains_in_order []= array(
|
||||||
|
"type" => "dns",
|
||||||
|
"value" => $domain
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Send new-order request
|
||||||
|
$response = $this->signedRequest($this->_req_uris['newOrder'], array(
|
||||||
|
"identifiers" => $domains_in_order
|
||||||
|
), false);
|
||||||
|
|
||||||
|
if ($this->client->getLastCode() == 403) {
|
||||||
|
$this->log("Got status 403 - setting LE status to unregistered.");
|
||||||
|
$this->_acc_location = '';
|
||||||
|
$this->setLeRegisteredState(0);
|
||||||
|
throw new RuntimeException("Got 'unauthorized' response - we need to re-register at next run. Whole response: " . json_encode($response));
|
||||||
|
}
|
||||||
|
|
||||||
|
// if response is not an array but a string, it's most likely a server-error, e.g.
|
||||||
|
// <HTML><HEAD><TITLE>Error</TITLE></HEAD><BODY>An error occurred while processing your request.
|
||||||
|
// <p>Reference #179.d8be1402.1458059103.3613c4db</BODY></HTML>
|
||||||
|
if (! is_array($response)) {
|
||||||
|
throw new RuntimeException("Invalid response from LE for domain $domain. Whole response: " . json_encode($response));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! array_key_exists('authorizations', $response)) {
|
||||||
|
throw new RuntimeException("No authorizations received for $domain. Whole response: " . json_encode($response));
|
||||||
|
}
|
||||||
|
|
||||||
|
$authorizations = $response['authorizations'];
|
||||||
|
$finalizeLink = $response['finalize'];
|
||||||
|
|
||||||
|
$i = 0;
|
||||||
|
|
||||||
|
foreach ($authorizations as $authorization) {
|
||||||
|
|
||||||
|
// 1. getting available authentication options
|
||||||
|
// -------------------------------------------
|
||||||
|
|
||||||
|
$domain = $response['identifiers'][$i++]['value'];
|
||||||
|
|
||||||
|
$this->log("Requesting challenge for $domain");
|
||||||
|
|
||||||
|
// get authorization
|
||||||
|
$auth_response = $this->client->get($authorization);
|
||||||
|
|
||||||
|
if (! array_key_exists('challenges', $auth_response)) {
|
||||||
|
throw new RuntimeException("No challenges received for $domain. Whole response: " . json_encode($auth_response));
|
||||||
|
}
|
||||||
|
|
||||||
|
// choose http-01 challenge only
|
||||||
|
$challenge = array_reduce($auth_response['challenges'], function ($v, $w) {
|
||||||
|
return $v ? $v : ($w['type'] == 'http-01' ? $w : false);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (! $challenge) {
|
||||||
|
throw new RuntimeException("HTTP Challenge for $domain is not available. Whole response: " . json_encode($response));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->log("Got challenge token for $domain");
|
||||||
|
$location = $challenge['url'];
|
||||||
|
|
||||||
|
// 2. saving authentication token for web verification
|
||||||
|
// ---------------------------------------------------
|
||||||
|
|
||||||
|
$directory = Settings::Get('system.letsencryptchallengepath') . '/.well-known/acme-challenge';
|
||||||
|
$tokenPath = $directory . '/' . $challenge['token'];
|
||||||
|
|
||||||
|
if (! file_exists($directory) && ! @mkdir($directory, 0755, true)) {
|
||||||
|
throw new \RuntimeException("Couldn't create directory to expose challenge: ${tokenPath}");
|
||||||
|
}
|
||||||
|
|
||||||
|
$header = array(
|
||||||
|
// need to be in precise order!
|
||||||
|
"e" => Base64UrlSafeEncoder::encode($accountKeyDetails["rsa"]["e"]),
|
||||||
|
"kty" => "RSA",
|
||||||
|
"n" => Base64UrlSafeEncoder::encode($accountKeyDetails["rsa"]["n"])
|
||||||
|
);
|
||||||
|
$payload = $challenge['token'] . '.' . Base64UrlSafeEncoder::encode(hash('sha256', json_encode($header), true));
|
||||||
|
|
||||||
|
file_put_contents($tokenPath, $payload);
|
||||||
|
chmod($tokenPath, 0644);
|
||||||
|
|
||||||
|
// 3. verification process itself
|
||||||
|
// -------------------------------
|
||||||
|
|
||||||
|
$uri = "http://${domain}/.well-known/acme-challenge/${challenge['token']}";
|
||||||
|
|
||||||
|
$this->log("Token for $domain saved at $tokenPath and should be available at $uri");
|
||||||
|
|
||||||
|
// simple self check
|
||||||
|
if (Settings::Get('system.disable_le_selfcheck') == '0') {
|
||||||
|
$selfcheckpayload = HttpClient::urlGet($uri, false);
|
||||||
|
if ($payload !== trim($selfcheckpayload)) {
|
||||||
|
$errmsg = json_encode(error_get_last());
|
||||||
|
if ($errmsg != "null") {
|
||||||
|
$errmsg = "; PHP error: " . $errmsg;
|
||||||
|
} else {
|
||||||
|
$errmsg = "";
|
||||||
|
}
|
||||||
|
$this->logger->logAction(CRON_ACTION, LOG_WARNING, "[Lets Encrypt self-check] Please check $uri - token seems to be not available. This is just a simple self-check, it might be wrong but consider using this information when Let's Encrypt fails to issue a certificate" . $errmsg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->log("Sending request to challenge");
|
||||||
|
|
||||||
|
// send request to challenge
|
||||||
|
$result = $this->signedRequest($challenge['url'], array(
|
||||||
|
"type" => "http-01",
|
||||||
|
"keyAuthorization" => $payload,
|
||||||
|
"token" => $challenge['token']
|
||||||
|
), false);
|
||||||
|
|
||||||
|
// waiting loop
|
||||||
|
// we wait for a maximum of 30 seconds to avoid endless loops
|
||||||
|
$count = 0;
|
||||||
|
do {
|
||||||
|
if (empty($result['status']) || $result['status'] == "invalid") {
|
||||||
|
@unlink($tokenPath);
|
||||||
|
throw new \RuntimeException("Verification ended with error: " . json_encode($result));
|
||||||
|
}
|
||||||
|
$ended = ! ($result['status'] === "pending" || $result['status'] === "processing");
|
||||||
|
|
||||||
|
if (! $ended) {
|
||||||
|
$this->log("Verification " . $result['status'] . ", sleeping 1s");
|
||||||
|
sleep(1);
|
||||||
|
$count ++;
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = $this->client->get($location);
|
||||||
|
} while (! $ended && $count < 30);
|
||||||
|
|
||||||
|
$this->log("Verification ended with status: ${result['status']}");
|
||||||
|
@unlink($tokenPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
// requesting certificate
|
||||||
|
// ----------------------
|
||||||
|
|
||||||
|
// generate private key for domain if not exist
|
||||||
|
if (empty($domainkey) || Settings::Get('system.letsencryptreuseold') == 0) {
|
||||||
|
$keys = $this->generateKey();
|
||||||
|
$domainkey = $keys['private'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// load domain key
|
||||||
|
$privateDomainKey = openssl_pkey_get_private($domainkey);
|
||||||
|
|
||||||
|
if (empty($csr)) {
|
||||||
|
$csr = $this->generateCSR($privateDomainKey, $domains);
|
||||||
|
}
|
||||||
|
|
||||||
|
// request certificates creation
|
||||||
|
$result = $this->signedRequest($finalizeLink, array(
|
||||||
|
'csr' => $csr
|
||||||
|
), false);
|
||||||
|
if ($this->client->getLastCode() !== 200) {
|
||||||
|
throw new \RuntimeException("Invalid response code: " . $this->client->getLastCode() . ", " . json_encode($result));
|
||||||
|
}
|
||||||
|
if (! isset($result['certificate'])) {
|
||||||
|
throw new \RuntimeException("No certificate URL specified in result");
|
||||||
|
}
|
||||||
|
|
||||||
|
$certificates = array();
|
||||||
|
$certdata = $this->client->get($result['certificate']);
|
||||||
|
$this->log("Got certificate! YAY!");
|
||||||
|
$certificates[] = $certdata;
|
||||||
|
foreach ($this->client->getLastLinks() as $link) {
|
||||||
|
$this->log("Requesting chained cert at $link");
|
||||||
|
$result = $this->client->get($link);
|
||||||
|
$certificates[] = $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($certificates))
|
||||||
|
throw new \RuntimeException('No certificates generated');
|
||||||
|
|
||||||
|
$fullchain = implode("\n", $certificates);
|
||||||
|
$crt = array_shift($certificates);
|
||||||
|
$chain = implode("\n", $certificates);
|
||||||
|
|
||||||
|
$this->log("Done, returning new certificates and key");
|
||||||
|
return array(
|
||||||
|
'fullchain' => $fullchain,
|
||||||
|
'crt' => $crt,
|
||||||
|
'chain' => $chain,
|
||||||
|
'key' => $domainkey,
|
||||||
|
'csr' => $csr
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function setLeRegisteredState($state)
|
||||||
|
{
|
||||||
|
if ($this->isLeProduction) {
|
||||||
|
if ($this->isFroxlorVhost) {
|
||||||
|
Settings::Set('system.leregistered', $state);
|
||||||
|
Settings::Set('system.leaccount', $this->_acc_location);
|
||||||
|
} else {
|
||||||
|
$upd_stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "` SET `leregistered` = :registered, `leaccount` = :kid WHERE `customerid` = :customerid;");
|
||||||
|
Database::pexecute($upd_stmt, array(
|
||||||
|
'registered' => $state,
|
||||||
|
'kid' => $this->_acc_location,
|
||||||
|
'customerid' => $this->customerId
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function parsePemFromBody($body)
|
||||||
|
{
|
||||||
|
$pem = chunk_split(base64_encode($body), 64, "\n");
|
||||||
|
return "-----BEGIN CERTIFICATE-----\n" . $pem . "-----END CERTIFICATE-----\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
private function postNewReg()
|
||||||
|
{
|
||||||
|
$this->log('Getting last terms of service URL');
|
||||||
|
$directory = $this->client->get('/directory');
|
||||||
|
if (! isset($directory['meta']) || ! isset($directory['meta']['termsOfService'])) {
|
||||||
|
throw new \RuntimeException("No terms of service link available!");
|
||||||
|
}
|
||||||
|
$this->log('Sending registration to letsencrypt server');
|
||||||
|
|
||||||
|
return $this->signedRequest($this->_req_uris['newAccount'], array(
|
||||||
|
'termsOfServiceAgreed' => true
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
private function generateCSR($privateKey, array $domains)
|
||||||
|
{
|
||||||
|
$domain = reset($domains);
|
||||||
|
$san = implode(",", array_map(function ($dns) {
|
||||||
|
return "DNS:" . $dns;
|
||||||
|
}, $domains));
|
||||||
|
$tmpConf = tmpfile();
|
||||||
|
$tmpConfMeta = stream_get_meta_data($tmpConf);
|
||||||
|
$tmpConfPath = $tmpConfMeta["uri"];
|
||||||
|
|
||||||
|
// workaround to get SAN working
|
||||||
|
fwrite($tmpConf, 'HOME = .
|
||||||
|
RANDFILE = $ENV::HOME/.rnd
|
||||||
|
[ req ]
|
||||||
|
default_bits = ' . Settings::Get('system.letsencryptkeysize') . '
|
||||||
|
default_keyfile = privkey.pem
|
||||||
|
distinguished_name = req_distinguished_name
|
||||||
|
req_extensions = v3_req
|
||||||
|
[ req_distinguished_name ]
|
||||||
|
countryName = Country Name (2 letter code)
|
||||||
|
[ v3_req ]
|
||||||
|
basicConstraints = CA:FALSE
|
||||||
|
subjectAltName = ' . $san . '
|
||||||
|
keyUsage = nonRepudiation, digitalSignature, keyEncipherment');
|
||||||
|
|
||||||
|
$csr = openssl_csr_new(array(
|
||||||
|
"CN" => $domain,
|
||||||
|
"ST" => Settings::Get('system.letsencryptstate'),
|
||||||
|
"C" => Settings::Get('system.letsencryptcountrycode'),
|
||||||
|
"O" => "Unknown"
|
||||||
|
), $privateKey, array(
|
||||||
|
"config" => $tmpConfPath,
|
||||||
|
"digest_alg" => "sha256"
|
||||||
|
));
|
||||||
|
|
||||||
|
if (! $csr)
|
||||||
|
throw new \RuntimeException("CSR couldn't be generated! " . openssl_error_string());
|
||||||
|
|
||||||
|
openssl_csr_export($csr, $csr);
|
||||||
|
fclose($tmpConf);
|
||||||
|
|
||||||
|
preg_match('~REQUEST-----(.*)-----END~s', $csr, $matches);
|
||||||
|
|
||||||
|
return trim(Base64UrlSafeEncoder::encode(base64_decode($matches[1])));
|
||||||
|
}
|
||||||
|
|
||||||
|
private function generateKey()
|
||||||
|
{
|
||||||
|
$res = openssl_pkey_new(array(
|
||||||
|
"private_key_type" => OPENSSL_KEYTYPE_RSA,
|
||||||
|
"private_key_bits" => (int) Settings::Get('system.letsencryptkeysize')
|
||||||
|
));
|
||||||
|
|
||||||
|
if (! openssl_pkey_export($res, $privateKey)) {
|
||||||
|
throw new \RuntimeException("Key export failed!");
|
||||||
|
}
|
||||||
|
|
||||||
|
$details = openssl_pkey_get_details($res);
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'private' => $privateKey,
|
||||||
|
'public' => $details['key']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function signedRequest($uri, array $payload, $needs_jwk = true)
|
||||||
|
{
|
||||||
|
$privateKey = openssl_pkey_get_private($this->accountKey);
|
||||||
|
$details = openssl_pkey_get_details($privateKey);
|
||||||
|
|
||||||
|
$header = array(
|
||||||
|
"alg" => "RS256"
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($needs_jwk) {
|
||||||
|
$header["jwk"] = array(
|
||||||
|
"kty" => "RSA",
|
||||||
|
"n" => Base64UrlSafeEncoder::encode($details["rsa"]["n"]),
|
||||||
|
"e" => Base64UrlSafeEncoder::encode($details["rsa"]["e"])
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
// need account-url
|
||||||
|
$header["kid"] = $this->_acc_location;
|
||||||
|
}
|
||||||
|
|
||||||
|
$protected = $header;
|
||||||
|
$protected["nonce"] = $this->client->getLastNonce();
|
||||||
|
$protected["url"] = $uri;
|
||||||
|
|
||||||
|
$payload64 = Base64UrlSafeEncoder::encode(json_encode($payload, JSON_UNESCAPED_SLASHES));
|
||||||
|
$protected64 = Base64UrlSafeEncoder::encode(json_encode($protected));
|
||||||
|
|
||||||
|
openssl_sign($protected64 . '.' . $payload64, $signed, $privateKey, "SHA256");
|
||||||
|
|
||||||
|
$signed64 = Base64UrlSafeEncoder::encode($signed);
|
||||||
|
|
||||||
|
$data = array(
|
||||||
|
'protected' => $protected64,
|
||||||
|
'payload' => $payload64,
|
||||||
|
'signature' => $signed64
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->log("Sending signed request to $uri");
|
||||||
|
return $this->client->post($uri, json_encode($data));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function log($message)
|
||||||
|
{
|
||||||
|
$this->logger->logAction(CRON_ACTION, LOG_INFO, "letsencrypt-v2 " . $message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Client
|
||||||
|
{
|
||||||
|
|
||||||
|
private $lastCode;
|
||||||
|
|
||||||
|
public $lastHeader;
|
||||||
|
|
||||||
|
private $base;
|
||||||
|
|
||||||
|
public function __construct($base)
|
||||||
|
{
|
||||||
|
$this->base = $base;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function curl($method, $url, $data = null)
|
||||||
|
{
|
||||||
|
$headers = array(
|
||||||
|
'Accept: application/jose+json',
|
||||||
|
'Content-Type: application/jose+json'
|
||||||
|
);
|
||||||
|
$handle = curl_init();
|
||||||
|
curl_setopt($handle, CURLOPT_URL, preg_match('~^http~', $url) ? $url : $this->base . $url);
|
||||||
|
curl_setopt($handle, CURLOPT_HTTPHEADER, $headers);
|
||||||
|
curl_setopt($handle, CURLOPT_RETURNTRANSFER, true);
|
||||||
|
curl_setopt($handle, CURLOPT_HEADER, true);
|
||||||
|
|
||||||
|
// DO NOT DO THAT!
|
||||||
|
// curl_setopt($handle, CURLOPT_SSL_VERIFYHOST, false);
|
||||||
|
// curl_setopt($handle, CURLOPT_SSL_VERIFYPEER, false);
|
||||||
|
|
||||||
|
switch ($method) {
|
||||||
|
case 'GET':
|
||||||
|
break;
|
||||||
|
case 'POST':
|
||||||
|
curl_setopt($handle, CURLOPT_POST, true);
|
||||||
|
curl_setopt($handle, CURLOPT_POSTFIELDS, $data);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$response = curl_exec($handle);
|
||||||
|
|
||||||
|
if (curl_errno($handle)) {
|
||||||
|
throw new \RuntimeException('Curl: ' . curl_error($handle));
|
||||||
|
}
|
||||||
|
|
||||||
|
$header_size = curl_getinfo($handle, CURLINFO_HEADER_SIZE);
|
||||||
|
|
||||||
|
$header = substr($response, 0, $header_size);
|
||||||
|
$body = substr($response, $header_size);
|
||||||
|
|
||||||
|
$this->lastHeader = $header;
|
||||||
|
$this->lastCode = curl_getinfo($handle, CURLINFO_HTTP_CODE);
|
||||||
|
|
||||||
|
$data = json_decode($body, true);
|
||||||
|
return $data === null ? $body : $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function post($url, $data)
|
||||||
|
{
|
||||||
|
return $this->curl('POST', $url, $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get($url)
|
||||||
|
{
|
||||||
|
return $this->curl('GET', $url);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLastNonce()
|
||||||
|
{
|
||||||
|
if (preg_match('~Replay\-Nonce: (.+)~i', $this->lastHeader, $matches)) {
|
||||||
|
return trim($matches[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->curl('GET', '/acme/new-nonce');
|
||||||
|
return $this->getLastNonce();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLastLocation()
|
||||||
|
{
|
||||||
|
if (preg_match('~Location: (.+)~i', $this->lastHeader, $matches)) {
|
||||||
|
return trim($matches[1]);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLastCode()
|
||||||
|
{
|
||||||
|
return $this->lastCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLastLinks()
|
||||||
|
{
|
||||||
|
preg_match_all('~Link: <(.+)>;rel="up"~', $this->lastHeader, $matches);
|
||||||
|
return $matches[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Base64UrlSafeEncoder
|
||||||
|
{
|
||||||
|
|
||||||
|
public static function encode($input)
|
||||||
|
{
|
||||||
|
return str_replace('=', '', strtr(base64_encode($input), '+/', '-_'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function decode($input)
|
||||||
|
{
|
||||||
|
$remainder = strlen($input) % 4;
|
||||||
|
if ($remainder) {
|
||||||
|
$padlen = 4 - $remainder;
|
||||||
|
$input .= str_repeat('=', $padlen);
|
||||||
|
}
|
||||||
|
return base64_decode(strtr($input, '-_', '+/'));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -19,46 +19,53 @@
|
|||||||
*
|
*
|
||||||
* Support Tickets - Tickets-Class
|
* Support Tickets - Tickets-Class
|
||||||
*/
|
*/
|
||||||
|
class ticket
|
||||||
class ticket {
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Userinfo
|
* Userinfo
|
||||||
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private $userinfo = array();
|
private $userinfo = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ticket ID
|
* Ticket ID
|
||||||
* @var tid
|
*
|
||||||
|
* @var int
|
||||||
*/
|
*/
|
||||||
private $tid = - 1;
|
private $tid = - 1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ticket Data Array
|
* Ticket Data Array
|
||||||
* @var t_data
|
*
|
||||||
|
* @var array
|
||||||
*/
|
*/
|
||||||
private $t_data = array();
|
private $t_data = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ticket-Object-Array
|
* Ticket-Object-Array
|
||||||
* @var tickets
|
*
|
||||||
|
* @var ticket[]
|
||||||
*/
|
*/
|
||||||
static private $tickets = array();
|
private static $tickets = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class constructor.
|
* Class constructor.
|
||||||
*
|
*
|
||||||
* @param array userinfo
|
* @param
|
||||||
* @param int ticket id
|
* array userinfo
|
||||||
|
* @param
|
||||||
|
* int ticket id
|
||||||
*/
|
*/
|
||||||
private function __construct($userinfo, $tid = - 1) {
|
private function __construct($userinfo, $tid = - 1)
|
||||||
|
{
|
||||||
$this->userinfo = $userinfo;
|
$this->userinfo = $userinfo;
|
||||||
$this->tid = $tid;
|
$this->tid = $tid;
|
||||||
|
|
||||||
// initialize data array
|
// initialize data array
|
||||||
$this->initData();
|
$this->initData();
|
||||||
|
|
||||||
// read data from database
|
// read data from database
|
||||||
$this->readData();
|
$this->readData();
|
||||||
}
|
}
|
||||||
@@ -66,21 +73,24 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Singleton ftw ;-)
|
* Singleton ftw ;-)
|
||||||
*
|
*
|
||||||
* @param array userinfo
|
* @param
|
||||||
* @param int ticket id
|
* array userinfo
|
||||||
|
* @param
|
||||||
|
* int ticket id
|
||||||
*/
|
*/
|
||||||
static public function getInstanceOf($_usernfo, $_tid) {
|
static public function getInstanceOf($_usernfo, $_tid)
|
||||||
if (!isset(self::$tickets[$_tid])) {
|
{
|
||||||
self::$tickets[$_tid] = new ticket($_usernfo, $_tid);
|
if (! isset(self::$tickets[$_tid . '-' . $_usernfo['userid']])) {
|
||||||
|
self::$tickets[$_tid . '-' . $_usernfo['userid']] = new ticket($_usernfo, $_tid);
|
||||||
}
|
}
|
||||||
return self::$tickets[$_tid];
|
return self::$tickets[$_tid . '-' . $_usernfo['userid']];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize data-array
|
* Initialize data-array
|
||||||
*/
|
*/
|
||||||
private function initData() {
|
private function initData()
|
||||||
|
{
|
||||||
$this->Set('customer', 0, true, true);
|
$this->Set('customer', 0, true, true);
|
||||||
$this->Set('admin', 1, true, true);
|
$this->Set('admin', 1, true, true);
|
||||||
$this->Set('subject', '', true, true);
|
$this->Set('subject', '', true, true);
|
||||||
@@ -100,16 +110,33 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Read ticket data from database.
|
* Read ticket data from database.
|
||||||
*/
|
*/
|
||||||
private function readData() {
|
private function readData()
|
||||||
|
{
|
||||||
if (isset($this->tid)
|
if (isset($this->tid) && $this->tid != - 1) {
|
||||||
&& $this->tid != - 1
|
|
||||||
) {
|
if ($this->userinfo['customerid'] > 0) {
|
||||||
$_ticket_stmt = Database::prepare('
|
$_ticket_stmt = Database::prepare('
|
||||||
SELECT * FROM `' . TABLE_PANEL_TICKETS . '` WHERE `id` = :tid'
|
SELECT * FROM `' . TABLE_PANEL_TICKETS . '` WHERE `id` = :tid AND `customerid` = :cid');
|
||||||
);
|
$tdata = array(
|
||||||
$_ticket = Database::pexecute_first($_ticket_stmt, array('tid' => $this->tid));
|
'tid' => $this->tid,
|
||||||
|
'cid' => $this->userinfo['customerid']
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$_ticket_stmt = Database::prepare('
|
||||||
|
SELECT * FROM `' . TABLE_PANEL_TICKETS . '` WHERE `id` = :tid' . ($this->userinfo['customers_see_all'] ? '' : ' AND `adminid` = :adminid'));
|
||||||
|
$tdata = array(
|
||||||
|
'tid' => $this->tid
|
||||||
|
);
|
||||||
|
if ($this->userinfo['customers_see_all'] != '1') {
|
||||||
|
$tdata['adminid'] = $this->userinfo['adminid'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$_ticket = Database::pexecute_first($_ticket_stmt, $tdata);
|
||||||
|
|
||||||
|
if ($_ticket == false) {
|
||||||
|
throw new Exception("Invalid ticket id");
|
||||||
|
}
|
||||||
|
|
||||||
$this->Set('customer', $_ticket['customerid'], true, false);
|
$this->Set('customer', $_ticket['customerid'], true, false);
|
||||||
$this->Set('admin', $_ticket['adminid'], true, false);
|
$this->Set('admin', $_ticket['adminid'], true, false);
|
||||||
$this->Set('subject', $_ticket['subject'], true, false);
|
$this->Set('subject', $_ticket['subject'], true, false);
|
||||||
@@ -130,8 +157,8 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Insert data to database
|
* Insert data to database
|
||||||
*/
|
*/
|
||||||
public function Insert() {
|
public function Insert()
|
||||||
|
{
|
||||||
$ins_stmt = Database::prepare("
|
$ins_stmt = Database::prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_TICKETS . "` SET
|
INSERT INTO `" . TABLE_PANEL_TICKETS . "` SET
|
||||||
`customerid` = :customerid,
|
`customerid` = :customerid,
|
||||||
@@ -146,8 +173,7 @@ class ticket {
|
|||||||
`status` = :status,
|
`status` = :status,
|
||||||
`lastreplier` = :lastreplier,
|
`lastreplier` = :lastreplier,
|
||||||
`by` = :by,
|
`by` = :by,
|
||||||
`answerto` = :answerto"
|
`answerto` = :answerto");
|
||||||
);
|
|
||||||
$ins_data = array(
|
$ins_data = array(
|
||||||
'customerid' => $this->Get('customer'),
|
'customerid' => $this->Get('customer'),
|
||||||
'adminid' => $this->Get('admin'),
|
'adminid' => $this->Get('admin'),
|
||||||
@@ -171,8 +197,9 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Update data in database
|
* Update data in database
|
||||||
*/
|
*/
|
||||||
public function Update() {
|
public function Update()
|
||||||
|
{
|
||||||
|
|
||||||
// Update "main" ticket
|
// Update "main" ticket
|
||||||
$upd_stmt = Database::prepare('
|
$upd_stmt = Database::prepare('
|
||||||
UPDATE `' . TABLE_PANEL_TICKETS . '` SET
|
UPDATE `' . TABLE_PANEL_TICKETS . '` SET
|
||||||
@@ -180,8 +207,7 @@ class ticket {
|
|||||||
`lastchange` = :lastchange,
|
`lastchange` = :lastchange,
|
||||||
`status` = :status,
|
`status` = :status,
|
||||||
`lastreplier` = :lastreplier
|
`lastreplier` = :lastreplier
|
||||||
WHERE `id` = :tid'
|
WHERE `id` = :tid');
|
||||||
);
|
|
||||||
$upd_data = array(
|
$upd_data = array(
|
||||||
'priority' => $this->Get('priority'),
|
'priority' => $this->Get('priority'),
|
||||||
'lastchange' => $this->Get('lastchange'),
|
'lastchange' => $this->Get('lastchange'),
|
||||||
@@ -196,38 +222,44 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Moves a ticket to the archive
|
* Moves a ticket to the archive
|
||||||
*/
|
*/
|
||||||
public function Archive() {
|
public function Archive()
|
||||||
|
{
|
||||||
|
|
||||||
// Update "main" ticket
|
// Update "main" ticket
|
||||||
$upd_stmt = Database::prepare('
|
$upd_stmt = Database::prepare('
|
||||||
UPDATE `' . TABLE_PANEL_TICKETS . '` SET `archived` = "1" WHERE `id` = :tid'
|
UPDATE `' . TABLE_PANEL_TICKETS . '` SET `archived` = "1" WHERE `id` = :tid');
|
||||||
);
|
Database::pexecute($upd_stmt, array(
|
||||||
Database::pexecute($upd_stmt, array('tid' => $this->tid));
|
'tid' => $this->tid
|
||||||
|
));
|
||||||
|
|
||||||
// Update "answers" to ticket
|
// Update "answers" to ticket
|
||||||
$upd_stmt = Database::prepare('
|
$upd_stmt = Database::prepare('
|
||||||
UPDATE `' . TABLE_PANEL_TICKETS . '` SET `archived` = "1" WHERE `answerto` = :tid'
|
UPDATE `' . TABLE_PANEL_TICKETS . '` SET `archived` = "1" WHERE `answerto` = :tid');
|
||||||
);
|
Database::pexecute($upd_stmt, array(
|
||||||
Database::pexecute($upd_stmt, array('tid' => $this->tid));
|
'tid' => $this->tid
|
||||||
|
));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove ticket from database
|
* Remove ticket from database
|
||||||
*/
|
*/
|
||||||
public function Delete() {
|
public function Delete()
|
||||||
|
{
|
||||||
|
|
||||||
// Delete "main" ticket
|
// Delete "main" ticket
|
||||||
$del_stmt = Database::prepare('
|
$del_stmt = Database::prepare('
|
||||||
DELETE FROM `' . TABLE_PANEL_TICKETS . '` WHERE `id` = :tid'
|
DELETE FROM `' . TABLE_PANEL_TICKETS . '` WHERE `id` = :tid');
|
||||||
);
|
Database::pexecute($del_stmt, array(
|
||||||
Database::pexecute($del_stmt, array('tid' => $this->tid));
|
'tid' => $this->tid
|
||||||
|
));
|
||||||
|
|
||||||
// Delete "answers" to ticket"
|
// Delete "answers" to ticket"
|
||||||
$del_stmt = Database::prepare('
|
$del_stmt = Database::prepare('
|
||||||
DELETE FROM `' . TABLE_PANEL_TICKETS . '` WHERE `answerto` = :tid'
|
DELETE FROM `' . TABLE_PANEL_TICKETS . '` WHERE `answerto` = :tid');
|
||||||
);
|
Database::pexecute($del_stmt, array(
|
||||||
Database::pexecute($del_stmt, array('tid' => $this->tid));
|
'tid' => $this->tid
|
||||||
|
));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -237,16 +269,17 @@ class ticket {
|
|||||||
public function sendMail($customerid = - 1, $template_subject = null, $default_subject = null, $template_body = null, $default_body = null)
|
public function sendMail($customerid = - 1, $template_subject = null, $default_subject = null, $template_body = null, $default_body = null)
|
||||||
{
|
{
|
||||||
global $mail, $theme;
|
global $mail, $theme;
|
||||||
|
|
||||||
// Some checks are to be made here in the future
|
// Some checks are to be made here in the future
|
||||||
if ($customerid != - 1) {
|
if ($customerid != - 1) {
|
||||||
// Get e-mail message for customer
|
// Get e-mail message for customer
|
||||||
$usr_stmt = Database::prepare('
|
$usr_stmt = Database::prepare('
|
||||||
SELECT `name`, `firstname`, `company`, `email`
|
SELECT `name`, `firstname`, `company`, `email`
|
||||||
FROM `' . TABLE_PANEL_CUSTOMERS . '` WHERE `customerid` = :customerid'
|
FROM `' . TABLE_PANEL_CUSTOMERS . '` WHERE `customerid` = :customerid');
|
||||||
);
|
$usr = Database::pexecute_first($usr_stmt, array(
|
||||||
$usr = Database::pexecute_first($usr_stmt, array('customerid' => $customerid));
|
'customerid' => $customerid
|
||||||
|
));
|
||||||
|
|
||||||
$replace_arr = array(
|
$replace_arr = array(
|
||||||
'FIRSTNAME' => $usr['firstname'],
|
'FIRSTNAME' => $usr['firstname'],
|
||||||
'NAME' => $usr['name'],
|
'NAME' => $usr['name'],
|
||||||
@@ -268,23 +301,21 @@ class ticket {
|
|||||||
SELECT `value` FROM `" . TABLE_PANEL_TEMPLATES . "`
|
SELECT `value` FROM `" . TABLE_PANEL_TEMPLATES . "`
|
||||||
WHERE `adminid`= :adminid
|
WHERE `adminid`= :adminid
|
||||||
AND `language`= :lang
|
AND `language`= :lang
|
||||||
AND `templategroup`= 'mails' AND `varname`= :tplsubject"
|
AND `templategroup`= 'mails' AND `varname`= :tplsubject");
|
||||||
);
|
|
||||||
$result = Database::pexecute_first($result_stmt, $tpl_seldata);
|
$result = Database::pexecute_first($result_stmt, $tpl_seldata);
|
||||||
$mail_subject = html_entity_decode(replace_variables((($result['value'] != '') ? $result['value'] : $default_subject), $replace_arr));
|
$mail_subject = html_entity_decode(replace_variables((($result['value'] != '') ? $result['value'] : $default_subject), $replace_arr));
|
||||||
|
|
||||||
unset($tpl_seldata['tplsubject']);
|
unset($tpl_seldata['tplsubject']);
|
||||||
$tpl_seldata['tplmailbody'] = $template_body;
|
$tpl_seldata['tplmailbody'] = $template_body;
|
||||||
|
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT `value` FROM `" . TABLE_PANEL_TEMPLATES . "`
|
SELECT `value` FROM `" . TABLE_PANEL_TEMPLATES . "`
|
||||||
WHERE `adminid`= :adminid
|
WHERE `adminid`= :adminid
|
||||||
AND `language`= :lang
|
AND `language`= :lang
|
||||||
AND `templategroup`= 'mails' AND `varname`= :tplmailbody"
|
AND `templategroup`= 'mails' AND `varname`= :tplmailbody");
|
||||||
);
|
|
||||||
$result = Database::pexecute_first($result_stmt, $tpl_seldata);
|
$result = Database::pexecute_first($result_stmt, $tpl_seldata);
|
||||||
$mail_body = html_entity_decode(replace_variables((($result['value'] != '') ? $result['value'] : $default_body), $replace_arr));
|
$mail_body = html_entity_decode(replace_variables((($result['value'] != '') ? $result['value'] : $default_body), $replace_arr));
|
||||||
|
|
||||||
if ($customerid != - 1) {
|
if ($customerid != - 1) {
|
||||||
$_mailerror = false;
|
$_mailerror = false;
|
||||||
try {
|
try {
|
||||||
@@ -294,28 +325,30 @@ class ticket {
|
|||||||
$mail->MsgHTML(str_replace("\n", "<br />", $mail_body));
|
$mail->MsgHTML(str_replace("\n", "<br />", $mail_body));
|
||||||
$mail->AddAddress($usr['email'], $usr['firstname'] . ' ' . $usr['name']);
|
$mail->AddAddress($usr['email'], $usr['firstname'] . ' ' . $usr['name']);
|
||||||
$mail->Send();
|
$mail->Send();
|
||||||
} catch(phpmailerException $e) {
|
} catch (phpmailerException $e) {
|
||||||
$mailerr_msg = $e->errorMessage();
|
$mailerr_msg = $e->errorMessage();
|
||||||
$_mailerror = true;
|
$_mailerror = true;
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
$mailerr_msg = $e->getMessage();
|
$mailerr_msg = $e->getMessage();
|
||||||
$_mailerror = true;
|
$_mailerror = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_mailerror) {
|
if ($_mailerror) {
|
||||||
$rstlog = FroxlorLogger::getInstanceOf(array('loginname' => 'ticket_class'));
|
$rstlog = FroxlorLogger::getInstanceOf(array(
|
||||||
|
'loginname' => 'ticket_class'
|
||||||
|
));
|
||||||
$rstlog->logAction(ADM_ACTION, LOG_ERR, "Error sending mail: " . $mailerr_msg);
|
$rstlog->logAction(ADM_ACTION, LOG_ERR, "Error sending mail: " . $mailerr_msg);
|
||||||
standard_error('errorsendingmail', $usr['email']);
|
standard_error('errorsendingmail', $usr['email']);
|
||||||
}
|
}
|
||||||
$mail->ClearAddresses();
|
$mail->ClearAddresses();
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$admin_stmt = Database::prepare("
|
$admin_stmt = Database::prepare("
|
||||||
SELECT `name`, `email` FROM `" . TABLE_PANEL_ADMINS . "`
|
SELECT `name`, `email` FROM `" . TABLE_PANEL_ADMINS . "`
|
||||||
WHERE `adminid` = :adminid"
|
WHERE `adminid` = :adminid");
|
||||||
);
|
$admin = Database::pexecute_first($admin_stmt, array(
|
||||||
$admin = Database::pexecute_first($admin_stmt, array('adminid' => $this->userinfo['adminid']));
|
'adminid' => $this->userinfo['adminid']
|
||||||
|
));
|
||||||
$_mailerror = false;
|
$_mailerror = false;
|
||||||
try {
|
try {
|
||||||
$mail->SetFrom(Settings::Get('ticket.noreply_email'), Settings::Get('ticket.noreply_name'));
|
$mail->SetFrom(Settings::Get('ticket.noreply_email'), Settings::Get('ticket.noreply_name'));
|
||||||
@@ -324,20 +357,22 @@ class ticket {
|
|||||||
$mail->MsgHTML(str_replace("\n", "<br />", $mail_body));
|
$mail->MsgHTML(str_replace("\n", "<br />", $mail_body));
|
||||||
$mail->AddAddress($admin['email'], $admin['name']);
|
$mail->AddAddress($admin['email'], $admin['name']);
|
||||||
$mail->Send();
|
$mail->Send();
|
||||||
} catch(phpmailerException $e) {
|
} catch (phpmailerException $e) {
|
||||||
$mailerr_msg = $e->errorMessage();
|
$mailerr_msg = $e->errorMessage();
|
||||||
$_mailerror = true;
|
$_mailerror = true;
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
$mailerr_msg = $e->getMessage();
|
$mailerr_msg = $e->getMessage();
|
||||||
$_mailerror = true;
|
$_mailerror = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_mailerror) {
|
if ($_mailerror) {
|
||||||
$rstlog = FroxlorLogger::getInstanceOf(array('loginname' => 'ticket_class'));
|
$rstlog = FroxlorLogger::getInstanceOf(array(
|
||||||
|
'loginname' => 'ticket_class'
|
||||||
|
));
|
||||||
$rstlog->logAction(ADM_ACTION, LOG_ERR, "Error sending mail: " . $mailerr_msg);
|
$rstlog->logAction(ADM_ACTION, LOG_ERR, "Error sending mail: " . $mailerr_msg);
|
||||||
standard_error('errorsendingmail', $admin['email']);
|
standard_error('errorsendingmail', $admin['email']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$mail->ClearAddresses();
|
$mail->ClearAddresses();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -345,21 +380,18 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Add a support-categories
|
* Add a support-categories
|
||||||
*/
|
*/
|
||||||
static public function addCategory($_category = null, $_admin = 1, $_order = 1) {
|
static public function addCategory($_category = null, $_admin = 1, $_order = 1)
|
||||||
|
{
|
||||||
if ($_category != null
|
if ($_category != null && $_category != '') {
|
||||||
&& $_category != ''
|
|
||||||
) {
|
|
||||||
if ($_order < 1) {
|
if ($_order < 1) {
|
||||||
$_order = 1;
|
$_order = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$ins_stmt = Database::prepare("
|
$ins_stmt = Database::prepare("
|
||||||
INSERT INTO `" . TABLE_PANEL_TICKET_CATS . "` SET
|
INSERT INTO `" . TABLE_PANEL_TICKET_CATS . "` SET
|
||||||
`name` = :name,
|
`name` = :name,
|
||||||
`adminid` = :adminid,
|
`adminid` = :adminid,
|
||||||
`logicalorder` = :lo"
|
`logicalorder` = :lo");
|
||||||
);
|
|
||||||
$ins_data = array(
|
$ins_data = array(
|
||||||
'name' => $_category,
|
'name' => $_category,
|
||||||
'adminid' => $_admin,
|
'adminid' => $_admin,
|
||||||
@@ -374,23 +406,24 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Edit a support-categories
|
* Edit a support-categories
|
||||||
*/
|
*/
|
||||||
static public function editCategory($_category = null, $_id = 0, $_order = 1) {
|
static public function editCategory($_category = null, $_id = 0, $_order = 1)
|
||||||
|
{
|
||||||
if ($_category != null
|
if ($_category != null && $_category != '' && $_id != 0) {
|
||||||
&& $_category != ''
|
|
||||||
&& $_id != 0
|
|
||||||
) {
|
|
||||||
if ($_order < 1) {
|
if ($_order < 1) {
|
||||||
$_order = 1;
|
$_order = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$upd_stmt = Database::prepare("
|
$upd_stmt = Database::prepare("
|
||||||
UPDATE `" . TABLE_PANEL_TICKET_CATS . "` SET
|
UPDATE `" . TABLE_PANEL_TICKET_CATS . "` SET
|
||||||
`name` = :name,
|
`name` = :name,
|
||||||
`logicalorder` = :lo
|
`logicalorder` = :lo
|
||||||
WHERE `id` = :id
|
WHERE `id` = :id
|
||||||
");
|
");
|
||||||
Database::pexecute($upd_stmt, array('name' => $_category, 'lo' => $_order, 'id' => $_id));
|
Database::pexecute($upd_stmt, array(
|
||||||
|
'name' => $_category,
|
||||||
|
'lo' => $_order,
|
||||||
|
'id' => $_id
|
||||||
|
));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@@ -399,40 +432,43 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Delete a support-categories
|
* Delete a support-categories
|
||||||
*/
|
*/
|
||||||
static public function deleteCategory($_id = 0) {
|
static public function deleteCategory($_id = 0)
|
||||||
|
{
|
||||||
if ($_id != 0) {
|
if ($_id != 0) {
|
||||||
|
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT COUNT(`id`) as `numtickets` FROM `" . TABLE_PANEL_TICKETS . "`
|
SELECT COUNT(`id`) as `numtickets` FROM `" . TABLE_PANEL_TICKETS . "`
|
||||||
WHERE `category` = :cat"
|
WHERE `category` = :cat");
|
||||||
);
|
$result = Database::pexecute_first($result_stmt, array(
|
||||||
$result = Database::pexecute_first($result_stmt, array('cat' => $_id));
|
'cat' => $_id
|
||||||
|
));
|
||||||
|
|
||||||
if ($result['numtickets'] == "0") {
|
if ($result['numtickets'] == "0") {
|
||||||
$del_stmt = Database::prepare("
|
$del_stmt = Database::prepare("
|
||||||
DELETE FROM `" . TABLE_PANEL_TICKET_CATS . "` WHERE `id` = :id"
|
DELETE FROM `" . TABLE_PANEL_TICKET_CATS . "` WHERE `id` = :id");
|
||||||
);
|
Database::pexecute($del_stmt, array(
|
||||||
Database::pexecute($del_stmt, array('id' => $_id));
|
'id' => $_id
|
||||||
|
));
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return a support-category-name
|
* Return a support-category-name
|
||||||
*/
|
*/
|
||||||
static public function getCategoryName($_id = 0) {
|
static public function getCategoryName($_id = 0)
|
||||||
|
{
|
||||||
if ($_id != 0) {
|
if ($_id != 0) {
|
||||||
$stmt = Database::prepare("
|
$stmt = Database::prepare("
|
||||||
SELECT `name` FROM `" . TABLE_PANEL_TICKET_CATS . "` WHERE `id` = :id"
|
SELECT `name` FROM `" . TABLE_PANEL_TICKET_CATS . "` WHERE `id` = :id");
|
||||||
);
|
$category = Database::pexecute_first($stmt, array(
|
||||||
$category = Database::pexecute_first($stmt, array('id' => $_id));
|
'id' => $_id
|
||||||
|
));
|
||||||
return $category['name'];
|
return $category['name'];
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
@@ -440,32 +476,33 @@ class ticket {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* get the highest order number
|
* get the highest order number
|
||||||
*
|
*
|
||||||
* @param object $_uid admin-id (optional)
|
* @param object $_uid
|
||||||
*
|
* admin-id (optional)
|
||||||
|
*
|
||||||
* @return int highest order number
|
* @return int highest order number
|
||||||
*/
|
*/
|
||||||
static public function getHighestOrderNumber($_uid = 0) {
|
static public function getHighestOrderNumber($_uid = 0)
|
||||||
|
{
|
||||||
$where = '';
|
$where = '';
|
||||||
$sel_data = array();
|
$sel_data = array();
|
||||||
if ($_uid > 0) {
|
if ($_uid > 0) {
|
||||||
$where = " WHERE `adminid` = :adminid";
|
$where = " WHERE `adminid` = :adminid";
|
||||||
$sel_data['adminid'] = $_uid;
|
$sel_data['adminid'] = $_uid;
|
||||||
}
|
}
|
||||||
$sql = "SELECT MAX(`logicalorder`) as `highestorder` FROM `" . TABLE_PANEL_TICKET_CATS . "`".$where.";";
|
$sql = "SELECT MAX(`logicalorder`) as `highestorder` FROM `" . TABLE_PANEL_TICKET_CATS . "`" . $where . ";";
|
||||||
$result_stmt = Database::prepare($sql);
|
$result_stmt = Database::prepare($sql);
|
||||||
$result = Database::pexecute_first($result_stmt, $sel_data);
|
$result = Database::pexecute_first($result_stmt, $sel_data);
|
||||||
return (isset($result['highestorder']) ? (int)$result['highestorder'] : 0);
|
return (isset($result['highestorder']) ? (int) $result['highestorder'] : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* returns the last x archived tickets
|
* returns the last x archived tickets
|
||||||
*/
|
*/
|
||||||
static public function getLastArchived($_num = 10, $_admin = 1) {
|
static public function getLastArchived($_num = 10, $_admin = 1)
|
||||||
|
{
|
||||||
if ($_num > 0) {
|
if ($_num > 0) {
|
||||||
|
|
||||||
$archived = array();
|
$archived = array();
|
||||||
$counter = 0;
|
$counter = 0;
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
@@ -477,12 +514,13 @@ class ticket {
|
|||||||
FROM `" . TABLE_PANEL_TICKETS . "` `main`
|
FROM `" . TABLE_PANEL_TICKETS . "` `main`
|
||||||
WHERE `main`.`answerto` = '0' AND `main`.`archived` = '1'
|
WHERE `main`.`answerto` = '0' AND `main`.`archived` = '1'
|
||||||
AND `main`.`adminid` = :adminid
|
AND `main`.`adminid` = :adminid
|
||||||
ORDER BY `main`.`lastchange` DESC LIMIT 0, ".(int)$_num
|
ORDER BY `main`.`lastchange` DESC LIMIT 0, " . (int) $_num);
|
||||||
);
|
Database::pexecute($result_stmt, array(
|
||||||
Database::pexecute($result_stmt, array('adminid' => $_admin));
|
'adminid' => $_admin
|
||||||
|
));
|
||||||
|
|
||||||
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
$archived[$counter]['id'] = $row['id'];
|
$archived[$counter]['id'] = $row['id'];
|
||||||
$archived[$counter]['customerid'] = $row['customerid'];
|
$archived[$counter]['customerid'] = $row['customerid'];
|
||||||
$archived[$counter]['adminid'] = $row['adminid'];
|
$archived[$counter]['adminid'] = $row['adminid'];
|
||||||
@@ -496,9 +534,9 @@ class ticket {
|
|||||||
$archived[$counter]['lastchange'] = $row['lastchange'];
|
$archived[$counter]['lastchange'] = $row['lastchange'];
|
||||||
$archived[$counter]['status'] = $row['status'];
|
$archived[$counter]['status'] = $row['status'];
|
||||||
$archived[$counter]['by'] = $row['by'];
|
$archived[$counter]['by'] = $row['by'];
|
||||||
$counter++;
|
$counter ++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($archived[0]['id'])) {
|
if (isset($archived[0]['id'])) {
|
||||||
return $archived;
|
return $archived;
|
||||||
} else {
|
} else {
|
||||||
@@ -516,129 +554,102 @@ class ticket {
|
|||||||
static public function getArchiveSearchStatement($subject = null, $priority = null, $fromdate = null, $todate = null, $message = null, $customer = - 1, $admin = 1, $categories = null)
|
static public function getArchiveSearchStatement($subject = null, $priority = null, $fromdate = null, $todate = null, $message = null, $customer = - 1, $admin = 1, $categories = null)
|
||||||
{
|
{
|
||||||
$search_params = array();
|
$search_params = array();
|
||||||
|
|
||||||
$query = "
|
$query = "
|
||||||
SELECT `main`.*, (
|
SELECT `main`.*, (
|
||||||
SELECT COUNT(`sub`.`id`) FROM `" . TABLE_PANEL_TICKETS . "` `sub`
|
SELECT COUNT(`sub`.`id`) FROM `" . TABLE_PANEL_TICKETS . "` `sub`
|
||||||
WHERE `sub`.`answerto` = `main`.`id`
|
WHERE `sub`.`answerto` = `main`.`id`
|
||||||
) as `ticket_answers`
|
) as `ticket_answers`
|
||||||
FROM `" . TABLE_PANEL_TICKETS . "` `main`
|
FROM `" . TABLE_PANEL_TICKETS . "` `main`
|
||||||
WHERE `main`.`archived` = '1' AND `main`.`adminid` = :admin"
|
WHERE `main`.`archived` = '1' AND `main`.`adminid` = :admin";
|
||||||
;
|
|
||||||
|
|
||||||
$search_params['admin'] = $admin;
|
$search_params['admin'] = $admin;
|
||||||
|
|
||||||
if ($subject != NULL
|
if ($subject != NULL && $subject != '') {
|
||||||
&& $subject != ''
|
|
||||||
) {
|
|
||||||
$query .= " AND `main`.`subject` LIKE :subject";
|
$query .= " AND `main`.`subject` LIKE :subject";
|
||||||
$search_params['subject'] = "%".$subject."%";
|
$search_params['subject'] = "%" . $subject . "%";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($priority != null
|
if ($priority != null && isset($priority[0]) && $priority[0] != '') {
|
||||||
&& isset($priority[0])
|
|
||||||
&& $priority[0] != ''
|
if (isset($priority[1]) && $priority[1] != '') {
|
||||||
) {
|
|
||||||
|
if (isset($priority[2]) && $priority[2] != '') {
|
||||||
if (isset($priority[1])
|
|
||||||
&& $priority[1] != ''
|
|
||||||
) {
|
|
||||||
|
|
||||||
if (isset($priority[2])
|
|
||||||
&& $priority[2] != ''
|
|
||||||
) {
|
|
||||||
|
|
||||||
$query .= " AND (`main`.`priority` = '1' OR `main`.`priority` = '2' OR `main`.`priority` = '3')";
|
$query .= " AND (`main`.`priority` = '1' OR `main`.`priority` = '2' OR `main`.`priority` = '3')";
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$query .= " AND (`main`.`priority` = '1' OR `main`.`priority` = '1')";
|
$query .= " AND (`main`.`priority` = '1' OR `main`.`priority` = '1')";
|
||||||
}
|
}
|
||||||
|
} elseif (isset($priority[2]) && $priority[2] != '') {
|
||||||
} elseif (isset($priority[2])
|
|
||||||
&& $priority[2] != ''
|
|
||||||
) {
|
|
||||||
|
|
||||||
$query .= " AND (`main`.`priority` = '1' OR `main`.`priority` = '3')";
|
$query .= " AND (`main`.`priority` = '1' OR `main`.`priority` = '3')";
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$query .= " AND `main`.`priority` = '1'";
|
$query .= " AND `main`.`priority` = '1'";
|
||||||
}
|
}
|
||||||
|
} elseif ($priority != null && isset($priority[1]) && $priority[1] != '') {
|
||||||
} elseif($priority != null
|
if (isset($priority[2]) && $priority[2] != '') {
|
||||||
&& isset($priority[1])
|
|
||||||
&& $priority[1] != ''
|
|
||||||
) {
|
|
||||||
if (isset($priority[2])
|
|
||||||
&& $priority[2] != ''
|
|
||||||
) {
|
|
||||||
$query .= " AND (`main`.`priority` = '2' OR `main`.`priority` = '3')";
|
$query .= " AND (`main`.`priority` = '2' OR `main`.`priority` = '3')";
|
||||||
} else {
|
} else {
|
||||||
$query .= " AND `main`.`priority` = '2'";
|
$query .= " AND `main`.`priority` = '2'";
|
||||||
}
|
}
|
||||||
|
} elseif ($priority != null) {
|
||||||
} elseif($priority != null) {
|
|
||||||
|
if (isset($priority[3]) && $priority[3] != '') {
|
||||||
if (isset($priority[3])
|
|
||||||
&& $priority[3] != ''
|
|
||||||
) {
|
|
||||||
$query .= " AND `main`.`priority` = '3'";
|
$query .= " AND `main`.`priority` = '3'";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($fromdate != null
|
if ($fromdate != null && $fromdate > 0) {
|
||||||
&& $fromdate > 0
|
|
||||||
) {
|
|
||||||
$query .= " AND `main`.`lastchange` > :fromdate";
|
$query .= " AND `main`.`lastchange` > :fromdate";
|
||||||
$search_params['fromdate'] = strtotime($fromdate);
|
$search_params['fromdate'] = strtotime($fromdate);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($todate != null
|
if ($todate != null && $todate > 0) {
|
||||||
&& $todate > 0
|
|
||||||
) {
|
|
||||||
$query .= " AND `main`.`lastchange` < :todate";
|
$query .= " AND `main`.`lastchange` < :todate";
|
||||||
$search_params['todate'] = strtotime($todate);
|
$search_params['todate'] = strtotime($todate);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($message != null
|
if ($message != null && $message != '') {
|
||||||
&& $message != ''
|
|
||||||
) {
|
|
||||||
$query .= " AND `main`.`message` LIKE :message";
|
$query .= " AND `main`.`message` LIKE :message";
|
||||||
$search_params['message'] = "%".$message."%";
|
$search_params['message'] = "%" . $message . "%";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($customer != - 1) {
|
if ($customer != - 1) {
|
||||||
$query .= " AND `main`.`customerid` = :customer";
|
$query .= " AND `main`.`customerid` = :customer";
|
||||||
$search_params['customer'] = $customer;
|
$search_params['customer'] = $customer;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($categories != null) {
|
if ($categories != null) {
|
||||||
|
|
||||||
$cats = array();
|
$cats = array();
|
||||||
foreach ($categories as $index => $catid) {
|
foreach ($categories as $index => $catid) {
|
||||||
if ($catid != "") {
|
if ($catid != "") {
|
||||||
$cats[] = $catid;
|
$cats[] = $catid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count($cats) > 0) {
|
if (count($cats) > 0) {
|
||||||
$query .= " AND (";
|
$query .= " AND (";
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($cats as $catid) {
|
foreach ($cats as $catid) {
|
||||||
if (isset($catid) && $catid > 0) {
|
if (isset($catid) && $catid > 0) {
|
||||||
$query .= "`main`.`category` = :catid_".$catid." OR ";
|
$query .= "`main`.`category` = :catid_" . $catid . " OR ";
|
||||||
$search_params['catid_'.$catid] = $catid;
|
$search_params['catid_' . $catid] = $catid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count($cats) > 0) {
|
if (count($cats) > 0) {
|
||||||
$query = substr($query, 0, strlen($query) - 3);
|
$query = substr($query, 0, strlen($query) - 3);
|
||||||
$query .= ") ";
|
$query .= ") ";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return array('0' => $query, '1' => $search_params);
|
return array(
|
||||||
|
'0' => $query,
|
||||||
|
'1' => $search_params
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -646,8 +657,7 @@ class ticket {
|
|||||||
*/
|
*/
|
||||||
static public function getStatusText($_lng, $_status = 0)
|
static public function getStatusText($_lng, $_status = 0)
|
||||||
{
|
{
|
||||||
switch($_status)
|
switch ($_status) {
|
||||||
{
|
|
||||||
case 0:
|
case 0:
|
||||||
return $_lng['ticket']['open'];
|
return $_lng['ticket']['open'];
|
||||||
break;
|
break;
|
||||||
@@ -668,8 +678,7 @@ class ticket {
|
|||||||
*/
|
*/
|
||||||
static public function getPriorityText($_lng, $_priority = 0)
|
static public function getPriorityText($_lng, $_priority = 0)
|
||||||
{
|
{
|
||||||
switch($_priority)
|
switch ($_priority) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
return $_lng['ticket']['high'];
|
return $_lng['ticket']['high'];
|
||||||
break;
|
break;
|
||||||
@@ -684,19 +693,19 @@ class ticket {
|
|||||||
|
|
||||||
private function convertLatin1ToHtml($str)
|
private function convertLatin1ToHtml($str)
|
||||||
{
|
{
|
||||||
$html_entities = array (
|
$html_entities = array(
|
||||||
"Ä" => "Ä",
|
"Ä" => "Ä",
|
||||||
"ä" => "ä",
|
"ä" => "ä",
|
||||||
"Ö" => "Ö",
|
"Ö" => "Ö",
|
||||||
"ö" => "ö",
|
"ö" => "ö",
|
||||||
"Ü" => "Ü",
|
"Ü" => "Ü",
|
||||||
"ü" => "ü",
|
"ü" => "ü",
|
||||||
"ß" => "ß"
|
"ß" => "ß"
|
||||||
/*
|
/*
|
||||||
* @TODO continue this table for all the special-characters
|
* @TODO continue this table for all the special-characters
|
||||||
*/
|
*/
|
||||||
);
|
);
|
||||||
|
|
||||||
foreach ($html_entities as $key => $value) {
|
foreach ($html_entities as $key => $value) {
|
||||||
$str = str_replace($key, $value, $str);
|
$str = str_replace($key, $value, $str);
|
||||||
}
|
}
|
||||||
@@ -706,45 +715,47 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* function customerHasTickets
|
* function customerHasTickets
|
||||||
*
|
*
|
||||||
* @param int customer-id
|
* @param
|
||||||
*
|
* int customer-id
|
||||||
* @return array/bool array of ticket-ids if customer has any, else false
|
*
|
||||||
|
* @return array/bool array of ticket-ids if customer has any, else false
|
||||||
*/
|
*/
|
||||||
static public function customerHasTickets($_cid = 0) {
|
static public function customerHasTickets($_cid = 0)
|
||||||
|
{
|
||||||
if ($_cid != 0) {
|
if ($_cid != 0) {
|
||||||
$result_stmt = Database::prepare("
|
$result_stmt = Database::prepare("
|
||||||
SELECT `id` FROM `" . TABLE_PANEL_TICKETS . "` WHERE `customerid` = :cid"
|
SELECT `id` FROM `" . TABLE_PANEL_TICKETS . "` WHERE `customerid` = :cid");
|
||||||
);
|
Database::pexecute($result_stmt, array(
|
||||||
Database::pexecute($result_stmt, array('cid' => $_cid));
|
'cid' => $_cid
|
||||||
|
));
|
||||||
|
|
||||||
$tickets = array();
|
$tickets = array();
|
||||||
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
$tickets[] = $row['id'];
|
$tickets[] = $row['id'];
|
||||||
}
|
}
|
||||||
|
|
||||||
return $tickets;
|
return $tickets;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a data-var
|
* Get a data-var
|
||||||
*/
|
*/
|
||||||
public function Get($_var = '', $_vartrusted = false) {
|
public function Get($_var = '', $_vartrusted = false)
|
||||||
|
{
|
||||||
if ($_var != '') {
|
if ($_var != '') {
|
||||||
if (!$_vartrusted) {
|
if (! $_vartrusted) {
|
||||||
$_var = htmlspecialchars($_var);
|
$_var = htmlspecialchars($_var);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($this->t_data[$_var])) {
|
if (isset($this->t_data[$_var])) {
|
||||||
if (strtolower($_var) == 'message') {
|
if (strtolower($_var) == 'message') {
|
||||||
// avoid double line-breaks, #1413
|
// avoid double line-breaks, #1413
|
||||||
$this->t_data[$_var] = str_replace("<br />\n", "\n", $this->t_data[$_var]);
|
$this->t_data[$_var] = str_replace("<br />\n", "\n", $this->t_data[$_var]);
|
||||||
return nl2br($this->t_data[$_var]);
|
return nl2br($this->t_data[$_var]);
|
||||||
} elseif(strtolower($_var) == 'subject') {
|
} elseif (strtolower($_var) == 'subject') {
|
||||||
return nl2br($this->t_data[$_var]);
|
return nl2br($this->t_data[$_var]);
|
||||||
} else {
|
} else {
|
||||||
return $this->t_data[$_var];
|
return $this->t_data[$_var];
|
||||||
@@ -758,25 +769,21 @@ class ticket {
|
|||||||
/**
|
/**
|
||||||
* Set a data-var
|
* Set a data-var
|
||||||
*/
|
*/
|
||||||
public function Set($_var = '', $_value = '', $_vartrusted = false, $_valuetrusted = false) {
|
public function Set($_var = '', $_value = '', $_vartrusted = false, $_valuetrusted = false)
|
||||||
|
{
|
||||||
if ($_var != ''
|
if ($_var != '' && $_value != '') {
|
||||||
&& $_value != ''
|
if (! $_vartrusted) {
|
||||||
) {
|
|
||||||
if (!$_vartrusted) {
|
|
||||||
$_var = strip_tags($_var);
|
$_var = strip_tags($_var);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$_valuetrusted) {
|
if (! $_valuetrusted) {
|
||||||
$_value = strip_tags($_value, '<br />');
|
$_value = strip_tags($_value, '<br />');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strtolower($_var) == 'message'
|
if (strtolower($_var) == 'message' || strtolower($_var) == 'subject') {
|
||||||
|| strtolower($_var) == 'subject'
|
|
||||||
) {
|
|
||||||
$_value = $this->convertLatin1ToHtml($_value);
|
$_value = $this->convertLatin1ToHtml($_value);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->t_data[$_var] = $_value;
|
$this->t_data[$_var] = $_value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,13 +17,14 @@
|
|||||||
* @since 0.9.29
|
* @since 0.9.29
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
class ConfigIO
|
||||||
class ConfigIO {
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* constructor
|
* constructor
|
||||||
*/
|
*/
|
||||||
public function __construct() {}
|
public function __construct()
|
||||||
|
{}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* clean up former created configs, including (if enabled)
|
* clean up former created configs, including (if enabled)
|
||||||
@@ -32,39 +33,40 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
public function cleanUp() {
|
public function cleanUp()
|
||||||
|
{
|
||||||
|
|
||||||
// old error logs
|
// old error logs
|
||||||
$this->_cleanErrLogs();
|
$this->_cleanErrLogs();
|
||||||
|
|
||||||
// awstats files
|
// awstats files
|
||||||
$this->_cleanAwstatsFiles();
|
$this->_cleanAwstatsFiles();
|
||||||
|
|
||||||
// fcgid files
|
// fcgid files
|
||||||
$this->_cleanFcgidFiles();
|
$this->_cleanFcgidFiles();
|
||||||
|
|
||||||
// php-fpm files
|
// php-fpm files
|
||||||
$this->_cleanFpmFiles();
|
$this->_cleanFpmFiles();
|
||||||
|
|
||||||
// clean webserver-configs
|
// clean webserver-configs
|
||||||
$this->_cleanWebserverConfigs();
|
$this->_cleanWebserverConfigs();
|
||||||
|
|
||||||
// old htpasswd files
|
// old htpasswd files
|
||||||
$this->_cleanHtpasswdFiles();
|
$this->_cleanHtpasswdFiles();
|
||||||
|
|
||||||
// customer-specified ssl-certificates
|
// customer-specified ssl-certificates
|
||||||
$this->_cleanCustomerSslCerts();
|
$this->_cleanCustomerSslCerts();
|
||||||
}
|
}
|
||||||
|
|
||||||
private function _cleanErrLogs() {
|
private function _cleanErrLogs()
|
||||||
|
{
|
||||||
$err_dir = makeCorrectDir(FROXLOR_INSTALL_DIR."/logs/");
|
$err_dir = makeCorrectDir(FROXLOR_INSTALL_DIR . "/logs/");
|
||||||
if (@is_dir($err_dir)) {
|
if (@is_dir($err_dir)) {
|
||||||
// now get rid of old stuff
|
// now get rid of old stuff
|
||||||
//(but append /*.log so we don't delete the directory)
|
// (but append /*.log so we don't delete the directory)
|
||||||
$err_dir.='/*.log';
|
$err_dir .= '/*.log';
|
||||||
safe_exec('rm -rf '. makeCorrectFile($err_dir));
|
safe_exec('rm -f ' . makeCorrectFile($err_dir));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -73,8 +75,9 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
private function _cleanCustomerSslCerts() {
|
private function _cleanCustomerSslCerts()
|
||||||
|
{
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* only clean up if we're actually using SSL
|
* only clean up if we're actually using SSL
|
||||||
*/
|
*/
|
||||||
@@ -82,14 +85,14 @@ class ConfigIO {
|
|||||||
// get correct directory
|
// get correct directory
|
||||||
$configdir = $this->_getFile('system', 'customer_ssl_path');
|
$configdir = $this->_getFile('system', 'customer_ssl_path');
|
||||||
if ($configdir !== false) {
|
if ($configdir !== false) {
|
||||||
|
|
||||||
$configdir = makeCorrectDir($configdir);
|
$configdir = makeCorrectDir($configdir);
|
||||||
|
|
||||||
if (@is_dir($configdir)) {
|
if (@is_dir($configdir)) {
|
||||||
// now get rid of old stuff
|
// now get rid of old stuff
|
||||||
//(but append /* so we don't delete the directory)
|
// (but append /* so we don't delete the directory)
|
||||||
$configdir.='/*';
|
$configdir .= '/*';
|
||||||
safe_exec('rm -rf '. makeCorrectFile($configdir));
|
safe_exec('rm -f ' . makeCorrectFile($configdir));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -100,39 +103,38 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
private function _cleanWebserverConfigs() {
|
private function _cleanWebserverConfigs()
|
||||||
|
{
|
||||||
|
|
||||||
// get directories
|
// get directories
|
||||||
$configdirs = array();
|
$configdirs = array();
|
||||||
$dir = $this->_getFile('system', 'apacheconf_vhost');
|
$dir = $this->_getFile('system', 'apacheconf_vhost');
|
||||||
if ($dir !== false)
|
if ($dir !== false)
|
||||||
$configdirs[] = makeCorrectDir($dir);
|
$configdirs[] = makeCorrectDir($dir);
|
||||||
|
|
||||||
$dir = $this->_getFile('system', 'apacheconf_diroptions');
|
$dir = $this->_getFile('system', 'apacheconf_diroptions');
|
||||||
if ($dir !== false)
|
if ($dir !== false)
|
||||||
$configdirs[] = makeCorrectDir($dir);
|
$configdirs[] = makeCorrectDir($dir);
|
||||||
|
|
||||||
// file pattern
|
// file pattern
|
||||||
$pattern = "/^([0-9]){2}_(froxlor|syscp)_(.+)\.conf$/";
|
$pattern = "/^([0-9]){2}_(froxlor|syscp)_(.+)\.conf$/";
|
||||||
|
|
||||||
// check ALL the folders
|
// check ALL the folders
|
||||||
foreach ($configdirs as $config_dir) {
|
foreach ($configdirs as $config_dir) {
|
||||||
|
|
||||||
// check directory
|
// check directory
|
||||||
if (@is_dir($config_dir)) {
|
if (@is_dir($config_dir)) {
|
||||||
|
|
||||||
// create directory iterator
|
// create directory iterator
|
||||||
$its = new RecursiveIteratorIterator(
|
$its = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($config_dir));
|
||||||
new RecursiveDirectoryIterator($config_dir)
|
|
||||||
);
|
|
||||||
|
|
||||||
// iterate through all subdirs,
|
// iterate through all subdirs,
|
||||||
// look for vhost/diroption files
|
// look for vhost/diroption files
|
||||||
// and delete them
|
// and delete them
|
||||||
foreach ($its as $fullFileName => $it ) {
|
foreach ($its as $fullFileName => $it) {
|
||||||
if ($it->isFile() && preg_match($pattern, $it->getFilename())) {
|
if ($it->isFile() && preg_match($pattern, $it->getFilename())) {
|
||||||
// remove file
|
// remove file
|
||||||
safe_exec('rm -f '. escapeshellarg(makeCorrectFile($its->getPathname())));
|
safe_exec('rm -f ' . escapeshellarg(makeCorrectFile($its->getPathname())));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -144,19 +146,20 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
private function _cleanHtpasswdFiles() {
|
private function _cleanHtpasswdFiles()
|
||||||
|
{
|
||||||
|
|
||||||
// get correct directory
|
// get correct directory
|
||||||
$configdir = $this->_getFile('system', 'apacheconf_htpasswddir');
|
$configdir = $this->_getFile('system', 'apacheconf_htpasswddir');
|
||||||
|
|
||||||
if ($configdir !== false) {
|
if ($configdir !== false) {
|
||||||
$configdir = makeCorrectDir($configdir);
|
$configdir = makeCorrectDir($configdir);
|
||||||
|
|
||||||
if (@is_dir($configdir)) {
|
if (@is_dir($configdir)) {
|
||||||
// now get rid of old stuff
|
// now get rid of old stuff
|
||||||
//(but append /* so we don't delete the directory)
|
// (but append /* so we don't delete the directory)
|
||||||
$configdir.='/*';
|
$configdir .= '/*';
|
||||||
safe_exec('rm -rf '. makeCorrectFile($configdir));
|
safe_exec('rm -f ' . makeCorrectFile($configdir));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -166,37 +169,36 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
private function _cleanAwstatsFiles() {
|
private function _cleanAwstatsFiles()
|
||||||
|
{
|
||||||
if (Settings::Get('system.awstats_enabled') == '0') {
|
if (Settings::Get('system.awstats_enabled') == '0') {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
//dhr: cleanout froxlor-generated awstats configs prior to re-creation
|
// dhr: cleanout froxlor-generated awstats configs prior to re-creation
|
||||||
$awstatsclean['header'] = "## GENERATED BY FROXLOR\n";
|
$awstatsclean['header'] = "## GENERATED BY FROXLOR\n";
|
||||||
$awstatsclean['headerold'] = "## GENERATED BY SYSCP\n";
|
$awstatsclean['headerold'] = "## GENERATED BY SYSCP\n";
|
||||||
$awstatsclean['path'] = $this->_getFile('system', 'awstats_conf');
|
$awstatsclean['path'] = $this->_getFile('system', 'awstats_conf');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* don't do anything if the directory does not exist
|
* don't do anything if the directory does not exist
|
||||||
* (e.g. awstats not installed yet or whatever)
|
* (e.g.
|
||||||
|
* awstats not installed yet or whatever)
|
||||||
* fixes #45
|
* fixes #45
|
||||||
*/
|
*/
|
||||||
if ($awstatsclean['path'] !== false && is_dir($awstatsclean['path'])) {
|
if ($awstatsclean['path'] !== false && is_dir($awstatsclean['path'])) {
|
||||||
$awstatsclean['dir'] = dir($awstatsclean['path']);
|
$awstatsclean['dir'] = dir($awstatsclean['path']);
|
||||||
while ($awstatsclean['entry'] = $awstatsclean['dir']->read()) {
|
while ($awstatsclean['entry'] = $awstatsclean['dir']->read()) {
|
||||||
$awstatsclean['fullentry'] = makeCorrectFile($awstatsclean['path'].'/'.$awstatsclean['entry']);
|
$awstatsclean['fullentry'] = makeCorrectFile($awstatsclean['path'] . '/' . $awstatsclean['entry']);
|
||||||
/**
|
/**
|
||||||
* don't do anything if the file does not exist
|
* don't do anything if the file does not exist
|
||||||
*/
|
*/
|
||||||
if (@file_exists($awstatsclean['fullentry'])) {
|
if (@file_exists($awstatsclean['fullentry'])) {
|
||||||
$awstatsclean['fh'] = fopen($awstatsclean['fullentry'], 'r');
|
$awstatsclean['fh'] = fopen($awstatsclean['fullentry'], 'r');
|
||||||
$awstatsclean['headerRead'] = fgets($awstatsclean['fh'], strlen($awstatsclean['header'])+1);
|
$awstatsclean['headerRead'] = fgets($awstatsclean['fh'], strlen($awstatsclean['header']) + 1);
|
||||||
fclose($awstatsclean['fh']);
|
fclose($awstatsclean['fh']);
|
||||||
|
|
||||||
if ($awstatsclean['headerRead'] == $awstatsclean['header']
|
if ($awstatsclean['headerRead'] == $awstatsclean['header'] || $awstatsclean['headerRead'] == $awstatsclean['headerold']) {
|
||||||
|| $awstatsclean['headerRead'] == $awstatsclean['headerold']
|
|
||||||
) {
|
|
||||||
$awstats_conf_file = makeCorrectFile($awstatsclean['fullentry']);
|
$awstats_conf_file = makeCorrectFile($awstatsclean['fullentry']);
|
||||||
@unlink($awstats_conf_file);
|
@unlink($awstats_conf_file);
|
||||||
}
|
}
|
||||||
@@ -204,7 +206,7 @@ class ConfigIO {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
unset($awstatsclean);
|
unset($awstatsclean);
|
||||||
//end dhr
|
// end dhr
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -212,39 +214,37 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
private function _cleanFcgidFiles() {
|
private function _cleanFcgidFiles()
|
||||||
|
{
|
||||||
if (Settings::Get('system.mod_fcgid') == '0') {
|
if (Settings::Get('system.mod_fcgid') == '0') {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get correct directory
|
// get correct directory
|
||||||
$configdir = $this->_getFile('system', 'mod_fcgid_configdir');
|
$configdir = $this->_getFile('system', 'mod_fcgid_configdir');
|
||||||
if ($configdir !== false) {
|
if ($configdir !== false) {
|
||||||
|
|
||||||
$configdir = makeCorrectDir($configdir);
|
$configdir = makeCorrectDir($configdir);
|
||||||
|
|
||||||
if (@is_dir($configdir)) {
|
if (@is_dir($configdir)) {
|
||||||
// create directory iterator
|
// create directory iterator
|
||||||
$its = new RecursiveIteratorIterator(
|
$its = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($configdir));
|
||||||
new RecursiveDirectoryIterator($configdir)
|
|
||||||
);
|
|
||||||
|
|
||||||
// iterate through all subdirs,
|
// iterate through all subdirs,
|
||||||
// look for php-fcgi-starter files
|
// look for php-fcgi-starter files
|
||||||
// and take immutable-flag away from them
|
// and take immutable-flag away from them
|
||||||
// so we can delete them :)
|
// so we can delete them :)
|
||||||
foreach ($its as $fullFileName => $it ) {
|
foreach ($its as $fullFileName => $it) {
|
||||||
if ($it->isFile() && $it->getFilename() == 'php-fcgi-starter') {
|
if ($it->isFile() && $it->getFilename() == 'php-fcgi-starter') {
|
||||||
// set chattr -i
|
// set chattr -i
|
||||||
removeImmutable($its->getPathname());
|
removeImmutable($its->getPathname());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// now get rid of old stuff
|
// now get rid of old stuff
|
||||||
//(but append /* so we don't delete the directory)
|
// (but append /* so we don't delete the directory)
|
||||||
$configdir.='/*';
|
$configdir .= '/*';
|
||||||
safe_exec('rm -rf '. makeCorrectFile($configdir));
|
safe_exec('rm -rf ' . makeCorrectFile($configdir));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -254,33 +254,36 @@ class ConfigIO {
|
|||||||
*
|
*
|
||||||
* @return null
|
* @return null
|
||||||
*/
|
*/
|
||||||
private function _cleanFpmFiles() {
|
private function _cleanFpmFiles()
|
||||||
|
{
|
||||||
if (Settings::Get('phpfpm.enabled') == '0') {
|
if (Settings::Get('phpfpm.enabled') == '0') {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get correct directory
|
// get all fpm config paths
|
||||||
$configdir = $this->_getFile('phpfpm', 'configdir');
|
$fpmconf_sel = Database::prepare("SELECT config_dir FROM `" . TABLE_PANEL_FPMDAEMONS . "`");
|
||||||
if ($configdir !== false) {
|
Database::pexecute($fpmconf_sel);
|
||||||
|
$fpmconf_paths = $fpmconf_sel->fetchAll(PDO::FETCH_ASSOC);
|
||||||
$configdir = makeCorrectDir($configdir);
|
// clean all php-fpm config-dirs
|
||||||
|
foreach ($fpmconf_paths as $configdir) {
|
||||||
|
$configdir = makeCorrectDir($configdir['config_dir']);
|
||||||
if (@is_dir($configdir)) {
|
if (@is_dir($configdir)) {
|
||||||
// now get rid of old stuff
|
// now get rid of old stuff
|
||||||
//(but append /* so we don't delete the directory)
|
// (but append /*.conf so we don't delete the directory)
|
||||||
$configdir.='/*';
|
$configdir .= '/*.conf';
|
||||||
safe_exec('rm -rf '. makeCorrectFile($configdir));
|
safe_exec('rm -f ' . makeCorrectFile($configdir));
|
||||||
|
} else {
|
||||||
|
safe_exec('mkdir -p ' . $configdir);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// also remove aliasconfigdir #1273
|
// also remove aliasconfigdir #1273
|
||||||
$aliasconfigdir = $this->_getFile('phpfpm', 'aliasconfigdir');
|
$aliasconfigdir = $this->_getFile('phpfpm', 'aliasconfigdir');
|
||||||
if ($aliasconfigdir !== false) {
|
if ($aliasconfigdir !== false) {
|
||||||
$aliasconfigdir = makeCorrectDir($aliasconfigdir);
|
$aliasconfigdir = makeCorrectDir($aliasconfigdir);
|
||||||
if (@is_dir($aliasconfigdir)) {
|
if (@is_dir($aliasconfigdir)) {
|
||||||
$aliasconfigdir.='/*';
|
$aliasconfigdir .= '/*';
|
||||||
safe_exec('rm -rf '. makeCorrectFile($aliasconfigdir));
|
safe_exec('rm -rf ' . makeCorrectFile($aliasconfigdir));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -288,17 +291,21 @@ class ConfigIO {
|
|||||||
/**
|
/**
|
||||||
* returns a file/direcotry from the settings and checks whether it exists
|
* returns a file/direcotry from the settings and checks whether it exists
|
||||||
*
|
*
|
||||||
* @param string $group settings-group
|
* @param string $group
|
||||||
* @param string $varname var-name
|
* settings-group
|
||||||
* @param boolean $check_exists check if the file exists
|
* @param string $varname
|
||||||
*
|
* var-name
|
||||||
|
* @param boolean $check_exists
|
||||||
|
* check if the file exists
|
||||||
|
*
|
||||||
* @return string|boolean complete path including filename if any or false on error
|
* @return string|boolean complete path including filename if any or false on error
|
||||||
*/
|
*/
|
||||||
private function _getFile($group, $varname, $check_exists = true) {
|
private function _getFile($group, $varname, $check_exists = true)
|
||||||
|
{
|
||||||
|
|
||||||
// read from settings
|
// read from settings
|
||||||
$file = Settings::Get($group.'.'.$varname);
|
$file = Settings::Get($group . '.' . $varname);
|
||||||
|
|
||||||
// check whether it exists
|
// check whether it exists
|
||||||
if ($check_exists && @file_exists($file) == false) {
|
if ($check_exists && @file_exists($file) == false) {
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -89,6 +89,10 @@ class DomainSSL {
|
|||||||
$ssl_files['ssl_cert_chainfile'] = makeCorrectFile($sslcertpath.'/'.$domain['domain'].'_chain.pem');
|
$ssl_files['ssl_cert_chainfile'] = makeCorrectFile($sslcertpath.'/'.$domain['domain'].'_chain.pem');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// will only be generated to be used externally, froxlor does not need this
|
||||||
|
if ($dom_certs['ssl_fullchain_file'] != '') {
|
||||||
|
$ssl_files['ssl_fullchain_file'] = makeCorrectFile($sslcertpath.'/'.$domain['domain'].'_fullchain.pem');
|
||||||
|
}
|
||||||
// create them on the filesystem
|
// create them on the filesystem
|
||||||
foreach ($ssl_files as $type => $filename) {
|
foreach ($ssl_files as $type => $filename) {
|
||||||
if ($filename != '') {
|
if ($filename != '') {
|
||||||
|
|||||||
@@ -17,8 +17,8 @@
|
|||||||
* @since 0.9.31
|
* @since 0.9.31
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
class WebserverBase
|
||||||
class WebserverBase {
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* returns an array with all entries required for all
|
* returns an array with all entries required for all
|
||||||
@@ -26,28 +26,45 @@ class WebserverBase {
|
|||||||
*
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
public static function getVhostsToCreate() {
|
public static function getVhostsToCreate()
|
||||||
|
{
|
||||||
$query = "SELECT `d`.*, `pd`.`domain` AS `parentdomain`, `c`.`loginname`,
|
$query = "SELECT `d`.*, `pd`.`domain` AS `parentdomain`, `c`.`loginname`,
|
||||||
`d`.`phpsettingid`, `c`.`adminid`, `c`.`guid`, `c`.`email`,
|
`d`.`phpsettingid`, `c`.`adminid`, `c`.`guid`, `c`.`email`,
|
||||||
`c`.`documentroot` AS `customerroot`, `c`.`deactivated`,
|
`c`.`documentroot` AS `customerroot`, `c`.`deactivated`,
|
||||||
`c`.`phpenabled` AS `phpenabled_customer`,
|
`c`.`phpenabled` AS `phpenabled_customer`,
|
||||||
`d`.`phpenabled` AS `phpenabled_vhost`,
|
`d`.`phpenabled` AS `phpenabled_vhost`,
|
||||||
`d`.`mod_fcgid_starter`,`d`.`mod_fcgid_maxrequests`
|
`d`.`mod_fcgid_starter`,`d`.`mod_fcgid_maxrequests`,
|
||||||
FROM `".TABLE_PANEL_DOMAINS."` `d`
|
`d`.`ocsp_stapling`
|
||||||
|
FROM `" . TABLE_PANEL_DOMAINS . "` `d`
|
||||||
|
|
||||||
LEFT JOIN `".TABLE_PANEL_CUSTOMERS."` `c` USING(`customerid`)
|
LEFT JOIN `" . TABLE_PANEL_CUSTOMERS . "` `c` USING(`customerid`)
|
||||||
LEFT JOIN `".TABLE_PANEL_DOMAINS."` `pd` ON (`pd`.`id` = `d`.`parentdomainid`)
|
LEFT JOIN `" . TABLE_PANEL_DOMAINS . "` `pd` ON (`pd`.`id` = `d`.`parentdomainid`)
|
||||||
|
|
||||||
WHERE `d`.`aliasdomain` IS NULL AND `d`.`email_only` <> '1'
|
WHERE `d`.`aliasdomain` IS NULL AND `d`.`email_only` <> '1'
|
||||||
ORDER BY `d`.`parentdomainid` DESC, `d`.`iswildcarddomain`, `d`.`domain` ASC;
|
ORDER BY `d`.`parentdomainid` DESC, `d`.`iswildcarddomain`, `d`.`domain` ASC;
|
||||||
";
|
";
|
||||||
|
|
||||||
$result_domains_stmt = Database::query($query);
|
$result_domains_stmt = Database::query($query);
|
||||||
|
|
||||||
|
// prepare IP statement
|
||||||
|
$ip_stmt = Database::prepare("
|
||||||
|
SELECT `di`.`id_domain` , `p`.`ssl`, `p`.`ssl_cert_file`, `p`.`ssl_key_file`, `p`.`ssl_ca_file`, `p`.`ssl_cert_chainfile`
|
||||||
|
FROM `" . TABLE_DOMAINTOIP . "` `di`, `" . TABLE_PANEL_IPSANDPORTS . "` `p`
|
||||||
|
WHERE `p`.`id` = `di`.`id_ipandports`
|
||||||
|
AND `di`.`id_domain` = :domainid
|
||||||
|
AND `p`.`ssl` = '1'
|
||||||
|
");
|
||||||
|
|
||||||
|
// prepare fpm-config select query
|
||||||
|
$fpm_sel_stmt = Database::prepare("
|
||||||
|
SELECT f.id FROM `" . TABLE_PANEL_FPMDAEMONS . "` f
|
||||||
|
LEFT JOIN `" . TABLE_PANEL_PHPCONFIGS . "` p ON p.fpmsettingid = f.id
|
||||||
|
WHERE p.id = :phpconfigid
|
||||||
|
");
|
||||||
|
|
||||||
$domains = array();
|
$domains = array();
|
||||||
while ($domain = $result_domains_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($domain = $result_domains_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
// set whole domain
|
// set whole domain
|
||||||
$domains[$domain['domain']] = $domain;
|
$domains[$domain['domain']] = $domain;
|
||||||
// set empty-defaults for non-ssl
|
// set empty-defaults for non-ssl
|
||||||
@@ -56,31 +73,38 @@ class WebserverBase {
|
|||||||
$domains[$domain['domain']]['ssl_key_file'] = '';
|
$domains[$domain['domain']]['ssl_key_file'] = '';
|
||||||
$domains[$domain['domain']]['ssl_ca_file'] = '';
|
$domains[$domain['domain']]['ssl_ca_file'] = '';
|
||||||
$domains[$domain['domain']]['ssl_cert_chainfile'] = '';
|
$domains[$domain['domain']]['ssl_cert_chainfile'] = '';
|
||||||
|
|
||||||
// now, if the domain has an ssl ip/port assigned, get
|
// now, if the domain has an ssl ip/port assigned, get
|
||||||
// the corresponding information from the db
|
// the corresponding information from the db
|
||||||
if (domainHasSslIpPort($domain['id'])) {
|
if (domainHasSslIpPort($domain['id'])) {
|
||||||
|
|
||||||
$ip_stmt = Database::prepare("
|
$ssl_ip = Database::pexecute_first($ip_stmt, array(
|
||||||
SELECT `di`.`id_domain` , `p`.`ssl`, `p`.`ssl_cert_file`, `p`.`ssl_key_file`, `p`.`ssl_ca_file`, `p`.`ssl_cert_chainfile`
|
'domainid' => $domain['id']
|
||||||
FROM `".TABLE_DOMAINTOIP."` `di`, `".TABLE_PANEL_IPSANDPORTS."` `p`
|
));
|
||||||
WHERE `p`.`id` = `di`.`id_ipandports`
|
|
||||||
AND `di`.`id_domain` = :domainid
|
|
||||||
AND `p`.`ssl` = '1'
|
|
||||||
");
|
|
||||||
$ssl_ip = Database::pexecute_first($ip_stmt, array('domainid' => $domain['id']));
|
|
||||||
|
|
||||||
// set ssl info for domain
|
// set ssl info for domain
|
||||||
$domains[$domain['domain']]['ssl'] = '1';
|
$domains[$domain['domain']]['ssl'] = '1';
|
||||||
$domains[$domain['domain']]['ssl_cert_file'] = $ssl_ip['ssl_cert_file'];
|
$domains[$domain['domain']]['ssl_cert_file'] = $ssl_ip['ssl_cert_file'];
|
||||||
$domains[$domain['domain']]['ssl_key_file'] = $ssl_ip['ssl_key_file'];
|
$domains[$domain['domain']]['ssl_key_file'] = $ssl_ip['ssl_key_file'];
|
||||||
$domains[$domain['domain']]['ssl_ca_file'] = $ssl_ip['ssl_ca_file'];
|
$domains[$domain['domain']]['ssl_ca_file'] = $ssl_ip['ssl_ca_file'];
|
||||||
$domains[$domain['domain']]['ssl_cert_chainfile'] = $ssl_ip['ssl_cert_chainfile'];
|
$domains[$domain['domain']]['ssl_cert_chainfile'] = $ssl_ip['ssl_cert_chainfile'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// read fpm-config-id if using fpm
|
||||||
|
if ((int) Settings::Get('phpfpm.enabled') == 1) {
|
||||||
|
|
||||||
|
$fpm_config = Database::pexecute_first($fpm_sel_stmt, array(
|
||||||
|
'phpconfigid' => $domain['phpsettingid']
|
||||||
|
));
|
||||||
|
if ($fpm_config) {
|
||||||
|
$domains[$domain['domain']]['fpm_config_id'] = $fpm_config['id'];
|
||||||
|
} else {
|
||||||
|
// fallback
|
||||||
|
$domains[$domain['domain']]['fpm_config_id'] = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $domains;
|
return $domains;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -353,7 +353,7 @@ exit "$RETVAL"
|
|||||||
<!--DNS -->
|
<!--DNS -->
|
||||||
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
||||||
<!--Bind9 -->
|
<!--Bind9 -->
|
||||||
<daemon name="bind" title="Bind9 nameserver">
|
<daemon name="bind" title="Bind9 nameserver" default="true">
|
||||||
<install><![CDATA[emerge net-dns/bind]]></install>
|
<install><![CDATA[emerge net-dns/bind]]></install>
|
||||||
<file name="/etc/bind/default.zone">
|
<file name="/etc/bind/default.zone">
|
||||||
<content><![CDATA[
|
<content><![CDATA[
|
||||||
@@ -2138,7 +2138,7 @@ protocol lda {
|
|||||||
driver = mysql
|
driver = mysql
|
||||||
connect = host=<SQL_HOST> dbname=<SQL_DB> user=<SQL_UNPRIVILEGED_USER> password=<SQL_UNPRIVILEGED_PASSWORD>
|
connect = host=<SQL_HOST> dbname=<SQL_DB> user=<SQL_UNPRIVILEGED_USER> password=<SQL_UNPRIVILEGED_PASSWORD>
|
||||||
default_pass_scheme = CRYPT
|
default_pass_scheme = CRYPT
|
||||||
password_query = "SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota,'M') AS userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR '%Ls' = 'smtp' OR '%Ls' = 'sieve')"
|
password_query = "SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota,'M') AS userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR ((postfix = 'Y' AND '%Ls' = 'smtp') OR (postfix = 'Y' AND '%Ls' = 'sieve')))"
|
||||||
user_query = "SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir, maildir) AS mail, uid, gid, CONCAT('*:storage=', quota,'M') AS quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u')"
|
user_query = "SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir, maildir) AS mail, uid, gid, CONCAT('*:storage=', quota,'M') AS quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u')"
|
||||||
iterate_query = "SELECT username AS user FROM mail_users WHERE (imap = 1 OR pop3 = 1)"
|
iterate_query = "SELECT username AS user FROM mail_users WHERE (imap = 1 OR pop3 = 1)"
|
||||||
]]>
|
]]>
|
||||||
@@ -3422,10 +3422,17 @@ MAILDIRPATH=.maildir
|
|||||||
<daemon name="proftpd" title="ProFTPd" default="true">
|
<daemon name="proftpd" title="ProFTPd" default="true">
|
||||||
<command><![CDATA[echo "net-ftp/proftpd mysql" >> /etc/portage/package.use]]></command>
|
<command><![CDATA[echo "net-ftp/proftpd mysql" >> /etc/portage/package.use]]></command>
|
||||||
<install><![CDATA[emerge net-ftp/proftpd]]></install>
|
<install><![CDATA[emerge net-ftp/proftpd]]></install>
|
||||||
<commands>
|
<file name="/etc/proftpd/create-cert.sh" chown="root:0" chmod="0700">
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
<content><![CDATA[#!/bin/bash
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
<command><![CDATA[chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key]]></command>
|
[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
|
chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[/etc/proftpd/create-cert.sh]]></command>
|
||||||
|
<command><![CDATA[rm -f /etc/proftpd/create-cert.sh]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
||||||
backup="true">
|
backup="true">
|
||||||
|
|||||||
@@ -48,6 +48,11 @@
|
|||||||
<include>//service[@type='http']/general/commands</include>
|
<include>//service[@type='http']/general/commands</include>
|
||||||
<command><![CDATA[a2dismod userdir]]></command>
|
<command><![CDATA[a2dismod userdir]]></command>
|
||||||
<command><![CDATA[a2enmod headers]]></command>
|
<command><![CDATA[a2enmod headers]]></command>
|
||||||
|
<command>
|
||||||
|
<visibility mode="true">{{settings.system.use_ssl}}
|
||||||
|
</visibility>
|
||||||
|
<content><![CDATA[a2enmod ssl]]></content>
|
||||||
|
</command>
|
||||||
<command>
|
<command>
|
||||||
<visibility mode="true">{{settings.phpfpm.enabled}}
|
<visibility mode="true">{{settings.phpfpm.enabled}}
|
||||||
</visibility>
|
</visibility>
|
||||||
@@ -365,7 +370,7 @@ exit "$RETVAL"
|
|||||||
<!--DNS -->
|
<!--DNS -->
|
||||||
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
||||||
<!--Bind9 -->
|
<!--Bind9 -->
|
||||||
<daemon name="bind" title="Bind9 nameserver">
|
<daemon name="bind" title="Bind9 nameserver" default="true">
|
||||||
<install><![CDATA[apt-get install bind9]]></install>
|
<install><![CDATA[apt-get install bind9]]></install>
|
||||||
<command><![CDATA[echo "include \"{{settings.system.bindconf_directory}}froxlor_bind.conf\";" >> /etc/bind/named.conf.local]]></command>
|
<command><![CDATA[echo "include \"{{settings.system.bindconf_directory}}froxlor_bind.conf\";" >> /etc/bind/named.conf.local]]></command>
|
||||||
<command><![CDATA[touch {{settings.system.bindconf_directory}}froxlor_bind.conf]]></command>
|
<command><![CDATA[touch {{settings.system.bindconf_directory}}froxlor_bind.conf]]></command>
|
||||||
@@ -2714,7 +2719,7 @@ user_query = SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir
|
|||||||
# SELECT userid AS user, password, \
|
# SELECT userid AS user, password, \
|
||||||
# home AS userdb_home, uid AS userdb_uid, gid AS userdb_gid \
|
# home AS userdb_home, uid AS userdb_uid, gid AS userdb_gid \
|
||||||
# FROM users WHERE userid = '%u'
|
# FROM users WHERE userid = '%u'
|
||||||
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota, 'M') as userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR '%Ls' = 'smtp' OR '%Ls' = 'sieve')
|
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota, 'M') as userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR ((postfix = 'Y' AND '%Ls' = 'smtp') OR (postfix = 'Y' AND '%Ls' = 'sieve')))
|
||||||
|
|
||||||
# Query to get a list of all usernames.
|
# Query to get a list of all usernames.
|
||||||
#iterate_query = SELECT username AS user FROM users
|
#iterate_query = SELECT username AS user FROM users
|
||||||
@@ -3814,10 +3819,17 @@ plugin {
|
|||||||
<!-- Proftpd -->
|
<!-- Proftpd -->
|
||||||
<daemon name="proftpd" title="ProFTPd" default="true">
|
<daemon name="proftpd" title="ProFTPd" default="true">
|
||||||
<install><![CDATA[apt-get install proftpd-basic proftpd-mod-mysql]]></install>
|
<install><![CDATA[apt-get install proftpd-basic proftpd-mod-mysql]]></install>
|
||||||
<commands>
|
<file name="/etc/proftpd/create-cert.sh" chown="root:0" chmod="0700">
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
<content><![CDATA[#!/bin/bash
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
<command><![CDATA[chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key]]></command>
|
[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
|
chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[/etc/proftpd/create-cert.sh]]></command>
|
||||||
|
<command><![CDATA[rm -f /etc/proftpd/create-cert.sh]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
||||||
backup="true">
|
backup="true">
|
||||||
@@ -4469,9 +4481,9 @@ PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
|
|||||||
<!-- libnss-mysql -->
|
<!-- libnss-mysql -->
|
||||||
<daemon name="libnss" title="libnss-mysql (required for FCGID/php-fpm/mpm-itk)">
|
<daemon name="libnss" title="libnss-mysql (required for FCGID/php-fpm/mpm-itk)">
|
||||||
<install><![CDATA[apt-get install nscd
|
<install><![CDATA[apt-get install nscd
|
||||||
wget http://ftp.us.debian.org/debian/pool/main/libn/libnss-mysql-bg/libnss-mysql-bg_1.5-5_`dpkg --print-architecture`.deb
|
wget http://debian.froxlor.org/pool/main/libn/libnss-mysql-bg/libnss-mysql-bg_1.5-3+frx1_amd64.deb
|
||||||
dpkg -i libnss-mysql-bg_1.5-5_`dpkg --print-architecture`.deb
|
dpkg -i libnss-mysql-bg_1.5-3+frx1_amd64.deb
|
||||||
rm libnss-mysql-bg_1.5-5_`dpkg --print-architecture`.deb
|
rm libnss-mysql-bg_1.5-3+frx1_amd64.deb
|
||||||
]]></install>
|
]]></install>
|
||||||
<file name="/etc/libnss-mysql.cfg" chown="root:root" chmod="0600"
|
<file name="/etc/libnss-mysql.cfg" chown="root:root" chmod="0600"
|
||||||
backup="true">
|
backup="true">
|
||||||
@@ -4634,6 +4646,44 @@ aliases: files
|
|||||||
</content>
|
</content>
|
||||||
</file>
|
</file>
|
||||||
</daemon>
|
</daemon>
|
||||||
|
<!-- libnss-extrausers -->
|
||||||
|
<daemon name="libnssextrausers" title="libnss-extrausers (alternative to libnss-mysql, required for FCGID/php-fpm/mpm-itk)">
|
||||||
|
<install><![CDATA[apt-get install nscd libnss-extrausers]]></install>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[mkdir -p /var/lib/extrausers]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/passwd]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/group]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/shadow]]></command>
|
||||||
|
</commands>
|
||||||
|
<file name="/etc/nsswitch.conf" backup="true">
|
||||||
|
<content><![CDATA[
|
||||||
|
# Make sure that `passwd`, `group` and `shadow` have extrausers in their lines
|
||||||
|
# You should place extrausers at the end, so that it is queried after the other mechanisams
|
||||||
|
#
|
||||||
|
passwd: compat extrausers
|
||||||
|
group: compat extrausers
|
||||||
|
shadow: compat extrausers
|
||||||
|
|
||||||
|
hosts: files dns
|
||||||
|
networks: files dns
|
||||||
|
|
||||||
|
services: db files
|
||||||
|
protocols: db files
|
||||||
|
rpc: db files
|
||||||
|
ethers: db files
|
||||||
|
netmasks: files
|
||||||
|
netgroup: files
|
||||||
|
bootparams: files
|
||||||
|
|
||||||
|
automount: files
|
||||||
|
aliases: files
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<command><![CDATA[/etc/init.d/nscd restart]]></command>
|
||||||
|
<!-- clear group chache -->
|
||||||
|
<command><![CDATA[nscd --invalidate=group]]></command>
|
||||||
|
</daemon>
|
||||||
<!-- Logrotate -->
|
<!-- Logrotate -->
|
||||||
<daemon name="logrotate" title="Logrotate">
|
<daemon name="logrotate" title="Logrotate">
|
||||||
<install><![CDATA[apt-get install logrotate]]></install>
|
<install><![CDATA[apt-get install logrotate]]></install>
|
||||||
@@ -4710,6 +4760,11 @@ aliases: files
|
|||||||
</visibility>
|
</visibility>
|
||||||
<command><![CDATA[a2dismod php5]]></command>
|
<command><![CDATA[a2dismod php5]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
|
<commands index="5">
|
||||||
|
<visibility mode="equals" value="apache2">{{settings.system.webserver}}
|
||||||
|
</visibility>
|
||||||
|
<command><![CDATA[/etc/init.d/apache2 restart]]></command>
|
||||||
|
</commands>
|
||||||
<!-- instead of just restarting apache, we let the cronjob do all the
|
<!-- instead of just restarting apache, we let the cronjob do all the
|
||||||
dirty work -->
|
dirty work -->
|
||||||
<command><![CDATA[php {{const.FROXLOR_INSTALL_DIR}}/scripts/froxlor_master_cronjob.php --force]]></command>
|
<command><![CDATA[php {{const.FROXLOR_INSTALL_DIR}}/scripts/froxlor_master_cronjob.php --force]]></command>
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<froxlor>
|
<froxlor>
|
||||||
<distribution name="Ubuntu" codename="Precise" version="12.04" defaulteditor="/usr/bin/nano">
|
<distribution name="Ubuntu" codename="Precise" version="12.04" defaulteditor="/usr/bin/nano" deprecated="true">
|
||||||
<services>
|
<services>
|
||||||
<!-- HTTP -->
|
<!-- HTTP -->
|
||||||
<service type="http" title="{{lng.admin.configfiles.http}}">
|
<service type="http" title="{{lng.admin.configfiles.http}}">
|
||||||
@@ -49,6 +49,11 @@
|
|||||||
<include>//service[@type='http']/general/commands</include>
|
<include>//service[@type='http']/general/commands</include>
|
||||||
<command><![CDATA[a2dismod userdir]]></command>
|
<command><![CDATA[a2dismod userdir]]></command>
|
||||||
<command><![CDATA[a2enmod headers]]></command>
|
<command><![CDATA[a2enmod headers]]></command>
|
||||||
|
<command>
|
||||||
|
<visibility mode="true">{{settings.system.use_ssl}}
|
||||||
|
</visibility>
|
||||||
|
<content><![CDATA[a2enmod ssl]]></content>
|
||||||
|
</command>
|
||||||
<file name="/etc/apache2/mods-enabled/fastcgi.conf">
|
<file name="/etc/apache2/mods-enabled/fastcgi.conf">
|
||||||
<visibility mode="true">{{settings.phpfpm.enabled}}
|
<visibility mode="true">{{settings.phpfpm.enabled}}
|
||||||
</visibility>
|
</visibility>
|
||||||
@@ -334,7 +339,7 @@ exit "$RETVAL"
|
|||||||
<!--DNS -->
|
<!--DNS -->
|
||||||
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
||||||
<!--Bind9 -->
|
<!--Bind9 -->
|
||||||
<daemon name="bind" title="Bind9 nameserver">
|
<daemon name="bind" title="Bind9 nameserver" default="true">
|
||||||
<install><![CDATA[apt-get install bind9]]></install>
|
<install><![CDATA[apt-get install bind9]]></install>
|
||||||
<command><![CDATA[echo "include \"{{settings.system.bindconf_directory}}froxlor_bind.conf\";" >> /etc/bind/named.conf]]></command>
|
<command><![CDATA[echo "include \"{{settings.system.bindconf_directory}}froxlor_bind.conf\";" >> /etc/bind/named.conf]]></command>
|
||||||
<command><![CDATA[touch {{settings.system.bindconf_directory}}froxlor_bind.conf]]></command>
|
<command><![CDATA[touch {{settings.system.bindconf_directory}}froxlor_bind.conf]]></command>
|
||||||
@@ -726,7 +731,7 @@ smtpd_sasl_local_domain = $myhostname
|
|||||||
broken_sasl_auth_clients = yes
|
broken_sasl_auth_clients = yes
|
||||||
|
|
||||||
# Virtual delivery settings
|
# Virtual delivery settings
|
||||||
virtual_mailbox_base = <VIRTUAL_MAILBOX_BASE>
|
virtual_mailbox_base = /
|
||||||
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual_mailbox_maps.cf
|
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual_mailbox_maps.cf
|
||||||
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual_mailbox_domains.cf
|
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual_mailbox_domains.cf
|
||||||
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual_alias_maps.cf
|
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual_alias_maps.cf
|
||||||
@@ -1029,7 +1034,7 @@ userdb {
|
|||||||
driver = mysql
|
driver = mysql
|
||||||
connect = host=<SQL_HOST> dbname=<SQL_DB> user=<SQL_UNPRIVILEGED_USER> password=<SQL_UNPRIVILEGED_PASSWORD>
|
connect = host=<SQL_HOST> dbname=<SQL_DB> user=<SQL_UNPRIVILEGED_USER> password=<SQL_UNPRIVILEGED_PASSWORD>
|
||||||
default_pass_scheme = CRYPT
|
default_pass_scheme = CRYPT
|
||||||
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('maildir:storage=', (quota*1024)) as userdb_quota FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR '%Ls' = 'smtp' OR '%Ls' = 'sieve')
|
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('maildir:storage=', (quota*1024)) as userdb_quota FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR ((postfix = 'Y' AND '%Ls' = 'smtp') OR (postfix = 'Y' AND '%Ls' = 'sieve')))
|
||||||
user_query = SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir, maildir) AS mail, uid, gid, CONCAT('maildir:storage=', (quota*1024)) as quota FROM mail_users WHERE (username = '%u' OR email = '%u')
|
user_query = SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir, maildir) AS mail, uid, gid, CONCAT('maildir:storage=', (quota*1024)) as quota FROM mail_users WHERE (username = '%u' OR email = '%u')
|
||||||
iterate_query = SELECT username AS user FROM mail_users WHERE (imap = 1 OR pop3 = 1)
|
iterate_query = SELECT username AS user FROM mail_users WHERE (imap = 1 OR pop3 = 1)
|
||||||
]]>
|
]]>
|
||||||
@@ -1143,10 +1148,17 @@ MYSQL_AUXOPTIONS_FIELD CONCAT("allowimap=",imap,",allowpop3=",pop3)
|
|||||||
<!-- Proftpd -->
|
<!-- Proftpd -->
|
||||||
<daemon name="proftpd" title="ProFTPd" default="true">
|
<daemon name="proftpd" title="ProFTPd" default="true">
|
||||||
<install><![CDATA[apt-get install proftpd-basic proftpd-mod-mysql]]></install>
|
<install><![CDATA[apt-get install proftpd-basic proftpd-mod-mysql]]></install>
|
||||||
<commands>
|
<file name="/etc/proftpd/create-cert.sh" chown="root:0" chmod="0700">
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
<content><![CDATA[#!/bin/bash
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
<command><![CDATA[chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key]]></command>
|
[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
|
chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[/etc/proftpd/create-cert.sh]]></command>
|
||||||
|
<command><![CDATA[rm -f /etc/proftpd/create-cert.sh]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
||||||
backup="true">
|
backup="true">
|
||||||
@@ -1624,6 +1636,44 @@ netmasks: files
|
|||||||
netgroup: files
|
netgroup: files
|
||||||
bootparams: files
|
bootparams: files
|
||||||
|
|
||||||
|
automount: files
|
||||||
|
aliases: files
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<command><![CDATA[/etc/init.d/nscd restart]]></command>
|
||||||
|
<!-- clear group chache -->
|
||||||
|
<command><![CDATA[nscd --invalidate=group]]></command>
|
||||||
|
</daemon>
|
||||||
|
<!-- libnss-extrausers -->
|
||||||
|
<daemon name="libnssextrausers" title="libnss-extrausers (alternative to libnss-mysql, required for FCGID/php-fpm/mpm-itk)">
|
||||||
|
<install><![CDATA[apt-get install nscd libnss-extrausers]]></install>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[mkdir -p /var/lib/extrausers]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/passwd]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/group]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/shadow]]></command>
|
||||||
|
</commands>
|
||||||
|
<file name="/etc/nsswitch.conf" backup="true">
|
||||||
|
<content><![CDATA[
|
||||||
|
# Make sure that `passwd`, `group` and `shadow` have extrausers in their lines
|
||||||
|
# You should place extrausers at the end, so that it is queried after the other mechanisams
|
||||||
|
#
|
||||||
|
passwd: compat extrausers
|
||||||
|
group: compat extrausers
|
||||||
|
shadow: compat extrausers
|
||||||
|
|
||||||
|
hosts: files dns
|
||||||
|
networks: files dns
|
||||||
|
|
||||||
|
services: db files
|
||||||
|
protocols: db files
|
||||||
|
rpc: db files
|
||||||
|
ethers: db files
|
||||||
|
netmasks: files
|
||||||
|
netgroup: files
|
||||||
|
bootparams: files
|
||||||
|
|
||||||
automount: files
|
automount: files
|
||||||
aliases: files
|
aliases: files
|
||||||
]]>
|
]]>
|
||||||
@@ -1709,6 +1759,11 @@ aliases: files
|
|||||||
</visibility>
|
</visibility>
|
||||||
<command><![CDATA[a2dismod php5]]></command>
|
<command><![CDATA[a2dismod php5]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
|
<commands index="5">
|
||||||
|
<visibility mode="equals" value="apache2">{{settings.system.webserver}}
|
||||||
|
</visibility>
|
||||||
|
<command><![CDATA[/etc/init.d/apache2 restart]]></command>
|
||||||
|
</commands>
|
||||||
<!-- instead of just restarting apache, we let the cronjob do all the
|
<!-- instead of just restarting apache, we let the cronjob do all the
|
||||||
dirty work -->
|
dirty work -->
|
||||||
<command><![CDATA[php {{const.FROXLOR_INSTALL_DIR}}/scripts/froxlor_master_cronjob.php --force]]></command>
|
<command><![CDATA[php {{const.FROXLOR_INSTALL_DIR}}/scripts/froxlor_master_cronjob.php --force]]></command>
|
||||||
|
|||||||
@@ -1774,7 +1774,7 @@ default_pass_scheme = CRYPT
|
|||||||
#password_query = \
|
#password_query = \
|
||||||
# SELECT username, domain, password \
|
# SELECT username, domain, password \
|
||||||
# FROM users WHERE username = '%n' AND domain = '%d'
|
# FROM users WHERE username = '%n' AND domain = '%d'
|
||||||
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota, 'M') as userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR '%Ls' = 'smtp' OR '%Ls' = 'sieve')
|
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota, 'M') as userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR ((postfix = 'Y' AND '%Ls' = 'smtp') OR (postfix = 'Y' AND '%Ls' = 'sieve')))
|
||||||
#password_query = SELECT username as user, password, '/var/vmail/%d/%n' as userdb_home, 'maildir:/var/vmail/%d/%n' as userdb_mail, 150 as userdb_uid, 12 as userdb_gid FROM mailbox WHERE username = '%u' AND active = '1'
|
#password_query = SELECT username as user, password, '/var/vmail/%d/%n' as userdb_home, 'maildir:/var/vmail/%d/%n' as userdb_mail, 150 as userdb_uid, 12 as userdb_gid FROM mailbox WHERE username = '%u' AND active = '1'
|
||||||
|
|
||||||
# userdb query to retrieve the user information. It can return fields:
|
# userdb query to retrieve the user information. It can return fields:
|
||||||
@@ -2089,7 +2089,7 @@ LoadModule mod_ctrls_admin.c
|
|||||||
# (http://www.castaglia.org/proftpd/modules/mod_vroot.html)
|
# (http://www.castaglia.org/proftpd/modules/mod_vroot.html)
|
||||||
# Using this module rather than the kernel's chroot() system call works
|
# Using this module rather than the kernel's chroot() system call works
|
||||||
# around issues with PAM and chroot (http://bugzilla.redhat.com/506735)
|
# around issues with PAM and chroot (http://bugzilla.redhat.com/506735)
|
||||||
LoadModule mod_vroot.c
|
# LoadModule mod_vroot.c
|
||||||
#
|
#
|
||||||
# Provide a flexible way of specifying that certain configuration directives
|
# Provide a flexible way of specifying that certain configuration directives
|
||||||
# only apply to certain sessions, based on credentials such as connection
|
# only apply to certain sessions, based on credentials such as connection
|
||||||
|
|||||||
4669
lib/configfiles/stretch.xml
Normal file
4669
lib/configfiles/stretch.xml
Normal file
File diff suppressed because it is too large
Load Diff
@@ -49,6 +49,11 @@
|
|||||||
<include>//service[@type='http']/general/commands</include>
|
<include>//service[@type='http']/general/commands</include>
|
||||||
<command><![CDATA[a2dismod userdir]]></command>
|
<command><![CDATA[a2dismod userdir]]></command>
|
||||||
<command><![CDATA[a2enmod headers]]></command>
|
<command><![CDATA[a2enmod headers]]></command>
|
||||||
|
<command>
|
||||||
|
<visibility mode="true">{{settings.system.use_ssl}}
|
||||||
|
</visibility>
|
||||||
|
<content><![CDATA[a2enmod ssl]]></content>
|
||||||
|
</command>
|
||||||
<file name="/etc/apache2/mods-enabled/fastcgi.conf">
|
<file name="/etc/apache2/mods-enabled/fastcgi.conf">
|
||||||
<visibility mode="true">{{settings.phpfpm.enabled}}
|
<visibility mode="true">{{settings.phpfpm.enabled}}
|
||||||
</visibility>
|
</visibility>
|
||||||
@@ -85,6 +90,11 @@ Alias "/.well-known/acme-challenge" "{{settings.system.letsencryptchallengepath}
|
|||||||
<include>//service[@type='http']/general/commands</include>
|
<include>//service[@type='http']/general/commands</include>
|
||||||
<command><![CDATA[a2dismod userdir]]></command>
|
<command><![CDATA[a2dismod userdir]]></command>
|
||||||
<command><![CDATA[a2enmod headers]]></command>
|
<command><![CDATA[a2enmod headers]]></command>
|
||||||
|
<command>
|
||||||
|
<visibility mode="true">{{settings.system.use_ssl}}
|
||||||
|
</visibility>
|
||||||
|
<content><![CDATA[a2enmod ssl]]></content>
|
||||||
|
</command>
|
||||||
<file name="/etc/apache2/mods-enabled/fastcgi.conf">
|
<file name="/etc/apache2/mods-enabled/fastcgi.conf">
|
||||||
<visibility mode="true">{{settings.phpfpm.enabled}}
|
<visibility mode="true">{{settings.phpfpm.enabled}}
|
||||||
</visibility>
|
</visibility>
|
||||||
@@ -367,7 +377,7 @@ exit "$RETVAL"
|
|||||||
<!--DNS -->
|
<!--DNS -->
|
||||||
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
<service type="dns" title="{{lng.admin.configfiles.dns}}">
|
||||||
<!--Bind9 -->
|
<!--Bind9 -->
|
||||||
<daemon name="bind" title="Bind9 nameserver">
|
<daemon name="bind" title="Bind9 nameserver" default="true">
|
||||||
<install><![CDATA[apt-get install bind9]]></install>
|
<install><![CDATA[apt-get install bind9]]></install>
|
||||||
<command><![CDATA[echo "include \"{{settings.system.bindconf_directory}}froxlor_bind.conf\";" >> /etc/bind/named.conf]]></command>
|
<command><![CDATA[echo "include \"{{settings.system.bindconf_directory}}froxlor_bind.conf\";" >> /etc/bind/named.conf]]></command>
|
||||||
<command><![CDATA[touch {{settings.system.bindconf_directory}}froxlor_bind.conf]]></command>
|
<command><![CDATA[touch {{settings.system.bindconf_directory}}froxlor_bind.conf]]></command>
|
||||||
@@ -761,7 +771,7 @@ smtpd_sasl_local_domain = $myhostname
|
|||||||
broken_sasl_auth_clients = yes
|
broken_sasl_auth_clients = yes
|
||||||
|
|
||||||
# Virtual delivery settings
|
# Virtual delivery settings
|
||||||
virtual_mailbox_base = <VIRTUAL_MAILBOX_BASE>
|
virtual_mailbox_base = /
|
||||||
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual_mailbox_maps.cf
|
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual_mailbox_maps.cf
|
||||||
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual_mailbox_domains.cf
|
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual_mailbox_domains.cf
|
||||||
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual_alias_maps.cf
|
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual_alias_maps.cf
|
||||||
@@ -1038,7 +1048,7 @@ auth_mechanisms = plain login
|
|||||||
driver = mysql
|
driver = mysql
|
||||||
connect = host=<SQL_HOST> dbname=<SQL_DB> user=<SQL_UNPRIVILEGED_USER> password=<SQL_UNPRIVILEGED_PASSWORD>
|
connect = host=<SQL_HOST> dbname=<SQL_DB> user=<SQL_UNPRIVILEGED_USER> password=<SQL_UNPRIVILEGED_PASSWORD>
|
||||||
default_pass_scheme = CRYPT
|
default_pass_scheme = CRYPT
|
||||||
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota, 'M') as userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR '%Ls' = 'smtp' OR '%Ls' = 'sieve')
|
password_query = SELECT username AS user, password_enc AS password, CONCAT(homedir, maildir) AS userdb_home, uid AS userdb_uid, gid AS userdb_gid, CONCAT('maildir:', homedir, maildir) AS userdb_mail, CONCAT('*:storage=', quota, 'M') as userdb_quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u') AND ((imap = 1 AND '%Ls' = 'imap') OR (pop3 = 1 AND '%Ls' = 'pop3') OR ((postfix = 'Y' AND '%Ls' = 'smtp') OR (postfix = 'Y' AND '%Ls' = 'sieve')))
|
||||||
user_query = SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir, maildir) AS mail, uid, gid, CONCAT('*:storage=', quota, 'M') as quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u')
|
user_query = SELECT CONCAT(homedir, maildir) AS home, CONCAT('maildir:', homedir, maildir) AS mail, uid, gid, CONCAT('*:storage=', quota, 'M') as quota_rule FROM mail_users WHERE (username = '%u' OR email = '%u')
|
||||||
iterate_query = SELECT username AS user FROM mail_users WHERE (imap = 1 OR pop3 = 1)
|
iterate_query = SELECT username AS user FROM mail_users WHERE (imap = 1 OR pop3 = 1)
|
||||||
]]>
|
]]>
|
||||||
@@ -1152,10 +1162,17 @@ MYSQL_AUXOPTIONS_FIELD CONCAT("allowimap=",imap,",allowpop3=",pop3)
|
|||||||
<!-- Proftpd -->
|
<!-- Proftpd -->
|
||||||
<daemon name="proftpd" title="ProFTPd" default="true">
|
<daemon name="proftpd" title="ProFTPd" default="true">
|
||||||
<install><![CDATA[apt-get install proftpd-basic proftpd-mod-mysql]]></install>
|
<install><![CDATA[apt-get install proftpd-basic proftpd-mod-mysql]]></install>
|
||||||
<commands>
|
<file name="/etc/proftpd/create-cert.sh" chown="root:0" chmod="0700">
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
<content><![CDATA[#!/bin/bash
|
||||||
<command><![CDATA[[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"]]></command>
|
[ -f /etc/ssl/certs/proftpd.crt ] || openssl req -new -x509 -newkey rsa:4096 -days 3650 -nodes -out /etc/ssl/certs/proftpd.crt -keyout /etc/ssl/private/proftpd.key -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
<command><![CDATA[chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key]]></command>
|
[ -f /etc/ssl/certs/proftpd_ec.crt ] || openssl req -new -x509 -nodes -newkey ec:<(openssl ecparam -name secp521r1) -keyout /etc/ssl/private/proftpd_ec.key -out /etc/ssl/certs/proftpd_ec.crt -days 3650 -subj "/C=US/ST=Some-State/O=Internet Widgits Pty Ltd/CN=<SERVERNAME>"
|
||||||
|
chmod 0600 /etc/ssl/private/proftpd.key /etc/ssl/private/proftpd_ec.key
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[/etc/proftpd/create-cert.sh]]></command>
|
||||||
|
<command><![CDATA[rm -f /etc/proftpd/create-cert.sh]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
<file name="/etc/proftpd/proftpd.conf" chown="root:0" chmod="0600"
|
||||||
backup="true">
|
backup="true">
|
||||||
@@ -1642,6 +1659,44 @@ aliases: files
|
|||||||
<!-- clear group chache -->
|
<!-- clear group chache -->
|
||||||
<command><![CDATA[nscd --invalidate=group]]></command>
|
<command><![CDATA[nscd --invalidate=group]]></command>
|
||||||
</daemon>
|
</daemon>
|
||||||
|
<!-- libnss-extrausers -->
|
||||||
|
<daemon name="libnssextrausers" title="libnss-extrausers (alternative to libnss-mysql, required for FCGID/php-fpm/mpm-itk)">
|
||||||
|
<install><![CDATA[apt-get install nscd libnss-extrausers]]></install>
|
||||||
|
<commands index="1">
|
||||||
|
<command><![CDATA[mkdir -p /var/lib/extrausers]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/passwd]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/group]]></command>
|
||||||
|
<command><![CDATA[touch /var/lib/extrausers/shadow]]></command>
|
||||||
|
</commands>
|
||||||
|
<file name="/etc/nsswitch.conf" backup="true">
|
||||||
|
<content><![CDATA[
|
||||||
|
# Make sure that `passwd`, `group` and `shadow` have extrausers in their lines
|
||||||
|
# You should place extrausers at the end, so that it is queried after the other mechanisams
|
||||||
|
#
|
||||||
|
passwd: compat extrausers
|
||||||
|
group: compat extrausers
|
||||||
|
shadow: compat extrausers
|
||||||
|
|
||||||
|
hosts: files dns
|
||||||
|
networks: files dns
|
||||||
|
|
||||||
|
services: db files
|
||||||
|
protocols: db files
|
||||||
|
rpc: db files
|
||||||
|
ethers: db files
|
||||||
|
netmasks: files
|
||||||
|
netgroup: files
|
||||||
|
bootparams: files
|
||||||
|
|
||||||
|
automount: files
|
||||||
|
aliases: files
|
||||||
|
]]>
|
||||||
|
</content>
|
||||||
|
</file>
|
||||||
|
<command><![CDATA[/etc/init.d/nscd restart]]></command>
|
||||||
|
<!-- clear group chache -->
|
||||||
|
<command><![CDATA[nscd --invalidate=group]]></command>
|
||||||
|
</daemon>
|
||||||
<!-- Logrotate -->
|
<!-- Logrotate -->
|
||||||
<daemon name="logrotate" title="Logrotate">
|
<daemon name="logrotate" title="Logrotate">
|
||||||
<install><![CDATA[apt-get install logrotate]]></install>
|
<install><![CDATA[apt-get install logrotate]]></install>
|
||||||
@@ -1718,6 +1773,11 @@ aliases: files
|
|||||||
</visibility>
|
</visibility>
|
||||||
<command><![CDATA[a2dismod php5]]></command>
|
<command><![CDATA[a2dismod php5]]></command>
|
||||||
</commands>
|
</commands>
|
||||||
|
<commands index="5">
|
||||||
|
<visibility mode="equals" value="apache2">{{settings.system.webserver}}
|
||||||
|
</visibility>
|
||||||
|
<command><![CDATA[/etc/init.d/apache2 restart]]></command>
|
||||||
|
</commands>
|
||||||
<!-- instead of just restarting apache, we let the cronjob do all the
|
<!-- instead of just restarting apache, we let the cronjob do all the
|
||||||
dirty work -->
|
dirty work -->
|
||||||
<command><![CDATA[php {{const.FROXLOR_INSTALL_DIR}}/scripts/froxlor_master_cronjob.php --force]]></command>
|
<command><![CDATA[php {{const.FROXLOR_INSTALL_DIR}}/scripts/froxlor_master_cronjob.php --force]]></command>
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -205,6 +205,7 @@ if (hasUpdates($version) || hasDbUpdates($dbversion)
|
|||||||
fwrite($debugHandler, '*** WARNING *** - all new settings etc. will be stored with the default value, that might not always be right for your system!' . "\n");
|
fwrite($debugHandler, '*** WARNING *** - all new settings etc. will be stored with the default value, that might not always be right for your system!' . "\n");
|
||||||
fwrite($debugHandler, "*** WARNING *** - If you don't want this to happen in the future consider removing the --allow-autoupdate flag from the cronjob\n");
|
fwrite($debugHandler, "*** WARNING *** - If you don't want this to happen in the future consider removing the --allow-autoupdate flag from the cronjob\n");
|
||||||
// including update procedures
|
// including update procedures
|
||||||
|
define('_CRON_UPDATE', 1);
|
||||||
include_once FROXLOR_INSTALL_DIR.'/install/updatesql.php';
|
include_once FROXLOR_INSTALL_DIR.'/install/updatesql.php';
|
||||||
// pew - everything went better than expected
|
// pew - everything went better than expected
|
||||||
$cronlog->logAction(CRON_ACTION, LOG_WARNING, 'Automatic update done - you should check your settings to be sure everything is fine');
|
$cronlog->logAction(CRON_ACTION, LOG_WARNING, 'Automatic update done - you should check your settings to be sure everything is fine');
|
||||||
|
|||||||
@@ -14,7 +14,6 @@
|
|||||||
* @package Formfields
|
* @package Formfields
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'customer_add' => array(
|
'customer_add' => array(
|
||||||
'title' => $lng['admin']['customer_add'],
|
'title' => $lng['admin']['customer_add'],
|
||||||
@@ -29,20 +28,30 @@ return array(
|
|||||||
'type' => 'text'
|
'type' => 'text'
|
||||||
),
|
),
|
||||||
'createstdsubdomain' => array(
|
'createstdsubdomain' => array(
|
||||||
'label' => $lng['admin']['stdsubdomain_add'].'?',
|
'label' => $lng['admin']['stdsubdomain_add'] . '?',
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
'value' => array('1')
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
)
|
||||||
),
|
),
|
||||||
'store_defaultindex' => array(
|
'store_defaultindex' => array(
|
||||||
'label' => $lng['admin']['store_defaultindex'].'?',
|
'label' => $lng['admin']['store_defaultindex'] . '?',
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
'value' => array('1')
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
)
|
||||||
),
|
),
|
||||||
'new_customer_password' => array(
|
'new_customer_password' => array(
|
||||||
'label' => $lng['login']['password'],
|
'label' => $lng['login']['password'],
|
||||||
@@ -53,15 +62,20 @@ return array(
|
|||||||
'label' => $lng['customer']['generated_pwd'],
|
'label' => $lng['customer']['generated_pwd'],
|
||||||
'type' => 'text',
|
'type' => 'text',
|
||||||
'visible' => (Settings::Get('panel.password_regex') == ''),
|
'visible' => (Settings::Get('panel.password_regex') == ''),
|
||||||
'value' => generatePassword(),
|
'value' => generatePassword()
|
||||||
),
|
),
|
||||||
'sendpassword' => array(
|
'sendpassword' => array(
|
||||||
'label' => $lng['admin']['sendpassword'],
|
'label' => $lng['admin']['sendpassword'],
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
'value' => array('1')
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
)
|
||||||
),
|
),
|
||||||
'def_language' => array(
|
'def_language' => array(
|
||||||
'label' => $lng['login']['language'],
|
'label' => $lng['login']['language'],
|
||||||
@@ -135,12 +149,27 @@ return array(
|
|||||||
'label' => $lng['usersettings']['custom_notes']['show'],
|
'label' => $lng['usersettings']['custom_notes']['show'],
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
),
|
),
|
||||||
'value' => array()
|
'value' => array()
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
'section_cpre' => array(
|
||||||
|
'visible' => !empty($hosting_plans),
|
||||||
|
'title' => $lng['admin']['plans']['use_plan'],
|
||||||
|
'image' => 'icons/user_add.png',
|
||||||
|
'fields' => array(
|
||||||
|
'use_plan' => array(
|
||||||
|
'label' => $lng['admin']['plans']['use_plan'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $hosting_plans
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
'section_c' => array(
|
'section_c' => array(
|
||||||
'title' => $lng['admin']['servicedata'],
|
'title' => $lng['admin']['servicedata'],
|
||||||
'image' => 'icons/user_add.png',
|
'image' => 'icons/user_add.png',
|
||||||
@@ -149,7 +178,7 @@ return array(
|
|||||||
'label' => $lng['customer']['diskspace'],
|
'label' => $lng['customer']['diskspace'],
|
||||||
'type' => 'textul',
|
'type' => 'textul',
|
||||||
'value' => 0,
|
'value' => 0,
|
||||||
'maxlength' => 6,
|
'maxlength' => 16,
|
||||||
'mandatory' => true,
|
'mandatory' => true,
|
||||||
'ul_field' => $diskspace_ul
|
'ul_field' => $diskspace_ul
|
||||||
),
|
),
|
||||||
@@ -157,7 +186,7 @@ return array(
|
|||||||
'label' => $lng['customer']['traffic'],
|
'label' => $lng['customer']['traffic'],
|
||||||
'type' => 'textul',
|
'type' => 'textul',
|
||||||
'value' => 0,
|
'value' => 0,
|
||||||
'maxlength' => 4,
|
'maxlength' => 14,
|
||||||
'mandatory' => true,
|
'mandatory' => true,
|
||||||
'ul_field' => $traffic_ul
|
'ul_field' => $traffic_ul
|
||||||
),
|
),
|
||||||
@@ -206,18 +235,28 @@ return array(
|
|||||||
'label' => $lng['customer']['email_imap'],
|
'label' => $lng['customer']['email_imap'],
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
'value' => array('1'),
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
),
|
||||||
'mandatory' => true
|
'mandatory' => true
|
||||||
),
|
),
|
||||||
'email_pop3' => array(
|
'email_pop3' => array(
|
||||||
'label' => $lng['customer']['email_pop3'],
|
'label' => $lng['customer']['email_pop3'],
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
'value' => array('1'),
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
),
|
||||||
'mandatory' => true
|
'mandatory' => true
|
||||||
),
|
),
|
||||||
'ftps' => array(
|
'ftps' => array(
|
||||||
@@ -244,28 +283,51 @@ return array(
|
|||||||
'ul_field' => $mysqls_ul
|
'ul_field' => $mysqls_ul
|
||||||
),
|
),
|
||||||
'phpenabled' => array(
|
'phpenabled' => array(
|
||||||
'label' => $lng['admin']['phpenabled'].'?',
|
'label' => $lng['admin']['phpenabled'] . '?',
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
'value' => array('1')
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'allowed_phpconfigs' => array(
|
||||||
|
'visible' => (((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['title'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => $phpconfigs,
|
||||||
|
'value' => ((int) Settings::Get('system.mod_fcgid') == 1 ? array(
|
||||||
|
Settings::Get('system.mod_fcgid_defaultini')
|
||||||
|
) : (int) Settings::Get('phpfpm.enabled') == 1 ? array(
|
||||||
|
Settings::Get('phpfpm.defaultini')
|
||||||
|
) : array()),
|
||||||
|
'is_array' => 1
|
||||||
),
|
),
|
||||||
'perlenabled' => array(
|
'perlenabled' => array(
|
||||||
'label' => $lng['admin']['perlenabled'].'?',
|
'label' => $lng['admin']['perlenabled'] . '?',
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
)
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
)
|
||||||
),
|
),
|
||||||
'dnsenabled' => array(
|
'dnsenabled' => array(
|
||||||
'label' => $lng['admin']['dnsenabled'].'?',
|
'label' => $lng['admin']['dnsenabled'] . '?',
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
'values' => array(
|
'values' => array(
|
||||||
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
array(
|
||||||
),
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
'visible' => (Settings::Get('system.dnsenabled') == '1' ? true : false)
|
'visible' => (Settings::Get('system.dnsenabled') == '1' ? true : false)
|
||||||
),
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -150,6 +150,18 @@ return array(
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
'section_cpre' => array(
|
||||||
|
'visible' => !empty($hosting_plans),
|
||||||
|
'title' => $lng['admin']['plans']['use_plan'],
|
||||||
|
'image' => 'icons/user_add.png',
|
||||||
|
'fields' => array(
|
||||||
|
'use_plan' => array(
|
||||||
|
'label' => $lng['admin']['plans']['use_plan'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $hosting_plans
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
'section_c' => array(
|
'section_c' => array(
|
||||||
'title' => $lng['admin']['servicedata'],
|
'title' => $lng['admin']['servicedata'],
|
||||||
'image' => 'icons/user_edit.png',
|
'image' => 'icons/user_edit.png',
|
||||||
@@ -158,7 +170,7 @@ return array(
|
|||||||
'label' => $lng['customer']['diskspace'],
|
'label' => $lng['customer']['diskspace'],
|
||||||
'type' => 'textul',
|
'type' => 'textul',
|
||||||
'value' => $result['diskspace'],
|
'value' => $result['diskspace'],
|
||||||
'maxlength' => 6,
|
'maxlength' => 16,
|
||||||
'mandatory' => true,
|
'mandatory' => true,
|
||||||
'ul_field' => $diskspace_ul
|
'ul_field' => $diskspace_ul
|
||||||
),
|
),
|
||||||
@@ -166,7 +178,7 @@ return array(
|
|||||||
'label' => $lng['customer']['traffic'],
|
'label' => $lng['customer']['traffic'],
|
||||||
'type' => 'textul',
|
'type' => 'textul',
|
||||||
'value' => $result['traffic'],
|
'value' => $result['traffic'],
|
||||||
'maxlength' => 4,
|
'maxlength' => 14,
|
||||||
'mandatory' => true,
|
'mandatory' => true,
|
||||||
'ul_field' => $traffic_ul
|
'ul_field' => $traffic_ul
|
||||||
),
|
),
|
||||||
@@ -260,6 +272,14 @@ return array(
|
|||||||
),
|
),
|
||||||
'value' => array($result['phpenabled'])
|
'value' => array($result['phpenabled'])
|
||||||
),
|
),
|
||||||
|
'allowed_phpconfigs' => array(
|
||||||
|
'visible' => (((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['title'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => $phpconfigs,
|
||||||
|
'value' => isset($result['allowed_phpconfigs']) && !empty($result['allowed_phpconfigs']) ? json_decode($result['allowed_phpconfigs'], JSON_OBJECT_AS_ARRAY) : array(),
|
||||||
|
'is_array' => 1
|
||||||
|
),
|
||||||
'perlenabled' => array(
|
'perlenabled' => array(
|
||||||
'label' => $lng['admin']['perlenabled'].'?',
|
'label' => $lng['admin']['perlenabled'].'?',
|
||||||
'type' => 'checkbox',
|
'type' => 'checkbox',
|
||||||
|
|||||||
@@ -131,6 +131,19 @@ return array(
|
|||||||
'type' => 'textarea',
|
'type' => 'textarea',
|
||||||
'cols' => 60,
|
'cols' => 60,
|
||||||
'rows' => 12
|
'rows' => 12
|
||||||
|
),
|
||||||
|
'notryfiles' => array(
|
||||||
|
'visible' => (Settings::Get('system.webserver') == 'nginx' && $userinfo['change_serversettings'] == '1'),
|
||||||
|
'label' => $lng['admin']['notryfiles']['title'],
|
||||||
|
'desc' => $lng['admin']['notryfiles']['description'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array(
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array()
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
@@ -173,6 +186,19 @@ return array(
|
|||||||
),
|
),
|
||||||
'value' => array()
|
'value' => array()
|
||||||
),
|
),
|
||||||
|
'http2' => array(
|
||||||
|
'visible' => ($ssl_ipsandports != '' ? true : false) && Settings::Get('system.webserver') != 'lighttpd' && Settings::Get('system.http2_support') == '1',
|
||||||
|
'label' => $lng['admin']['domain_http2']['title'],
|
||||||
|
'desc' => $lng['admin']['domain_http2']['description'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array (
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array()
|
||||||
|
),
|
||||||
'no_ssl_available_info' => array(
|
'no_ssl_available_info' => array(
|
||||||
'visible' => ($ssl_ipsandports == '' ? true : false),
|
'visible' => ($ssl_ipsandports == '' ? true : false),
|
||||||
'label' => 'SSL',
|
'label' => 'SSL',
|
||||||
@@ -213,7 +239,24 @@ return array(
|
|||||||
)
|
)
|
||||||
),
|
),
|
||||||
'value' => array()
|
'value' => array()
|
||||||
)
|
),
|
||||||
|
'ocsp_stapling' => array(
|
||||||
|
'visible' => ($ssl_ipsandports != '' ? true : false) &&
|
||||||
|
Settings::Get('system.webserver') != 'lighttpd',
|
||||||
|
'label' => $lng['admin']['domain_ocsp_stapling']['title'],
|
||||||
|
'desc' => $lng['admin']['domain_ocsp_stapling']['description'] .
|
||||||
|
(Settings::Get('system.webserver') == 'nginx' ?
|
||||||
|
$lng['admin']['domain_ocsp_stapling']['nginx_version_warning'] :
|
||||||
|
""),
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array (
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array()
|
||||||
|
),
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
'section_c' => array(
|
'section_c' => array(
|
||||||
|
|||||||
@@ -161,6 +161,21 @@ return array(
|
|||||||
'value' => array(
|
'value' => array(
|
||||||
'1'
|
'1'
|
||||||
)
|
)
|
||||||
|
),
|
||||||
|
'notryfiles' => array(
|
||||||
|
'visible' => (Settings::Get('system.webserver') == 'nginx' && $userinfo['change_serversettings'] == '1'),
|
||||||
|
'label' => $lng['admin']['notryfiles']['title'],
|
||||||
|
'desc' => $lng['admin']['notryfiles']['description'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array(
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
$result['notryfiles']
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
@@ -207,6 +222,21 @@ return array(
|
|||||||
$result['letsencrypt']
|
$result['letsencrypt']
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
'http2' => array(
|
||||||
|
'visible' => ($ssl_ipsandports != '' ? true : false) && Settings::Get('system.webserver') != 'lighttpd' && Settings::Get('system.http2_support') == '1',
|
||||||
|
'label' => $lng['admin']['domain_http2']['title'],
|
||||||
|
'desc' => $lng['admin']['domain_http2']['description'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array (
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
$result['http2']
|
||||||
|
)
|
||||||
|
),
|
||||||
'no_ssl_available_info' => array(
|
'no_ssl_available_info' => array(
|
||||||
'visible' => ($ssl_ipsandports == '' ? true : false),
|
'visible' => ($ssl_ipsandports == '' ? true : false),
|
||||||
'label' => 'SSL',
|
'label' => 'SSL',
|
||||||
@@ -251,7 +281,26 @@ return array(
|
|||||||
'value' => array(
|
'value' => array(
|
||||||
$result['hsts_preload']
|
$result['hsts_preload']
|
||||||
)
|
)
|
||||||
)
|
),
|
||||||
|
'ocsp_stapling' => array(
|
||||||
|
'visible' => ($ssl_ipsandports != '' ? true : false) &&
|
||||||
|
Settings::Get('system.webserver') != 'lighttpd',
|
||||||
|
'label' => $lng['admin']['domain_ocsp_stapling']['title'],
|
||||||
|
'desc' => $lng['admin']['domain_ocsp_stapling']['description'] .
|
||||||
|
(Settings::Get('system.webserver') == 'nginx' ?
|
||||||
|
$lng['admin']['domain_ocsp_stapling']['nginx_version_warning'] :
|
||||||
|
""),
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array (
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
$result['ocsp_stapling']
|
||||||
|
)
|
||||||
|
),
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
'section_c' => array(
|
'section_c' => array(
|
||||||
@@ -291,6 +340,21 @@ return array(
|
|||||||
'type' => 'select',
|
'type' => 'select',
|
||||||
'select_var' => $phpconfigs
|
'select_var' => $phpconfigs
|
||||||
),
|
),
|
||||||
|
'phpsettingsforsubdomains' => array(
|
||||||
|
'visible' => ($userinfo['change_serversettings'] == '1' ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettingsforsubdomains'],
|
||||||
|
'desc' => $lng['serversettings']['phpsettingsforsubdomains']['description'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array(
|
||||||
|
'label' => $lng['panel']['yes'],
|
||||||
|
'value' => '1'
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'value' => array(
|
||||||
|
'1'
|
||||||
|
)
|
||||||
|
),
|
||||||
'mod_fcgid_starter' => array(
|
'mod_fcgid_starter' => array(
|
||||||
'visible' => ((int) Settings::Get('system.mod_fcgid') == 1 ? true : false),
|
'visible' => ((int) Settings::Get('system.mod_fcgid') == 1 ? true : false),
|
||||||
'label' => $lng['admin']['mod_fcgid_starter']['title'],
|
'label' => $lng['admin']['mod_fcgid_starter']['title'],
|
||||||
|
|||||||
95
lib/formfields/admin/phpconfig/formfield.fpmconfig_add.php
Normal file
95
lib/formfields/admin/phpconfig/formfield.fpmconfig_add.php
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2010 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> (2010-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Formfields
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'fpmconfig_add' => array(
|
||||||
|
'title' => $lng['admin']['phpsettings']['addsettings'],
|
||||||
|
'image' => 'icons/phpsettings_add.png',
|
||||||
|
'sections' => array(
|
||||||
|
'section_a' => array(
|
||||||
|
'title' => $lng['admin']['phpsettings']['addsettings'],
|
||||||
|
'image' => 'icons/phpsettings_add.png',
|
||||||
|
'fields' => array(
|
||||||
|
'description' => array(
|
||||||
|
'label' => $lng['admin']['phpsettings']['description'],
|
||||||
|
'type' => 'text',
|
||||||
|
'maxlength' => 50
|
||||||
|
),
|
||||||
|
'reload_cmd' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['reload'],
|
||||||
|
'type' => 'text',
|
||||||
|
'maxlength' => 255,
|
||||||
|
'value' => 'service php7.0-fpm restart'
|
||||||
|
),
|
||||||
|
'config_dir' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['configdir'],
|
||||||
|
'type' => 'text',
|
||||||
|
'maxlength' => 255,
|
||||||
|
'value' => '/etc/php/7.0/fpm/pool.d/'
|
||||||
|
),
|
||||||
|
'pm' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['pm'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $pm_select
|
||||||
|
),
|
||||||
|
'max_children' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_children']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_children']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 1
|
||||||
|
),
|
||||||
|
'start_servers' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['start_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['start_servers']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 20
|
||||||
|
),
|
||||||
|
'min_spare_servers' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 5
|
||||||
|
),
|
||||||
|
'max_spare_servers' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 35
|
||||||
|
),
|
||||||
|
'max_requests' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_requests']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_requests']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 0
|
||||||
|
),
|
||||||
|
'idle_timeout' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 30
|
||||||
|
),
|
||||||
|
'limit_extensions' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['description'],
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => '.php'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
96
lib/formfields/admin/phpconfig/formfield.fpmconfig_edit.php
Normal file
96
lib/formfields/admin/phpconfig/formfield.fpmconfig_edit.php
Normal file
@@ -0,0 +1,96 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2010 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> (2010-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Formfields
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'fpmconfig_edit' => array(
|
||||||
|
'title' => $lng['admin']['phpsettings']['editsettings'],
|
||||||
|
'image' => 'icons/phpsettings_edit.png',
|
||||||
|
'sections' => array(
|
||||||
|
'section_a' => array(
|
||||||
|
'title' => $lng['admin']['phpsettings']['editsettings'],
|
||||||
|
'image' => 'icons/phpsettings_edit.png',
|
||||||
|
'fields' => array(
|
||||||
|
'description' => array(
|
||||||
|
'label' => $lng['admin']['phpsettings']['description'],
|
||||||
|
'type' => 'text',
|
||||||
|
'maxlength' => 50,
|
||||||
|
'value' => $result['description']
|
||||||
|
),
|
||||||
|
'reload_cmd' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['reload'],
|
||||||
|
'type' => 'text',
|
||||||
|
'maxlength' => 255,
|
||||||
|
'value' => $result['reload_cmd']
|
||||||
|
),
|
||||||
|
'config_dir' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['configdir'],
|
||||||
|
'type' => 'text',
|
||||||
|
'maxlength' => 255,
|
||||||
|
'value' => $result['config_dir']
|
||||||
|
),
|
||||||
|
'pm' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['pm'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $pm_select
|
||||||
|
),
|
||||||
|
'max_children' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_children']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_children']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['max_children']
|
||||||
|
),
|
||||||
|
'start_servers' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['start_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['start_servers']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['start_servers']
|
||||||
|
),
|
||||||
|
'min_spare_servers' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['min_spare_servers']
|
||||||
|
),
|
||||||
|
'max_spare_servers' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['max_spare_servers']
|
||||||
|
),
|
||||||
|
'max_requests' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_requests']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_requests']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['max_requests']
|
||||||
|
),
|
||||||
|
'idle_timeout' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['description'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['idle_timeout']
|
||||||
|
),
|
||||||
|
'limit_extensions' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['description'],
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => $result['limit_extensions']
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
@@ -36,6 +36,12 @@ return array(
|
|||||||
'maxlength' => 255,
|
'maxlength' => 255,
|
||||||
'value' => '/usr/bin/php-cgi'
|
'value' => '/usr/bin/php-cgi'
|
||||||
),
|
),
|
||||||
|
'fpmconfig' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['fpmdesc'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $fpmconfigs
|
||||||
|
),
|
||||||
'file_extensions' => array(
|
'file_extensions' => array(
|
||||||
'visible' => (Settings::Get('system.mod_fcgid') == 1 ? true : false),
|
'visible' => (Settings::Get('system.mod_fcgid') == 1 ? true : false),
|
||||||
'label' => $lng['admin']['phpsettings']['file_extensions'],
|
'label' => $lng['admin']['phpsettings']['file_extensions'],
|
||||||
@@ -84,6 +90,79 @@ return array(
|
|||||||
'maxlength' => 10,
|
'maxlength' => 10,
|
||||||
'value' => '5s'
|
'value' => '5s'
|
||||||
),
|
),
|
||||||
|
'phpfpm_pass_authorizationheader' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['pass_authorizationheader'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
||||||
|
),
|
||||||
|
'value' => array()
|
||||||
|
),
|
||||||
|
'override_fpmconfig' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['override_fpmconfig'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
||||||
|
),
|
||||||
|
'value' => array()
|
||||||
|
),
|
||||||
|
'pm' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['pm'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $pm_select
|
||||||
|
),
|
||||||
|
'max_children' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_children']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_children']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 1
|
||||||
|
),
|
||||||
|
'start_servers' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['start_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['start_servers']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 20
|
||||||
|
),
|
||||||
|
'min_spare_servers' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 5
|
||||||
|
),
|
||||||
|
'max_spare_servers' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 35
|
||||||
|
),
|
||||||
|
'max_requests' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_requests']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_requests']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 0
|
||||||
|
),
|
||||||
|
'idle_timeout' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => 30
|
||||||
|
),
|
||||||
|
'limit_extensions' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => '.php'
|
||||||
|
),
|
||||||
'phpsettings' => array(
|
'phpsettings' => array(
|
||||||
'style' => 'align-top',
|
'style' => 'align-top',
|
||||||
'label' => $lng['admin']['phpsettings']['phpinisettings'],
|
'label' => $lng['admin']['phpsettings']['phpinisettings'],
|
||||||
|
|||||||
@@ -37,6 +37,12 @@ return array(
|
|||||||
'maxlength' => 255,
|
'maxlength' => 255,
|
||||||
'value' => $result['binary']
|
'value' => $result['binary']
|
||||||
),
|
),
|
||||||
|
'fpmconfig' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['fpmdesc'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $fpmconfigs
|
||||||
|
),
|
||||||
'file_extensions' => array(
|
'file_extensions' => array(
|
||||||
'visible' => (Settings::Get('system.mod_fcgid') == 1 ? true : false),
|
'visible' => (Settings::Get('system.mod_fcgid') == 1 ? true : false),
|
||||||
'label' => $lng['admin']['phpsettings']['file_extensions'],
|
'label' => $lng['admin']['phpsettings']['file_extensions'],
|
||||||
@@ -87,6 +93,79 @@ return array(
|
|||||||
'maxlength' => 10,
|
'maxlength' => 10,
|
||||||
'value' => $result['fpm_reqslow']
|
'value' => $result['fpm_reqslow']
|
||||||
),
|
),
|
||||||
|
'phpfpm_pass_authorizationheader' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['pass_authorizationheader'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
||||||
|
),
|
||||||
|
'value' => array($result['pass_authorizationheader'])
|
||||||
|
),
|
||||||
|
'override_fpmconfig' => array(
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['override_fpmconfig'],
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'values' => array(
|
||||||
|
array ('label' => $lng['panel']['yes'], 'value' => '1')
|
||||||
|
),
|
||||||
|
'value' => array($result['override_fpmconfig'])
|
||||||
|
),
|
||||||
|
'pm' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['pm'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $pm_select
|
||||||
|
),
|
||||||
|
'max_children' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_children']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_children']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['max_children']
|
||||||
|
),
|
||||||
|
'start_servers' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['start_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['start_servers']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['start_servers']
|
||||||
|
),
|
||||||
|
'min_spare_servers' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['min_spare_servers']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['min_spare_servers']
|
||||||
|
),
|
||||||
|
'max_spare_servers' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_spare_servers']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['max_spare_servers']
|
||||||
|
),
|
||||||
|
'max_requests' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['max_requests']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['max_requests']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['max_requests']
|
||||||
|
),
|
||||||
|
'idle_timeout' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['idle_timeout']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $result['idle_timeout']
|
||||||
|
),
|
||||||
|
'limit_extensions' => array(
|
||||||
|
'visible' => (Settings::Get('phpfpm.enabled') == 1 ? true : false),
|
||||||
|
'label' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['title'],
|
||||||
|
'desc' => $lng['serversettings']['phpfpm_settings']['limit_extensions']['description'].$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'],
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => $result['limit_extensions']
|
||||||
|
),
|
||||||
'phpsettings' => array(
|
'phpsettings' => array(
|
||||||
'style' => 'align-top',
|
'style' => 'align-top',
|
||||||
'label' => $lng['admin']['phpsettings']['phpinisettings'],
|
'label' => $lng['admin']['phpsettings']['phpinisettings'],
|
||||||
|
|||||||
41
lib/formfields/admin/plans/formfield.plans_add.php
Normal file
41
lib/formfields/admin/plans/formfield.plans_add.php
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2010 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> (2010-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Formfields
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'plans_add' => array(
|
||||||
|
'title' => $lng['admin']['plans']['add'],
|
||||||
|
'image' => 'icons/templates_add_big.png',
|
||||||
|
'sections' => array(
|
||||||
|
'section_a' => array(
|
||||||
|
'title' => $lng['admin']['plans']['plan_details'],
|
||||||
|
'image' => 'icons/templates_add_big.png',
|
||||||
|
'fields' => array(
|
||||||
|
'name' => array(
|
||||||
|
'label' => $lng['admin']['plans']['name'],
|
||||||
|
'type' => 'text'
|
||||||
|
),
|
||||||
|
'description' => array(
|
||||||
|
'label' => $lng['admin']['plans']['description'],
|
||||||
|
'type' => 'textarea',
|
||||||
|
'cols' => 60,
|
||||||
|
'rows' => 12
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
43
lib/formfields/admin/plans/formfield.plans_edit.php
Normal file
43
lib/formfields/admin/plans/formfield.plans_edit.php
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2010 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> (2010-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Formfields
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'plans_edit' => array(
|
||||||
|
'title' => $lng['admin']['plans']['edit'],
|
||||||
|
'image' => 'icons/templates_edit_big.png',
|
||||||
|
'sections' => array(
|
||||||
|
'section_a' => array(
|
||||||
|
'title' => $lng['admin']['plans']['plan_details'],
|
||||||
|
'image' => 'icons/templates_edit_big.png',
|
||||||
|
'fields' => array(
|
||||||
|
'name' => array(
|
||||||
|
'label' => $lng['admin']['plans']['name'],
|
||||||
|
'type' => 'text',
|
||||||
|
'value' => $result['name']
|
||||||
|
),
|
||||||
|
'description' => array(
|
||||||
|
'label' => $lng['admin']['plans']['description'],
|
||||||
|
'type' => 'textarea',
|
||||||
|
'cols' => 60,
|
||||||
|
'rows' => 12,
|
||||||
|
'value' => $result['description']
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
@@ -70,6 +70,12 @@ return array(
|
|||||||
'label' => $lng['domain']['openbasedirpath'],
|
'label' => $lng['domain']['openbasedirpath'],
|
||||||
'type' => 'select',
|
'type' => 'select',
|
||||||
'select_var' => $openbasedir
|
'select_var' => $openbasedir
|
||||||
|
),
|
||||||
|
'phpsettingid' => array(
|
||||||
|
'visible' => (((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) && $has_phpconfigs ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['title'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $phpconfigs
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -81,6 +81,12 @@ return array(
|
|||||||
'label' => $lng['domain']['openbasedirpath'],
|
'label' => $lng['domain']['openbasedirpath'],
|
||||||
'type' => 'select',
|
'type' => 'select',
|
||||||
'select_var' => $openbasedir
|
'select_var' => $openbasedir
|
||||||
|
),
|
||||||
|
'phpsettingid' => array(
|
||||||
|
'visible' => (((int) Settings::Get('system.mod_fcgid') == 1 || (int) Settings::Get('phpfpm.enabled') == 1) && $has_phpconfigs ? true : false),
|
||||||
|
'label' => $lng['admin']['phpsettings']['title'],
|
||||||
|
'type' => 'select',
|
||||||
|
'select_var' => $phpconfigs
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -24,8 +24,8 @@ return array(
|
|||||||
'image' => 'icons/backup_big.png',
|
'image' => 'icons/backup_big.png',
|
||||||
'fields' => array(
|
'fields' => array(
|
||||||
'path' => array(
|
'path' => array(
|
||||||
'label' => $lng['panel']['path'],
|
'label' => $lng['panel']['backuppath']['title'],
|
||||||
'desc' => (Settings::Get('panel.pathedit') != 'Dropdown' ? $lng['panel']['pathDescription'] : null).(isset($pathSelect['note']) ? '<br />'.$pathSelect['value'] : ''),
|
'desc' => $lng['panel']['backuppath']['description'].'<br>'.(Settings::Get('panel.pathedit') != 'Dropdown' ? $lng['panel']['pathDescription'] : null).(isset($pathSelect['note']) ? '<br />'.$pathSelect['value'] : ''),
|
||||||
'type' => $pathSelect['type'],
|
'type' => $pathSelect['type'],
|
||||||
'select_var' => $pathSelect['value'],
|
'select_var' => $pathSelect['value'],
|
||||||
'value' => $pathSelect['value']
|
'value' => $pathSelect['value']
|
||||||
|
|||||||
@@ -54,20 +54,8 @@ function generateDkimEntries($domain)
|
|||||||
// end-part
|
// end-part
|
||||||
$dkim_txt .= 't=s';
|
$dkim_txt .= 't=s';
|
||||||
|
|
||||||
if (Settings::Get('system.dns_server') == 'pdns') {
|
|
||||||
// PowerDNS does not need/want splitted content
|
|
||||||
$txt_record_split = $dkim_txt;
|
|
||||||
} else {
|
|
||||||
// split if necessary
|
|
||||||
$txt_record_split = '';
|
|
||||||
$lbr = 50;
|
|
||||||
for ($pos = 0; $pos <= strlen($dkim_txt) - 1; $pos += $lbr) {
|
|
||||||
$txt_record_split .= (($pos == 0) ? '("' : "\t\t\t\t\t \"") . substr($dkim_txt, $pos, $lbr) . (($pos >= strlen($dkim_txt) - $lbr) ? '")' : '"') . "\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// dkim-entry
|
// dkim-entry
|
||||||
$zone_dkim[] = $txt_record_split;
|
$zone_dkim[] = $dkim_txt;
|
||||||
|
|
||||||
// adsp-entry
|
// adsp-entry
|
||||||
if (Settings::Get('dkim.dkim_add_adsp') == "1") {
|
if (Settings::Get('dkim.dkim_add_adsp') == "1") {
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ function validateFormFieldOption($fieldname, $fielddata, $newfieldvalue)
|
|||||||
$returnvalue = isset($fielddata['option_options'][$newfieldvalue]);
|
$returnvalue = isset($fielddata['option_options'][$newfieldvalue]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if($returnvalue === true)
|
if($returnvalue === true || $fielddata['visible'] == false)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -63,7 +63,7 @@ function getOutstandingTasks() {
|
|||||||
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
|
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
|
||||||
if ($row['data'] != '') {
|
if ($row['data'] != '') {
|
||||||
$row['data'] = unserialize($row['data']);
|
$row['data'] = json_decode($row['data'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// rebuilding webserver-configuration
|
// rebuilding webserver-configuration
|
||||||
|
|||||||
@@ -70,7 +70,7 @@ function inserttask($type, $param1 = '', $param2 = '', $param3 = '', $param4 = '
|
|||||||
$data['uid'] = $param2;
|
$data['uid'] = $param2;
|
||||||
$data['gid'] = $param3;
|
$data['gid'] = $param3;
|
||||||
$data['store_defaultindex'] = $param4;
|
$data['store_defaultindex'] = $param4;
|
||||||
$data = serialize($data);
|
$data = json_encode($data);
|
||||||
Database::pexecute($ins_stmt, array('type' => '2', 'data' => $data));
|
Database::pexecute($ins_stmt, array('type' => '2', 'data' => $data));
|
||||||
|
|
||||||
} elseif ($type == '6'
|
} elseif ($type == '6'
|
||||||
@@ -78,7 +78,7 @@ function inserttask($type, $param1 = '', $param2 = '', $param3 = '', $param4 = '
|
|||||||
) {
|
) {
|
||||||
$data = array();
|
$data = array();
|
||||||
$data['loginname'] = $param1;
|
$data['loginname'] = $param1;
|
||||||
$data = serialize($data);
|
$data = json_encode($data);
|
||||||
Database::pexecute($ins_stmt, array('type' => '6', 'data' => $data));
|
Database::pexecute($ins_stmt, array('type' => '6', 'data' => $data));
|
||||||
|
|
||||||
} elseif ($type == '7'
|
} elseif ($type == '7'
|
||||||
@@ -88,7 +88,7 @@ function inserttask($type, $param1 = '', $param2 = '', $param3 = '', $param4 = '
|
|||||||
$data = array();
|
$data = array();
|
||||||
$data['loginname'] = $param1;
|
$data['loginname'] = $param1;
|
||||||
$data['email'] = $param2;
|
$data['email'] = $param2;
|
||||||
$data = serialize($data);
|
$data = json_encode($data);
|
||||||
Database::pexecute($ins_stmt, array('type' => '7', 'data' => $data));
|
Database::pexecute($ins_stmt, array('type' => '7', 'data' => $data));
|
||||||
|
|
||||||
} elseif ($type == '8'
|
} elseif ($type == '8'
|
||||||
@@ -98,13 +98,13 @@ function inserttask($type, $param1 = '', $param2 = '', $param3 = '', $param4 = '
|
|||||||
$data = array();
|
$data = array();
|
||||||
$data['loginname'] = $param1;
|
$data['loginname'] = $param1;
|
||||||
$data['homedir'] = $param2;
|
$data['homedir'] = $param2;
|
||||||
$data = serialize($data);
|
$data = json_encode($data);
|
||||||
Database::pexecute($ins_stmt, array('type' => '8', 'data' => $data));
|
Database::pexecute($ins_stmt, array('type' => '8', 'data' => $data));
|
||||||
|
|
||||||
} elseif ($type == '20'
|
} elseif ($type == '20'
|
||||||
&& is_array($param1)
|
&& is_array($param1)
|
||||||
) {
|
) {
|
||||||
$data = serialize($param1);
|
$data = json_encode($param1);
|
||||||
Database::pexecute($ins_stmt, array('type' => '20', 'data' => $data));
|
Database::pexecute($ins_stmt, array('type' => '20', 'data' => $data));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -25,6 +25,8 @@ function phpErrHandler($errno, $errstr, $errfile, $errline, $errcontext) {
|
|||||||
if (empty($theme)) {
|
if (empty($theme)) {
|
||||||
$theme = "Sparkle";
|
$theme = "Sparkle";
|
||||||
}
|
}
|
||||||
|
// prevent possible file-path-disclosure
|
||||||
|
$errfile = str_replace(FROXLOR_INSTALL_DIR, "", $errfile);
|
||||||
// if we're not on the shell, output a nicer error-message
|
// if we're not on the shell, output a nicer error-message
|
||||||
$err_hint = file_get_contents(FROXLOR_INSTALL_DIR.'/templates/'.$theme.'/misc/phperrornice.tpl');
|
$err_hint = file_get_contents(FROXLOR_INSTALL_DIR.'/templates/'.$theme.'/misc/phperrornice.tpl');
|
||||||
// replace values
|
// replace values
|
||||||
|
|||||||
@@ -36,9 +36,11 @@ function getRedirectCodesArray() {
|
|||||||
* return an array of all enabled redirect-codes
|
* return an array of all enabled redirect-codes
|
||||||
* for the settings form
|
* for the settings form
|
||||||
*
|
*
|
||||||
|
* @param bool $add_desc optional, default true, add the code-description
|
||||||
|
*
|
||||||
* @return array array of enabled redirect-codes
|
* @return array array of enabled redirect-codes
|
||||||
*/
|
*/
|
||||||
function getRedirectCodes() {
|
function getRedirectCodes($add_desc = true) {
|
||||||
|
|
||||||
global $lng;
|
global $lng;
|
||||||
|
|
||||||
@@ -47,7 +49,10 @@ function getRedirectCodes() {
|
|||||||
|
|
||||||
$codes = array();
|
$codes = array();
|
||||||
while ($rc = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
while ($rc = $result_stmt->fetch(PDO::FETCH_ASSOC)) {
|
||||||
$codes[$rc['id']] = $rc['code']. ' ('.$lng['redirect_desc'][$rc['desc']].')';
|
$codes[$rc['id']] = $rc['code'];
|
||||||
|
if ($add_desc) {
|
||||||
|
$codes[$rc['id']] .= ' ('.$lng['redirect_desc'][$rc['desc']].')';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $codes;
|
return $codes;
|
||||||
@@ -58,12 +63,18 @@ function getRedirectCodes() {
|
|||||||
* domain-id
|
* domain-id
|
||||||
*
|
*
|
||||||
* @param integer $domainid id of the domain
|
* @param integer $domainid id of the domain
|
||||||
* @param string $default
|
|
||||||
*
|
*
|
||||||
* @return string redirect-code
|
* @return string redirect-code
|
||||||
*/
|
*/
|
||||||
function getDomainRedirectCode($domainid = 0, $default = '') {
|
function getDomainRedirectCode($domainid = 0) {
|
||||||
|
|
||||||
|
// get system default
|
||||||
|
$default = '301';
|
||||||
|
if (Settings::Get('customredirect.enabled') == '1') {
|
||||||
|
$all_codes = getRedirectCodes(false);
|
||||||
|
$_default = $all_codes[Settings::Get('customredirect.default')];
|
||||||
|
$default = ($_default == '---') ? $default : $_default;
|
||||||
|
}
|
||||||
$code = $default;
|
$code = $default;
|
||||||
if ($domainid > 0) {
|
if ($domainid > 0) {
|
||||||
|
|
||||||
|
|||||||
@@ -42,6 +42,8 @@ function dieWithMail($message, $subject = "[froxlor] Cronjob error") {
|
|||||||
$_mail->Password = Settings::Get('system.mail_smtp_passwd');
|
$_mail->Password = Settings::Get('system.mail_smtp_passwd');
|
||||||
if (Settings::Get('system.mail_smtp_usetls')) {
|
if (Settings::Get('system.mail_smtp_usetls')) {
|
||||||
$_mail->SMTPSecure = 'tls';
|
$_mail->SMTPSecure = 'tls';
|
||||||
|
} else {
|
||||||
|
$mail->SMTPAutoTLS = false;
|
||||||
}
|
}
|
||||||
$_mail->Port = Settings::Get('system.mail_smtp_port');
|
$_mail->Port = Settings::Get('system.mail_smtp_port');
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,7 +29,7 @@
|
|||||||
* @author Florian Lippert <flo@syscp.org>
|
* @author Florian Lippert <flo@syscp.org>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function makeoption($title, $value, $selvalue = NULL, $title_trusted = false, $value_trusted = false, $id = NULL)
|
function makeoption($title, $value, $selvalue = NULL, $title_trusted = false, $value_trusted = false, $id = NULL, $disabled = false)
|
||||||
{
|
{
|
||||||
if($selvalue !== NULL
|
if($selvalue !== NULL
|
||||||
&& ((is_array($selvalue) && in_array($value, $selvalue)) || $value == $selvalue))
|
&& ((is_array($selvalue) && in_array($value, $selvalue)) || $value == $selvalue))
|
||||||
@@ -40,6 +40,10 @@ function makeoption($title, $value, $selvalue = NULL, $title_trusted = false, $v
|
|||||||
{
|
{
|
||||||
$selected = '';
|
$selected = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($disabled) {
|
||||||
|
$selected .= ' disabled="disabled"';
|
||||||
|
}
|
||||||
|
|
||||||
if(!$title_trusted)
|
if(!$title_trusted)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -63,3 +63,15 @@ function standard_error($errors = '', $replacer = '') {
|
|||||||
eval("echo \"" . getTemplate('misc/error', '1') . "\";");
|
eval("echo \"" . getTemplate('misc/error', '1') . "\";");
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function dynamic_error($message) {
|
||||||
|
global $userinfo, $s, $header, $footer, $lng, $theme;
|
||||||
|
$_SESSION['requestData'] = $_POST;
|
||||||
|
$link = '';
|
||||||
|
if (isset($_SERVER['HTTP_REFERER']) && strpos($_SERVER['HTTP_REFERER'], $_SERVER['HTTP_HOST']) !== false) {
|
||||||
|
$link = '<a href="'.htmlentities($_SERVER['HTTP_REFERER']).'">'.$lng['panel']['back'].'</a>';
|
||||||
|
}
|
||||||
|
$error = $message;
|
||||||
|
eval("echo \"" . getTemplate('misc/error', '1') . "\";");
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|||||||
@@ -20,27 +20,22 @@
|
|||||||
/**
|
/**
|
||||||
* Returns Array, whose elements have been checked whether thay are empty or not
|
* Returns Array, whose elements have been checked whether thay are empty or not
|
||||||
*
|
*
|
||||||
* @param array The array to trim
|
* @param array $source
|
||||||
|
* The array to trim
|
||||||
* @return array The trim'med array
|
* @return array The trim'med array
|
||||||
* @author Florian Lippert <flo@syscp.org>
|
* @author Florian Lippert <flo@syscp.org>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function array_trim($source)
|
function array_trim($source)
|
||||||
{
|
{
|
||||||
$returnval = array();
|
$returnval = array();
|
||||||
|
if (is_array($source)) {
|
||||||
if(is_array($source))
|
foreach ($source as $var => $val) {
|
||||||
{
|
if ($val != ' ' && $val != '') {
|
||||||
while(list($var, $val) = each($source))
|
$returnval[$var] = $val;
|
||||||
{
|
}
|
||||||
if($val != ' '
|
|
||||||
&& $val != '')$returnval[$var] = $val;
|
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
$returnval = $source;
|
$returnval = $source;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $returnval;
|
return $returnval;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,33 +16,36 @@
|
|||||||
* @package Functions
|
* @package Functions
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function storeSettingMysqlAccessHost($fieldname, $fielddata, $newfieldvalue)
|
function storeSettingMysqlAccessHost($fieldname, $fielddata, $newfieldvalue)
|
||||||
{
|
{
|
||||||
$returnvalue = storeSettingField($fieldname, $fielddata, $newfieldvalue);
|
$returnvalue = storeSettingField($fieldname, $fielddata, $newfieldvalue);
|
||||||
|
|
||||||
if($returnvalue !== false && is_array($fielddata) && isset($fielddata['settinggroup']) && $fielddata['settinggroup'] == 'system' && isset($fielddata['varname']) && $fielddata['varname'] == 'mysql_access_host')
|
if ($returnvalue !== false && is_array($fielddata) && isset($fielddata['settinggroup']) && $fielddata['settinggroup'] == 'system' && isset($fielddata['varname']) && $fielddata['varname'] == 'mysql_access_host') {
|
||||||
{
|
|
||||||
$mysql_access_host_array = array_map('trim', explode(',', $newfieldvalue));
|
$mysql_access_host_array = array_map('trim', explode(',', $newfieldvalue));
|
||||||
|
|
||||||
if(in_array('127.0.0.1', $mysql_access_host_array)
|
if (in_array('127.0.0.1', $mysql_access_host_array) && ! in_array('localhost', $mysql_access_host_array)) {
|
||||||
&& !in_array('localhost', $mysql_access_host_array))
|
|
||||||
{
|
|
||||||
$mysql_access_host_array[] = 'localhost';
|
$mysql_access_host_array[] = 'localhost';
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!in_array('127.0.0.1', $mysql_access_host_array)
|
if (! in_array('127.0.0.1', $mysql_access_host_array) && in_array('localhost', $mysql_access_host_array)) {
|
||||||
&& in_array('localhost', $mysql_access_host_array))
|
|
||||||
{
|
|
||||||
$mysql_access_host_array[] = '127.0.0.1';
|
$mysql_access_host_array[] = '127.0.0.1';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// be aware that ipv6 addresses are enclosed in [ ] when passed here
|
||||||
|
$mysql_access_host_array = array_map('cleanMySQLAccessHost', $mysql_access_host_array);
|
||||||
|
|
||||||
$mysql_access_host_array = array_unique(array_trim($mysql_access_host_array));
|
$mysql_access_host_array = array_unique(array_trim($mysql_access_host_array));
|
||||||
$newfieldvalue = implode(',', $mysql_access_host_array);
|
$newfieldvalue = implode(',', $mysql_access_host_array);
|
||||||
correctMysqlUsers($mysql_access_host_array);
|
correctMysqlUsers($mysql_access_host_array);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $returnvalue;
|
return $returnvalue;
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
function cleanMySQLAccessHost($value)
|
||||||
|
{
|
||||||
|
if (substr($value, 0, 1) == '[' && substr($value, - 1) == ']') {
|
||||||
|
return substr($value, 1, - 1);
|
||||||
|
}
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
|||||||
@@ -24,12 +24,14 @@ function checkFcgidPhpFpm($fieldname, $fielddata, $newfieldvalue, $allnewfieldva
|
|||||||
'system_mod_fcgid_enabled' => array(
|
'system_mod_fcgid_enabled' => array(
|
||||||
'other_post_field' => 'system_phpfpm_enabled',
|
'other_post_field' => 'system_phpfpm_enabled',
|
||||||
'other_enabled' => 'phpfpm.enabled',
|
'other_enabled' => 'phpfpm.enabled',
|
||||||
'other_enabled_lng' => 'phpfpmstillenabled'
|
'other_enabled_lng' => 'phpfpmstillenabled',
|
||||||
|
'deactivate' => array('phpfpm.enabled_ownvhost' => 0)
|
||||||
),
|
),
|
||||||
'system_phpfpm_enabled' => array(
|
'system_phpfpm_enabled' => array(
|
||||||
'other_post_field' => 'system_mod_fcgid_enabled',
|
'other_post_field' => 'system_mod_fcgid_enabled',
|
||||||
'other_enabled' => 'system.mod_fcgid',
|
'other_enabled' => 'system.mod_fcgid',
|
||||||
'other_enabled_lng' => 'fcgidstillenabled'
|
'other_enabled_lng' => 'fcgidstillenabled',
|
||||||
|
'deactivate' => array('system.mod_fcgid_ownvhost' => 0)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -56,6 +58,13 @@ function checkFcgidPhpFpm($fieldname, $fielddata, $newfieldvalue, $allnewfieldva
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (in_array(FORMFIELDS_PLAUSIBILITY_CHECK_OK, $returnvalue)) {
|
||||||
|
// be sure to deactivate the other one for the froxlor-vhost
|
||||||
|
// to avoid having a settings-deadlock
|
||||||
|
foreach ($check_array[$fieldname]['deactivate'] as $setting => $value) {
|
||||||
|
Settings::Set($setting, $value, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $returnvalue;
|
return $returnvalue;
|
||||||
|
|||||||
@@ -156,7 +156,8 @@ if (version_compare(PHP_VERSION, "5.4.0", "<")) {
|
|||||||
if (get_magic_quotes_gpc()) {
|
if (get_magic_quotes_gpc()) {
|
||||||
$in = array(&$_GET, &$_POST, &$_COOKIE);
|
$in = array(&$_GET, &$_POST, &$_COOKIE);
|
||||||
|
|
||||||
while (list($k, $v) = each($in)) {
|
$_in = $in;
|
||||||
|
foreach ($_in as $k => $v) {
|
||||||
foreach ($v as $key => $val) {
|
foreach ($v as $key => $val) {
|
||||||
if (!is_array($val)) {
|
if (!is_array($val)) {
|
||||||
$in[$k][$key] = stripslashes($val);
|
$in[$k][$key] = stripslashes($val);
|
||||||
@@ -563,6 +564,8 @@ if (Settings::Get('system.mail_use_smtp')) {
|
|||||||
$mail->Password = Settings::Get('system.mail_smtp_passwd');
|
$mail->Password = Settings::Get('system.mail_smtp_passwd');
|
||||||
if (Settings::Get('system.mail_smtp_usetls')) {
|
if (Settings::Get('system.mail_smtp_usetls')) {
|
||||||
$mail->SMTPSecure = 'tls';
|
$mail->SMTPSecure = 'tls';
|
||||||
|
} else {
|
||||||
|
$mail->SMTPAutoTLS = false;
|
||||||
}
|
}
|
||||||
$mail->Port = Settings::Get('system.mail_smtp_port');
|
$mail->Port = Settings::Get('system.mail_smtp_port');
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -214,6 +214,11 @@ return array(
|
|||||||
'label' => $lng['admin']['ipsandports']['ipsandports'],
|
'label' => $lng['admin']['ipsandports']['ipsandports'],
|
||||||
'required_resources' => 'change_serversettings'
|
'required_resources' => 'change_serversettings'
|
||||||
),
|
),
|
||||||
|
array(
|
||||||
|
'url' => 'admin_plans.php?page=overview',
|
||||||
|
'label' => $lng['admin']['plans']['plans'],
|
||||||
|
'required_resources' => 'customers'
|
||||||
|
),
|
||||||
array(
|
array(
|
||||||
'url' => 'admin_settings.php?page=updatecounters',
|
'url' => 'admin_settings.php?page=updatecounters',
|
||||||
'label' => $lng['admin']['updatecounters'],
|
'label' => $lng['admin']['updatecounters'],
|
||||||
@@ -267,6 +272,12 @@ return array(
|
|||||||
'label' => $lng['admin']['autoupdate'],
|
'label' => $lng['admin']['autoupdate'],
|
||||||
'required_resources' => 'change_serversettings',
|
'required_resources' => 'change_serversettings',
|
||||||
'show_element' => extension_loaded('zip')
|
'show_element' => extension_loaded('zip')
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'url' => 'admin_settings.php?page=wipecleartextmailpws',
|
||||||
|
'label' => $lng['admin']['wipecleartextmailpwd'],
|
||||||
|
'required_resources' => 'change_serversettings',
|
||||||
|
'show_element' => (Settings::Get('system.mailpwcleartext') == true)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
@@ -279,6 +290,12 @@ return array(
|
|||||||
'label' => $lng['menue']['phpsettings']['maintitle'],
|
'label' => $lng['menue']['phpsettings']['maintitle'],
|
||||||
'show_element' => (Settings::Get('system.mod_fcgid') == true || Settings::Get('phpfpm.enabled') == true)
|
'show_element' => (Settings::Get('system.mod_fcgid') == true || Settings::Get('phpfpm.enabled') == true)
|
||||||
),
|
),
|
||||||
|
array(
|
||||||
|
'url' => 'admin_phpsettings.php?page=fpmdaemons',
|
||||||
|
'label' => $lng['menue']['phpsettings']['fpmdaemons'],
|
||||||
|
'required_resources' => 'change_serversettings',
|
||||||
|
'show_element' => Settings::Get('phpfpm.enabled') == true
|
||||||
|
),
|
||||||
array(
|
array(
|
||||||
'url' => 'admin_settings.php?page=phpinfo',
|
'url' => 'admin_settings.php?page=phpinfo',
|
||||||
'label' => $lng['admin']['phpinfo'],
|
'label' => $lng['admin']['phpinfo'],
|
||||||
@@ -313,6 +330,10 @@ return array(
|
|||||||
array(
|
array(
|
||||||
'url' => 'admin_message.php?page=message',
|
'url' => 'admin_message.php?page=message',
|
||||||
'label' => $lng['admin']['message']
|
'label' => $lng['admin']['message']
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'url' => 'admin_settings.php?page=testmail',
|
||||||
|
'label' => $lng['admin']['testmail']
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -51,5 +51,7 @@ define('TABLE_PANEL_DOMAINREDIRECTS', 'domain_redirect_codes');
|
|||||||
define('TABLE_PANEL_DOMAIN_SSL_SETTINGS', 'domain_ssl_settings');
|
define('TABLE_PANEL_DOMAIN_SSL_SETTINGS', 'domain_ssl_settings');
|
||||||
define('TABLE_DOMAINTOIP', 'panel_domaintoip');
|
define('TABLE_DOMAINTOIP', 'panel_domaintoip');
|
||||||
define('TABLE_DOMAIN_DNS', 'domain_dns_entries');
|
define('TABLE_DOMAIN_DNS', 'domain_dns_entries');
|
||||||
|
define('TABLE_PANEL_FPMDAEMONS', 'panel_fpmdaemons');
|
||||||
|
define('TABLE_PANEL_PLANS', 'panel_plans');
|
||||||
|
|
||||||
require dirname(__FILE__).'/version.inc.php';
|
require dirname(__FILE__).'/version.inc.php';
|
||||||
|
|||||||
@@ -16,10 +16,10 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// Main version variable
|
// Main version variable
|
||||||
$version = '0.9.38.5';
|
$version = '0.9.40';
|
||||||
|
|
||||||
// Database version (YYYYMMDDC where C is a daily counter)
|
// Database version (YYYYMMDDC where C is a daily counter)
|
||||||
$dbversion = '201612110';
|
$dbversion = '201809280';
|
||||||
|
|
||||||
// Distribution branding-tag (used for Debian etc.)
|
// Distribution branding-tag (used for Debian etc.)
|
||||||
$branding = '';
|
$branding = '';
|
||||||
|
|||||||
@@ -1031,7 +1031,7 @@ $lng['dkim']['dkim_notes']['description'] = 'Notities die van belang kunnen zijn
|
|||||||
$lng['dkim']['dkim_add_adsp']['title'] = 'DKIM ADSP toevoegen';
|
$lng['dkim']['dkim_add_adsp']['title'] = 'DKIM ADSP toevoegen';
|
||||||
$lng['dkim']['dkim_add_adsp']['description'] = 'Indien u niet weet wat dit is, laat het op "actief" staan.';
|
$lng['dkim']['dkim_add_adsp']['description'] = 'Indien u niet weet wat dit is, laat het op "actief" staan.';
|
||||||
$lng['dkim']['dkim_add_adsppolicy']['title'] = 'ADSP beleid';
|
$lng['dkim']['dkim_add_adsppolicy']['title'] = 'ADSP beleid';
|
||||||
$lng['dkim']['dkim_add_adsppolicy']['description'] = 'Voor meer informatie inzake deze instelling zie <a target="blank" href="http://redmine.froxlor.org/projects/froxlor/wiki/En-dkim-adsp-policies">DKIM ADSP policies</a>';
|
$lng['dkim']['dkim_add_adsppolicy']['description'] = 'Voor meer informatie inzake deze instelling zie <a target="blank" href="https://en.wikipedia.org/wiki/Author_Domain_Signing_Practices">DKIM ADSP policies</a>';
|
||||||
|
|
||||||
$lng['admin']['cron']['cronsettings'] = 'Instellingen cron-taken';
|
$lng['admin']['cron']['cronsettings'] = 'Instellingen cron-taken';
|
||||||
$lng['cron']['cronname'] = 'naam cron-taak';
|
$lng['cron']['cronname'] = 'naam cron-taak';
|
||||||
@@ -1146,7 +1146,7 @@ $lng['serversettings']['perl_path']['description'] = 'Alleen relevant voor light
|
|||||||
// ADDED IN FROXLOR 0.9.12-svn1
|
// ADDED IN FROXLOR 0.9.12-svn1
|
||||||
$lng['admin']['fcgid_settings'] = 'FCGID';
|
$lng['admin']['fcgid_settings'] = 'FCGID';
|
||||||
$lng['serversettings']['mod_fcgid_ownvhost']['title'] = 'FCGID inschakelen voor de VHost voor Froxlor';
|
$lng['serversettings']['mod_fcgid_ownvhost']['title'] = 'FCGID inschakelen voor de VHost voor Froxlor';
|
||||||
$lng['serversettings']['mod_fcgid_ownvhost']['description'] = 'Indien ingeschakeld wordt Froxlor ook uitgevoerd onder een lokale gebruiker<br /><strong>Let op:</strong>Dit vereist handmatige configuratie, zie <a target="blank" href="http://redmine.froxlor.org/projects/froxlor/wiki/HandbookApache2_fcgid">FCGID - handbook</a>';
|
$lng['serversettings']['mod_fcgid_ownvhost']['description'] = 'Indien ingeschakeld wordt Froxlor ook uitgevoerd onder een lokale gebruiker<br /><strong>Let op:</strong>Dit vereist handmatige configuratie, zie <a target="blank" href="https://github.com/Froxlor/Froxlor/wiki/apache2-with-fcgid">FCGID - handbook</a>';
|
||||||
$lng['admin']['mod_fcgid_user'] = 'Lokale gebruiker voor FCGID (Froxlor vhost)';
|
$lng['admin']['mod_fcgid_user'] = 'Lokale gebruiker voor FCGID (Froxlor vhost)';
|
||||||
$lng['admin']['mod_fcgid_group'] = 'Lokale groep voor FCGID (Froxlor vhost)';
|
$lng['admin']['mod_fcgid_group'] = 'Lokale groep voor FCGID (Froxlor vhost)';
|
||||||
|
|
||||||
|
|||||||
@@ -229,6 +229,7 @@ $lng['error']['destinationalreadyexistasmail'] = 'The forwarder to %s already ex
|
|||||||
$lng['error']['destinationalreadyexist'] = 'You have already defined a forwarder to %s .';
|
$lng['error']['destinationalreadyexist'] = 'You have already defined a forwarder to %s .';
|
||||||
$lng['error']['destinationiswrong'] = 'The forwarder %s contains invalid character(s) or is incomplete.';
|
$lng['error']['destinationiswrong'] = 'The forwarder %s contains invalid character(s) or is incomplete.';
|
||||||
$lng['error']['ticketnotaccessible'] = 'You cannot access this ticket.';
|
$lng['error']['ticketnotaccessible'] = 'You cannot access this ticket.';
|
||||||
|
$lng['error']['backupfoldercannotbedocroot'] = 'The folder for backups cannot be your homedir, please chose a folder within your homedir, e.g. /backups';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Questions
|
* Questions
|
||||||
@@ -337,6 +338,14 @@ $lng['serversettings']['documentroot_prefix']['title'] = 'Home directory';
|
|||||||
$lng['serversettings']['documentroot_prefix']['description'] = 'Where should all home directories be stored?';
|
$lng['serversettings']['documentroot_prefix']['description'] = 'Where should all home directories be stored?';
|
||||||
$lng['serversettings']['logfiles_directory']['title'] = 'Logfiles directory';
|
$lng['serversettings']['logfiles_directory']['title'] = 'Logfiles directory';
|
||||||
$lng['serversettings']['logfiles_directory']['description'] = 'Where should all log files be stored?';
|
$lng['serversettings']['logfiles_directory']['description'] = 'Where should all log files be stored?';
|
||||||
|
$lng['serversettings']['logfiles_script']['title'] = 'Custom script to pipe log-files to';
|
||||||
|
$lng['serversettings']['logfiles_script']['description'] = 'You can specify a script here and use the placeholders <strong>{LOGFILE}, {DOMAIN} and {CUSTOMER}</strong> if needed. In case you want to use it you will need to activate the <strong>Pipe webserver logfiles</strong> option too. No prefixed pipe-character is needed.';
|
||||||
|
$lng['serversettings']['logfiles_format']['title'] = 'Access-log format';
|
||||||
|
$lng['serversettings']['logfiles_format']['description'] = 'Enter a custom log-format here according to your webservers specifications, leave empty for default';
|
||||||
|
$lng['serversettings']['logfiles_type']['title'] = 'Access-log type';
|
||||||
|
$lng['serversettings']['logfiles_type']['description'] = 'Chose between <strong>combined</strong> or <strong>vhost_combined</strong> here.';
|
||||||
|
$lng['serversettings']['logfiles_piped']['title'] = 'Pipe webserver logfiles to specified script (see above)';
|
||||||
|
$lng['serversettings']['logfiles_piped']['description'] = 'When using a custom script for the logfiles you need to activate this in order for it to be executed';
|
||||||
$lng['serversettings']['ipaddress']['title'] = 'IP-address';
|
$lng['serversettings']['ipaddress']['title'] = 'IP-address';
|
||||||
$lng['serversettings']['ipaddress']['description'] = 'What\'s the main IP-address of this server?';
|
$lng['serversettings']['ipaddress']['description'] = 'What\'s the main IP-address of this server?';
|
||||||
$lng['serversettings']['hostname']['title'] = 'Hostname';
|
$lng['serversettings']['hostname']['title'] = 'Hostname';
|
||||||
@@ -508,8 +517,8 @@ $lng['changepassword']['also_change_webalizer'] = ' also change password for the
|
|||||||
|
|
||||||
$lng['serversettings']['mailpwcleartext']['title'] = 'Also save passwords of mail accounts unencrypted in database';
|
$lng['serversettings']['mailpwcleartext']['title'] = 'Also save passwords of mail accounts unencrypted in database';
|
||||||
$lng['serversettings']['mailpwcleartext']['description'] = 'If this is set to yes, all passwords will also be saved unencrypted (clear text, plain readable for everyone with database access) in the mail_users-table. Only activate this if you intend to use SASL!';
|
$lng['serversettings']['mailpwcleartext']['description'] = 'If this is set to yes, all passwords will also be saved unencrypted (clear text, plain readable for everyone with database access) in the mail_users-table. Only activate this if you intend to use SASL!';
|
||||||
$lng['serversettings']['mailpwcleartext']['removelink'] = 'Click here to wipe all unencrypted passwords from the table.';
|
$lng['admin']['wipecleartextmailpwd'] = 'Clear plaintext passwords';
|
||||||
$lng['question']['admin_cleartextmailpws_reallywipe'] = 'Do you really want to wipe all unencrypted mail account passwords from the table mail_users? This cannot be reverted!';
|
$lng['question']['admin_cleartextmailpws_reallywipe'] = 'Do you really want to wipe all unencrypted mail account passwords from the table mail_users? This cannot be reverted! The setting to store email passwords unencrypted will also be set to OFF';
|
||||||
$lng['admin']['configfiles']['overview'] = 'Overview';
|
$lng['admin']['configfiles']['overview'] = 'Overview';
|
||||||
$lng['admin']['configfiles']['wizard'] = 'Wizard';
|
$lng['admin']['configfiles']['wizard'] = 'Wizard';
|
||||||
$lng['admin']['configfiles']['distribution'] = 'Distribution';
|
$lng['admin']['configfiles']['distribution'] = 'Distribution';
|
||||||
@@ -534,7 +543,7 @@ $lng['panel']['back'] = 'Back';
|
|||||||
// ADDED IN 1.2.16-svn12
|
// ADDED IN 1.2.16-svn12
|
||||||
|
|
||||||
$lng['serversettings']['mod_fcgid']['title'] = 'Enable FCGID';
|
$lng['serversettings']['mod_fcgid']['title'] = 'Enable FCGID';
|
||||||
$lng['serversettings']['mod_fcgid']['description'] = 'Use this to run PHP with the corresponding useraccount.<br /><br /><b>This needs a special webserver configuration for Apache, see <a target="blank" href="http://redmine.froxlor.org/projects/froxlor/wiki/HandbookApache2_fcgid">FCGID - handbook</a></b>';
|
$lng['serversettings']['mod_fcgid']['description'] = 'Use this to run PHP with the corresponding useraccount.<br /><br /><b>This needs a special webserver configuration for Apache, see <a target="blank" href="https://github.com/Froxlor/Froxlor/wiki/apache2-with-fcgid">FCGID - handbook</a></b>';
|
||||||
$lng['serversettings']['sendalternativemail']['title'] = 'Use alternative email-address';
|
$lng['serversettings']['sendalternativemail']['title'] = 'Use alternative email-address';
|
||||||
$lng['serversettings']['sendalternativemail']['description'] = 'Send the password-email to a different address during email-account-creation';
|
$lng['serversettings']['sendalternativemail']['description'] = 'Send the password-email to a different address during email-account-creation';
|
||||||
$lng['emails']['alternative_emailaddress'] = 'Alternative e-mail-address';
|
$lng['emails']['alternative_emailaddress'] = 'Alternative e-mail-address';
|
||||||
@@ -940,6 +949,7 @@ $lng['admin']['phpsettings']['phpinisettings'] = 'php.ini settings';
|
|||||||
$lng['error']['nopermissionsorinvalidid'] = 'You don\'t have enough permissions to change these settings or an invalid id was given.';
|
$lng['error']['nopermissionsorinvalidid'] = 'You don\'t have enough permissions to change these settings or an invalid id was given.';
|
||||||
$lng['panel']['view'] = 'view';
|
$lng['panel']['view'] = 'view';
|
||||||
$lng['question']['phpsetting_reallydelete'] = 'Do you really want to delete these settings? All domains which use these settings currently will be changed to the default config.';
|
$lng['question']['phpsetting_reallydelete'] = 'Do you really want to delete these settings? All domains which use these settings currently will be changed to the default config.';
|
||||||
|
$lng['question']['fpmsetting_reallydelete'] = 'Do you really want to delete these php-fpm settings? All php configurations which use these settings currently will be changed to the default config.';
|
||||||
$lng['admin']['phpsettings']['addnew'] = 'Create new settings';
|
$lng['admin']['phpsettings']['addnew'] = 'Create new settings';
|
||||||
$lng['error']['phpsettingidwrong'] = 'A PHP Configuration with this id doesn\'t exist';
|
$lng['error']['phpsettingidwrong'] = 'A PHP Configuration with this id doesn\'t exist';
|
||||||
$lng['error']['descriptioninvalid'] = 'The description is too short, too long or contains illegal characters.';
|
$lng['error']['descriptioninvalid'] = 'The description is too short, too long or contains illegal characters.';
|
||||||
@@ -1001,6 +1011,7 @@ $lng['error']['ipportdoesntexist'] = 'The ip/port combination you have chosen do
|
|||||||
|
|
||||||
$lng['admin']['phpserversettings'] = 'PHP Settings';
|
$lng['admin']['phpserversettings'] = 'PHP Settings';
|
||||||
$lng['admin']['phpsettings']['binary'] = 'PHP Binary';
|
$lng['admin']['phpsettings']['binary'] = 'PHP Binary';
|
||||||
|
$lng['admin']['phpsettings']['fpmdesc'] = 'PHP-FPM config';
|
||||||
$lng['admin']['phpsettings']['file_extensions'] = 'File extensions';
|
$lng['admin']['phpsettings']['file_extensions'] = 'File extensions';
|
||||||
$lng['admin']['phpsettings']['file_extensions_note'] = '(without dot, separated by spaces)';
|
$lng['admin']['phpsettings']['file_extensions_note'] = '(without dot, separated by spaces)';
|
||||||
$lng['admin']['mod_fcgid_maxrequests']['title'] = 'Maximum php requests for this domain (empty for default value)';
|
$lng['admin']['mod_fcgid_maxrequests']['title'] = 'Maximum php requests for this domain (empty for default value)';
|
||||||
@@ -1102,7 +1113,7 @@ $lng['dkim']['dkim_notes']['description'] = 'Notes that might be of interest to
|
|||||||
$lng['dkim']['dkim_add_adsp']['title'] = 'Add DKIM ADSP entry';
|
$lng['dkim']['dkim_add_adsp']['title'] = 'Add DKIM ADSP entry';
|
||||||
$lng['dkim']['dkim_add_adsp']['description'] = 'If you don\'t know what this is, leave it "enabled"';
|
$lng['dkim']['dkim_add_adsp']['description'] = 'If you don\'t know what this is, leave it "enabled"';
|
||||||
$lng['dkim']['dkim_add_adsppolicy']['title'] = 'ADSP policy';
|
$lng['dkim']['dkim_add_adsppolicy']['title'] = 'ADSP policy';
|
||||||
$lng['dkim']['dkim_add_adsppolicy']['description'] = 'For more information about this setting see <a target="blank" href="http://redmine.froxlor.org/projects/froxlor/wiki/En-dkim-adsp-policies">DKIM ADSP policies</a>';
|
$lng['dkim']['dkim_add_adsppolicy']['description'] = 'For more information about this setting see <a target="blank" href="https://en.wikipedia.org/wiki/Author_Domain_Signing_Practices">DKIM ADSP policies</a>';
|
||||||
|
|
||||||
$lng['admin']['cron']['cronsettings'] = 'Cronjob settings';
|
$lng['admin']['cron']['cronsettings'] = 'Cronjob settings';
|
||||||
$lng['cron']['cronname'] = 'cronjob-name';
|
$lng['cron']['cronname'] = 'cronjob-name';
|
||||||
@@ -1293,7 +1304,7 @@ $lng['error']['intvaluetoolow'] = 'The given number is too low (field %s)';
|
|||||||
$lng['error']['intvaluetoohigh'] = 'The given number is too high (field %s)';
|
$lng['error']['intvaluetoohigh'] = 'The given number is too high (field %s)';
|
||||||
$lng['admin']['phpfpm_settings'] = 'PHP-FPM';
|
$lng['admin']['phpfpm_settings'] = 'PHP-FPM';
|
||||||
$lng['serversettings']['phpfpm']['title'] = 'Enable php-fpm';
|
$lng['serversettings']['phpfpm']['title'] = 'Enable php-fpm';
|
||||||
$lng['serversettings']['phpfpm']['description'] = '<b>This needs a special webserver configuration see FPM-handbook for <a target="blank" href="http://redmine.froxlor.org/projects/froxlor/wiki/HandbookApache2_phpfpm">Apache2</a> or <a target="blank" href="http://redmine.froxlor.org/projects/froxlor/wiki/HandbookNginx_phpfpm">nginx</a></b>';
|
$lng['serversettings']['phpfpm']['description'] = '<b>This needs a special webserver configuration see FPM-handbook for <a target="blank" href="https://github.com/Froxlor/Froxlor/wiki/apache2-with-php-fpm">Apache2</a> or <a target="blank" href="https://github.com/Froxlor/Froxlor/wiki/nginx-with-php-fpm">nginx</a></b>';
|
||||||
$lng['serversettings']['phpfpm_settings']['configdir'] = 'Configuration directory of php-fpm';
|
$lng['serversettings']['phpfpm_settings']['configdir'] = 'Configuration directory of php-fpm';
|
||||||
$lng['serversettings']['phpfpm_settings']['aliasconfigdir'] = 'Configuration Alias-directory of php-fpm';
|
$lng['serversettings']['phpfpm_settings']['aliasconfigdir'] = 'Configuration Alias-directory of php-fpm';
|
||||||
$lng['serversettings']['phpfpm_settings']['reload'] = 'php-fpm restart command';
|
$lng['serversettings']['phpfpm_settings']['reload'] = 'php-fpm restart command';
|
||||||
@@ -1646,7 +1657,7 @@ $lng['admin']['usedmax'] = 'Used / Max';
|
|||||||
$lng['admin']['used'] = 'Used';
|
$lng['admin']['used'] = 'Used';
|
||||||
$lng['mysql']['size'] = 'Size';
|
$lng['mysql']['size'] = 'Size';
|
||||||
|
|
||||||
$lng['error']['invalidhostname'] = 'Hostname can\'t be empty nor can it consist only of whitespaces';
|
$lng['error']['invalidhostname'] = 'Hostname needs to be avalid domain. It can\'t be empty nor can it consist only of whitespaces';
|
||||||
|
|
||||||
$lng['traffic']['http'] = 'HTTP (MiB)';
|
$lng['traffic']['http'] = 'HTTP (MiB)';
|
||||||
$lng['traffic']['ftp'] = 'FTP (MiB)';
|
$lng['traffic']['ftp'] = 'FTP (MiB)';
|
||||||
@@ -1656,7 +1667,7 @@ $lng['traffic']['mail'] = 'Mail (MiB)';
|
|||||||
$lng['serversettings']['mod_fcgid']['idle_timeout']['title'] = 'Idle Timeout';
|
$lng['serversettings']['mod_fcgid']['idle_timeout']['title'] = 'Idle Timeout';
|
||||||
$lng['serversettings']['mod_fcgid']['idle_timeout']['description'] = 'Timeout setting for Mod FastCGI.';
|
$lng['serversettings']['mod_fcgid']['idle_timeout']['description'] = 'Timeout setting for Mod FastCGI.';
|
||||||
$lng['serversettings']['phpfpm_settings']['idle_timeout']['title'] = 'Idle Timeout';
|
$lng['serversettings']['phpfpm_settings']['idle_timeout']['title'] = 'Idle Timeout';
|
||||||
$lng['serversettings']['phpfpm_settings']['idle_timeout']['description'] = 'Timeout setting for PHP5 FPM FastCGI.';
|
$lng['serversettings']['phpfpm_settings']['idle_timeout']['description'] = 'Timeout setting for PHP FPM FastCGI.';
|
||||||
|
|
||||||
// ADDED IN 0.9.27-svn2
|
// ADDED IN 0.9.27-svn2
|
||||||
$lng['panel']['cancel'] = 'Cancel';
|
$lng['panel']['cancel'] = 'Cancel';
|
||||||
@@ -1826,7 +1837,7 @@ $lng['serversettings']['panel_password_special_char_required']['description'] =
|
|||||||
$lng['serversettings']['panel_password_special_char']['title'] = 'Special characters list';
|
$lng['serversettings']['panel_password_special_char']['title'] = 'Special characters list';
|
||||||
$lng['serversettings']['panel_password_special_char']['description'] = 'One of these characters is required if the above option is set.';
|
$lng['serversettings']['panel_password_special_char']['description'] = 'One of these characters is required if the above option is set.';
|
||||||
$lng['phpfpm']['use_mod_proxy']['title'] = 'Use mod_proxy / mod_proxy_fcgi';
|
$lng['phpfpm']['use_mod_proxy']['title'] = 'Use mod_proxy / mod_proxy_fcgi';
|
||||||
$lng['phpfpm']['use_mod_proxy']['description'] = 'Activate to use php-fpm via mod_proxy_fcgi. Requires at least apache-2.4.9';
|
$lng['phpfpm']['use_mod_proxy']['description'] = '<strong class="red">Must be enabled when using Debian 9.x (Stretch)</strong>. Activate to use php-fpm via mod_proxy_fcgi. Requires at least apache-2.4.9';
|
||||||
$lng['error']['no_phpinfo'] = 'Sorry, unable to read phpinfo()';
|
$lng['error']['no_phpinfo'] = 'Sorry, unable to read phpinfo()';
|
||||||
|
|
||||||
$lng['admin']['movetoadmin'] = 'Move customer';
|
$lng['admin']['movetoadmin'] = 'Move customer';
|
||||||
@@ -1840,16 +1851,16 @@ $lng['domains']['import_file'] = 'CSV-File';
|
|||||||
$lng['success']['domain_import_successfully'] = 'Successfully imported %s domains.';
|
$lng['success']['domain_import_successfully'] = 'Successfully imported %s domains.';
|
||||||
$lng['error']['domain_import_error'] = 'Following error occurred while importing domains: %s';
|
$lng['error']['domain_import_error'] = 'Following error occurred while importing domains: %s';
|
||||||
$lng['admin']['note'] = 'Note';
|
$lng['admin']['note'] = 'Note';
|
||||||
$lng['domains']['import_description'] = 'Detailed information about the structure of the import-file and how to import successfully, please visit <a href="http://redmine.froxlor.org/projects/froxlor/wiki/DomainBulkActionDoc" target="_blank">http://redmine.froxlor.org/projects/froxlor/wiki/DomainBulkActionDoc</a>';
|
$lng['domains']['import_description'] = 'Detailed information about the structure of the import-file and how to import successfully, please visit <a href="https://github.com/Froxlor/Froxlor/wiki/Domain-import-documenation" target="_blank">https://github.com/Froxlor/Froxlor/wiki/Domain-import-documenation</a>';
|
||||||
$lng['usersettings']['custom_notes']['title'] = 'Custom notes';
|
$lng['usersettings']['custom_notes']['title'] = 'Custom notes';
|
||||||
$lng['usersettings']['custom_notes']['description'] = 'Feel free to put any notes you want/need in here. They will show up in the admin/customer overview for the corresponding user.';
|
$lng['usersettings']['custom_notes']['description'] = 'Feel free to put any notes you want/need in here. They will show up in the admin/customer overview for the corresponding user.';
|
||||||
$lng['usersettings']['custom_notes']['show'] = 'Show your notes on the dashboard of the user';
|
$lng['usersettings']['custom_notes']['show'] = 'Show your notes on the dashboard of the user';
|
||||||
$lng['error']['fcgidandphpfpmnogoodtogether'] = 'FCGID and PHP-FPM cannot be activated at the same time';
|
$lng['error']['fcgidandphpfpmnogoodtogether'] = 'FCGID and PHP-FPM cannot be activated at the same time';
|
||||||
|
|
||||||
// Added in Froxlor 0.9.34
|
// Added in Froxlor 0.9.34
|
||||||
$lng['admin']['configfiles']['legend'] = 'You are about to configure a service/daemon. The following legend explains the nomenclature.';
|
$lng['admin']['configfiles']['legend'] = '<h3>You are about to configure a service/daemon</h3>';
|
||||||
$lng['admin']['configfiles']['commands'] = '<span class="red">Commands:</span> These commands are to be executed line by line as root-user in a shell. It is safe to copy the whole block and paste it into the shell.';
|
$lng['admin']['configfiles']['commands'] = '<span class="red">Commands:</span> These commands are to be executed line by line as root-user in a shell. It is safe to copy the whole block and paste it into the shell.';
|
||||||
$lng['admin']['configfiles']['files'] = '<span class="red">Configfiles:</span> This is an example of the contents of a configuration file. The commands before these textfields should open an editor with the target file. Just copy and paste the contents into the editor and save the file.<br><br><span class="red">Please note:</span> The MySQL-password has not been replaced for security reasons. Please replace "MYSQL_PASSWORD" on your own. If you forgot your MySQL-password you\'ll find it in "lib/userdata.inc.php"';
|
$lng['admin']['configfiles']['files'] = '<span class="red">Configfiles:</span> The commands before the textfields should open an editor with the target file. Just copy and paste the contents into the editor and save the file.<br><span class="red">Please note:</span> The MySQL-password has not been replaced for security reasons. Please replace "FROXLOR_MYSQL_PASSWORD" on your own or use the javascript form below to replace it on-site. If you forgot your MySQL-password you\'ll find it in "lib/userdata.inc.php"';
|
||||||
$lng['serversettings']['apache_itksupport']['title'] = 'Use modifications for Apache ITK-MPM';
|
$lng['serversettings']['apache_itksupport']['title'] = 'Use modifications for Apache ITK-MPM';
|
||||||
$lng['serversettings']['apache_itksupport']['description'] = '<strong class="red">ATTENTION:</strong> use only if you acutally have apache itk-mpm enabled<br />otherwise your webserver will not be able to start';
|
$lng['serversettings']['apache_itksupport']['description'] = '<strong class="red">ATTENTION:</strong> use only if you acutally have apache itk-mpm enabled<br />otherwise your webserver will not be able to start';
|
||||||
$lng['integrity_check']['DatabaseCharset'] = 'Characterset of database (should be UTF-8)';
|
$lng['integrity_check']['DatabaseCharset'] = 'Characterset of database (should be UTF-8)';
|
||||||
@@ -1938,7 +1949,7 @@ $lng['admin']['letsencrypt']['description'] = 'Get a free certificate from <a hr
|
|||||||
$lng['customer']['letsencrypt']['title'] = 'Use Let\'s Encrypt';
|
$lng['customer']['letsencrypt']['title'] = 'Use Let\'s Encrypt';
|
||||||
$lng['customer']['letsencrypt']['description'] = 'Get a free certificate from <a href="https://letsencrypt.org">Let\'s Encrypt</a>. The certificate will be created and renewed automatically.<br><strong class="red">ATTENTION:</strong> This feature is still in beta.';
|
$lng['customer']['letsencrypt']['description'] = 'Get a free certificate from <a href="https://letsencrypt.org">Let\'s Encrypt</a>. The certificate will be created and renewed automatically.<br><strong class="red">ATTENTION:</strong> This feature is still in beta.';
|
||||||
$lng['error']['sslredirectonlypossiblewithsslipport'] = 'Using Let\'s Encrypt is only possible when the domain has at least one ssl-enabled IP/port combination assigned.';
|
$lng['error']['sslredirectonlypossiblewithsslipport'] = 'Using Let\'s Encrypt is only possible when the domain has at least one ssl-enabled IP/port combination assigned.';
|
||||||
$lng['error']['nowildcardwithletsencrypt'] = 'Let\'s Encrypt cannot (yet) handle wildcard-domains. Please set the ServerAlias to WWW or disable it completely';
|
$lng['error']['nowildcardwithletsencrypt'] = 'Let\'s Encrypt cannot handle wildcard-domains using ACME v1. Please set the ServerAlias to WWW or disable it completely';
|
||||||
$lng['panel']['letsencrypt'] = 'Using Let\'s encrypt';
|
$lng['panel']['letsencrypt'] = 'Using Let\'s encrypt';
|
||||||
$lng['crondesc']['cron_letsencrypt'] = 'updating Let\'s Encrypt certificates';
|
$lng['crondesc']['cron_letsencrypt'] = 'updating Let\'s Encrypt certificates';
|
||||||
$lng['serversettings']['letsencryptca']['title'] = "Let's Encrypt environment";
|
$lng['serversettings']['letsencryptca']['title'] = "Let's Encrypt environment";
|
||||||
@@ -1972,7 +1983,7 @@ $lng['error']['autoupdate_9'] = 'The downloaded file did not pass the integrity
|
|||||||
|
|
||||||
$lng['admin']['server_php'] = 'PHP';
|
$lng['admin']['server_php'] = 'PHP';
|
||||||
$lng['domains']['termination_date'] = 'Date of termination';
|
$lng['domains']['termination_date'] = 'Date of termination';
|
||||||
$lng['domains']['termination_date_overview'] = 'canceled until ';
|
$lng['domains']['termination_date_overview'] = 'terminated as of ';
|
||||||
$lng['panel']['set'] = 'Apply';
|
$lng['panel']['set'] = 'Apply';
|
||||||
$lng['customer']['selectserveralias_addinfo'] = 'This option can be set when editing the domain. Its initial value is inherited from the parent-domain.';
|
$lng['customer']['selectserveralias_addinfo'] = 'This option can be set when editing the domain. Its initial value is inherited from the parent-domain.';
|
||||||
$lng['error']['mailaccistobedeleted'] = "Another account with the same name (%s) is currently being deleted and can therefore not be added at this moment.";
|
$lng['error']['mailaccistobedeleted'] = "Another account with the same name (%s) is currently being deleted and can therefore not be added at this moment.";
|
||||||
@@ -2038,8 +2049,8 @@ $lng['serversettings']['le_froxlor_enabled']['description'] = "If activated, the
|
|||||||
$lng['serversettings']['le_froxlor_redirect']['title'] = "Enable SSL-redirect for the froxlor vhost";
|
$lng['serversettings']['le_froxlor_redirect']['title'] = "Enable SSL-redirect for the froxlor vhost";
|
||||||
$lng['serversettings']['le_froxlor_redirect']['description'] = "If activated, all http requests to your froxlor will be redirected to the corresponding SSL site.";
|
$lng['serversettings']['le_froxlor_redirect']['description'] = "If activated, all http requests to your froxlor will be redirected to the corresponding SSL site.";
|
||||||
$lng['admin']['froxlorvhost'] = 'Froxlor VirtualHost settings';
|
$lng['admin']['froxlorvhost'] = 'Froxlor VirtualHost settings';
|
||||||
$lng['serversettings']['option_unavailable_websrv'] = '<br><em class="red">Availble only for: %s</em>';
|
$lng['serversettings']['option_unavailable_websrv'] = '<br><em class="red">Available only for: %s</em>';
|
||||||
$lng['serversettings']['option_unavailable'] = '<br><em class="red">Option not availble due to other settings.</em>';
|
$lng['serversettings']['option_unavailable'] = '<br><em class="red">Option not available due to other settings.</em>';
|
||||||
$lng['serversettings']['letsencryptacmeconf']['title'] = "Path to the acme.conf snippet";
|
$lng['serversettings']['letsencryptacmeconf']['title'] = "Path to the acme.conf snippet";
|
||||||
$lng['serversettings']['letsencryptacmeconf']['description'] = "File name of the config snippet which allows the web server to serve the acme challenge.";
|
$lng['serversettings']['letsencryptacmeconf']['description'] = "File name of the config snippet which allows the web server to serve the acme challenge.";
|
||||||
$lng['admin']['hostname'] = 'Hostname';
|
$lng['admin']['hostname'] = 'Hostname';
|
||||||
@@ -2063,5 +2074,59 @@ $lng['admin']['domain_hsts_incsub']['description'] = 'The optional "includeSubDo
|
|||||||
$lng['admin']['domain_hsts_preload']['title'] = 'Include domain in <a href="https://hstspreload.appspot.com/" target="_blank">HSTS preload list</a>';
|
$lng['admin']['domain_hsts_preload']['title'] = 'Include domain in <a href="https://hstspreload.appspot.com/" target="_blank">HSTS preload list</a>';
|
||||||
$lng['admin']['domain_hsts_preload']['description'] = 'If you would like this domain to be included in the HSTS preload list maintained by Chrome (and used by Firefox and Safari), then use activate this.<br>Sending the preload directive from your site can have PERMANENT CONSEQUENCES and prevent users from accessing your site and any of its subdomains.<br>Please read the details at <a href="https://hstspreload.appspot.com/#removal" target="_blank">hstspreload.appspot.com/#removal</a> before sending the header with "preload".';
|
$lng['admin']['domain_hsts_preload']['description'] = 'If you would like this domain to be included in the HSTS preload list maintained by Chrome (and used by Firefox and Safari), then use activate this.<br>Sending the preload directive from your site can have PERMANENT CONSEQUENCES and prevent users from accessing your site and any of its subdomains.<br>Please read the details at <a href="https://hstspreload.appspot.com/#removal" target="_blank">hstspreload.appspot.com/#removal</a> before sending the header with "preload".';
|
||||||
|
|
||||||
$lng['serversettings']['nginx_http2_support']['title'] = 'Nginx HTTP2 Support';
|
$lng['serversettings']['http2_support']['title'] = 'HTTP2 Support';
|
||||||
$lng['serversettings']['nginx_http2_support']['description'] = 'enable http2 support for ssl. ENABLE ONLY IF YOUR Nginx SUPPORT THIS FEATURE. (version 1.9.5+)';
|
$lng['serversettings']['http2_support']['description'] = 'enable HTTP2 support for ssl.<br><em class="red">ENABLE ONLY IF YOUR WEBSERVER SUPPORTS THIS FEATURE (nginx version 1.9.5+, apache2 version 2.4.17+)</em>';
|
||||||
|
|
||||||
|
$lng['error']['noipportgiven'] = 'No IP/port given';
|
||||||
|
|
||||||
|
// Added in froxlor 0.9.38.8
|
||||||
|
$lng['admin']['domain_ocsp_stapling']['title'] = 'OCSP stapling';
|
||||||
|
$lng['admin']['domain_ocsp_stapling']['description'] = 'See <a target="_blank" href="https://en.wikipedia.org/wiki/OCSP_stapling">Wikipedia</a> for a detailed explanation of OCSP stapling';
|
||||||
|
$lng['admin']['domain_ocsp_stapling']['nginx_version_warning'] = '<br /><strong class="red">WARNING:</strong> Nginx version 1.3.7 or above is required for OCSP stapling. If your version is older, the webserver will NOT start correctly while OCSP stapling is enabled!';
|
||||||
|
$lng['serversettings']['ssl']['apache24_ocsp_cache_path']['title'] = 'Apache 2.4: path to the OCSP stapling cache';
|
||||||
|
$lng['serversettings']['ssl']['apache24_ocsp_cache_path']['description'] = 'Configures the cache used to store OCSP responses which get included in TLS handshakes.';
|
||||||
|
$lng['serversettings']['nssextrausers']['title'] = 'Use libnss-extrausers instead of libnss-mysql';
|
||||||
|
$lng['serversettings']['nssextrausers']['description'] = 'Do not read users from the database but from files. Please only activate if you have already gone through the required configuration steps (system -> libnss-extrausers).<br><strong class="red">For Debian/Ubuntu only (or if you have compiled libnss-extrausers yourself!)</strong>';
|
||||||
|
$lng['admin']['domain_http2']['title'] = 'HTTP2 support';
|
||||||
|
$lng['admin']['domain_http2']['description'] = 'See <a target="_blank" href="https://en.wikipedia.org/wiki/HTTP/2">Wikipedia</a> for a detailed explanation of HTTP2';
|
||||||
|
$lng['admin']['testmail'] = 'SMTP test';
|
||||||
|
$lng['success']['testmailsent'] = 'Test mail sent successfully';
|
||||||
|
$lng['serversettings']['disable_le_selfcheck']['title'] = "Disable Let's Encrypt local self-check";
|
||||||
|
$lng['serversettings']['disable_le_selfcheck']['description'] = "If activated, froxlor will <strong>not</strong> perform its self-check for token accessability. Needed for NATed IP's or similar.";
|
||||||
|
$lng['menue']['phpsettings']['fpmdaemons'] = 'PHP-FPM versions';
|
||||||
|
$lng['admin']['phpsettings']['activephpconfigs'] = 'In use for php-config(s)';
|
||||||
|
$lng['admin']['phpsettingsforsubdomains'] = 'Apply php-config to all subdomains:';
|
||||||
|
$lng['serversettings']['phpsettingsforsubdomains']['description'] = 'If yes the chosen php-config will be updated to all subdomains';
|
||||||
|
$lng['serversettings']['leapiversion']['title'] = "Chose Let's Encrypt ACME implementation";
|
||||||
|
$lng['serversettings']['leapiversion']['description'] = "Chose between ACME v1 and ACME v2 implementation for Let's Encrypt.";
|
||||||
|
$lng['error']['nowildcardwithletsencryptv2'] = 'Let\'s Encrypt can only validate wildcard-domains by DNS with ACME v2, sorry. Please set the ServerAlias to WWW or disable it completely';
|
||||||
|
$lng['admin']['phpsettings']['pass_authorizationheader'] = 'Add "-pass-header Authorization" / "CGIPassAuth On" to vhosts';
|
||||||
|
$lng['serversettings']['ssl']['ssl_protocols']['title'] = 'Configure the TLS protocol version';
|
||||||
|
$lng['serversettings']['ssl']['ssl_protocols']['description'] = 'This is a list of ssl protocols that you want (or don\'t want) to use when using SSL. <b>Notice:</b> Some older browsers may not support the newest protcol versions.<br /><br /><b>Default value is:</b><pre>TLSv1, TLSv1.2</pre>';
|
||||||
|
$lng['serversettings']['phpfpm_settings']['limit_extensions']['title'] = 'Allowed extensions';
|
||||||
|
$lng['serversettings']['phpfpm_settings']['limit_extensions']['description'] = 'Limits the extensions of the main script FPM will allow to parse. This can prevent configuration mistakes on the web server side. You should only limit FPM to .php extensions to prevent malicious users to use other extensions to execute php code. Default value: .php';
|
||||||
|
$lng['phpfpm']['ini_flags'] = 'Enter possible <strong>php_flag</strong>s for php.ini. One entry per line';
|
||||||
|
$lng['phpfpm']['ini_values'] = 'Enter possible <strong>php_value</strong>s for php.ini. One entry per line';
|
||||||
|
$lng['phpfpm']['ini_admin_flags'] = 'Enter possible <strong>php_admin_flag</strong>s for php.ini. One entry per line';
|
||||||
|
$lng['phpfpm']['ini_admin_values'] = 'Enter possible <strong>php_admin_value</strong>s for php.ini. One entry per line';
|
||||||
|
$lng['serversettings']['phpfpm_settings']['envpath'] = 'Paths to add to the PATH environment. Leave empty for no PATH environment variable';
|
||||||
|
$lng['admin']['configfiles']['importexport'] = 'Import/Export';
|
||||||
|
$lng['success']['settingsimported'] = 'Settings imported successfully';
|
||||||
|
$lng['error']['jsonextensionnotfound'] = 'This feature requires the php json-extension.';
|
||||||
|
|
||||||
|
// added in froxlor 0.9.39
|
||||||
|
$lng['admin']['plans']['name'] = 'Plan name';
|
||||||
|
$lng['admin']['plans']['description'] = 'Description';
|
||||||
|
$lng['admin']['plans']['last_update'] = 'Last updated';
|
||||||
|
$lng['admin']['plans']['plans'] = 'Hosting plans';
|
||||||
|
$lng['admin']['plans']['plan_details'] = 'Plan details';
|
||||||
|
$lng['admin']['plans']['add'] = 'Add new plan';
|
||||||
|
$lng['admin']['plans']['edit'] = 'Edit plan';
|
||||||
|
$lng['admin']['plans']['use_plan'] = 'Apply plan';
|
||||||
|
$lng['question']['plan_reallydelete'] = 'Do you really want to delete the hosting plan %s?';
|
||||||
|
$lng['admin']['notryfiles']['title'] = 'No autogenerated try_files';
|
||||||
|
$lng['admin']['notryfiles']['description'] = 'Say yes here if you want to specify a custom try_files directive in specialsettings (needed for some wordpress plugins for example).';
|
||||||
|
$lng['serversettings']['phpfpm_settings']['override_fpmconfig'] = 'Override FPM-daemon settings (pm, max_children, etc.)';
|
||||||
|
$lng['serversettings']['phpfpm_settings']['override_fpmconfig_addinfo'] = '<br /><span class="red">Only used if "Override FPM-daemon settings" is set to "Yes"</span>';
|
||||||
|
$lng['panel']['backuppath']['title'] = 'Destination path for the backup';
|
||||||
|
$lng['panel']['backuppath']['description'] = 'This is the path where the backups will be stored. If backup of web-data is selected, all files from the homedir are stored excluding the backup-folder specified here.';
|
||||||
|
|||||||
@@ -569,18 +569,18 @@ $lng['serversettings']['webalizer_quiet']['description'] = 'Verbosité du progra
|
|||||||
|
|
||||||
$lng['ticket']['admin_email'] = 'root@localhost';
|
$lng['ticket']['admin_email'] = 'root@localhost';
|
||||||
$lng['ticket']['noreply_email'] = 'billets@froxlor';
|
$lng['ticket']['noreply_email'] = 'billets@froxlor';
|
||||||
$lng['admin']['ticketsystem'] = 'Système de billets';
|
$lng['admin']['ticketsystem'] = 'Système de tickets';
|
||||||
$lng['menue']['ticket']['ticket'] = 'Billets de support';
|
$lng['menue']['ticket']['ticket'] = 'Tickets support';
|
||||||
$lng['menue']['ticket']['categories'] = 'Catégories de support';
|
$lng['menue']['ticket']['categories'] = 'Catégories de support';
|
||||||
$lng['menue']['ticket']['archive'] = 'Archives de billets';
|
$lng['menue']['ticket']['archive'] = 'Archives de tickets';
|
||||||
$lng['ticket']['description'] = 'Entrez une description !';
|
$lng['ticket']['description'] = 'Entrez une description !';
|
||||||
$lng['ticket']['ticket_new'] = 'Ouvrir un nouveau billet';
|
$lng['ticket']['ticket_new'] = 'Ouvrir un nouveau ticket';
|
||||||
$lng['ticket']['ticket_reply'] = 'Réponse au billet';
|
$lng['ticket']['ticket_reply'] = 'Réponse au ticket';
|
||||||
$lng['ticket']['ticket_reopen'] = 'Réouvrir le billet';
|
$lng['ticket']['ticket_reopen'] = 'Réouvrir le ticket';
|
||||||
$lng['ticket']['ticket_newcateory'] = 'Créer une nouvelle catégorie';
|
$lng['ticket']['ticket_newcateory'] = 'Créer une nouvelle catégorie';
|
||||||
$lng['ticket']['ticket_editcateory'] = 'Editer la catégorie';
|
$lng['ticket']['ticket_editcateory'] = 'Editer la catégorie';
|
||||||
$lng['ticket']['ticket_view'] = 'Voir l\'historique du billet';
|
$lng['ticket']['ticket_view'] = 'Voir l\'historique du ticket';
|
||||||
$lng['ticket']['ticketcount'] = 'Billets';
|
$lng['ticket']['ticketcount'] = 'Tickets';
|
||||||
$lng['ticket']['ticket_answers'] = 'Réponses';
|
$lng['ticket']['ticket_answers'] = 'Réponses';
|
||||||
// $lng['ticket']['lastchange'] = 'Dernière action';
|
// $lng['ticket']['lastchange'] = 'Dernière action';
|
||||||
$lng['ticket']['lastchange'] = 'Dernier changement';
|
$lng['ticket']['lastchange'] = 'Dernier changement';
|
||||||
@@ -601,8 +601,8 @@ $lng['ticket']['answer'] = 'Répondre';
|
|||||||
$lng['ticket']['close'] = 'Fermer';
|
$lng['ticket']['close'] = 'Fermer';
|
||||||
$lng['ticket']['reopen'] = 'Réouvrir';
|
$lng['ticket']['reopen'] = 'Réouvrir';
|
||||||
$lng['ticket']['archive'] = 'Archive';
|
$lng['ticket']['archive'] = 'Archive';
|
||||||
$lng['ticket']['ticket_delete'] = 'Effacer le billet';
|
$lng['ticket']['ticket_delete'] = 'Effacer le ticket';
|
||||||
$lng['ticket']['lastarchived'] = 'Billets récemment archivés';
|
$lng['ticket']['lastarchived'] = 'Tickets récemment archivés';
|
||||||
$lng['ticket']['archivedtime'] = 'Archivé';
|
$lng['ticket']['archivedtime'] = 'Archivé';
|
||||||
$lng['ticket']['open'] = 'Ouvert';
|
$lng['ticket']['open'] = 'Ouvert';
|
||||||
$lng['ticket']['wait_reply'] = 'Attente d\'une réponse';
|
$lng['ticket']['wait_reply'] = 'Attente d\'une réponse';
|
||||||
@@ -610,43 +610,43 @@ $lng['ticket']['replied'] = 'Répondu';
|
|||||||
$lng['ticket']['closed'] = 'Fermé';
|
$lng['ticket']['closed'] = 'Fermé';
|
||||||
$lng['ticket']['staff'] = 'L\'équipe';
|
$lng['ticket']['staff'] = 'L\'équipe';
|
||||||
$lng['ticket']['customer'] = 'Client';
|
$lng['ticket']['customer'] = 'Client';
|
||||||
$lng['ticket']['old_tickets'] = 'Messages du billet';
|
$lng['ticket']['old_tickets'] = 'Messages du ticket';
|
||||||
$lng['ticket']['search'] = 'Rechercher dans les archives';
|
$lng['ticket']['search'] = 'Rechercher dans les archives';
|
||||||
$lng['ticket']['nocustomer'] = 'Aucun choix';
|
$lng['ticket']['nocustomer'] = 'Aucun choix';
|
||||||
$lng['ticket']['archivesearch'] = 'Résultat de la recherche dans les archives';
|
$lng['ticket']['archivesearch'] = 'Résultat de la recherche dans les archives';
|
||||||
$lng['ticket']['noresults'] = 'Aucun billet trouvé';
|
$lng['ticket']['noresults'] = 'Aucun ticket trouvé';
|
||||||
$lng['ticket']['notmorethanxopentickets'] = 'Pour éviter les abus, vous ne pouvez avoir plus de %s billets ouverts';
|
$lng['ticket']['notmorethanxopentickets'] = 'Pour éviter les abus, vous ne pouvez avoir plus de %s tickets ouverts';
|
||||||
$lng['ticket']['supportstatus'] = 'Etat du support';
|
$lng['ticket']['supportstatus'] = 'Etat du support';
|
||||||
$lng['ticket']['supportavailable'] = '<span class="ticket_low">Nos équipes de support sont disponibles et prètes à vous assister.</span>';
|
$lng['ticket']['supportavailable'] = '<span class="ticket_low">Nos équipes de support sont disponibles et prètes à vous assister.</span>';
|
||||||
$lng['ticket']['supportnotavailable'] = '<span class="ticket_high">Nos équipes de support ne sont actuellement pas disponibles.</span>';
|
$lng['ticket']['supportnotavailable'] = '<span class="ticket_high">Nos équipes de support ne sont actuellement pas disponibles.</span>';
|
||||||
$lng['admin']['templates']['ticket'] = 'E-mail de notification pour les billets de support';
|
$lng['admin']['templates']['ticket'] = 'E-mail de notification pour les tickets de support';
|
||||||
$lng['admin']['templates']['SUBJECT'] = 'Sera remplacé par le sujet du billet de support.';
|
$lng['admin']['templates']['SUBJECT'] = 'Sera remplacé par le sujet du ticket de support.';
|
||||||
$lng['admin']['templates']['new_ticket_for_customer'] = 'Informe le client que le billet a été envoyé';
|
$lng['admin']['templates']['new_ticket_for_customer'] = 'Informe le client que le ticket a été envoyé';
|
||||||
$lng['admin']['templates']['new_ticket_by_customer'] = 'Notifie l\'administrateur qu\'un nouveau billet a été ouvert par un client';
|
$lng['admin']['templates']['new_ticket_by_customer'] = 'Notifie l\'administrateur qu\'un nouveau ticket a été ouvert par un client';
|
||||||
$lng['admin']['templates']['new_reply_ticket_by_customer'] = 'Notifie l\'administrateur d\'une réponse du client au billet';
|
$lng['admin']['templates']['new_reply_ticket_by_customer'] = 'Notifie l\'administrateur d\'une réponse du client au ticket';
|
||||||
$lng['admin']['templates']['new_ticket_by_staff'] = 'Informe le client qu\'un billet a été ouvert par l\'équipe de support';
|
$lng['admin']['templates']['new_ticket_by_staff'] = 'Informe le client qu\'un ticket a été ouvert par l\'équipe de support';
|
||||||
$lng['admin']['templates']['new_reply_ticket_by_staff'] = 'Informe le client d\'une réponse de l\'équipe de support au billet';
|
$lng['admin']['templates']['new_reply_ticket_by_staff'] = 'Informe le client d\'une réponse de l\'équipe de support au ticket';
|
||||||
$lng['mails']['new_ticket_for_customer']['mailbody'] = 'Bonjour {FIRSTNAME} {NAME},\n\nVotre demande de billet de support ayant comme sujet "{SUBJECT}" a été envoyé.\n\nVous receverez une notification lorsque votre billet aura une réponse.\n\nMerci,\nL\'équipe Froxlor.';
|
$lng['mails']['new_ticket_for_customer']['mailbody'] = 'Bonjour {FIRSTNAME} {NAME},\n\nVotre demande de ticket de support ayant comme sujet "{SUBJECT}" a été envoyé.\n\nVous receverez une notification lorsque votre billet aura une réponse.\n\nMerci,\nL\'équipe Froxlor.';
|
||||||
$lng['mails']['new_ticket_for_customer']['subject'] = 'Votre billet de support a été envoyé';
|
$lng['mails']['new_ticket_for_customer']['subject'] = 'Votre ticket de support a été envoyé';
|
||||||
$lng['mails']['new_ticket_by_customer']['mailbody'] = 'Bonjour administrateur,\n\nUn nouveau billet de support ayant comme sujet "{SUBJECT}" a été ouvert.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nl\'équipe Froxlor.';
|
$lng['mails']['new_ticket_by_customer']['mailbody'] = 'Bonjour administrateur,\n\nUn nouveau ticket de support ayant comme sujet "{SUBJECT}" a été ouvert.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nl\'équipe Froxlor.';
|
||||||
$lng['mails']['new_ticket_by_customer']['subject'] = 'Nouveau billet de support soumis';
|
$lng['mails']['new_ticket_by_customer']['subject'] = 'Nouveau ticket de support soumis';
|
||||||
$lng['mails']['new_reply_ticket_by_customer']['mailbody'] = 'Bonjour administrateur,\n\nLe billet de support "{SUBJECT}" a reçu une réponse de la part du client.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nL\'équipe Froxlor.';
|
$lng['mails']['new_reply_ticket_by_customer']['mailbody'] = 'Bonjour administrateur,\n\nLe ticket de support "{SUBJECT}" a reçu une réponse de la part du client.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nL\'équipe Froxlor.';
|
||||||
$lng['mails']['new_reply_ticket_by_customer']['subject'] = 'Nouvelle réponse au billet de support';
|
$lng['mails']['new_reply_ticket_by_customer']['subject'] = 'Nouvelle réponse au ticket de support';
|
||||||
$lng['mails']['new_ticket_by_staff']['mailbody'] = 'Bonjour {FIRSTNAME} {NAME},\n\nUn billet de support ayant comme sujet "{SUBJECT}" a été ouvert pour vous par notre équipe.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nL\'équipe Froxlor.';
|
$lng['mails']['new_ticket_by_staff']['mailbody'] = 'Bonjour {FIRSTNAME} {NAME},\n\nUn ticket de support ayant comme sujet "{SUBJECT}" a été ouvert pour vous par notre équipe.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nL\'équipe Froxlor.';
|
||||||
$lng['mails']['new_ticket_by_staff']['subject'] = 'Nouvelle demande de support soumise';
|
$lng['mails']['new_ticket_by_staff']['subject'] = 'Nouvelle demande de support soumise';
|
||||||
$lng['mails']['new_reply_ticket_by_staff']['mailbody'] = 'Bonjour {FIRSTNAME} {NAME},\n\nLe billet de support ayant comme sujet "{SUBJECT}" a reçu une réponse par notre équipe.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nL\équipe Froxlor.';
|
$lng['mails']['new_reply_ticket_by_staff']['mailbody'] = 'Bonjour {FIRSTNAME} {NAME},\n\nLe ticket de support ayant comme sujet "{SUBJECT}" a reçu une réponse par notre équipe.\n\nVeuillez vous connecter pour consulter le billet.\n\nMerci,\nL\équipe Froxlor.';
|
||||||
$lng['mails']['new_reply_ticket_by_staff']['subject'] = 'Nouvelle réponse au billet de support';
|
$lng['mails']['new_reply_ticket_by_staff']['subject'] = 'Nouvelle réponse au ticket de support';
|
||||||
$lng['question']['ticket_reallyclose'] = 'Etes-vous sûr de vouloir clôturer le billet "%s" ?';
|
$lng['question']['ticket_reallyclose'] = 'Etes-vous sûr de vouloir clôturer le ticket "%s" ?';
|
||||||
$lng['question']['ticket_reallydelete'] = 'Etes-vous sûr de vouloir supprimer le billet "%s" ?';
|
$lng['question']['ticket_reallydelete'] = 'Etes-vous sûr de vouloir supprimer le ticket "%s" ?';
|
||||||
$lng['question']['ticket_reallydeletecat'] = 'Etes-vous sûr de vouloir supprimer la catégorie "%s" ?';
|
$lng['question']['ticket_reallydeletecat'] = 'Etes-vous sûr de vouloir supprimer la catégorie "%s" ?';
|
||||||
$lng['question']['ticket_reallyarchive'] = 'Etes-vous sûr de vouloir archiver le billet "%s" ?';
|
$lng['question']['ticket_reallyarchive'] = 'Etes-vous sûr de vouloir archiver le ticket "%s" ?';
|
||||||
$lng['error']['nomoreticketsavailable'] = 'Vous n\'avez plus de billets de disponibles. Veuillez contacter votre administrateur.';
|
$lng['error']['nomoreticketsavailable'] = 'Vous n\'avez plus de tickets de disponibles. Veuillez contacter votre administrateur.';
|
||||||
$lng['error']['nocustomerforticket'] = 'Ne peut créer de billet sans client';
|
$lng['error']['nocustomerforticket'] = 'Impossible de créer un ticket sans clients dans la base';
|
||||||
$lng['error']['categoryhastickets'] = 'La catégorie possède des billets.<br />Veuillez d\'abord supprimer tous les billets de cette catégorie.';
|
$lng['error']['categoryhastickets'] = 'La catégorie possède des tickets.<br />Veuillez d\'abord supprimer tous les tickets de cette catégorie.';
|
||||||
$lng['admin']['ticketsettings'] = 'Paramètres des billets de support';
|
$lng['admin']['ticketsettings'] = 'Paramètres des tickets de support';
|
||||||
$lng['admin']['archivelastrun'] = 'Derniers billets archivés';
|
$lng['admin']['archivelastrun'] = 'Derniers tickets archivés';
|
||||||
$lng['serversettings']['ticket']['noreply_email']['title'] = 'Adresse e-mail de non réponse';
|
$lng['serversettings']['ticket']['noreply_email']['title'] = 'Adresse e-mail de non réponse';
|
||||||
$lng['serversettings']['ticket']['noreply_email']['description'] = 'L\'adresse e-mail de l\'expéditeur de notification pour les billets de support, quelque chose du type no-reply@domaine.com';
|
$lng['serversettings']['ticket']['noreply_email']['description'] = 'L\'adresse e-mail de l\'expéditeur de notification pour les tickets de support, quelque chose du type no-reply@domaine.com';
|
||||||
$lng['serversettings']['ticket']['worktime_begin']['title'] = 'Début du support (hh:mm)';
|
$lng['serversettings']['ticket']['worktime_begin']['title'] = 'Début du support (hh:mm)';
|
||||||
$lng['serversettings']['ticket']['worktime_begin']['description'] = 'Horaire de début du support';
|
$lng['serversettings']['ticket']['worktime_begin']['description'] = 'Horaire de début du support';
|
||||||
$lng['serversettings']['ticket']['worktime_end']['title'] = 'Fin du support (hh:mm)';
|
$lng['serversettings']['ticket']['worktime_end']['title'] = 'Fin du support (hh:mm)';
|
||||||
@@ -655,21 +655,21 @@ $lng['serversettings']['ticket']['worktime_sat'] = 'Support disponible le samedi
|
|||||||
$lng['serversettings']['ticket']['worktime_sun'] = 'Support disponible le dimanche ?';
|
$lng['serversettings']['ticket']['worktime_sun'] = 'Support disponible le dimanche ?';
|
||||||
$lng['serversettings']['ticket']['worktime_all']['title'] = 'Aucune limite horaire pour le support';
|
$lng['serversettings']['ticket']['worktime_all']['title'] = 'Aucune limite horaire pour le support';
|
||||||
$lng['serversettings']['ticket']['worktime_all']['description'] = 'Si "Oui", les options pour le début et la fin du support seront écrasés.';
|
$lng['serversettings']['ticket']['worktime_all']['description'] = 'Si "Oui", les options pour le début et la fin du support seront écrasés.';
|
||||||
$lng['serversettings']['ticket']['archiving_days'] = 'Après combien de jours un billet fermé sera automatiquement archivé ?';
|
$lng['serversettings']['ticket']['archiving_days'] = 'Après combien de jours un ticket fermé sera automatiquement archivé ?';
|
||||||
$lng['customer']['tickets'] = 'Billet de support';
|
$lng['customer']['tickets'] = 'Ticket de support';
|
||||||
|
|
||||||
// ADDED IN 1.2.18-svn4
|
// ADDED IN 1.2.18-svn4
|
||||||
|
|
||||||
$lng['admin']['domain_nocustomeraddingavailable'] = 'Il n\'est acutellement pas possible d\'ajouter de domaines. Vous devez d\'abord ajouter un client.';
|
$lng['admin']['domain_nocustomeraddingavailable'] = 'Il n\'est acutellement pas possible d\'ajouter de domaines. Vous devez d\'abord ajouter un client.';
|
||||||
$lng['serversettings']['ticket']['enable'] = 'Activer le système de billets';
|
$lng['serversettings']['ticket']['enable'] = 'Activer le système de tickets';
|
||||||
$lng['serversettings']['ticket']['concurrentlyopen'] = 'Combien de billets peuvent être ouverts au même moment ?';
|
$lng['serversettings']['ticket']['concurrentlyopen'] = 'Combien de tickets peuvent être ouverts au même moment ?';
|
||||||
$lng['error']['norepymailiswrong'] = 'L\'adresse de "non réponse" n\'est pas bonne. Une adresse e-mail valide doit être entrée.';
|
$lng['error']['norepymailiswrong'] = 'L\'adresse de "non réponse" n\'est pas bonne. Une adresse e-mail valide doit être entrée.';
|
||||||
$lng['error']['tadminmailiswrong'] = 'L\'adresse de "l\'administrateur de billets" n\'est pas bonne. Une adresse e-mail valide doit être entrée.';
|
$lng['error']['tadminmailiswrong'] = 'L\'adresse de "l\'administrateur de tickets" n\'est pas bonne. Une adresse e-mail valide doit être entrée.';
|
||||||
$lng['ticket']['awaitingticketreply'] = 'Vous avez %s billet(s) de support non répondu(s).';
|
$lng['ticket']['awaitingticketreply'] = 'Vous avez %s ticket(s) de support non répondu(s).';
|
||||||
|
|
||||||
// ADDED IN 1.2.18-svn5
|
// ADDED IN 1.2.18-svn5
|
||||||
|
|
||||||
$lng['serversettings']['ticket']['noreply_name'] = 'Nom de l\'expéditeur e-mail des billets';
|
$lng['serversettings']['ticket']['noreply_name'] = 'Nom de l\'expéditeur e-mail des tickets';
|
||||||
|
|
||||||
// ADDED IN 1.2.19-svn1
|
// ADDED IN 1.2.19-svn1
|
||||||
|
|
||||||
@@ -679,8 +679,8 @@ $lng['serversettings']['mod_fcgid']['tmpdir']['title'] = 'Dossier temporaire pou
|
|||||||
|
|
||||||
// ADDED IN 1.2.19-svn3
|
// ADDED IN 1.2.19-svn3
|
||||||
|
|
||||||
$lng['serversettings']['ticket']['reset_cycle']['title'] = 'Intervalle de réinitialisation des billets utilisés';
|
$lng['serversettings']['ticket']['reset_cycle']['title'] = 'Intervalle de réinitialisation des tickets utilisés';
|
||||||
$lng['serversettings']['ticket']['reset_cycle']['description'] = 'Remettre le compteur de billets à 0 dans le temps imparti';
|
$lng['serversettings']['ticket']['reset_cycle']['description'] = 'Remettre le compteur de tickets à 0 dans le temps imparti';
|
||||||
$lng['admin']['tickets']['daily'] = 'Journalière';
|
$lng['admin']['tickets']['daily'] = 'Journalière';
|
||||||
$lng['admin']['tickets']['weekly'] = 'Hebdomadaire';
|
$lng['admin']['tickets']['weekly'] = 'Hebdomadaire';
|
||||||
$lng['admin']['tickets']['monthly'] = 'Mensuelle';
|
$lng['admin']['tickets']['monthly'] = 'Mensuelle';
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user