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