Skip to content

Commit

Permalink
Merge pull request #4465 from nilsteampassnet/crypt_session
Browse files Browse the repository at this point in the history
Crypt session
  • Loading branch information
nilsteampassnet authored Nov 15, 2024
2 parents d6937bb + 60b1eaf commit 8297c51
Show file tree
Hide file tree
Showing 14 changed files with 257 additions and 67 deletions.
2 changes: 1 addition & 1 deletion includes/config/include.php
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@

define('TP_VERSION', '3.1.2');
define("UPGRADE_MIN_DATE", "1731422875");
define('TP_VERSION_MINOR', '151');
define('TP_VERSION_MINOR', '156');
define('TP_TOOL_NAME', 'Teampass');
define('TP_ONE_DAY_SECONDS', 86400);
define('TP_ONE_WEEK_SECONDS', 604800);
Expand Down
3 changes: 2 additions & 1 deletion includes/core/login.oauth2.php
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,14 @@
*/

use TeampassClasses\OAuth2Controller\OAuth2Controller;
use TeampassClasses\SessionManager\SessionManager;

session_start();
require_once __DIR__. '/../../includes/config/include.php';
require_once __DIR__.'/../../sources/main.functions.php';

// init
loadClasses();
$session = SessionManager::getSession();

// Création d'une instance du contrôleur
$OAuth2 = new OAuth2Controller($SETTINGS);
Expand Down
8 changes: 0 additions & 8 deletions includes/libraries/csrfp/libs/csrf/csrfprotector.php
Original file line number Diff line number Diff line change
Expand Up @@ -132,14 +132,6 @@ public static function init($length = null, $action = null, $logger = null)
}


//SessionManager::getSession();
// Start session in case its not, and unit test is not going on
if (session_id() == '' && !defined('__CSRFP_UNIT_TEST__')) {
//session_name('teampass_session');
session_start();
//$_SESSION['CPM'] = 1;
}

// Load configuration file and properties & Check locally for a
// config.php then check for a config/csrf_config.php file in the
// root folder for composer installations
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
<?php
namespace TeampassClasses\SessionManager;

/**
* Teampass - a collaborative passwords manager.
* ---
* This file is part of the TeamPass project.
*
* TeamPass is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 3 of the License.
*
* TeamPass is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* Certain components of this file may be under different licenses. For
* details, see the `licenses` directory or individual file headers.
* ---
* @file EncryptedSessionProxy.php
* @author Nils Laumaillé (nils@teampass.net)
* @copyright 2009-2024 Teampass.net
* @license GPL-3.0
* @see https://www.teampass.net
*/

use Defuse\Crypto\Crypto;
use Defuse\Crypto\Key;
use Symfony\Component\HttpFoundation\Session\Storage\Proxy\SessionHandlerProxy;

class EncryptedSessionProxy extends SessionHandlerProxy
{
protected $handler;
private $key;

/**
* Constructor.
*
* @param \SessionHandlerInterface $handler
* @param Key $key
*/
public function __construct(
\SessionHandlerInterface $handler,
Key $key
) {
parent::__construct($handler);
$this->key = $key;
}

/**
* Decrypt the session data after reading it from the session handler.
*
* @param string $id
*
* @return string
*/
public function read($id): string
{
$data = parent::read($id);

if ($data !== '') {
return Crypto::decrypt($data, $this->key);
}

return '';
}

/**
* Encrypt the session data before writing it to the session handler.
*
* @param string $id
* @param string $data
*
* @return bool
*/
public function write($id, $data): bool
{
$data = Crypto::encrypt($data, $this->key);

return parent::write($id, $data);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -30,15 +30,25 @@

use Symfony\Component\HttpFoundation\Session\Session;
use Symfony\Component\HttpFoundation\Request;
use Defuse\Crypto\Key;
use TeampassClasses\SessionManager\EncryptedSessionProxy;

class SessionManager
{
private static $session = null;

public static function getSession()
{
if (null === self::$session) {
self::$session = new Session();
if (null === self::$session) {
// Load the encryption key
$key = Key::loadFromAsciiSafeString(file_get_contents(SECUREPATH . "/" . SECUREFILE));

// Create an instance of EncryptedSessionProxy
$handler = new EncryptedSessionProxy(new \SessionHandler(), $key);

// Create a new session with the encrypted session handler
self::$session = new Session(new \Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage([], $handler));

if (session_status() === PHP_SESSION_NONE) {
$request = Request::createFromGlobals();
$isSecure = $request->isSecure();
Expand All @@ -58,73 +68,73 @@ public static function getSession()
}

public static function addRemoveFromSessionArray($key, $values = [], $action = 'add') {
// Récupérer le tableau de la session
// Retrieve the array from the session
$sessionArray = self::getSession()->get($key, []);

foreach ($values as $value) {
if ($action === 'add') {
// Ajouter la valeur au tableau
// Add the value to the array
$sessionArray[] = $value;
} elseif ($action === 'remove') {
// Trouver l'index de la valeur dans le tableau
// Find the index of the value in the array
$index = array_search($value, $sessionArray);

// Si la valeur est trouvée dans le tableau, la supprimer
// If the value is found in the array, remove it
if ($index !== false) {
unset($sessionArray[$index]);
}
}
}

// Réaffecter le tableau à la session
// Reassign the array to the session
self::getSession()->set($key, $sessionArray);
}

public static function specificOpsOnSessionArray($key, $action = 'pop', $value = null) {
// Récupérer le tableau de la session
// Retrieve the array from the session
$sessionArray = self::getSession()->get($key, []);

if ($action === 'pop') {
// Supprimer la dernière valeur du tableau
// Remove the last value from the array
array_pop($sessionArray);
} elseif ($action === 'shift') {
// Supprimer la première valeur du tableau
// Remove the first value from the array
array_shift($sessionArray);
} elseif ($action === 'reset') {
// Réinitialiser le tableau
// Reset the array
$sessionArray = [];
} elseif ($action === 'unshift' && is_null($value) === false) {
// Ajouter une valeur au début du tableau
// Add a value to the beginning of the array
array_unshift($sessionArray, $value);
}

// Réaffecter le tableau à la session
// Reassign the array to the session
self::getSession()->set($key, $sessionArray);
}

public static function addRemoveFromSessionAssociativeArray($key, $values = [], $action = 'add') {
// Récupérer le tableau de la session
// Retrieve the array from the session
$sessionArray = self::getSession()->get($key, []);

if ($action === 'add') {
// Ajouter la valeur au tableau
// Add the value to the array
array_push($sessionArray, $values);
} elseif ($action === 'remove') {
// Si la valeur existe dans le tableau, la supprimer
// If the value exists in the array, remove it
if (($key = array_search($values, $sessionArray)) !== false) {
unset($sessionArray[$key]);
}
}

// Réaffecter le tableau à la session
// Reassign the array to the session
self::getSession()->set($key, $sessionArray);
}

public static function getCookieValue($cookieName)
{
$request = Request::createFromGlobals();

// Vérifier si le cookie existe
// Check if the cookie exists
if ($request->cookies->has($cookieName)) {
return $request->cookies->get($cookieName);
}
Expand Down
6 changes: 2 additions & 4 deletions install/install.queries.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,13 @@
use Defuse\Crypto\Key;
use Defuse\Crypto\Crypto;
use Defuse\Crypto\Exception as CryptoException;
use EZimuel\PHPSecureSession;
use Hackzilla\PasswordGenerator\Generator\ComputerPasswordGenerator;
use Hackzilla\PasswordGenerator\RandomGenerator\Php7RandomGenerator;
use TeampassClasses\SuperGlobal\SuperGlobal;
use TeampassClasses\Language\Language;
use TeampassClasses\PasswordManager\PasswordManager;
use TeampassClasses\ConfigManager\ConfigManager;
use TeampassClasses\SessionManager\SessionManager;
use Encryption\Crypt\aesctr;

// Do initial test
Expand All @@ -58,11 +58,9 @@

// init
loadClasses('DB');
$session = SessionManager::getSession();
$superGlobal = new SuperGlobal();
$lang = new Language();
if (session_status() == PHP_SESSION_NONE) {
session_start();
}

// Load config
$configManager = new ConfigManager();
Expand Down
10 changes: 7 additions & 3 deletions install/migrate_users_to_v3.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,16 @@
* @see https://www.teampass.net
*/

use TeampassClasses\SessionManager\SessionManager;
set_time_limit(600);


require_once './libs/SecureHandler.php';
session_name('teampass_session');
session_start();
require_once '../sources/main.functions.php';

// init
loadClasses();
$session = SessionManager::getSession();

error_reporting(E_ERROR | E_PARSE);
$_SESSION['db_encoding'] = 'utf8';
$_SESSION['CPM'] = 1;
Expand Down
8 changes: 7 additions & 1 deletion install/upgrade.php
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
* @see https://www.teampass.net
*/

use TeampassClasses\SessionManager\SessionManager;

header('X-XSS-Protection: 1; mode=block');
header('X-Frame-Options: SameOrigin');
Expand All @@ -42,7 +43,12 @@
ini_set('session.cookie_secure', 0);

require_once './libs/SecureHandler.php';
session_start();
require_once '../sources/main.functions.php';

// init
loadClasses();
$session = SessionManager::getSession();

//Session teampass tag
$_SESSION['CPM'] = 1;
define('MIN_PHP_VERSION', 8.1);
Expand Down
10 changes: 7 additions & 3 deletions install/upgrade_scripts_manager.php
Original file line number Diff line number Diff line change
Expand Up @@ -26,12 +26,16 @@
* @see https://www.teampass.net
*/

use TeampassClasses\SessionManager\SessionManager;
set_time_limit(600);


require_once './libs/SecureHandler.php';
session_name('teampass_session');
session_start();
require_once '../sources/main.functions.php';

// init
loadClasses();
$session = SessionManager::getSession();

error_reporting(E_ERROR | E_PARSE);
$_SESSION['db_encoding'] = 'utf8';
$_SESSION['CPM'] = 1;
Expand Down
4 changes: 0 additions & 4 deletions sources/identify.php
Original file line number Diff line number Diff line change
Expand Up @@ -30,15 +30,11 @@
*/

use voku\helper\AntiXSS;
use EZimuel\PHPSecureSession;
use TeampassClasses\SessionManager\SessionManager;
use Symfony\Component\HttpFoundation\Request as SymfonyRequest;
use TeampassClasses\Language\Language;
use TeampassClasses\PerformChecks\PerformChecks;
use TeampassClasses\ConfigManager\ConfigManager;
use LdapRecord\Connection;
use LdapRecord\Container;
use LdapRecord\Auth\Events\Failed;
use TeampassClasses\NestedTree\NestedTree;
use TeampassClasses\PasswordManager\PasswordManager;
use Duo\DuoUniversal\Client;
Expand Down
4 changes: 3 additions & 1 deletion sources/oauth.php
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
<?php
use TeampassClasses\OAuth2Controller\OAuth2Controller;
session_start();
use TeampassClasses\SessionManager\SessionManager;

require_once __DIR__. '/../includes/config/include.php';
require_once __DIR__.'/../sources/main.functions.php';

// init
loadClasses();
$session = SessionManager::getSession();

// MDP teampss.user c@mx5q^tL6
// MDP teampass.admin Goh@u939!879
Expand Down
5 changes: 0 additions & 5 deletions vendor/owasp/csrf-protector-php/libs/csrf/csrfprotector.php
Original file line number Diff line number Diff line change
Expand Up @@ -129,11 +129,6 @@ public static function init($length = null, $action = null, $logger = null)
return;
}

// Start session in case its not, and unit test is not going on
if (session_id() == '' && !defined('__CSRFP_UNIT_TEST__')) {
session_start();
}

// Load configuration file and properties & Check locally for a
// config.php then check for a config/csrf_config.php file in the
// root folder for composer installations
Expand Down
Loading

0 comments on commit 8297c51

Please sign in to comment.