- PHP - A linguagem usada
- Composer - Gerenciador de Pacotes
- PostgreSQL - Banco de Dados
Este é um programa fictício de armazenamento de dados de um grupo de torcedores de um time de rugby feito em PHP + Composer e com a ajuda de algumas bibliotecas como: phpoffice/phpspreadsheet e ext-pdo
O programa Le uma Planilha Excel(xlsx) que é considerada a base local dos torcedores e arquivos de atualização(xml) desses torcedores.
Armazenando esses dados em um servidor localhost via PostgreSQL - Alem disso possui a utilidade de Envio de Email para os torcedores ainda ativos
Foi feito um pequeno front-end para manter o mesmo universo do site do AllBlacks.
O software ainda tem alguns pequenos bugs mas o objetivo final foi cumprido - Teste Avaliativo empresa P21 Sistemas
PHP 8 Ou superior
PostgreSQL
Composer
A menos que use um container Docker para a aplicação sugiro trocar seu [ php.ini ] pelo comitado no projeto para que funcione via servidor embutido do PHP
php -S localhost:5432
Clone o projeto para a sua maquina e crie um novo banco de dados postgres
- clientes.xlsx - referente a planilha excel de iniciação;
- dados.xml - referente ao arquivo de atualização
- php-example.ini - [ php.ini ] usado para desenvolver
- desafioP21.pdf - Desafio solicitado pela empresa
Na pasta do projeto ja com o composer instalado na sua máquina ou ambiente virtual
composer install
Esse comando vai ler o [ * composer.json * ] e instalar as dependências necessárias para o projeto rodar
Adicione as informações sobre seu BD no arquivo: [ .env-example ] Essas informações serão usadas em Config/Connection.php.
Após isso troque o nome do arquivo para [ .env ] e suas variaveis do projeto estarão configuradas logo seu banco de dados ja está lincado com a aplicação.
Para testar entre em [ * exe_atualizar_arquivo.php * ]: e descomente os ECHOs de conexão, e com o server rodando clique no botão UPDATE para ver qual das mensagens aparece.
Após isso pode rodar a query para a criação da tabela que é usada no projeto
CREATE TABLE torcedores (
id_torcedor serial PRIMARY KEY,
nm_torcedor VARCHAR ( 100 ) NOT NULL,
nr_doc VARCHAR ( 30 ) NOT NULL,
nr_cep VARCHAR ( 30 ) NOT NULL,
ds_endereco VARCHAR ( 150 ),
nm_bairro VARCHAR ( 150 ),
nm_cidade VARCHAR ( 150 ),
ds_uf VARCHAR ( 150 ),
nr_telefone VARCHAR ( 25 ),
ds_email VARCHAR ( 50 ),
id_ativo SMALLINT DEFAULT 0
);
O projeto le 2 tipos de arquivos (xlsx) e (xml)!
Se no Upload do Formulário for adicionado um arquivo (xlsx) o banco de dados RESETA e SOBRESCREVE os dados salvos no banco pelos dados da nova planilha. O processo ocorre dessa forma porque teoricamente a planilha dos dados só seria usada 1 vez.
Apenas para migrar os dados de um ambiente local para um ambiente remoto.
Se no Upload do Formulário for adicionado um arquivo (xml) o software trata ele como uma atualização e atualizará os dados do banco fazendo um INSERT ou UPDATE na tabela dependendo da existencia ou nao desse dado no banco.
Se por acaso algum desses dados estiver em falta no banco é possivel adiciona-los a um documento xml no mesmo formato dos DOCS DE EXEMPLO e adicionar as informações
O sistema interpretará o Numero do Documento daquele usuario e Atualizará os dados dele no banco com os que vierem desse novo arquivo!
Baseado no README de - Armstrong Lohãns ?