NAME

WWW::Kinghost::Painel - Object for hosting automation using Kinghost (www.kinghost.net) v2 Control Panel

VERSION

0.04

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 );

SUMMARY

METHODS

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

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"}

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"}

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"}

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"}

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"}

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"}

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"}

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"}

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"}

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"}

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

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"}

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"}

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"}

EXAMPLES

Look at eg/ folder

AUTHORS

José Eduardo Perotta de Almeida, eduardo at web2solutions.com.br

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.

BUGS AND LIMITATIONS

novoMySQL FIXED

Please report any bugs or feature requests through the web interface at <http://rt.cpan.org>.

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.