This simple bridge library connects a Laravel-based application to Platform.sh. In the typical case it should be completely fire-and-forget.
Laravel prefers all configuration to come in through environment variables with specific names in a specific format. Platform.sh provides configuration information as environment variables in a different specific format. This library handles mapping the Platform.sh variables to the format Laravel expects for common values.
Simply require this package using Composer. When Composer's autoload is included this library will be activated and the environment variables set. As long as that happens before Laravel bootstraps its configuration (which it almost certainly will) everything should work fine with no further user-interaction necessary.
composer require platformsh/laravel-bridge
Note make sure to clear the cache on relevant platform.sh environments after updating this package.
php artisan cache:clear
-
If a Platform.sh relationship named
databaseis defined, it will be taken as an SQL database and mapped to theDB_*environment variables for Laravel. -
If a Platform.sh relationship named
rediscacheis defined, it will be mapped to theREDIS_*environment variables for Laravel. Additionally, theCACHE_DRIVER(up to Laravel v10) andCACHE_STORE(Laravel v11+) variables will be set toredisto activate it automatically. -
If a Platform.sh relationship named
redissessionis defined, theSESSION_DRIVERwill be set toredisand theREDIS_*variables set based on that relationship. NOTE: This means you must set 2 relationships to the same Redis service and endpoint, as Laravel reuses the same backend connection. -
The Laravel
APP_KEYis set based on thePLATFORM_PROJECT_ENTROPYvariable, which is provided for exactly this purpose. -
The Laravel
APP_URLvariable is set based on the current route if possible. -
The
SESSION_SECURE_COOKIEvariable is set to true if it's not already defined. A Platform.sh environment is by default encrypted-always, so there's no reason to allow unencrypted cookies. This can be overridden by setting the Platform.sh variableenv:SESSION_SECURE_COOKIEto 0. -
The
MAIL_DRIVER,MAIL_HOST, andMAIL_PORTvariables are set to support sending email through the Platform.sh mail gateway. TheMAIL_ENCRYPTIONvalue is also set to0to disable TLS, as it is not needed or supported within Platform.sh's network. Note, however, that doing so is only supported on Laravel 6.0.4 and later. On earlier versions you must manually modifymail.phpand setencryptiontonull:
'encryption' => null,
Laravel provides reasonable defaults for many environment variables already and this library does not override those. They may, however, be customized by setting a Platform.sh variable named env:ENV_NAME. (Note the env: prefix.) The most likely variables to override are listed below for convenience:
env:APP_NAME: The human-friendly name of the application.env:APP_ENV: Whether the application is inproductionordevelopmentmode.env:APP_DEBUG: Set true to enable verbose error messages.