2015-09-26 21:03:55 -04:00
|
|
|
<?php
|
|
|
|
/**
|
2016-07-11 05:58:15 -04:00
|
|
|
* PrivateBin
|
2015-09-26 21:03:55 -04:00
|
|
|
*
|
|
|
|
* a zero-knowledge paste bin
|
|
|
|
*
|
2016-07-11 05:58:15 -04:00
|
|
|
* @link https://github.com/PrivateBin/PrivateBin
|
2015-09-26 21:03:55 -04:00
|
|
|
* @copyright 2012 Sébastien SAUVAGE (sebsauvage.net)
|
2016-07-19 07:56:52 -04:00
|
|
|
* @license https://www.opensource.org/licenses/zlib-license.php The zlib/libpng License
|
2018-08-11 13:29:58 -04:00
|
|
|
* @version 1.2.1
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
2016-12-12 12:43:23 -05:00
|
|
|
|
2016-12-12 12:49:08 -05:00
|
|
|
namespace PrivateBin\Model;
|
2016-07-21 11:09:48 -04:00
|
|
|
|
2016-10-29 04:24:08 -04:00
|
|
|
use Exception;
|
2016-08-09 05:54:42 -04:00
|
|
|
use PrivateBin\Configuration;
|
|
|
|
use PrivateBin\Data\AbstractData;
|
2016-07-21 11:09:48 -04:00
|
|
|
|
2015-09-26 21:03:55 -04:00
|
|
|
/**
|
2016-08-09 05:54:42 -04:00
|
|
|
* AbstractModel
|
2015-09-26 21:03:55 -04:00
|
|
|
*
|
2016-07-11 05:58:15 -04:00
|
|
|
* Abstract model for PrivateBin objects.
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
2016-07-21 11:09:48 -04:00
|
|
|
abstract class AbstractModel
|
2015-09-26 21:03:55 -04:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Instance ID.
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $_id = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instance data.
|
|
|
|
*
|
|
|
|
* @access protected
|
2019-05-06 16:15:21 -04:00
|
|
|
* @var array
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
2019-05-06 16:15:21 -04:00
|
|
|
protected $_data = array('meta' => array());
|
2015-09-26 21:03:55 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Configuration.
|
|
|
|
*
|
|
|
|
* @access protected
|
2016-08-09 06:21:32 -04:00
|
|
|
* @var Configuration
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
|
|
|
protected $_conf;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Data storage.
|
|
|
|
*
|
|
|
|
* @access protected
|
2016-08-09 06:21:32 -04:00
|
|
|
* @var AbstractData
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
|
|
|
protected $_store;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instance constructor.
|
|
|
|
*
|
|
|
|
* @access public
|
2016-08-09 06:21:32 -04:00
|
|
|
* @param Configuration $configuration
|
|
|
|
* @param AbstractData $storage
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
2016-08-09 06:21:32 -04:00
|
|
|
public function __construct(Configuration $configuration, AbstractData $storage)
|
2015-09-26 21:03:55 -04:00
|
|
|
{
|
2016-08-15 10:45:47 -04:00
|
|
|
$this->_conf = $configuration;
|
|
|
|
$this->_store = $storage;
|
2015-09-26 21:03:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get ID.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
return $this->_id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set ID.
|
|
|
|
*
|
|
|
|
* @access public
|
2015-11-09 15:39:42 -05:00
|
|
|
* @param string $id
|
2015-09-26 21:03:55 -04:00
|
|
|
* @throws Exception
|
|
|
|
*/
|
2019-05-10 16:13:11 -04:00
|
|
|
public function setId($id)
|
2015-09-26 21:03:55 -04:00
|
|
|
{
|
2016-07-26 02:19:35 -04:00
|
|
|
if (!self::isValidId($id)) {
|
|
|
|
throw new Exception('Invalid paste ID.', 60);
|
|
|
|
}
|
2015-09-26 21:03:55 -04:00
|
|
|
$this->_id = $id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set data and recalculate ID.
|
|
|
|
*
|
|
|
|
* @access public
|
2019-05-06 16:15:21 -04:00
|
|
|
* @param array $data
|
2015-09-26 21:03:55 -04:00
|
|
|
* @throws Exception
|
|
|
|
*/
|
2019-05-06 16:15:21 -04:00
|
|
|
public function setData(array $data)
|
2015-09-26 21:03:55 -04:00
|
|
|
{
|
2019-05-06 16:15:21 -04:00
|
|
|
$data = $this->_sanitize($data);
|
|
|
|
$this->_validate($data);
|
|
|
|
$this->_data = $data;
|
2015-09-26 21:03:55 -04:00
|
|
|
|
2019-05-03 17:03:57 -04:00
|
|
|
// calculate a 64 bit checksum to avoid collisions
|
2019-05-10 17:09:35 -04:00
|
|
|
$this->setId(hash(version_compare(PHP_VERSION, '5.5', '>') ? 'fnv1a64' : 'fnv164', $data['ct']));
|
2015-09-26 21:03:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get instance data.
|
|
|
|
*
|
|
|
|
* @access public
|
2019-05-06 16:15:21 -04:00
|
|
|
* @return array
|
2015-09-26 21:03:55 -04:00
|
|
|
*/
|
2019-05-06 16:15:21 -04:00
|
|
|
public function get()
|
|
|
|
{
|
|
|
|
return $this->_data;
|
|
|
|
}
|
2015-09-26 21:03:55 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Store the instance's data.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
abstract public function store();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete the current instance.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
abstract public function delete();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test if current instance exists in store.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
abstract public function exists();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Validate ID.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @static
|
|
|
|
* @param string $id
|
|
|
|
* @return bool
|
|
|
|
*/
|
2019-05-10 16:13:11 -04:00
|
|
|
public static function isValidId($id)
|
2015-09-26 21:03:55 -04:00
|
|
|
{
|
|
|
|
return (bool) preg_match('#\A[a-f\d]{16}\z#', (string) $id);
|
|
|
|
}
|
2019-05-06 16:15:21 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sanitizes data to conform with current configuration.
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @param array $data
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
abstract protected function _sanitize(array $data);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Validate data.
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @param array $data
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
protected function _validate(array $data)
|
|
|
|
{
|
|
|
|
}
|
2015-09-26 21:03:55 -04:00
|
|
|
}
|