Pirate Skeleton Application
About
Ahoy pirate ! This is an simple PHP skeleton application (based on Zend Expressive) that is ready to sail in AWS Lightsail !
It comes with the features working out of the box to make it easier for you to spin your new webservice:
- PSR-7 Response caching layer
- CLI Command application
- Integration and Unit tests already configured
- One line command spins up the whole application
- Logger (Monolog) and (Bugsnag)
- Integration test to test your Swagger/OpenApi file against the response
Skeleton Start list
In order to start your project there is a checklist of items that you must replace to before start coding:
- Search for all instances of
pirate-application
and replace with your application name in lower case. - Search for all instances of
pirate-app
and replace with your application name in lower case as in to be used by a url. - Search for all instances of
PirateApplication
and replace with your application name in camel case. - Rename the
src/PirateApplication
,test/PirateApplicationIntegrationTest
andtest/PirateApplicationUnitTest
to the namespace corresponding to your project.
Now you can follow the Installation
section to setup your new Pirate Application :D
Installation
- Install Docker on your computer (https://www.docker.com/get-started)
- Add the PirateApplication entry on your
/etc/hosts
file: - Optional : Install Composer on your computer to make it easier
127.0.0.1 pirate-app.local
1 - Copy the .env.example
file:
$ cp .env.example .env
2 - Run composer install:
$ composer install
Alternatively you can run composer inside a docker machine:
$ docker run --rm --interactive --tty \
--volume $PWD:/app \
composer install
3 - Run docker-compose up:
$ docker-compose up
Alternatively you can run
composer up
if you have composer installed locally.
You can then browse to http://pirate-app.local/api/v1/ping . You should be able to see JSON ack response.
4 - Run Migrations and Seeds:
$ composer commander migrations:migrate
Composer scripts:
composer up
: Serves the application (equals todocker-composer up -d
)composer ps
: Shows Docker images currently running.composer stop
: Stops the application serving (equals todocker-compose stop
)composer check
: Runs PHPCS, PHPUNIT and PHPSTANcomposer coverage-html
: Generates HTML coverage and opens it on your browser.
Application Development Mode Tool
This Application comes with zf-development-mode. It provides a composer script to allow you to enable and disable development mode.
To enable development mode
Note: Do NOT run development mode on your production server!
Local composer:
$ composer development-enable
Note: Enabling development mode will also clear your configuration cache, to allow safely updating dependencies and ensuring any new configuration is picked up by your application.
To disable development mode
$ composer development-disable
Development mode status
$ composer development-status
Configuration caching
By default, the skeleton will create a configuration cache in
data/config-cache.php
. When in development mode, the configuration cache is
disabled, and switching in and out of development mode will remove the
configuration cache.
You may need to clear the configuration cache in production when deploying if you deploy to the same directory. You may do so using the following:
$ composer clear-config-cache
You may also change the location of the configuration cache itself by editing
the config/config.php
file and changing the config_cache_path
entry of the
local $cacheConfig
variable.
Testing
$ composer check
CLI Tool
$ composer commander
or if you don't have composer locally:
$ docker-compose run php php /code/bin/commander.php
Running the CLI (Commander) in Production:
Go to AWS lightsail's instance and SSH into it:
cd pirate-app
docker-compose -f docker-compose-production.yml run php php /code/bin/commander.php
Redis CLI
In order to connect to the Redis CLI run :
docker-compose run redis redis-cli -h redis
The documentation of Redis can be seem in https://redis.io/commands
Profiling and Profiling monitor
Update your docker-compose.yml
to enable XDebug profiling then go to http://pirate-app.local:8081 and you should be able to view your xdebug profiler logs.