Use secure session cookies (fixes #321)
This commit is contained in:
parent
de8c5e5dc7
commit
342b8c4a42
6 changed files with 23 additions and 8 deletions
|
@ -7,6 +7,7 @@
|
|||
namespace Alltube\Factory;
|
||||
|
||||
use Aura\Session\Session;
|
||||
use Slim\Container;
|
||||
|
||||
/**
|
||||
* Manage sessions.
|
||||
|
@ -17,11 +18,24 @@ class SessionFactory
|
|||
/**
|
||||
* Get the current session.
|
||||
*
|
||||
* @param Container $container
|
||||
* @return Session
|
||||
*/
|
||||
public static function create()
|
||||
public static function create(Container $container)
|
||||
{
|
||||
$session_factory = new \Aura\Session\SessionFactory();
|
||||
return $session_factory->newInstance($_COOKIE);
|
||||
$session = $session_factory->newInstance($_COOKIE);
|
||||
|
||||
$session->setCookieParams(['httponly' => true]);
|
||||
|
||||
$request = $container->get('request');
|
||||
if (
|
||||
in_array('https', $request->getHeader('X-Forwarded-Proto'))
|
||||
|| $request->getUri()->getScheme() == 'https'
|
||||
) {
|
||||
$session->setCookieParams(['secure' => true]);
|
||||
}
|
||||
|
||||
return $session;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue