Translated using Weblate (Slovenian)
[phpmyadmin.git] / libraries / session.lib.php
blob5b0404b99a730240b6916363b805f4b266ac5c05
1 <?php
2 /* vim: set expandtab sw=4 ts=4 sts=4: */
3 /**
4 * session library
6 * @package PhpMyAdmin
7 */
9 /**
10 * tries to secure session from hijacking and fixation
11 * should be called before login and after successful login
12 * (only required if sensitive information stored in session)
14 * @return void
16 function PMA_secureSession()
18 // prevent session fixation and XSS
19 if (session_status() === PHP_SESSION_ACTIVE && ! defined('TESTSUITE')) {
20 session_regenerate_id(true);
22 PMA_generateToken();
26 /**
27 * Generates PMA_token session variable.
29 * @return void
31 function PMA_generateToken()
33 if (class_exists('phpseclib\Crypt\Random')) {
34 $_SESSION[' PMA_token '] = bin2hex(phpseclib\Crypt\Random::string(16));
35 } else {
36 $_SESSION[' PMA_token '] = bin2hex(openssl_random_pseudo_bytes(16));
39 /**
40 * Check if token is properly generated (the genration can fail, for example
41 * due to missing /dev/random for openssl).
43 if (empty($_SESSION[' PMA_token '])) {
44 PMA_fatalError(
45 'Failed to generate random CSRF token!'