* This is a wrapper class for WP_Session / PHP $_SESSION and handles the storage of cart items, purchase sessions, etc
* @subpackage Classes/Session
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
// Exit if accessed directly
if ( ! defined( 'ABSPATH' ) ) exit;
* Defines our WP_Session constants, includes the necessary libraries and
* retrieves the WP Session instance
public function __construct() {
// Use WP_Session (default)
if ( ! defined( 'WP_SESSION_COOKIE' ) ) {
define( 'WP_SESSION_COOKIE', 'nf_wp_session' );
if ( ! class_exists( 'Recursive_ArrayAccess' ) ) {
require_once Ninja_Forms::$dir . 'includes/Libraries/Session/class-recursive-arrayaccess.php';
if ( ! class_exists( 'WP_Session' ) ) {
require_once Ninja_Forms::$dir . 'includes/Libraries/Session/class-wp-session.php';
require_once Ninja_Forms::$dir . 'includes/Libraries/Session/wp-session.php';
add_filter( 'wp_session_expiration_variant', array( $this, 'set_expiration_variant_time' ), 99999 );
add_filter( 'wp_session_expiration', array( $this, 'set_expiration_time' ), 99999 );
// Since we only loading this as needed, we will need to call init() manually.
// add_action( 'plugins_loaded', array( $this, 'init' ), -1 );
* Setup the WP_Session instance
$this->session = WP_Session::get_instance();
* @return string Session ID
public function get_id() {
return $this->session->session_id;
* Retrieve a session variable
* @param string $key Session key
* @return string Session variable
public function get( $key ) {
$key = sanitize_key( $key );
return isset( $this->session[ $key ] ) ? maybe_unserialize( $this->session[ $key ] ) : false;
* @param string $key Session key
* @param integer $value Session variable
* @return string Session variable
public function set( $key, $value ) {
$this->session->set_cookie();
$key = sanitize_key( $key );
if ( is_array( $value ) ) {
$this->session[ $key ] = serialize( $value );
$this->session[ $key ] = $value;
return $this->session[ $key ];
* Delete a session variable
public function delete() {
delete_option( '_wp_session_' . $this->session->session_id );
delete_option( '_wp_session_expires_' . $this->session->session_id );
* Force the cookie expiration variant time to 23 minutes
* @param int $exp Default expiration (1 hour)
public function set_expiration_variant_time( $exp ) {
* Force the cookie expiration time to 24 minutes
* @param int $exp Default expiration (1 hour)
public function set_expiration_time( $exp ) {