audunru / version-warning
Warn SPA users when they are using an outdated client
Installs: 1 222
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 1
Requires
- php: ^8.2
- laravel/framework: ^11.0
- spatie/laravel-package-tools: ^1.9
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- orchestra/testbench: ^9.0
- php-coveralls/php-coveralls: ^2.2
- phpmd/phpmd: ^2.10
- phpunit/phpunit: ^11.0
- roave/security-advisories: dev-latest
This package is auto-updated.
Last update: 2025-03-10 16:12:12 UTC
README
Laravel middleware to help you notify users who are using an outdated version of the SPA client.
When you deploy a new version of your SPA to your server, not all users will start using the new version immediately. Anyone who is already logged in and does not refresh the page, will continue to use the old client until they close the browser tab or refresh the page. This package is meant to help you notify users with an outdated client that they should reload in order to use the latest version.
Currently, the package gets its version info from a package.json
file in the root folder. This means that you will have to update the version in the package.json file whenever you make a change that requires all clients to update.
Installation
Step 1: Install with Composer
composer require audunru/version-warning
Step 2: Add middleware to your routes
Add the VersionWarning
middleware to your API routes:
'api' => [ 'throttle:api', \Illuminate\Routing\Middleware\SubstituteBindings::class, \audunru\VersionWarning\Middleware\VersionWarning::class, ],
Step 3: Notify user when client is outdated
Alternative A: Compare X-App-Version header client side
When you make a fetch request to the server, add a X-App-Version
header with a value of the client's current version. E.g.: X-App-Version: 1.18.1
.
The VersionWarning
middleware will compare the client version to the server version, and add a header called X-Version-Warning
to the response if the versions do not match.
On the client side, you should check for the presence of the X-Version-Warning
header. If it is present, the user should be notified that a reload is necessary so that the latest client assets (JavaScript and CSS) can be loaded.
Alternative B: Compare X-App-Version header client side
The VersionWarning
middleware adds a header called X-App-Version
to the response. On the client side, you can compare this version to the client version and notify the user in case of a mismatch.
Which version is the client running?
Set client version during build
If you're using Laravel Mix, you can include the current version during build time.
Set the MIX_VERSION environment variable in your build script (you should install the cross-var and cross-env packages so that this works on both Mac/Windows):
"production": "cross-var cross-env MIX_VERSION=$npm_package_version mix --production",
You can then use process.env.MIX_VERSION
in your frontend code.
Get client version from HTML meta tag
Add the following to your layout blade template:
<meta name="app-version" content="{{ app_version() }}" />
In your frontend code, read the value of this meta tag.
Configuration
Publish the configuration file by running:
php artisan vendor:publish --tag=version-warning-config
Development
Testing
Run tests:
composer test