Sergio Cambra
2014-07-04 d6e6528fffe519595a21134d0c91fc34763a4d91
set webdav sys_groupid onAfterInsert, it didn't work onBeforeInsert. Change server_id and sys_groupid if parent_domain_id changes
1 files modified
30 ■■■■ changed files
interface/web/sites/webdav_user_edit.php 30 ●●●● patch | view | raw | blame | history
interface/web/sites/webdav_user_edit.php
@@ -139,15 +139,6 @@
             */
            $hash = md5($this->dataRecord["username"] . ':' . $this->dataRecord["dir"] . ':' . $this->dataRecord["password"]);
            $this->dataRecord["password"] = $hash;
            /*
            *  Get the data of the domain, owning the webdav user
            */
            $web = $app->db->queryOneRecord("SELECT * FROM web_domain WHERE domain_id = ".$app->functions->intval($this->dataRecord["parent_domain_id"]));
            /* The server is the server of the domain */
            $this->dataRecord["server_id"] = $web["server_id"];
            /* The Webdav user shall be owned by the same group then the website */
            $this->dataRecord["sys_groupid"] = $web['sys_groupid'];
        }
        parent::onBeforeInsert();
@@ -155,6 +146,15 @@
    function onAfterInsert() {
        global $app, $conf;
        $web = $app->db->queryOneRecord("SELECT * FROM web_domain WHERE domain_id = ".$app->functions->intval($this->dataRecord["parent_domain_id"]));
        $server_id = $app->functions->intval($web["server_id"]);
        // The webdav user shall be owned by the same group then the website
        $sys_groupid = $app->functions->intval($web['sys_groupid']);
        $sql = "UPDATE webdav_user SET server_id = $server_id, sys_groupid = '$sys_groupid' WHERE webdav_user_id = ".$this->id;
        $app->db->query($sql);
    }
    function onBeforeUpdate() {
@@ -184,6 +184,18 @@
    function onAfterUpdate() {
        global $app, $conf;
        //* When the site of the webdav user has been changed
        if(isset($this->dataRecord['parent_domain_id']) && $this->oldDataRecord['parent_domain_id'] != $this->dataRecord['parent_domain_id']) {
            $web = $app->db->queryOneRecord("SELECT * FROM web_domain WHERE domain_id = ".$app->functions->intval($this->dataRecord["parent_domain_id"]));
            $server_id = $app->functions->intval($web["server_id"]);
            // The webdav user shall be owned by the same group then the website
            $sys_groupid = $app->functions->intval($web['sys_groupid']);
            $sql = "UPDATE webdav_user SET server_id = $server_id, sys_groupid = '$sys_groupid' WHERE webdav_user_id = ".$this->id;
            $app->db->query($sql);
        }
    }
}