tbrehm
2009-02-14 8eafcef0294fbaa36a8c7e653b621e26edf4603a
- Fixed moving of site when the client is changed.
- FS#501 - disable shell account untill jailkit is finished
5 files modified
27 ■■■■ changed files
interface/lib/classes/tform_actions.inc.php 6 ●●●●● patch | view | raw | blame | history
interface/lib/classes/validate_client.inc.php 2 ●●● patch | view | raw | blame | history
server/plugins-available/apache2_plugin.inc.php 8 ●●●● patch | view | raw | blame | history
server/plugins-available/shelluser_base_plugin.inc.php 7 ●●●●● patch | view | raw | blame | history
server/plugins-available/shelluser_jailkit_plugin.inc.php 4 ●●●● patch | view | raw | blame | history
interface/lib/classes/tform_actions.inc.php
@@ -80,9 +80,11 @@
                // Calling the action functions
                if($this->id > 0) {
                        $this->onUpdate();
                    $app->tform->action == 'EDIT';
                    $this->onUpdate();
                } else {
                        $this->onInsert();
                    $app->tform->action == 'NEW';
                    $this->onInsert();
                }
        }
interface/lib/classes/validate_client.inc.php
@@ -36,7 +36,7 @@
    function username_unique($field_name, $field_value, $validator) {
        global $app;
        
        if($app->tform->action == 'NEW') {
        if($app->tform->primary_id == 0) {
            $num_rec = $app->db->queryOneRecord("SELECT count(*) as number FROM sys_user WHERE username = '".$app->db->quote($field_value)."'");
                if($num_rec["number"] > 0) {
                    $errmsg = $validator['errmsg'];
server/plugins-available/apache2_plugin.inc.php
@@ -233,14 +233,15 @@
            return 0;
        }
        
        //* If the client of the site has been changed, we have a change of the document root
        if($this->action == 'update' && $data["new"]["document_root"] != $data["old"]["document_root"]) {
            
            // Get the old client ID
            //* Get the old client ID
            $old_client = $app->dbmaster->queryOneRecord("SELECT client_id FROM sys_group WHERE sys_group.groupid = ".intval($data["old"]["sys_groupid"]));
            $old_client_id = intval($old_client["client_id"]);
            unset($old_client);
            
            // Remove the old symlinks
            //* Remove the old symlinks
            $tmp_symlinks_array = explode(':',$web_config["website_symlinks"]);
            if(is_array($tmp_symlinks_array)) {
                foreach($tmp_symlinks_array as $tmp_symlink) {
@@ -256,6 +257,7 @@
                }
            }
            
            //* Move the site data
            $tmp_docroot = explode('/',$data["new"]["document_root"]);
            unset($tmp_docroot[count($tmp_docroot)-1]);
            $new_dir = implode('/',$tmp_docroot);
@@ -269,8 +271,10 @@
            exec('mv '.$data["old"]["document_root"].' '.$new_dir);
            $app->log("Moving site to new document root: ".'mv '.$data["old"]["document_root"].' '.$new_dir,LOGLEVEL_DEBUG);
            
            //* Change the home directory and group of the website user
            $command = 'usermod';
            $command .= ' --home '.escapeshellcmd($data["new"]["document_root"]);
            $command .= ' --gid '.escapeshellcmd($data['new']['system_group']);
            $command .= ' '.escapeshellcmd($data["new"]["system_user"]);
            exec($command);
            
server/plugins-available/shelluser_base_plugin.inc.php
@@ -87,6 +87,13 @@
            
                exec($command);
                $app->log("Added shelluser: ".$data['new']['username'],LOGLEVEL_DEBUG);
                //* Disable shell user temporarily if we use jailkit
                if($data['new']['chroot'] == 'jailkit') {
                    $command = 'usermod --lock '.escapeshellcmd($data['new']['username']);
                    exec($command);
                    $app->log("Disabling shelluser temporarily: ".$data['new']['username'],LOGLEVEL_DEBUG);
                }
            
            } else {
                $app->log("UID = $uid for shelluser:".$data['new']['username']." not allowed.",LOGLEVEL_ERROR);
server/plugins-available/shelluser_jailkit_plugin.inc.php
@@ -86,6 +86,10 @@
                $this->jailkit_config = $app->getconf->get_server_config($conf["server_id"], 'jailkit');
            
                $this->_setup_jailkit_chroot();
                $command .= 'usermod --unlock '.escapeshellcmd($data['new']['username']);
                exec($command);
                $this->_add_jailkit_user();
            }