Current File : //etc/zpanel/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;
}
}
}
}
}
}
?>