-
Notifications
You must be signed in to change notification settings - Fork 2
New Design with PHP 7 support #5
Comments
Great, so PHP 5.5 can be the minimum. That means using the short array syntax is feasible... As of PHP 5.4 you can also use the short array syntax, which replaces array() with []. My first pull request was two simple changes to allow the code to run under php7 but my next pull request will be huge because I'd like to use https://github.com/FriendsOfPHP/PHP-CS-Fixer to mass convert the entire codebase to |
I saw both changes were in the same PR, but I've merged #7 now. |
FWIW #9 was created with this and should only be temporary (GNU sed only)...
and can be removed with...
|
Following up from your comments in #9, I've added some initial backend docs (including the sql schema) for powerdns, dovecot and postifx in #10. I'm aware of your lack of intent to use the dovecot and postifx parts - no problem with that (I like courier too!) - but felt this would in conjunction with the missing schemas (my bad) would hopefully give a better idea with what was going on Albatross MySQL side. UI wise, there are three main components handled separately.
You can configure each of these separately and in any order you like. As long as in the end you have DNS pointing to the correct web and mail servers, the Site (web) and Email (mail) setup matches the domain and the Database created is set correctly in your apps php code all should work ok. I tried to design this more from a users point of view instead of a sysadmin/operations one. I.e.:
|
From a design point of view, I sought to get around the privilege problem of not wanting web based process being able to do system level stuff. So the model was created where the web UI would send jobs to a queue where a root/system level daemon also written in php ( As such items such as "create an account" are added to the amm queue, which triggers the jobpack "Account-CreateAccount". In there, the data is validated first for safety, then attempts the account classes "add" function. Upon success it then issues new jobs "Account-CreateHomeDir" to create the home directory and "Site-ConfPhpFpm" to configure up php-fpm for the user. The job then gets marked as closed.
|
Thanks for your input, I'll look at your docs and reread the above two posts again tomorrow. The Two codebase related points FWIW... globals and goto's really should be... shot on sight :-) With php5.5+ there are so many nicer ways to achieve the same end result with closures and anonymous functions, and just old school functions and classes for that matter. One of the reasons I like your codebase is that it is not polluted with some over-engineered framework and/or template engine, however, some thought on removing the goto's first then globals could be time well spent. That leads me to the 2nd point which is there is a lot of repeated boilerplate code that could be seriously refactored. I'd say at a guess that this...
could be reduced to at least half that size with a bit more of a DRY approach. |
Completely agree on the globals, gotos and boilerplate code. Just had not spent the time to do it in the past - had focused on stabilty and minor feature improvements before the 2 year lull with no changes. |
I just tested a ping test via ssh from nginx with each ping line being echoed back in real time. If you want to try this then somehow get this below to https://github.com/phpseclib/phpseclib/tree/master/phpseclib and add a
and then surf to somewhere this file is stored...
Update: I just tried the same script above but with a remote server and changed the ping target to point back to my local router and it worked. The only gotcha was that I had to |
As per #3 @markc we can discuss here about the new changes.
I'm currently using PHP 5.4 in my prod system, but I'm likely to keep that running the current Albatross version (now tagged and branched as cyprix-pre2015) on that one and replace it with a new server with different specs and the new setup based on master.
As such, I think PHP 5.5 is a sensible earliest version, with PHP 7 the prime target.
I'll admit some of the code is cringe worthy (like the globals and coding style - PSR-2 is a good choice). All this code and it's design dates back primarily to around 3-5 years ago when I was a young padawan in the industry (we all have to learn somehow ;) ).
Currently there are no roles within albatross itself, other than giving a user sudo privileges manually. The closest to that in albatross is the password override hack (feel free to remove this), where you can login as any user with a superpassword
$conf['rootpassword']
.There is no UI currently for adding users. However you can use the code below to send a new user create job to the amm daemon (which really needs root privileges). The "100001" is the ID of the user performing the action - but is just a reference for account creation and is not checked (no admin roles).
The success of the job can be checked either via mysql amm table (E.g.
mysql albatross -e "SELECT * FROM
ammWHERE uid='1441663549_543'"
) or the amm logs for full details.The text was updated successfully, but these errors were encountered: