No contexto deste documento, o termo "classe" refere-se a todas as classes, interfaces e traits.
Está biblioteca representa um esqueleto inicial para se trabalhar com gerenciamento de hosts remotos. Já a biblioteca crphp/wmi é um bom exemplo de implementação que usa está coleção de classes.
As palavras-chave "DEVE", "NÃO DEVE", "REQUER", "DEVERIA", "NÃO DEVERIA", "PODERIA", "NÃO PODERIA", "RECOMENDÁVEL", "PODE", e "OPCIONAL" neste documento devem ser interpretadas como descritas no RFC 2119. Tradução livre RFC 2119 pt-br.
- Referências
- Funcionalidades
- Requisitos (recomendados)
- Baixando o pacote crphp/core para o servidor
- Exemplos de uso
- Licença (MIT)
- PSR-1
- PSR-2
- RFC 2119. Tradução livre RFC 2119 pt-br
No contexto desta biblioteca as funcionalides abaixo são classe que precisam ser implementadas. Conforme já foi dito, a biblioteca crphp/wmi é um bom exemplo de implementação que usa está coleção de classes genéricas:
- Consultar CPU
- Consultar RAM
- Consultar Disco Rígido
- Listar Serviços
- Stop / Start de serviço
- Listar processos
- Alterar prioridade do processo
- Matar / Finalizar processos
- Transformação de unidades
- Transformação de timestamp Windows para data/hora
❗ Os requisitos sugeridos logo abaixo representam as versões utilizadas em nosso ambiente de desenvolvimento e produção, logo não garantimos que a solução aqui apresentada irá rodar integralmente caso as versões dos elementos abaixo sejam outras.
Servidor
- REQUER Apache >= 2.4.10
- REQUER PHP >= 5.5.12
Cliente
- NÃO REQUER instalar nenhum componente
Para a etapa abaixo estou pressupondo que você tenha o composer instalado e saiba utilizá-lo:
composer require crphp/core
Ou se preferir criar um projeto:
composer create-project --prefer-dist crphp/core nome_projeto
Caso ainda não tenha o composer instalado, obtenha este em: https://getcomposer.org/download/
Temos dois bons exemplos de bibliotecas que implementam este core, são respectivamente crphp/wmi e crphp/ssh.
Veja um exemplo de implementação utilizado pela biblioteca crphp/wmi:
use COM;
use \Exception;
use \RuntimeException;
use Crphp\Core\Sistema\Conector;
class Wmi extends Conector
{
public function conectar($host, $usuario = null, $senha = null, $porta = 135, $timeout = 10)
{
// Aqui você abre uma comunicação com o host remoto
}
public function executar($instrucao)
{
// Aqui você executa uma instrução remotamente
}
/*
* Os métodos status() e mensagemErro() possuem um comportamento genérico, provavelmente
* você não irá precisar reescrevê-los
*/
}
Veja um exemplo de implementação utilizado pela biblioteca crphp/ssh:
use \Exception;
use \RuntimeException;
use phpseclib\Net\SSH2;
use Crphp\Core\Sistema\Conector;
class Ssh extends Conector
{
public function conectar($host, $usuario = null, $senha = null, $porta = 135, $timeout = 10)
{
// Aqui você abre uma comunicação com o host remoto
}
public function executar($instrucao)
{
// Aqui você executa uma instrução remotamente
}
/*
* Os métodos status() e mensagemErro() possuem um comportamento genérico, provavelmente
* você não irá precisar reescrevê-los
*/
}
6 - Licença (MIT)
Para maiores informações, leia o arquivo de licença disponibilizado junto desta biblioteca.