2012-04-30 01:15:06 +08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ZeroBin
|
|
|
|
*
|
|
|
|
* a zero-knowledge paste bin
|
|
|
|
*
|
|
|
|
* @link http://sebsauvage.net/wiki/doku.php?id=php:zerobin
|
|
|
|
* @copyright 2012 Sébastien SAUVAGE (sebsauvage.net)
|
|
|
|
* @license http://www.opensource.org/licenses/zlib-license.php The zlib/libpng License
|
|
|
|
* @version 0.15
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2012-05-01 04:58:08 +08:00
|
|
|
* zerobin_abstract
|
2012-04-30 01:15:06 +08:00
|
|
|
*
|
2012-05-01 04:58:08 +08:00
|
|
|
* Abstract model for ZeroBin data access, implemented as a singleton.
|
2012-04-30 01:15:06 +08:00
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract class zerobin_abstract
|
2012-04-30 01:15:06 +08:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* singleton instance
|
|
|
|
*
|
|
|
|
* @access private
|
|
|
|
* @static
|
|
|
|
* @var zerobin
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
protected static $_instance = null;
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* enforce singleton, disable constructor
|
|
|
|
*
|
|
|
|
* Instantiate using {@link getInstance()}, zerobin is a singleton object.
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
*/
|
|
|
|
protected function __construct() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* enforce singleton, disable cloning
|
|
|
|
*
|
|
|
|
* Instantiate using {@link getInstance()}, zerobin is a singleton object.
|
|
|
|
*
|
|
|
|
* @access private
|
|
|
|
*/
|
|
|
|
private function __clone() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* get instance of singleton
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @static
|
2012-05-20 05:59:41 +08:00
|
|
|
* @return zerobin_abstract
|
2012-04-30 01:15:06 +08:00
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public static function getInstance($options);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a paste.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $pasteid
|
|
|
|
* @param array $paste
|
|
|
|
* @return int|false
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function create($pasteid, $paste);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Read a paste.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $pasteid
|
|
|
|
* @return string
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function read($pasteid);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete a paste and its discussion.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $pasteid
|
|
|
|
* @return void
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function delete($pasteid);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Test if a paste exists.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $dataid
|
|
|
|
* @return void
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function exists($pasteid);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a comment in a paste.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $pasteid
|
|
|
|
* @param string $parentid
|
|
|
|
* @param string $commentid
|
|
|
|
* @param array $comment
|
|
|
|
* @return int|false
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function createComment($pasteid, $parentid, $commentid, $comment);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Read all comments of paste.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $pasteid
|
|
|
|
* @return array
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function readComments($pasteid);
|
2012-04-30 01:15:06 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Test if a comment exists.
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $dataid
|
|
|
|
* @param string $parentid
|
|
|
|
* @param string $commentid
|
|
|
|
* @return void
|
|
|
|
*/
|
2012-05-01 04:58:08 +08:00
|
|
|
abstract public function existsComment($pasteid, $parentid, $commentid);
|
2012-04-30 01:15:06 +08:00
|
|
|
}
|