audunru/dynamic-cors

This package is abandoned and no longer maintained. No replacement package was suggested.

Dynamically change CORS options in Laravel

Maintainers

Package info

github.com/audunru/dynamic-cors

pkg:composer/audunru/dynamic-cors

Statistics

Installs: 2 338

Dependents: 0

Suggesters: 0

Stars: 3

Open Issues: 0

v2.0.6 2025-11-15 22:29 UTC

README

Build Status Coverage Status StyleCI

Typically used to configure custom allowed origins per user/account, so that your users can access your HTTP API from different domains without getting CORS errors.

Under the hood, this middleware dynamically sets Laravel's default CORS configuration options. Basically, it's a wrapper for calls like...

config("cors.allowed_origins", ["https://www.example.com"]);

... where the list of of allowed origins would dynamically change, for example come from the user's account settings.

Installation

composer require audunru/dynamic-cors

You will have to replace Laravel's default HandleCors middleware with a version that extends audunru\DynamicCors\Middleware\HandleCors.

  1. Ensure that you are manually managing Laravel's default global middleware.

  2. Remove \Illuminate\Http\Middleware\HandleCors::class from the middleware stack.

  3. Create a new file app/Http/Middleware/UserCors.php.

You can place this wherever you want, and of course name it according to what it does in your application.

This is an example where a user has a list of per-user allowed origins, perhaps controlled by themselves in the application UI.

namespace App\Http\Middleware;

use Closure;
use audunru\DynamicCors\Middleware\HandleCors;

class UserCors extends HandleCors
{
    public function handle($request, Closure $next)
    {
        $user = Auth::user();

        $this->allowedOrigins = array_merge(
            [config('app.url')],
            $user->allowedOrigins // Note: allowedOrigins does not exist by default, it's something you would have to create. Or make something completely different
        );

        return parent::handle($request, $next);
    }
}

audunru\DynamicCors\Middleware\HandleCors has protected properties for allowedOrigins and all the other CORS service settings. Any properties that you set in your middleware will be used by the CORS service. Properties that you don't set will use the value set in cors.php.

  1. Add \App\Http\Middleware\HandleCors::class to the middleware stack.

Development

Testing

Run tests:

composer test