/api-boilerplate

✨ Boilerplate for creating RESTful APIs and Admin Panel using Laravel, InfyOm, CoreUI and Vessel

Primary LanguagePHP

Laravel API Boilerplate

Criado com muito ☕ por Grupo Tesseract
Version 0.1.0

Requisitos · Instalação · Troubleshooting


Requisitos

  • Docker

    curl -fsSL https://get.docker.com | bash
  • Docker Compose

    sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
    sudo chmod +x /usr/local/bin/docker-compose

Instalação

git clone https://github.com/grupotesseract/api-boilerplate
cd api-boilerplate

É altamente recomendada a criação do alias abaixo. Inclua no seu arquivo ~/.zshrc ou ~/.bashrc:

alias v='./vessel'

Em seguida, com o alias acima habilitado no terminal, executar:

cp .env.example .env

v start
v comp i
v art key:generate
v art migrate --seed
v art passport:install

v y
v y watch

A partir de agora, você já deve conseguir visualizar a página inicial através do endereço http://localhost/. Tente efetuar login através do acesso:

Email: admin@grupotesseract.com.br
Senha: admin

Comando para gerar um CRUD

  • Criar arquivo na pasta database/model_schemas referente a entidade desejada. Nesta pasta, é possível visualizar exemplos de como criar a entidade e seus relacionamentos;
  • Executar o comando abaixo ao gerar algum CRUD, para gerar factories, seeds, e deixar os nomes das rotas e views semânticos de acordo com o plural. SUBSTITUIR a entidade de exemplo com o nome da nova entidade a ser criada, assim como o novo arquivo relacionado criado
v art \
  infyom:api_scaffold Cidade \
  --tableName=cidades \
  --plural=cidades \
  --fieldsFile=Cidade.json \
  --datatables=true \
  --factory \
  --seeder

Testes

Para rodar os testes, executar:

v test tests
  • Sendo test o comando do Vessel
  • E tests a pasta de testes da raiz do projeto

Troubleshooting

  • Caso encontre problemas ao iniciar o ambiente, talvez seja necessário verificar as versões do Docker e do Docker Compose. Verifique as versões com:

    docker -v           # Docker version 20.10.14, build a224086
    docker-compose -v   # docker-compose version 1.29.2, build 5becea4c

    Caso tenha problemas, você pode utilizar as mesmas versões que citamos em Requisitos.

  • A partir do Docker 18.09, a nova arquitetura de build BuildKit passou a ser utilizada, e o mesmo não está 100% compatível com o projeto no momento. Verifique se o BuildKit está habilitado nos arquivos ~/.docker/config.json ou /etc/docker/daemon.json. Algo como:

    {
      "features": {
        "buildkit": true
      }
    }

    Se estiver true, altere para false e reinicie o serviço do Docker com:

    sudo service docker restart

    Ou o comando da sua distro de preferência.

  • Pode ser também que nada disso resolveu, então recomendamos fazer uma limpeza completa no seu Docker (CUIDADO: esse comando vai deletar tudo do Docker: containers, imagens, volumes e networks)

    docker system prune -a -f

    Alguns bons gigabytes serão liberados após esse comando.