NAME

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

VERSION

version 0.007

SYNOPSIS

use Kinghost::Painel; 

my $painel = Kinghost::Painel->new();
#my $painel = new 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 = "45198";
my $dominio = "topjeca.com.br";
my $cliente = "107645";
my $pagoate = "2012-03-01";
my $senha = "testeteste";
my $plataforma = "Windows";
my $webmail = "SquirrelMail";
print $painel->novoDominio( $plano, $cliente, $pagoate, $dominio, $senha, $plataforma, $webmail );


# Novo Banco PGSql
my $idDominio = "291076";
my $senha = "teste";
print $painel->novoPGSql($idDominio, $senha);


# 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 = "291348";
my $email = 'caixa@topjeca.com.br';
my $senha = "fuzzy24k";
print $painel->editaSenhaCaixaEmail( $idDominio, $email, $senha );

# lista todas as caixas de e-mail do domínio
my $idDominio = "0000000";
print $painel->listaCaixasEmail( $idDominio );

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

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

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 = "291348";
my $email = 'caixa@topjeca.com.br';
my $senha = "fuzzy24k";
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"}

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

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

O método novoMySQL nao está funcionando devido a problemas de autenticação nessa página do painel. A URL da API referente à este recurso também está com problemas de autenticação

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.