package WWW::Kinghost::Painel;
use strict qw(vars);
use vars qw($VERSION) ;
use warnings 'all';
use utf8;
use WWW::Mechanize;
use HTML::TreeBuilder::XPath;
use HTML::Entities;
use JSON;
use DBI;
use Net::FTP;
$VERSION = '0.04' ;
my $statusLogin;
my $statusLoginV1;
my $statusLoginRegistro;
my $entitieschars;
my $mech;
sub new
{
my $class = shift;
my $self = {
};
$statusLogin = 0;
$entitieschars = 'ÁÍÓÚÉÄÏÖÜËÀÌÒÙÈÃÕÂÎÔÛÊáíóúéäïöüëàìòùèãõâîôûêÇç';
$mech = WWW::Mechanize->new;
$mech->agent_alias( 'Windows IE 6' );
bless $self, $class;
return $self, $class;
}
sub erro
{
my($self, $strErro) = @_;
my %resposta = (
status => "erro",
resposta => $strErro,
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
print $json_text;
exit;
}
sub erroFTP
{
my($self, $strErro, $ftperror) = @_;
my %resposta = (
status => "erro",
resposta => $strErro,
msgftp => $ftperror,
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
exit;
}
sub logar
{
my($self, $email, $senha) = @_;
my $html;
$mech->post("https://painel2.kinghost.net/login.php");
if($mech->success())
{
if($mech->status() == 200)
{
# loga no painel
$mech->submit_form(
form_id => "formLogin",
fields => {
email => $email,
senha => $senha,
}
);
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
# resposta da tentiva de cadastro
my $respostaloga = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($respostaloga, "abaixo para acessar o Painel de Controle") == -1)
{
$statusLogin = 1;
return "logged";
}
else
{
return "invalid login";
}
}
elsif($mech->status() == 404)
{
return "not found";
}
else
{
return "unknow HTTP error";
}
}
else
{
return "connection error";
}
}
sub logarV1
{
my($self, $email, $senha) = @_;
my $html;
$mech->get("https://painel.kinghost.net/login.php");
if($mech->success())
{
if($mech->status() == 200)
{
# loga no painel
$mech->submit_form(
form_id => "formLogin",
fields => {
email => $email,
senha => $senha,
}
);
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
# resposta da tentiva de cadastro
my $respostaloga = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($respostaloga, "abaixo para acessar o Painel de Controle") == -1)
{
$statusLoginV1 = 1;
return "logged";
}
else
{
return "invalid login";
}
}
elsif($mech->status() == 404)
{
return "not found";
}
else
{
return "unknow HTTP error";
}
}
else
{
return "connection error";
}
}
sub novoCliente
{
my($self, $empresa, $nome, $tipoPessoa, $cpfcnpj, $email, $emailcobranca, $senha, $senhaConfimacao, $telefone, $fax, $cep, $endereco, $cidade, $estado) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $table_rows;
# cria cliente
$mech->post("https://painel2.kinghost.net/cliente.php?editar");
$mech->submit_form(
form_id => "formEdit",
fields => {
acao => "sub_cliente",
subacao => "edita",
id_sub_cliente => 0,
'dados[TipoPessoa]' => $tipoPessoa,
'dados[CpfCnpj]' => $cpfcnpj,
'dados[Empresa]' => encode_entities($empresa, $entitieschars),
'dados[Nome]' => encode_entities($nome, $entitieschars),
'dados[Email]' => $email, # nao pode repetir
'dados[EmailCobranca]' => $emailcobranca, # nao pode repetir
'dados[SenhaPainel]' => $senha,
'senha1' => $senhaConfimacao,
'dados[Fone]' => $telefone,
'dados[Fax]' => $fax,
'dados[CEP]' => $cep,
'dados[Endereco]' => $endereco,
'dados[Cidade]' => $cidade,
'dados[Estado]' => $estado,
'dados[LimiteMapeamento]' => 1,
'dados[LimiteSubdominio]' => 1,
'dados[LimiteMysql]' => 1,
'dados[LimiteMssql]' => 0,
'dados[LimitePgsql]' => 1,
'dados[LimiteFirebird]' => 0,
'dados[LimiteFTPADD]' => 0,
'dados[UniBox]' => "INATIVO",
'dados[AcessoFTP]' => "INATIVO",
'dados[AcessoDownloadBackup]' => "INATIVO",
'dados[AcessoLogotipoWebmail]' => "INATIVO",
'dados[AcessoCupomGoogleAdwords]' => "ATIVO",
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
# resposta da tentiva de cadastro
my $respostaSalvaCliente = $tree->findnodes( '//body' )->[0]->as_HTML;
# salvo
if(index($respostaSalvaCliente, "Cliente") != -1 && index($respostaSalvaCliente, "Salvo") != -1)
{
$mech->get("https://painel2.kinghost.net/cliente.php");
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
$table_rows = $tree->findnodes( '//table[@class="default tralt"]/tr' );
foreach my $row ( $table_rows->get_nodelist )
{
my $tree_tr = HTML::TreeBuilder::XPath->new;
$tree_tr->parse( $row->as_HTML );
my $empresaR = $tree_tr->findvalue( '//td[1]' );
my $nomeR = $tree_tr->findvalue( '//td[2]' );
my $linkR = $tree_tr->findvalue( '//td[4]//a[1]' );
my $codigo = $row->as_HTML;
if(index($nomeR, $nome) != -1)
{
my @codigo = split(/f_cliente=/, $codigo);
@codigo = split(/"/, $codigo[1]); #"
%resposta = (
status => "sucesso",
resposta => "registrado",
codigo => $codigo[0],
nome => encode_entities($nome, $entitieschars),
);
}
$tree_tr->delete;
}
}
# e-mail em uso
elsif(index($respostaSalvaCliente, "existe") != -1 && index($respostaSalvaCliente, "cliente") != -1 && index($respostaSalvaCliente, "cadastrado") != -1 && index($respostaSalvaCliente, "e-mail") != -1)
{
%resposta = (
status => "erro",
resposta => "E-mail em uso",
);
}
else
{
# mostra resultado desconhecido
%resposta = (
status => "erro",
resposta => $respostaSalvaCliente,
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub novoDominio
{
my($self, $plano, $cliente, $pagoate, $dominio, $senha, $plataforma, $webmail) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $table_rows;
# cria dominio
$mech->post("https://painel2.kinghost.net/painel.inserir.php");
$mech->submit_form(
form_id => "novoDominio",
fields => {
acao => "dominio",
subacao => "adicionar",
'dados[plano_id]' => "$plano",
'dados[id_sub_cliente]' => "$cliente",
'dados[pagoate]' => "$pagoate",
'dados[dominio]' => "$dominio",
'dados[senha]' => "$senha",
'dados[plataforma]' => "$plataforma",
'dados[webmail]' => "$webmail",
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
# resposta da tentiva de cadastro
my $respostaSalvaDominio = $tree->findnodes( '//body' )->[0]->as_HTML;
# => alert##T##Dom%EDnio%20cadastrado%20com%20sucesso eval##T##window.location%3D%27%2Fdominio.lista.php%27%3B
# => alert##T##Este%20dom%EDnio%20j%E1%20est%E1%20em%20nosso%20sistema%20e%20n%E3o%20pode%20ser%20cadastrado%20novamente.
# ==> %20Favor%2C%20entre%20em%20contato%20com%20nosso%20atendimento%20para%20ver%20a%20situa%E7%E3o%20do%20mesmo.
if(index($respostaSalvaDominio, "cadastrado") != -1 && index($respostaSalvaDominio, "sucesso") != -1)
{
$mech->get("https://painel2.kinghost.net/dominio.lista.php");
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
$table_rows = $tree->findnodes( '//table[@class="default tralt"]/tr' );
foreach my $row ( $table_rows->get_nodelist )
{
my $tree_tr = HTML::TreeBuilder::XPath->new;
$tree_tr->parse( $row->as_HTML );
my $td1 = $tree_tr->findvalue( '//td[1]' );
my $codigo = $row->as_HTML;
if(index($td1, $dominio) != -1)
{
my @codigo = split(/redir\(/, $codigo);
@codigo = split(/\)/, $codigo[1]); #"
%resposta = (
status => "sucesso",
resposta => "registrado",
codigo => $codigo[0],
dominio => $dominio,
);
}
$tree_tr->delete;
}
}
elsif(index($respostaSalvaDominio, "Este") != -1 && index($respostaSalvaDominio, "nosso") != -1 && index($respostaSalvaDominio, "sistema") != -1)
{
%resposta = (
status => "erro",
resposta => "dominio ja existe",
dominio => $dominio,
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub novoPGSql
{
my($self, $idDominio, $senha) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# cria pgsql
$mech->post("https://painel2.kinghost.net/site.pgsql.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $inputValueNBanco = $tree->findnodes( '//input[@id="usuario"]' )->[0]->as_HTML;
my @nomeBanco = split(/value="/, $inputValueNBanco); #"
@nomeBanco = split(/"/, $nomeBanco[1]); #"
$banco = $nomeBanco[0];
$mech->submit_form(
form_id => "add",
fields => {
control => "pgsql",
action => "add",
id_dominio => "$idDominio",
usuario => $banco,
db => $banco,
senha => "$senha",
csenha => "$senha",
'charset' => "UTF8",
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
%resposta = (
status => "sucesso",
resposta => "banco criado",
banco => $banco,
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# cria pgsql
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub selecionaPgSQL
{
my($self, $idDominio, $novoservidor) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# seleciona pg
$mech->get("https://painel2.kinghost.net/site.pgsql.php?id_dominio=$idDominio");
my %hashform = (
acao => 'pgsql',
subacao => "configura_servidor",
id_dominio => $idDominio,
novo_servidor => $novoservidor,
);
$mech->post("https://painel2.kinghost.net/conectorPainel.php?acao=pgsql&subacao=configura_servidor&id_dominio=$idDominio&novo_servidor=$novoservidor", \%hashform);
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $paginaSeletor = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($paginaSeletor, "Servidor") != -1 && index($paginaSeletor, "configurado") != -1 && index($paginaSeletor, "sucesso") != -1)
{
%resposta = (
status => "sucesso",
resposta => "servidor selecionado com sucesso",
);
}
else
{
%resposta = (
status => "erro",
resposta => "erro ao selecionar servidor",
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
#migra ftp
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub conectarPGSql()
{
my($self, $hostbanco, $nomebanco, $userbanco, $senhabanco) = @_;
my $dsn = "DRIVER={PostGreSQL UNICODE}; SERVER=$hostbanco; DATABASE=$nomebanco; UID=$userbanco; PWD=$senhabanco; OPTION=3; set lc_monetary=pt_BR; set lc_numeric=pt_BR; set lc_time=pt_BR; SET datestyle TO POSTGRES, DMY;";
my $conexao = DBI->connect("DBI:ADO:$dsn") or die "problema ao conectar ao pgsql";
return $conexao;
}
sub rodaScriptPGSql()
{
my($self, $hostbanco, $nomebanco, $userbanco, $senhabanco, $sql) = @_;
my $conexao = $self->conectarPGSql( $hostbanco, $nomebanco, $userbanco, $senhabanco );
my $dbh = $conexao->prepare($sql);
$dbh->execute() or die $conexao->errstr;
$dbh->finish;
$conexao->disconnect;
my %resposta = (
status => "sucesso",
resposta => "executado com sucesso",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
print $json_text;
}
sub leScriptSQL
{
my($self, $arquivo, $path) = @_;
my $sql;
my $mudadir = chdir $path;
open(ARQUIVOSQL, "$arquivo") or die "Nao foi possivel abrir o arquivo para leitura: $!";
my @VetSQL = <ARQUIVOSQL>;
close ARQUIVOSQL;
my $i = 0;
foreach my $linha (@VetSQL)
{
if($i > 0)
{
$sql = $sql.$linha;
}
$i++;
};
return $sql;
}
sub novoMySQL
{
my($self, $idDominio, $senha) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
$mech->get("https://painel2.kinghost.net/painel.dominios.php?id_dominio=$idDominio");
# cria MySQL
$mech->post("https://painel2.kinghost.net/mysql.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $inputValueNBanco = $tree->findnodes( '//input[@id="db"]' )->[0]->as_HTML;
my @nomeBanco = split(/value="/, $inputValueNBanco); #"
@nomeBanco = split(/"/, $nomeBanco[1]); #"
$banco = $nomeBanco[0];
$mech->submit_form(
form_id => "formCria",
fields => {
acao => "mysql",
subacao => "cria",
id_dominio => "$idDominio",
senha => "$senha",
senha1 => "$senha",
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
%resposta = (
status => "sucesso",
resposta => "banco criado",
banco => $banco,
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# cria MySQL
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub importaFTPExterno
{
my($self, $idDominio, $host, $user, $pass, $dirOrigem, $dirDestino) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# migra ftp
$mech->post("https://painel2.kinghost.net/dominio.migra.ftp.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$mech->submit_form(
form_id => "formFTP",
fields => {
acao => "migracao_ftp",
subacao => "efetua_backup",
id_dominio => $idDominio,
host => $host,
user => $user,
pass => $pass,
baixar_subdir => "1",
dir_origem => '#personalizado#',
origem_input => $dirOrigem,
dir_destino => "3",
destino_input => $dirDestino,
}
);
# migra ftp
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $paginaMigra = $tree->findnodes( '//body' )->[0]->as_HTML;
#print $paginaMigra;
# alert##T##Diret%F3rio%20de%20origem%20inv%E1lido%20%28www%26%2347%3Bimovelmanager%29
# erro ao acessar ftp remoto alert##T##Erro%20ao%20utilizar%20diret%F3rio%20destino%20no%20FTP%20remoto%20%28www%2Fimovelmanager%29
# sucesso eval##T##window.location%20%3D%20%27%2Fdominio.migra.ftp.php%3Fid_dominio%3D291076%26id_migracao%3D59981%27%3B
if(index($paginaMigra, "Diret") != -1 && index($paginaMigra, "origem") != -1 && index($paginaMigra, "lido") != -1)
{
%resposta = (
status => "erro",
resposta => "diretorio de origem invalido",
);
}
elsif(index($paginaMigra, "Erro") != -1 && index($paginaMigra, "utilizar") != -1 && index($paginaMigra, "destino") != -1)
{
%resposta = (
status => "erro",
resposta => "Erro de FTP. Verifique as credenciais de acesso ao FTP ou o diretório alvo no FTP remoto",
);
}
elsif(index($paginaMigra, "dominio.migra.ftp.php") != -1 && index($paginaMigra, "id_dominio") != -1 && index($paginaMigra, "id_migracao") != -1)
{
%resposta = (
status => "sucesso",
resposta => "Migracao em andamento. Quando a migracao terminar os arquivos estarao em seu site",
);
}
else
{
%resposta = (
status => "erro",
resposta => "$paginaMigra",
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# migra ftp
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub deletaArquivoFTP
{
my($self, $host, $user, $password, $dirTarget, $file) = @_;
my %resposta;
my $ftp = Net::FTP->new($host, Debug => 0) or $self->erro("impossivel conectar a $host: $@");
$ftp->login($user, $password) or die "impossivel logar ", $ftp->message;
$ftp->cwd($dirTarget) or die "impossivel mudar de diretorio ", $ftp->message;
$ftp->delete( $file ) or die "impossivel excluir arquivo ", $ftp->message;
$ftp->quit;
my %resposta = (
status => "sucesso",
resposta => "$file excluído com sucesso",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
sub deletaArquivosFTP
{
my($self, $host, $user, $password, $dirTarget, @files) = @_;
my %resposta;
my $ftp = Net::FTP->new($host, Debug => 0) or $self->erroFTP("impossivel conectar a $host:", $@);
$ftp->login($user, $password) or $self->erroFTP("impossivel logar ", $ftp->message());
$ftp->cwd( $dirTarget) or $self->erroFTP("impossivel mudar de diretorio ", $ftp->message());
foreach my $file(@files)
{
$ftp->delete( $file ) or $self->erroFTP("impossivel excluir arquivo $file ", $ftp->message());
}
$ftp->quit;
my %resposta = (
status => "sucesso",
resposta => "Arquivos excluídos com sucesso",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
sub novoUserStats
{
my($self, $idDominio, $usuario, $senha) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# novoUserStats
$mech->get("https://painel2.kinghost.net/stats.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$mech->submit_form(
form_id => "formCria",
fields => {
acao => "stats",
subacao => "adicionar_usuario",
id_dominio => $idDominio,
usuario => $usuario,
senha => $senha,
senha1 => $senha,
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostanovoUserStats = $tree->findnodes( '//body' )->[0]->as_HTML;
# alert##T##usu%E1rio%20adicionado%20com%20sucesso eval##T##window.location%3D%27%2Fstats.php%3Fid_dominio%3D291348%27%3B
if(index($respostanovoUserStats, "adicionado") != -1 && index($respostanovoUserStats, "sucesso") != -1 && index($respostanovoUserStats, "id_dominio") != -1)
{
%resposta = (
status => "sucesso",
resposta => "usuario do stats criado com sucesso",
usuario => $usuario,
senha => $senha,
);
}
else
{
%resposta = (
status => "erro",
resposta => "$respostanovoUserStats",
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# novoUserStats
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub novaCaixaEmail
{
my($self, $idDominio, $caixa, $senha, $tamanho) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# novaCaixaEmail
$mech->get("https://painel2.kinghost.net/kingmail.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$mech->submit_form(
form_id => "addCaixa",
fields => {
acao => "addCaixaPostal",
id_dominio => $idDominio,
tipoAdd => "caixapostal",
novaCaixa => $caixa,
novaSenha => $senha,
novaSenha2 => $senha,
novaCaixaTamanho => $tamanho,
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostanovaCaixaEmail = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($respostanovaCaixaEmail, "caixa postal adicionada com") != -1)
{
%resposta = (
status => "sucesso",
resposta => "caixa de e-mail criada com sucesso",
usuario => $caixa,
senha => $senha,
);
}
elsif(index($respostanovaCaixaEmail, "Erro ao criar caixa postal") != -1)
{
%resposta = (
status => "erro",
resposta => "caixa postal ja existe",
usuario => $caixa,
);
}
else
{
%resposta = (
status => "erro",
resposta => "$respostanovaCaixaEmail",
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# novaCaixaEmail
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub editaSenhaCaixaEmail
{
my($self, $idDominio, $email, $senha) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# editaSenhaCaixaEmail
$mech->get("https://painel2.kinghost.net/kingmail.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$mech->submit_form(
form_id => "addCaixa",
fields => {
acao => "trocaSenha",
id_dominio => $idDominio,
mail => "$email",
novaSenha => $senha,
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostaeditaSenhaCaixaEmail = $tree->findnodes( '//body' )->[0]->as_HTML;
# BUG sempre responde a mesma coisa, mesma se a conta nao existir.
if(index($respostaeditaSenhaCaixaEmail, "Senha do email") != -1 && index($respostaeditaSenhaCaixaEmail, "Alterada Com") != -1)
{
%resposta = (
status => "sucesso",
resposta => "senha alterada com sucesso",
email => $email,
);
}
else
{
%resposta = (
status => "erro",
resposta => "$respostaeditaSenhaCaixaEmail",
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# editaSenhaCaixaEmail
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub listaCaixasEmail
{
my($self, $idDominio) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
# listaCaixasEmail
$mech->get("https://painel2.kinghost.net/kingmail.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostalistaCaixasEmail = $tree->findnodes( '//body' )->[0]->as_HTML;
my @codigo = split(/var contas = \[/, $respostalistaCaixasEmail);
@codigo = split(/\]/, $codigo[1]);
my @objJSONs = split(/\}\,/, $codigo[0]);
my @caixas;
foreach my $objJSON(@objJSONs)
{
#$objJSON = ~ s[}},][]g;
#print $objJSON."},";
my @vetObJson = split(/,/, $objJSON);
my @vetEmail = split(/\'username\'\:\'/, $vetObJson[1]); #'
@vetEmail = split(/\'/, $vetEmail[1]); #'
my @vetQuota = split(/\'quota\'\:\'/, $vetObJson[3]); #'
@vetQuota = split(/\'/, $vetQuota[1]); #'
my @vetOcupado = split(/\'ocupado\'\:\'/, $vetObJson[4]); #'
@vetOcupado = split(/\'/, $vetOcupado[1]); #'
my @vetTipo = split(/\'tipo\'\:\'/, $vetObJson[5]); #'
@vetTipo = split(/\'/, $vetTipo[1]); #'
#forma a caixa
my $caixa = {
caixa => $vetEmail[0],
quota => $vetQuota[0],
ocupado => $vetOcupado[0],
tipo => $vetTipo[0],
};
# poe a caixa na lista de caixas
push @caixas, $caixa;
}
%resposta = (
status => "sucesso",
caixas => [@caixas],
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
# editaSenhaCaixaEmail
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub checaDisponibilidadeDominioRevenda
{
my($self, $dominio) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
$mech->get("https://painel2.kinghost.net/dominio.lista.php");
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostalistaDominios = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($respostalistaDominios, $dominio) != -1)
{
%resposta = (
status => "erro",
resposta => "em uso na Revenda",
);
}
else
{
%resposta = (
status => "sucesso",
resposta => "liberado",
)
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub habilitaISAPIRewrite
{
my($self, $idDominio, $captcha) = @_;
my %resposta;
if($statusLogin)
{
my $html;
my $banco;
$mech->get("https://painel2.kinghost.net/painel.isapi_rewrite.php?id_dominio=$idDominio");
$mech->submit_form(
form_id => "configurarISAPIRewrite",
fields => {
acao => 'iis6',
subacao => "isapi_rewrite",
id_dominio => $idDominio,
isapi_rewrite => "On",
captcha => $captcha,
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $paginaISAPI = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($paginaISAPI, "Palavra digitada") != -1 && index($paginaISAPI, "por favor tente novamente") != -1)
{
%resposta = (
status => "erro",
resposta => "captcha errada",
);
}
elsif(index($paginaISAPI, "ISAPI Rewrite ativado com") != -1)#
{
%resposta = (
status => "sucesso",
resposta => "ISAPI Rewrite ativado com sucesso",
);
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub pegaServidorTemporario
{
my($self, $idDominio) = @_;
my %resposta;
if($statusLogin)
{
my $html;
$mech->get("https://painel2.kinghost.net/painel.dominios.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostaDominioInfo = $tree->findnodes( '//body' )->[0]->as_HTML;
my @vetTrata = split(/<td id="inf_url_alt">/, $respostaDominioInfo);
@vetTrata = split(/target="_blank">/, $vetTrata[1]);
@vetTrata = split(/<\/a><\/td>/, $vetTrata[1]);
my $endereco = $vetTrata[0];
%resposta = (
status => "sucesso",
resposta => "$endereco",
url => "$endereco",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub pegaServidorTemporarioAux
{
my($self, $idDominio) = @_;
my %resposta;
if($statusLogin)
{
my $html;
$mech->get("https://painel2.kinghost.net/painel.dominios.php?id_dominio=$idDominio");
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $respostaDominioInfo = $tree->findnodes( '//body' )->[0]->as_HTML;
my @vetTrata = split(/<td id="inf_url_alt">/, $respostaDominioInfo);
@vetTrata = split(/target="_blank">/, $vetTrata[1]);
@vetTrata = split(/<\/a><\/td>/, $vetTrata[1]);
my $endereco = $vetTrata[0];
return $endereco;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
else
{
%resposta = (
status => "erro",
resposta => "efetue login primeiro",
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
sub transfereDominio
{
my($self, $ID, $senha, $dominio, $idTec, $dns1, $dns2, $dns3, $dns4) = @_;
my %resposta;
my $html;
my $idDominio;
my $idCob;
if(! defined($idTec))
{
$idTec = "";
}
if(! defined($dns3))
{
$dns3 = "";
}
if(! defined($dns4))
{
$dns4 = "";
}
$mech->get("https://registro.br/cgi-bin/nicbr/stini");
$mech->submit_form(
with_fields => {
handle => $ID, # ID
passwd => $senha, # senha do ID
}
);
if($mech->success())
{
if($mech->status() == 200)
{
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
my $pagina = $tree->findnodes( '//body' )->[0]->as_HTML;
if(index($pagina, "Senha Incorreta") != -1)
{
# ==> erro de login
%resposta = (
status => "erro",
resposta => "Erro de login - Senha incorreta",
);
}
elsif(index($pagina, "ID Inexistente") != -1)
{
# ==> erro de login
%resposta = (
status => "erro",
resposta => "Erro de login - ID Inexistente",
);
}
else
{
# ==> transfere domain
my $pagina;
my @links = $mech->links();
foreach my $link (@links)
{
if($link->text() eq $dominio)
{
$mech->get("https://registro.br/" . $link->url());
my @vetId = split(/id\=/, $link->url());
$idDominio = $vetId[1];
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
$pagina = $tree->findnodes( '//body' )->[0]->as_HTML;
my @vetPag = split(/name\=\"cob\" id\=\"bil\" value\=\"/, $pagina); #"
@vetPag = split(/\"/, $vetPag[1]); #"
$idCob = $vetPag[0];
my %hashform = (
id => $idDominio,
dominio => $dominio,
tec => $idTec,
cob => $idCob,
host1 => $dns1,
host2 => $dns2,
host3 => $dns3,
host4 => $dns4,
);
$mech->post("https://registro.br/" . $link->url(), \%hashform);
$html = $mech->content;
$mech->update_html( $html );
my $tree = HTML::TreeBuilder::XPath->new;
$tree->parse( $html );
$pagina = $tree->findnodes( '//body' )->[0]->as_HTML;
}
}
if(index($pagina, "Contatos de dom") != -1 && index($pagina, "nios") != -1)
{
%resposta = (
status => "sucesso",
resposta => "Transferência efetuada com sucesso",
);
}
elsif(index($pagina, "Hostname inv") != -1 && index($pagina, "lido") != -1)
{
%resposta = (
status => "erro",
resposta => "Hostname inválido",
);
}
elsif(index($pagina, "Servidor DNS Slave 1: N") != -1 && index($pagina, "nio j") != -1 && index($pagina, "o informado") != -1)
{
%resposta = (
status => "erro",
resposta => "Servidor DNS Slave 1: Não informado",
);
}
elsif(index($pagina, "Servidor DNS Master: N") != -1 && index($pagina, "o informado") != -1)
{
%resposta = (
status => "erro",
resposta => "Servidor DNS Master: Não informado",
);
}
else
{
%resposta = (
status => "erro",
resposta => "$pagina",
)
}
# ==> transfere domain
}
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
elsif($mech->status() == 404)
{
%resposta = (
status => "erro",
resposta => "not found",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
else
{
%resposta = (
status => "erro",
resposta => "unknow HTTP error",
url => $mech->uri(),
);
my $json = \%resposta;
my $json_text = to_json($json, { utf8 => 1 });
return $json_text;
}
}
}
1;
__END__
=encoding utf8
=head1 NAME
WWW::Kinghost::Painel - Object for hosting automation using Kinghost (www.kinghost.net) v2 Control Panel
=head1 VERSION
0.04
=head1 SYNOPSIS
use WWW::Kinghost::Painel;
my $painel = WWW::Kinghost::Painel->new();
#my $painel = new WWW::Kinghost::Painel();
# Loga no painel
$painel->logar( "email@revenda.com.br", "senhadarevenda" );
# Novo Cliente
my $empresa = "Yogurteiras Top Jeca";
my $nome = "José da Silva";
my $tipoPessoa = "F"; # F - J - I(ignorar)
my $cpfcnpj = "000.000.000-00"; # CPF ou CNPJ
my $email = 'josesilva@gmail.com'; # não deve ser igual @dominiodocliente.com.br
my $emailcobranca = 'josesilva@gmail.com'; # não deve ser igual @dominiodocliente.com.br
my $senha = "xxxxxx";
my $senhaConfimacao = "xxxx";
my $telefone = "";
my $fax = "";
my $cep = "";
my $endereco = "";
my $cidade = "";
my $estado = "";
print $painel->novoCliente( $empresa, $nome, $tipoPessoa, $cpfcnpj, $email, $emailcobranca, $senha, $senhaConfimacao, $telefone, $fax, $cep, $endereco, $cidade, $estado );
# Novo Domínio
my $plano = "0000000";
my $dominio = "topjeca.com.br";
my $cliente = "107645";
my $pagoate = "2012-03-01";
my $senha = "testeteste";
my $plataforma = "Windows";
my $webmail = "SquirrelMail"; # SquirrelMail, NutsMail, RoundCube, TupiMail, Horde
print $painel->novoDominio( $plano, $cliente, $pagoate, $dominio, $senha, $plataforma, $webmail );
# Novo Banco PGSql
my $idDominio = "000000";
my $senha = "xxxxxx";
print $painel->novoPGSql( $idDominio, $senha );
# lê arquivo SQL
my $arquivo = "topjeca.sql";
my $path = $Server->MapPath("../../sql/"); # caminho absoluto
my $sql = $painel->leScriptSQL( $arquivo, $path );
# roda script SQL
my $hostbanco = "localhost";
my $nomebanco = "topjeca";
my $userbanco = "topjeca";
my $senhabanco = "xxxxxx";
my $sql = $painel->leScriptSQL( $arquivo, $path );
$painel->rodaScriptPGSql( $hostbanco, $nomebanco, $userbanco, $senhabanco, $sql );
# importa FTP externo
my $idDominio = "000000";
my $host = "ftp.xxxxxx.com.br";
my $user = "usuarioftp";
my $pass = "senhaftp";
my $dirOrigem = 'www';
my $dirDestino = 'www';
print $painel->importaFTPExterno( $idDominio, $host, $user, $pass, $dirOrigem, $dirDestino );
# cria user para o sistema de stats do domínio
my $idDominio = "000000";
my $usuario = "xxxxx";
my $senha = "xxxxx";
print $painel->novoUserStats( $idDominio, $usuario, $senha );
# cria nova conta de e-mail
my $idDominio = "00000";
my $caixa = "caixa";
my $senha = "xxxxx";
my $tamanho = "5242880"; # em bytes
print $painel->novaCaixaEmail( $idDominio, $caixa, $senha, $tamanho );
# edita senha de conta de e-mail
my $idDominio = "00000";
my $email = 'caixa@topjeca.com.br';
my $senha = "xxxxx";
print $painel->editaSenhaCaixaEmail( $idDominio, $email, $senha );
# lista todas as caixas de e-mail do domínio
my $idDominio = "0000000";
print $painel->listaCaixasEmail( $idDominio );
# Checa se o domínio ja é cadastrado na revenda
my $dominio = "web2solutions.com.br";
print $painel->checaDisponibilidadeDominioRevenda( $dominio );
# Pega o endereço provisório do domínio
my $idDominio = "0000000";
print $painel->pegaServidorTemporario( $idDominio );
#Transfere domínio no Registro.br
# ID da Entidade dententora do domínio
my $ID = "XXXXX";
# ID da Entidade dententora do domínio
my $senha = "XXXX";
my $dominio = "topjeca.com.br";
# Dominio que você deseja transferir
my $idTec = "XXXXX"; # ID da entidade que deseja transferir o contato técnico. deixe em branco caso nao queira transferir o contato técnico
# servidores DNS para o qual o domínio será transferido. Só é obrigatório o dns1 e dns2
my $dns1 = 'dns1.web2solutions.com.br';
my $dns2 = 'dns2.web2solutions.com.br';
my $dns3 = 'dns3.web2solutions.com.br';
my $dns4 = 'dns4.web2solutions.com.br';
print $painel->transfereDominio( $ID, $senha, $dominio, $idTec, $dns1, $dns2, $dns3, $dns4 );
=head1 SUMMARY
=head1 METHODS
=head2 logar
Loga no painel de controle. Este método deverá ser chamado antes de qualquer outro método. Ativa flag $statusLogin.
my $status_login = $painel->logar($email, $senha);
Return string
logged, invalid login, not found, unknow HTTP error, connection error
=head2 novoCliente
Cadastra novo cliente
# Novo Cliente
my $empresa = "Yogurteiras Top Jeca";
my $nome = "José da Silva";
my $tipoPessoa = "F"; # F - J - I(ignorar)
my $cpfcnpj = "000.000.000-00"; # CPF ou CNPJ
my $email = 'josesilva@gmail.com'; # não deve ser igual @dominiodocliente.com.br
my $emailcobranca = 'josesilva@gmail.com'; # não deve ser igual @dominiodocliente.com.br
my $senha = "xxxxxx";
my $senhaConfimacao = "xxxx";
my $telefone = "";
my $fax = "";
my $cep = "";
my $endereco = "";
my $cidade = "";
my $estado = "";
print $painel->novoCliente( $empresa, $nome, $tipoPessoa, $cpfcnpj, $email, $emailcobranca, $senha, $senhaConfimacao, $telefone, $fax, $cep, $endereco, $cidade, $estado );
Return JSON
{"nome":"José João25","resposta":"registrado","status":"sucesso","codigo":"107630"}
{"resposta":"E-mail em uso","status":"erro"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 novoDominio
Cadastra novo Dominio
my $plano = "45198";
my $dominio = "topjeca.com.br";
my $cliente = "107645";
my $pagoate = "2012-03-01";
my $senha = "testeteste";
my $plataforma = "Windows";
my $webmail = "SquirrelMail"; # SquirrelMail, NutsMail, RoundCube, TupiMail, Horde
print $painel->novoDominio( $plano, $cliente, $pagoate, $dominio, $senha, $plataforma, $webmail );
Return JSON
{"dominio":"topjeca.com.br","resposta":"registrado","status":"sucesso","codigo":"291076"}
{"dominio":"topjeca.com.br","resposta":"dominio ja existe","status":"erro"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 checaDisponibilidadeDominioRevenda
Checa se o domínio ja é cadastrado na revenda
my $dominio = "web2solutions.com.br";
print $painel->checaDisponibilidadeDominioRevenda( $dominio );
Return JSON
{"resposta":"em uso na kinghost","status":"erro"}
{"resposta":"liberado","status":"sucesso"}
=head2 pegaServidorTemporario
Pega o endereço provisório do domínio
my $idDominio = "0000000";
print $painel->pegaServidorTemporario( $idDominio );
Return JSON
{"resposta":"salamina.dominio.com.br","status":"sucesso"}
{"resposta":"error message","status":"erro"}
=head2 novoPGSql
Cadastra Banco PGSql. O nome do banco e do user é criado automaticamente pelo sistema da kinghost, não sendo opcional.
my $idDominio = "291076";
my $senha = "teste";
print $painel->novoPGSql( $idDominio, $senha );
Return JSON
{"resposta":"banco criado","status":"sucesso","banco":"topjeca"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 rodaScriptPGSql
Roda um script SQL direto no PostgreSQL Server
# informacoes sobre o banco
my $hostbanco = "localhost";
my $nomebanco = "topjeca";
my $userbanco = "topjeca";
my $senhabanco = "xxxxxxx";
# lê arquivo SQL
my $arquivo = "imeSaas.sql";
my $path = $Server->MapPath("../../sql/"); # caminho absoluto
my $sql = $painel->leScriptSQL($arquivo, $path);
# roda script SQL
$painel->rodaScriptPGSql( $hostbanco, $nomebanco, $userbanco, $senhabanco, $sql );
Print JSON
{"resposta":"relação \"desktop_config\" já existe","status":"erro"}
{"resposta":"executado com sucesso","status":"sucesso"}
=head2 novoMySQL
Cadastra Banco MySQL. O nome do banco e do user é criado automaticamente pelo sistema da kinghost, não sendo opcional.
print $painel->novoMySQL( $idDominio, $senha );
Return JSON
{"resposta":"banco criado","status":"sucesso","banco":"topjeca"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 novoUserStats
Protege e cria um usuário para acesso ao stats do domínio. www.dominio.com.br/stats
my $idDominio = "000000";
my $usuario = "xxxxx";
my $senha = "xxxxx";
print $painel->novoUserStats( $idDominio, $usuario, $senha );
Return JSON
{"resposta":"usuario do stats criado com sucesso","status":"sucesso"}
{"resposta":"error string","status":"erro"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 novaCaixaEmail
Cria caixa de e-mail
my $idDominio = "000000";
my $caixa = "caixa";
my $senha = "xxxxx";
# 1048576 > 1 MB, 2097152 > 2 MB, 3145728 > 3 MB, 4194304 > 4 MB, 5242880 > 5 MB,
# 6291456 > 6 MB, 7340032 > 7 MB, 8388608 > 8 MB, 9437184 > 9 MB, 10485760 > 10 MB,
# 11534336 > 11 MB, 12582912 > 12 MB, 13631488 > 13 MB, 14680064 > 14 MB, 15728640 > 15 MB,
# 16777216 > 16 MB, 17825792 > 17 MB, 18874368 > 18 MB, 19922944 > 19 MB,
my $tamanho = "5242880"; # em bytes
print $painel->novaCaixaEmail( $idDominio, $caixa, $senha, $tamanho );
Return JSON
{"usuario":"caixa","resposta":"caixa postal ja existe","status":"erro"}
{"senha":"senhaemail","usuario":"contato","resposta":"caixa de e-mail criada com sucesso","status":"sucesso"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 editaSenhaCaixaEmail
Edita senha de caixa de e-mail
my $idDominio = "00000";
my $email = 'caixa@topjeca.com.br';
my $senha = "xxxxx";
print $painel->editaSenhaCaixaEmail( $idDominio, $email, $senha );
Return JSON
{"email":"caixa@topjeca.com.br","resposta":"senha alterada com sucesso","status":"sucesso"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 listaCaixasEmail
Lista todas as caixas de e-mail do domínio
my $idDominio = "0000000";
print $painel->listaCaixasEmail( $idDominio );
Return JSON
{"caixas":
[
{"quota":"5242880","tipo":"mailbox","caixa":"caixa@topjeca.com.br","ocupado":"0"}
,{"quota":"5242880","tipo":"mailbox","caixa":"contato@topjeca.com.br","ocupado":"0"}
,{"quota":"1048576","tipo":"mailbox","caixa":"topjeca@topjeca.com.br","ocupado":"0"}
],"status":"sucesso"}
O valor de quota e ocupado é retornado em bytes
=head2 importaFTPExterno
Importa conteúdo de um FTP remoto para o ftp do domínio local. Informe o diretório de origem e o diretório de destino
my $idDominio = "000000";
my $host = "ftp.xxxxxx.com.br";
my $user = "usuarioftp";
my $pass = "senhaftp";
my $dirOrigem = 'www';
my $dirDestino = 'www';
print $painel->importaFTPExterno( $idDominio, $host, $user, $pass, $dirOrigem, $dirDestino );
Return JSON
{"resposta":"Migracao em andamento. Quando a migracao terminar os arquivos estarao em seu site","status":"sucesso"}
{"resposta":"Erro de FTP. Verifique as credenciais de acesso ao FTP ou o diretorio alvo no FTP remoto","status":"erro"}
{"resposta":"diretorio de origem invalido","status":"erro"}
{"resposta":"efetue login primeiro","status":"erro"}
=head2 deletaArquivoFTP
Deleta arquivo no FTP
my $host = "ftp.sitedocliente.com.br";
my $user = "sitedocliente";
my $password = "xxxxx";
my $dirTarget = '/www';
my $file = "index.htm";
print $painel->deletaArquivoFTP( $host, $user, $password, $dirTarget, $file );
Return JSON
{"resposta":"Arquivo nomedoarquivo excluído com sucesso","status":"sucesso"}
=head2 transfereDominio
Transfere domínio no Registro.br
# ID da Entidade dententora do domínio
my $ID = "XXXXX";
# ID da Entidade dententora do domínio
my $senha = "XXXX";
my $dominio = "topjeca.com.br";
# Dominio que você deseja transferir
my $idTec = "XXXXX"; # ID da entidade que deseja transferir o contato técnico. deixe em branco caso nao queira transferir o contato técnico
# servidores DNS para o qual o domínio será transferido. Só é obrigatório o dns1 e dns2
my $dns1 = 'dns1.suarevenda.com.br';
my $dns2 = 'dns2.suarevenda.com.br';
my $dns3 = 'dns3.suarevenda.com.br';
my $dns4 = 'dns4.suarevenda.com.br';
print $painel->transfereDominio( $ID, $senha, $dominio, $idTec, $dns1, $dns2, $dns3, $dns4 );
Return JSON
{"resposta":"dominio transferido","status":"sucesso"}
{"resposta":"ID tecnico invalido","status":"erro"}
=head1 EXAMPLES
Look at eg/ folder
=head1 AUTHORS
José Eduardo Perotta de Almeida, C<< eduardo at web2solutions.com.br >>
=head1 LICENSE AND COPYRIGHT
Copyright 2012 José Eduardo Perotta de Almeida.
This program is free software; you can redistribute it and/or modify it
under the terms of either: the GNU General Public License as published
by the Free Software Foundation; or the Artistic License.
See http://dev.perl.org/licenses/ for more information.
=head1 BUGS AND LIMITATIONS
novoMySQL FIXED
Please report any bugs or feature requests through the web interface at
<http://rt.cpan.org>.
=head1 DISCLAIMER OF WARRANTY
BECAUSE THIS SOFTWARE IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
FOR THE SOFTWARE, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT
WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER
PARTIES PROVIDE THE SOFTWARE "AS IS" WITHOUT WARRANTY OF ANY KIND,
EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
SOFTWARE IS WITH YOU. SHOULD THE SOFTWARE PROVE DEFECTIVE, YOU ASSUME
THE COST OF ALL NECESSARY SERVICING, REPAIR, OR CORRECTION.
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
REDISTRIBUTE THE SOFTWARE AS PERMITTED BY THE ABOVE LICENCE, BE LIABLE
TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL, OR
CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
SOFTWARE (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
FAILURE OF THE SOFTWARE TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
DAMAGES.
=cut
__END__