robertboes / sidecar-inertia-vite
A Sidecar function to run Inertia server-side rendering with Vite on Lambda.
Fund package maintenance!
RobertBoes
Installs: 1 211
Dependents: 0
Suggesters: 0
Security: 0
Stars: 17
Watchers: 2
Forks: 9
Open Issues: 3
Requires
- php: ^8.0
- hammerstone/sidecar: ^0.4
- illuminate/support: ^9|^10
- inertiajs/inertia-laravel: ^0.6
Requires (Dev)
- laravel/pint: ^1.2
- mockery/mockery: ^1.5
- orchestra/testbench: ^7.15|^8.0
- phpunit/phpunit: ^9.5|^10.0
This package is auto-updated.
Last update: 2024-12-29 02:42:13 UTC
README
🚨 Use this package with caution, as I'm still working on it
This package is based on hammerstonedev/sidecar-inertia. Aaron has done an amazing job with Sidecar and his original package lead me to figure out how to make it work with Vite.
Overview
This package provides a Sidecar function to run Inertia server-side rendering on AWS Lambda.
Sidecar packages, deploys, and executes AWS Lambda functions from your Laravel application.
Enabling SSR
Following the official Inertia docs on enabling SSR is a good place to start, but there are a few things you can skip:
- You do not need to
npm install @inertiajs/server
- Come back here when you get to the "Building your application" section
I won't go into detail on how to setup SSR with Vite and Laravel, but the upcoming Inertia docs have more detailed information along with the Laravel docs
By default the SSR gateway is disabled, you can enable this by setting SIDECAR_INERTIA_VITE_ENABLED=true
in your .env
or by adjusting the configuration file to your liking.
Installation
To require this package, run the following:
composer require robertboes/sidecar-inertia-vite
This will install Sidecar as well.
Using the Sidecar Gateway
This package automatically overwrites the Inertia SSR gateway if the config sidecar-inertia-vite.ssr_gateway_enabled
is true.
If for some reason the gateway isn't properly overwritten you can do this in your own service provider like so:
namespace App\Providers; use RobertBoes\SidecarInertiaVite\SidecarGateway; use Illuminate\Support\ServiceProvider; use Inertia\Ssr\Gateway; class AppServiceProvider extends ServiceProvider { public function register() { // Use Sidecar to run Inertia SSR. $this->app->instance(Gateway::class, new SidecarGateway); } }
Publishing Configuration
You can publish the configuration with the following command:
php artisan vendor:publish --provider="RobertBoes\SidecarInertiaVite\ServiceProvider" --tag="config"
Configuring Sidecar
If you haven't already, you'll need to configure Sidecar.
Publish the sidecar.php
configuration file by running
php artisan sidecar:install
To configure your Sidecar AWS credentials interactively, you can run
php artisan sidecar:configure
The official Sidecar docs go into much further detail.
Now update your config/sidecar.php
to include the function shipped with this package.
<?php return [ 'functions' => [ \RobertBoes\SidecarInertiaVite\SSRFunction::class, ], // ... ];
Updating Your JavaScript
This only covers Vue3, please follow the Inertia docs for Vue2 or React, and please open any issues.
This package assumes you're using a near-stock vite.config.js
, which means the paths are defined by the Laravel plugin.
And update your resources/js/ssr.js
to look something like this. The specifics may vary based on your application. If you're using Ziggy, you'll want to uncomment the Ziggy stuff. (This is based on the Inertia docs, with slight modifications.)
import {createSSRApp, h} from 'vue' import {renderToString} from '@vue/server-renderer' import {createInertiaApp} from '@inertiajs/inertia-vue3' import { resolvePageComponent } from 'laravel-vite-plugin/inertia-helpers'; // import { ZiggyVue } from '../../vendor/tightenco/ziggy/dist/vue.m'; const appName = 'Laravel'; export async function handler(page) { return await createInertiaApp({ page, render: renderToString, title: (title) => `${title} - ${appName}`, resolve: (name) => resolvePageComponent(`./Pages/${name}.vue`, import.meta.glob('./Pages/**/*.vue', { eager: false })), setup({ app, props, plugin }) { return createSSRApp({ render: () => h(app, props) }) .use(plugin) // .use(ZiggyVue, { // ...page.props.ziggy, // location: new URL(page.props.ziggy.location), // }) }, }) }
Bundling / node_modules
By default the config option sidecar-inertia-vite.bundle
is set to true.
This will bundle your SSR function using @vercel/ncc,
which produces a single file and doesn't require the inclusion of the node_modules
folder.
Using this approach it will generate a single index.mjs
file along with dynamically imported modules.
If you wish to not use this you can set the option to false
. This will create a Lambda function with roughly the following contents:
- assets/
- node_modules/
- ssr.mjs
Deploying Your SSR Function
After you have added the SSR function to your sidecar.php
, you should run php artisan sidecar:deploy --activate
to
deploy your function.
This will compile your JavaScript for you as a beforeDeployment
hook, so you don't have to worry about remembering to do that first.
Debugging SSR
It's recommended that you deploy your Sidecar function locally so that you can test SSR more quickly. You can run php artisan sidecar:deploy --activate
from your local machine and your SSR function will be deployed to Lambda.
You can also set debug
to true
in your config/sidecar-inertia-vite.php
file, so that Sidecar will throw exceptions when SSR fails instead of falling back to client-side rendering. This will help you diagnose issues quickly.
A note on Ziggy
I personally don't use Ziggy, but I did try this in a Laravel Jetstream application and everything seemed to work fine. If anything doesn't work or the docs need more explanation, feel free to submit a PR.