Instalando o projeto

O projeto se utiliza de contêineres Docker, através do pacote Laravel Sail para facilitar a configuração do ambiente de desenvolvimento. Portanto, é necessário que já possua o Docker e o Docker Compose instalados na máquina.

Você é livre para rodar o projeto em ambiente local mas esse texto não tratará essa situação.

Links para instalação e configuração de Docker:

Passos para o rodar o projeto localmente:

  • Faça um clone do projeto para sua máquina local
  • Crie um arquivo .env, recomendamos usar .env-example como base
  • Adicione ou altere as chaves conforme sua necessidade
  • acesse a pasta do projeto via console (terminal/PowerShell/CMD)
  • execute o comando:
docker run --rm \
    -u "$(id -u):$(id -g)" \
    -v "$(pwd):/var/www/html" \
    -w /var/www/html \
    laravelsail/php82-composer:latest \
    composer install --ignore-platform-reqs
  • Após finalizado processamento, execute o comando ./sail up -d

O primeiro comando realiza a instalação dos pacotes via composer especificados no arquivo composer.json e uma vez que a instalação termina, a pasta vendor passa a ficar disponível no projeto. O comando seguinte levanta os contêineres baseado na descrição de serviços feita no arquivo docker-compose.yml.

Por padrão, não é necessária nenhuma configuração no arquivo .env do projeto. Caso seja necessária alguma edição na configuração padrão (relacionado a binding ports ou credenciais de banco de dados), basta editar o arquivo .env.

Trabalhando com Contêineres

Uma vez que o projeto está rodando em cima de contêineres Docker, é clara a situação de que a máquina local não possui nenhum dos requisitos necessários para se trabalhar no projeto, assim, comandos como php artisan, composer ou npm não funcionarão localmente. Para executar comandos dentro de um dos contêineres do projeto, um php artisan route:list por exemplo, é preciso utilizar o docker para tal, como por exemplo:

docker-compose exec \ #execução de um comando num contêiner existente
    -u sail \ # especifica o nome do usuário a ser utilizado dentro do contêiner
    projeto_laravel.test \ # especifica qual contêiner receberá o comando
    php artisan route:list # qual o comando a ser executado

A execução, dessa forma, se torna muito verbosa e trabalhosa, podendo levar a potenciais erros de execução. Assim, o Laravel Sail oferece um script chamado sail e localizado em vendor/bin/. Esse script permite que tais comandos sejam executados através de aliases para que o fluxo de desenvolvimento seja mais natural e menos complexo. Assim, para se executar o mesmo comando php artisan route:list com o script sail ficaria:

./vendor/bin/sail artisan route:list

#ou

./vendor/bin/sail art route:list

Comandos disponíveis

Para conhecer os comandos disponíveis pelo script sail, execute ./vendor/bin/sail -h para obter a listagem completa das opções com descrição.

Próximos passos

Migrations são uma maneira de versionar as tabelas de sua base de dados. Para estruturar o seu banco de dados

  • Execute ./vendor/bin/sail art migrate para montar sua adicionar as tabelas ao seu banco

  • Execute ./vendor/bin/sail art db:seed para popular o seu banco com dados fictícios