Laravel Bridge
Back to home
On this page
Connect your Laravel-based app to Upsun Fixed with the platformsh/laravel-bridge
library.
Laravel expects all configuration to come in through environment variables with specific names in a specific format. Upsun Fixed provides configuration information as environment variables in a different specific format. This library handles mapping the Upsun Fixed variables to the format Laravel expects for common values.
Usage
Require this package using Composer. When Composer’s autoload is included, this library is activated and the environment variables set.
composer require platformsh/laravel-bridge
Make sure to clear the cache on relevant Upsun Fixed environments afterwards.
php artisan optimize:clear
What is mapped
-
If a Upsun Fixed relationship named
database
is defined, it is taken as an SQL database and mapped to theDB_*
environment variables for Laravel. -
If a Upsun Fixed relationship named
rediscache
is defined, it is mapped to theREDIS_*
environment variables for Laravel. TheCACHE_DRIVER
variable is also set toredis
to activate it automatically. -
If a Upsun Fixed relationship named
redissession
is defined, theSESSION_DRIVER
is set toredis
and 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_KEY
is set based on thePLATFORM_PROJECT_ENTROPY
variable, which is provided for exactly this purpose. -
The Laravel
APP_URL
variable is set based on the current route, when possible. -
The
SESSION_SECURE_COOKIE
variable is set totrue
if it’s not already defined. A Upsun Fixed environment is by default encrypted-always, so there’s no reason to allow unencrypted cookies. Overwrite this by setting the Upsun Fixed variableenv:SESSION_SECURE_COOKIE
to 0. -
The
MAIL_DRIVER
,MAIL_HOST
, andMAIL_PORT
variables are set to support sending email through the Upsun Fixed mail gateway. TheMAIL_ENCRYPTION
value is also set to0
to disable TLS, as it isn’t needed or supported within Upsun Fixed’s network. Note that doing so is only supported on Laravel 6.0.4 and later. On earlier versions, you must manually modifymail.php
and setencryption
tonull
:'encryption' => null,
Common environment variables not set
Laravel provides reasonable defaults for many environment variables already
and this library doesn’t override those.
Customize them by setting a Upsun Fixed variable named env:ENV_NAME
.
(Note the env:
prefix.)
The variables you are most likely to want to override are:
env:APP_NAME
: The human-friendly name of the app.env:APP_ENV
: Whether the app is inproduction
ordevelopment
mode.env:APP_DEBUG
: Settrue
to enable verbose error messages.
Now that your Laravel app is connected to Upsun Fixed, deploy it to see it in action.