Olá
Uma pista,
QUOTE
<?php
function whmreq ($request,$host,$user,$accesshash,$usessl) {
$cleanaccesshash = preg_replace("'(\r|\n)'","",$accesshash);
$authstr = $user . ":" . $cleanaccesshash;
$cpanelaccterr = "";
if (function_exists("curl_init")) {
$ch = curl_init();
if ($usessl) {
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0);
curl_setopt($ch, CURLOPT_URL, "https://${host}:2087" . $request);
} else {
curl_setopt($ch, CURLOPT_URL, "http://${host}:2086" . $request);
}
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
$curlheaders[0] = "Authorization: WHM $authstr";
curl_setopt($ch,CURLOPT_HTTPHEADER,$curlheaders);
$data=curl_exec ($ch);
curl_close ($ch);
} elseif (function_exists("socket_create")) {
if ($usessl) {
$cpanelaccterr = "SSL Support requires curl";
return;
}
$service_port = 2086;
$address = gethostbyname($host);
$socket = socket_create (AF_INET, SOCK_STREAM, 0);
if ($socket < 0) {
$cpanelaccterr = "socket_create() failed";
return;
}
$result = socket_connect ($socket, $address, $service_port);
if ($result < 0) {
$cpanelaccterr = "socket_connect() failed";
return;
}
$in = "GET $request HTTP/1.0\n";
socket_write($socket,$in,strlen($in));
$in = "Connection: close\n";
socket_write($socket,$in,strlen($in));
$in = "Authorization: WHM $authstr\n\n\n";
socket_write($socket,$in,strlen($in));
$inheader = 1;
while(($buf = socket_read($socket, 512)) != false) {
if (!$inheader) {
$data .= $buf;
}
if(preg_match("'\r\n\r\n$'s", $buf)) {
$inheader = 0;
}
if(preg_match("'\n\n$'s", $buf)) {
$inheader = 0;
}
if(preg_match("'\r\n$'s", $buf)) {
$inheader = 0;
}
}
} else {
$cpanelaccterr = "php not compiled with --enable-sockets OR curl";
return;
}
return $data;
}
function listaccts ($host,$user,$accesshash,$usessl) {
$result = whmreq("/scripts2/listaccts?nohtml=1&viewall=1",$host,$user,$accesshash,$usessl);
if ($cpanelaccterr != "") { return; }
$page = split("\n",$result);
foreach ($page as $line) {
list($acct,$contents) = split("=", $line);
if ($acct != "") {
$allc = split(",", $contents);
$accts[$acct] = $allc;
}
}
return($accts);
}
$host = "localhost";
$user = ""; //login
$accesshash = ''; //chave de acesso "procure no whm por Cluster/Acesso Remoto e clique em "Gerar Chave de Acesso Remoto" e gere uma chave de acesso
$accts = listaccts($host,$user,$accesshash,0);
foreach($accts as $contas){
list($dominio, $login, $plano) = $contas;
print "Dominio: $dominio | Login: $login | Plano: $plano<br>";
}
?>
Aqui está a dica de ouro "chave de acesso "procure no whm por Cluster/Acesso Remoto e clique em "Gerar Chave de Acesso Remoto" e gere uma chave de acesso"
Tem como desenvolver mais ferramentas, basta editar o arquivo "/usr/local/cpanel/Cpanel/Accounting.php.inc"
Tb tem como desenvolver muito mais coisas, eu mesmo estou estudando e encontrei muitas coisas legais que da pra montar.
O script acima foi eu que montei "não escrevi o código, só montei com que eu encontrei na net", está meio tosco, pois por enquanto só estou estudando e vendo as possibilidades, mas já da pra ter uma ideía de como fazer.
O resto é com vc!!!
Abraços e T+