When building a subscription based application, you will commonly need to restrict access to certain routes to users that have an active subscription. For example, you may not want to let a user create a project if they are not subscribed to a billing plan. For that reason, Spark provides a convenient subscription verification middleware that you may assign to your application’s routes.

If your application uses Laravel 11’s streamlined application structure which configures middleware within the bootstrap/app.php file, then Spark’s subscription verification middleware alias is automatically registered for you internally. However, if you are using an application structure that does not utilize the bootstrap/app.php file for middleware configuration, you may need to manually register the subscribed middleware alias in your application’s App\Http\Kernel class:

use Spark\Http\Middleware\VerifyBillableIsSubscribed;

protected $middlewareAliases = [
    // ...

    'subscribed' => VerifyBillableIsSubscribed::class
];

Then, you may attach the subscribed middleware to any of your application’s route definitions:

Route::post('/projects', [ProjectController::class, 'store'])
        ->middleware(['auth', 'subscribed']);

If the user has a valid subscription, the request will continue to execute normally. However, if the user does not have an valid subscription, they will be redirected to your application’s Spark billing portal. If the request is an XHR request, a response with a 402 HTTP status code will be returned to the client.

Of course, you may always manually inspect a billable model’s subscription status using the methods provided by Laravel Cashier, which can be especially useful for verifying that a user is subscribed to a particular plan.

Was this page helpful?