default services conflit ?
This commit is contained in:
@@ -0,0 +1,48 @@
|
||||
<?php
|
||||
|
||||
namespace Http\Message\Authentication;
|
||||
|
||||
use Http\Message\Authentication;
|
||||
use Psr\Http\Message\RequestInterface;
|
||||
|
||||
/**
|
||||
* Authenticate a PSR-7 Request using Basic Auth based on credentials in the URI.
|
||||
*
|
||||
* @author Márk Sági-Kazár <mark.sagikazar@gmail.com>
|
||||
*/
|
||||
final class AutoBasicAuth implements Authentication
|
||||
{
|
||||
/**
|
||||
* Whether user info should be removed from the URI.
|
||||
*
|
||||
* @var bool
|
||||
*/
|
||||
private $shouldRemoveUserInfo;
|
||||
|
||||
/**
|
||||
* @param bool|true $shouldRremoveUserInfo
|
||||
*/
|
||||
public function __construct($shouldRremoveUserInfo = true)
|
||||
{
|
||||
$this->shouldRemoveUserInfo = (bool) $shouldRremoveUserInfo;
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function authenticate(RequestInterface $request)
|
||||
{
|
||||
$uri = $request->getUri();
|
||||
$userInfo = $uri->getUserInfo();
|
||||
|
||||
if (!empty($userInfo)) {
|
||||
if ($this->shouldRemoveUserInfo) {
|
||||
$request = $request->withUri($uri->withUserInfo(''));
|
||||
}
|
||||
|
||||
$request = $request->withHeader('Authorization', sprintf('Basic %s', base64_encode($userInfo)));
|
||||
}
|
||||
|
||||
return $request;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user