Configuration Reference

The Platoon configuration is simple, and since it's a normal Laravel config file (which is really just a PHP file that returns an array), Laravel developers should feel right at home. The Platoon config is in the platoon.php file in your config directory. If it's not there, run the platoon:publish Artisan command.

The config file houses all deployment information for the current project and in most cases you'll want to commit the file to your repo. Platoon does not support password authentication, so you should not be including any sensitive authentication information in the config file.

Targets

Targets are the hosts where your project will be deployed to. You can have as many targets as you need, but you must have at least one. A typical target configuration looks something like this:

'targets' => [
    'staging' => [
        'host' => 'staging.test',
        'port' => 22,
        'username' => 'ssh-username',
        'root' => '/path/to/application/root',
        'php' => '/usr/bin/php',
        'composer' => '/path/to/composer.phar',
        'branch' => 'master',
        'migrate' => false,
    ],
]

The staging key is the name of the target. You'll use this name to reference this target when deploying. The only required options are host, username and root. All the others have default values. There are also assets and hooks settings that are not required. You can find out more about them under the Assets and Hooks sections.

Note

Platoon does not support password authentication. Your targets MUST be accessible using SSH keys. This means you'll need to generate a local key pair and copy the public key to the server.

Target settingDefaultDescription
host-The hostname or IP address of the remote target
port22The SSH port number
username-The SSH username
root-The path to the project root
php/usr/bin/phpThe full path to the PHP binary
composer<project-root>/composer.pharThe full path to where composer.phar is stored. Defaults to the project root.
branchmainThe branch to clone
migratefalseMigrate database changes on the target
assets[]Assets to copy during deployment. See Assets
hooks[]The hooks to run. See Hooks
paths[]Any changes to directory structure. See Directory Structure

Extra options

It's also possible to include a few additional options to the target config. At the moment, the option extra option supported is composer-flags. When running Composer, Platoon will use the following:

composer install --prefer-dist --no-dev --no-progress -optimize-autoloader

In addition, the -dallow_url_fopen=1 option is always passed to the PHP executable.

If you ever needed to add additional flags to the Composer or PHP CLI, you can use the extra.composer-flags and extra.php-flags options:

return [
    'targets' => [
        'dev' => [
            // ...
            'extra' => [
                'composer-flags' => [
                    '--dev',
                    '--optimize-autoloader',
                ],
                'php-flags' => [
                    '-dmemory_limit=512M',
                ],
            ],
        ],
    ],
];

Note

The --no-progress flag is always passed to Composer, and the -dallow_url_fopen=1 option is always set on the PHP CLI.

Directory structure

The path setting refers to the ROOT directory where the project is stored. In this root directory, Platoon will place all the bits needed for your project. By default there is a releases directory, a storage directory, a .env file and a symbolic link named live. During deployment, Platoon will create symbolic links for the .env file and storage directory into a new directory created in releases. A typical project directory structure looks something like this:

/path/to/project/
    |
    +- .env
    |
    +- live/  --> /path/to/project/releases/202201010000
    |
    +- releases/
    |   |
    |   +- 202201010000/
    |       |
    |       +- .env  --> /path/to/project/.env
    |       |
    |       +- storate/  --> /path/to/project/storage/
    |
    +- storage/

If you need to make changes to the .env file or the contents of the storage directory, you do so in the project root. This is the magic behind the zero-downtime deployment.

You can change the names of the directories that Platoon will create. In most cases, you should leave these settings alone, but if the need arises, you can pass an array to the paths config in your platoon.php target config:

'targets' => [
    'staging' => [
        //...
        'paths' => [
            'releases' => 'deployments',
            'live' => 'serve',
            'storage' => 'stuff',
            '.env' => 'config',
        ]
    ]
]
Path ConfigDefaultDescription
releasesreleasesThe directory where new releases are deployed
liveliveThe name of the symbolic link that the web server should serve
storagestorageThe name of the Laravel storage directory
.env.envThe name of the laravel .env file

Note that the .env and storage paths will always be named correctly when symlinked into the release. These settings allow you to change the name of the paths that Platoon will create.

Default target

Since it may be common to have more than one target, it's handy to have one of them set as the default. You can do this by supplying the name of one of the targets to the default config setting. Platoon will then use this target without you needing to specify it when deploying. If you don't specify a default in the config, then Platoon will assume that the first target specified is the default.

You can disable the default target completely by setting the default option to false. This can be useful if you are worried about deploying to the wrong host. Without a default, you're forced to make a choice about which target to deploy to.

Common target settings

There are situations where your targets might actually be the same phyiscal server. In this case, you can set up a common target and provide details that can be used across all the targets you specify. Anything you set for any particular target will then overwrite the common settings. To create a common target, simply name it common. You can provide any target setting to the common target and it will be the default set for all your other targets.

For example, you might want to set a common hostname, username and port number:

return [
    'targets' => [
        'common' => [
            'host' => 'common.host',
            'port' => 22,
            'username' => 'user',
            'php' => '/usr/bin/php',
            'composer' => '/path/to/composer.phar',
        ],
        'staging' => [
            'path' => '/opt/app/staging',
            'migrate' => true,
            'branch' => 'develop',
        ],
        'production' => [
            'path' => '/opt/app/production',
            'migrate' => false,
            'branch' => 'main',
        ]
    ]
]

Assets

It's strongly recommended that you never place compiled assets in your projects Git repository. It just makes things messy. Instead, assets should be compiled either on the target, or compiled and copied to the target during deployment. The latter is a common approach when dealing with a CI/CD pipeline. You can specify a list of assets to copy using the assets array on your target. You can also specify assets on the common target and it will be used for all other targets automatically.

The assets array is a key value pair. The key being the local file, and the value being the remote file.

'staging' => [
    //...
    'assets' => [
        'public/js/app.js' => 'public/js/app.js',
        'public/css/app.css' => 'public/css/app.css',
        'public/images/*' => 'public/images',
    ]
],

Take Note

When specifying whole directories, take note that if you specify a directory that already exists, the assets will be copied to a new directory INSIDE the directory you specified. This is likely NOT what you want and can be annoying to debug.

Directories are always copied recursively, so you don't need to specify any child paths.

Cleaning up

One of the final tasks that Platoon will complete is to clean up any old releases on the target. By default the current release and the previous one are left untouched and all other releases are removed. This will allow you to backtrack to a previous release if changes you make cause problems after deployment.

Hooks

Hooks are a simple way to add functionality to each task without needing to modify the Envoy script. This is handly if, for example. you need to provide your own build steps before deploying. Each step has a post hook, which means that scripts are executed AFTER the default scripts. There are currently 10 tasks. You can add hooks per target or to the common target config. Hooks must exist inside the hooks array and must be an array of bash commands:

'targets': [
    'staging': [
        //...
        'hooks' => [
            'build' => [
                'yarn production',
            ],
            'finish' => [
                'php ./artisan horizon:terminate'
            ],
        ]
    ]
]

With the exception of build and assets, all tasks are run on the remote server. The following hooks are available:

HookWhereDescription
buildlocalUse it to run any tasks BEFORE starting the deployment
installremoteAfter the repository is cloned into a new release directory
prepremoteAfter the symbolic links to .env and storage are created in the project root
composerremoteRun after the Composer executable is downloaded or updated
dependenciesremoteAfter Composer dependencies have been installed
assetslocalAfter the specified assets have been copied to the remote
databaseremoteAfter any database changes have been run
liveremoteAfter the live symbolic link is created, effective making the project live.
cleanupremoteAfter any old releases have been removed
finishremoteUse this to run any final deployment tasks

All hooks run on the remote target are executed within the project root path.

Platoon hooks also include a set of expansion tags that can make writing hooks a whole lot easier. For example, you can reference the configured PHP executable by using the @php tag. This means, you could write the previous finish hook like this:

'finish' => [
    '@php ./artisan horizon:terminate'
],

However, there is also a @artisan tag which will basically do that same thing inside the release directory:

'finish' => [
    '@artisan horizon:terminate'
],

This way you never have to worry about having the correct paths.

The following tags are provided:

TagExpansion
@phpThe full path to the configured PHP binary
@artisanThe full path to the artisan script prefixed with the configured PHP binary
@composerThe path to the configured composer phar
@baseThe project base directory
@releaseThe ID of the release currently being deployed
@installThe path to the current release directory. Same as using @base/releases/@release

Warning

Hooks defined for targets are NOT merged with the common target config. If you define a common hook, and then define the same hook on a target, the target's hook config will override the common config. For this reason, it is recommended that you don't define hooks under common unless you have good reason to do so.