laravel-api-templates
laravel-api-templates copied to clipboard
Laravel API starter kit collection using different structures.
A Laravel API starter kit collection using different structures.
data:image/s3,"s3://crabby-images/3a3a2/3a3a2d4a4492db2bccef19e6f6de910d5c8de853" alt="Screen Shot 2020-09-05 at 21 38 49"
data:image/s3,"s3://crabby-images/ec247/ec247940bbf43cd989ca99910f3aa2c3380bc2d7" alt="Screen Shot 2020-09-05 at 22 12 44"
data:image/s3,"s3://crabby-images/b9b56/b9b56d3f86946252d48e6531542cd51cbe1e144e" alt="Screen Shot 2019-05-26 at 11 29 40"
data:image/s3,"s3://crabby-images/78585/78585f2f2fbf6da10f3c696609fee4c6bcd6383e" alt="Screen Shot 2019-05-26 at 11 24 15"
What is it
This is a starter kit for your next API using Laravel, implemented with more than one structure, all battle-tested with the same features listed below.
Features
- 2FA
- ACL
- Anti Phishing Code on email
- Audit
- CORS
- Device authorization
- Etag
- Horizon
- Laravel 8.x, 7.x, 6.x, 5.8
- Login
- Login history
- Multiple localizations, preconfigured with en_US and pt_BR
- Password reset
- Password must not be in one of the 4 million weak passwords
- PHPCS PSR2, phpinsights and sonarqube analysis
- Register
- Swoole
- Tests
- Transactional events: Listen to events and send notifications only if the transaction is commited
- uuid
Soon:
- Background job example
Up and running
Environment: develop
~~The container used is created from Google Cloud Platform official php-docker + swoole and can be found here: https://github.com/ibrunotome/docker-laravel-appengine~~
The oficial php image from Google Cloud Platform is updated once in a lifetime so I decided to manage my own php images at http://github.com/ibrunotome/php
- Set the .env variables, see .env.example that is already configured to point to pgsql and redis services
- Run the container with
docker-compose -f docker-compose.develop.yml up
. Alternatively, if you have an older laptop, try running remotely with Blimp. - Enter into app container with
docker exec -it default-structure-app bash
- Run the migrations with
php artisan migrate:fresh
And it's up and running :)
Environment: testing
The container with xdebug is in the Dockerfile.testing
, you can get into this container using: docker-compose -f docker-compose.testing.yml up -d app
and then:
- Get into app container with
docker exec -it default-structure-app-testing bash
(off course, default-structure-app is for the default-structure) - Run tests with
composer test
- Run "lint" (phpcs) with
composer lint
- Run "lint and fix" (phpcbf) with
composer lint:fix
- Run phpcpd with
composer phpcpd
- Run php static analysis (level 5) with
composer static:analysis
- Run nunomaduro/phpinsights with
php artisan insights
To see sonarqube analysis, simple run docker-compose -f docker-compose.sonarqube.yml up
, the quality profile used is PSR-2.
Environment: production
See the contents of the .k8s
folder :)
Email layout
data:image/s3,"s3://crabby-images/949ff/949ffc1051fb5f00216f873f70c6f64245831abe" alt="screenshot 2019-02-07 08 26 51"
Database structure
data:image/s3,"s3://crabby-images/a1a47/a1a47fae21d16d3a85770622b08b23443b79f019" alt="Screen Shot 2019-05-26 at 17 55 32"
Routes
data:image/s3,"s3://crabby-images/84edd/84eddcfe94efcefddf0144c3ffa33af5c938aeba" alt="Screen Shot 2019-05-26 at 17 56 41"
Author
@ibrunotome |
Contributors
@crcms |
@ejj |