2012-09-12 13:45:42 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Handle data for the current customers session.
|
|
|
|
*
|
2014-08-31 05:49:58 +00:00
|
|
|
* @class WC_Session
|
|
|
|
* @version 2.0.0
|
|
|
|
* @package WooCommerce/Abstracts
|
|
|
|
* @category Abstract Class
|
|
|
|
* @author WooThemes
|
2012-09-12 13:45:42 +00:00
|
|
|
*/
|
2012-09-12 14:21:13 +00:00
|
|
|
abstract class WC_Session {
|
|
|
|
|
2013-11-28 12:54:19 +00:00
|
|
|
/** @var int $_customer_id */
|
2013-01-27 18:54:37 +00:00
|
|
|
protected $_customer_id;
|
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/** @var array $_data */
|
|
|
|
protected $_data = array();
|
2012-09-12 14:21:13 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/** @var bool $_dirty When something changes */
|
|
|
|
protected $_dirty = false;
|
2012-11-27 16:22:47 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
|
|
|
* __get function.
|
|
|
|
*
|
|
|
|
* @param mixed $key
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function __get( $key ) {
|
|
|
|
return $this->get( $key );
|
|
|
|
}
|
2012-11-27 16:22:47 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
|
|
|
* __set function.
|
|
|
|
*
|
|
|
|
* @param mixed $key
|
|
|
|
* @param mixed $value
|
|
|
|
*/
|
|
|
|
public function __set( $key, $value ) {
|
|
|
|
$this->set( $key, $value );
|
|
|
|
}
|
2012-11-27 16:22:47 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
|
|
|
* __isset function.
|
|
|
|
*
|
|
|
|
* @param mixed $key
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function __isset( $key ) {
|
|
|
|
return isset( $this->_data[ sanitize_title( $key ) ] );
|
|
|
|
}
|
2012-11-27 16:22:47 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
|
|
|
* __unset function.
|
|
|
|
*
|
|
|
|
* @param mixed $key
|
|
|
|
*/
|
|
|
|
public function __unset( $key ) {
|
2015-09-16 09:34:22 +00:00
|
|
|
$this->unset( $key );
|
2014-08-31 05:49:58 +00:00
|
|
|
}
|
2013-01-27 18:54:37 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
|
|
|
* Get a session variable
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @param mixed $default used if the session variable isn't set
|
|
|
|
* @return mixed value of session variable
|
|
|
|
*/
|
|
|
|
public function get( $key, $default = null ) {
|
|
|
|
$key = sanitize_key( $key );
|
|
|
|
return isset( $this->_data[ $key ] ) ? maybe_unserialize( $this->_data[ $key ] ) : $default;
|
|
|
|
}
|
2013-06-11 14:59:23 +00:00
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
|
|
|
* Set a session variable
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @param mixed $value
|
|
|
|
*/
|
|
|
|
public function set( $key, $value ) {
|
2015-01-20 09:46:57 +00:00
|
|
|
if ( $value !== $this->get( $key ) ) {
|
|
|
|
$this->_data[ sanitize_key( $key ) ] = maybe_serialize( $value );
|
|
|
|
$this->_dirty = true;
|
|
|
|
}
|
2014-08-31 05:49:58 +00:00
|
|
|
}
|
2013-06-11 14:59:23 +00:00
|
|
|
|
2015-08-11 08:11:36 +00:00
|
|
|
/**
|
|
|
|
* Delete a session variable
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
*/
|
2015-09-16 09:34:03 +00:00
|
|
|
public function unset( $key ) {
|
2015-08-11 08:11:36 +00:00
|
|
|
if ( isset( $this->_data[ $key ] ) ) {
|
|
|
|
unset( $this->_data[ $key ] );
|
|
|
|
$this->_dirty = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-31 05:49:58 +00:00
|
|
|
/**
|
2013-01-27 18:54:37 +00:00
|
|
|
* get_customer_id function.
|
|
|
|
*
|
|
|
|
* @access public
|
2013-11-28 12:54:19 +00:00
|
|
|
* @return int
|
2013-01-27 18:54:37 +00:00
|
|
|
*/
|
|
|
|
public function get_customer_id() {
|
|
|
|
return $this->_customer_id;
|
|
|
|
}
|
2014-08-31 05:49:58 +00:00
|
|
|
}
|