revolution / laravel-vercel-installer
Vercel Installer
Fund package maintenance!
invokable
Installs: 28 952
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
pkg:composer/revolution/laravel-vercel-installer
Requires
- php: ^8.2
- illuminate/support: ^11.0||^12.0
Requires (Dev)
- laravel/pint: ^1.22
- orchestra/testbench: ^9.0||^10.8
README
Install some files to run Laravel on Vercel.
Requirements
- PHP >= 8.2
- Laravel >= 11.0
Installation
composer require revolution/laravel-vercel-installer --dev php artisan vercel:install
Uninstall
composer remove revolution/laravel-vercel-installer --dev
Once you have run the command you can uninstall this package.
vercel.json
It will probably not work with the new spec that uses functions and rewrites in vercel.json.
regions
https://vercel.com/docs/edge-network/regions
builds
vercel-php@0.7.4 is PHP8.3
To use another version, check this repository. https://github.com/vercel-community/php
routes
If there are other files in public, add them to routes.
{
"src": "/images/(.*)",
"dest": "/public/images/$1"
},
env
Secret env is set in the vercel settings page.
php artisan key:generate --show command generates a new key without updating the .env file. Set this key on the Settings page APP_KEY.
Assets
Even if you build css/js assets during deployment, they probably won't be loaded. Since @vercel/static simply distributes the files included in the repository as is, @vercel/static cannot access files built with vercel-php.
There are two solutions: include pre-built files in the repository, or display assets inline with Vite::content().
Include pre-build assets
Build the assets locally and include them in the repository.
// .gitignore
!/public/build
Inline assets
Use Vite::content to display assets inline instead of @vite.
"scripts": { "vercel": [ "@php artisan migrate --force", "npm install", "npm run build" ] }
{{--@vite(['resources/css/app.css', 'resources/js/app.js'])--}}
<style>
{!! Vite::content('resources/css/app.css') !!}
</style>
<script>
{!! Vite::content('resources/js/app.js') !!}
</script>
Database
You can use AWS RDS or any public DB.
Migration command
If you define the migrate command in the scripts section of composer.json, it will be executed during deployment.
"scripts": { "vercel": [ "@php artisan migrate --force" ] }
Cache and session
array is default. You can't use the file driver.
If you're using a database, you can use the database driver.
We recommend using database or array with the failover driver.
TrustProxies
Laravel 10
If you have any problems with TrustProxies, change /app/Http/Middleware/TrustProxies.php.
class TrustProxies extends Middleware { /** * The trusted proxies for this application. * * @var array<int, string>|string|null */ protected $proxies = '*';
Laravel 11
Change /bootstrap/app.php
->withMiddleware(function (Middleware $middleware) { $middleware->trustProxies(at: '*'); })
API prefix
If you use Laravel's API routes, you will need to change the /api/ route as it conflicts with Vercel.
Laravel 11
/bootstrap/app.php
use Illuminate\Foundation\Application; return Application::configure(basePath: dirname(__DIR__)) ->withRouting( web: __DIR__.'/../routes/web.php', commands: __DIR__.'/../routes/console.php', api: __DIR__.'/../routes/api.php', apiPrefix: 'prefix/api', health: '/up', )
Disable build cache
Deployment often fails when you increase the package version in composer.json. To solve this, add VERCEL_FORCE_NO_BUILD_CACHE to Vercel's project settings - Environment Variables. Setting it in vercel.json probably won't solve the problem.
VERCEL_FORCE_NO_BUILD_CACHE:1
https://vercel.com/docs/deployments/troubleshoot-a-build#managing-build-cache
LICENSE
MIT