Current File : //root/panel/modules/pgusers/hooks/OnAfterDeleteClient.hook.php
<?php

DeleteClientPgDatabaseUser();

function DeleteClientPgDatabaseUser() {
    global $zdbh;
    $sql = "SELECT * FROM x_accounts WHERE ac_deleted_ts IS NOT NULL";
    $numrows = $zdbh->query($sql);
    if ($numrows->fetchColumn() <> 0) {
        $sql = $zdbh->prepare($sql);
        $sql->execute();
        while ($rowclient = $sql->fetch()) {
            $rowusers = "SELECT * FROM x_pg_users WHERE mu_acc_fk=:ac_id_pk AND mu_deleted_ts IS NULL";
            //$numuserrows = $zdbh->query($rowusers);      
            $numuserrows = $zdbh->prepare($rowusers);
            $numuserrows->bindParam(':ac_id_pk', $rowclient['ac_id_pk']);
            $numuserrows->execute();
            
            if ($numuserrows->fetchColumn() <> 0) {
                $rowusers = $zdbh->prepare($rowusers);
                $rowusers->bindParam(':ac_id_pk', $rowclient['ac_id_pk']);
                $rowusers->execute();
                while ($rowuser = $rowusers->fetch()) {
		
			
			include "/etc/sentora/panel/cnf/postgres.php";       
			$dbh1 = new PDO("pgsql:dbname=postgres;host=localhost", $pguser, $pgpwd);        
			$query="SELECT count(*) FROM pg_catalog.pg_user where usename='".$rowuser['mu_name_vc']."';";
			$nrows=0;
			$nrows=$dbh1->query($query)->fetchColumn();
			if($nrows)
			{ 
				$query="DROP OWNED BY ".$rowuser['mu_name_vc'].";";
				$numrows=$dbh1->query($query);
				$query="DROP USER  IF EXISTS ".$rowuser['mu_name_vc'].";";
				$numrows=$dbh1->query($query);
		
			}
			$dbh1=null;
                    /* 
					$delete = "SELECT EXISTS(SELECT 1 FROM mysql.user WHERE user = :mu_name_vc)";
                    $numrows = $zdbh->prepare($delete);
                    $numrows->bindParam(':mu_name_vc', $rowuser['mu_name_vc']);
                    
                    if ($numrows->execute()) {
                        if ($numrows->fetchColumn() <> 0) {
                            try {
                                $delete = $zdbh->prepare("DROP USER :mu_name_vc@:mu_access_vc;");
                                $delete->bindParam(':mu_name_vc', $rowuser['mu_name_vc']);
                                $delete->bindParam(':mu_access_vc', $rowuser['mu_access_vc']);
                                $delete->execute();
                                $delete = $zdbh->prepare("FLUSH PRIVILEGES");
                                $delete->execute();
                            } catch (PDOException $e) {
                                return false;
                            }
                        }
                    }
					*/
                    try {
                        $delete = $zdbh->prepare("
								UPDATE x_pg_users
								SET mu_deleted_ts = :time 
								WHERE mu_id_pk = :mu_id_pk");
                        $delete->bindParam(':time', time());
                        $delete->bindParam(':mu_id_pk', $rowuser['mu_id_pk']);
                        $delete->execute();
                        $delete = $zdbh->prepare("
								DELETE FROM x_pg_dbmap
								WHERE mm_user_fk = :mu_id_pk");
                        $delete->bindParam(':mu_id_pk', $rowuser['mu_id_pk']);
                        $delete->execute();
                    } catch (PDOException $e) {
                        return false;
                    }
                }
            }
        }
    }
}

?>