clam2021/vendor/tuupola/slim-basic-auth/UPGRADING.md
2021-05-13 13:04:00 -03:00

1.8 KiB

Updgrading from 2.x to 3.x

New namespace

For most cases it is enough just to update the classname. Instead of using the old Slim\Middleware namespace:

$app->add(new Slim\Middleware\HttpBasicAuthentication([
    "users" => [
        "root" => "t00r",
        "somebody" => "passw0rd"
    ]
]));

You should now use Tuupola\Middleware instead:

$app->add(new Tuupola\Middleware\HttpBasicAuthentication([
    "users" => [
        "root" => "t00r",
        "somebody" => "passw0rd"
    ]
]));

Changed parameter names

Parameters callback and passthrough were renamed to before and ignore. In other words instead of doing:

$app->add(new Slim\Middleware\HttpBasicAuthentication([
    "passthrough" => ["/token"],
    "callback" => function ($request, $response, $arguments) {
        print_r($arguments);
    }
]));

You should now do the following instead:

$app->add(new Tuupola\Middleware\HttpBasicAuthentication([
    "ignore" => ["/token"],
    "before" => function ($request, $response, $arguments) {
        print_r($arguments);
    }
]));

Note that before() should now return an instance of Psr\Http\Message\RequestInterface. Anything else will be ignored.

Most setter are removed

Most public setters and getters were removed. If you had code like following:

$auth = (new Slim\Middleware\HttpBasicAuthentication)
    ->setPath(["/admin", "/api"])
    ->setRealm("Protected"),
    ->setUsers([
        "root" => "t00r",
        "somebody" => "passw0rd"
    ]);

$app->add($auth);

Settings should now be passed in constructor instead:

$app->add(new Tuupola\Middleware\HttpBasicAuthentication([
    "path" => ["/admin", "/api"],
    "realm" => "Protected",
    "users" => [
        "root" => "t00r",
        "somebody" => "passw0rd"
    ]
]));