From e98422a09892675f23852320e0d46b4071bf22b4 Mon Sep 17 00:00:00 2001 From: Alexander Sulfrian Date: Fri, 11 Dec 2009 03:13:01 +0100 Subject: seperated storage classes --- paste/include/storage/FileStorage.php | 71 ++++++++++++++++++++++++ paste/include/storage/MysqlStorage.php | 95 +++++++++++++++++++++++++++++++++ paste/include/storage/StorageEngine.php | 61 +++++++++++++++++++++ 3 files changed, 227 insertions(+) create mode 100644 paste/include/storage/FileStorage.php create mode 100644 paste/include/storage/MysqlStorage.php create mode 100644 paste/include/storage/StorageEngine.php (limited to 'paste/include/storage') diff --git a/paste/include/storage/FileStorage.php b/paste/include/storage/FileStorage.php new file mode 100644 index 0000000..a6ea0f2 --- /dev/null +++ b/paste/include/storage/FileStorage.php @@ -0,0 +1,71 @@ +storage_path = $path; + } + + public function setContent($content) + { + global $config; + + do { + $filename = sha1(date('r') . rand(1000)); + } while (file_exists(realpath($storage_path . '/' , $filename))); + + if ($config['short_results_path']) { + $urlbase = $config['short_results_path']; + } else { + $urlbase = $config['site_domain'] . $config['site_path'] . '/' . $config['results_dir']; + } + $content = $this->prepareContent($filename, $urlbase, $content); + $filename = $filename . ".html"; + + // write content + $outfile = realpath($storage_path . '/' , $filename); + $fp = fopen($outfile, "w"); + fwrite($fp, $content); + fclose($fp); + + return $pasteUrl; + } +} + +?> diff --git a/paste/include/storage/MysqlStorage.php b/paste/include/storage/MysqlStorage.php new file mode 100644 index 0000000..239f113 --- /dev/null +++ b/paste/include/storage/MysqlStorage.php @@ -0,0 +1,95 @@ +mysql = new mysqli($host, $user, $password, $database); + if ($this->mysql->connect_error) { + header('HTTP/1.0 503 Service Unavailable'); + die('MySQL Connect Error (' + . $this->mysql->connect_errno . ') ' + . $this->mysql->connect_error); + } + + $this->table = $table; + if (! $this->mysql->query("CREATE TABLE IF NOT EXISTS $table ( +pid VARCHAR(40) PRIMARY KEY, +content MEDIUMTEXT, +FULLTEXT INDEX (content) +);")) + { + header('HTTP/1.0 503 Service Unavailable'); + die('MySQL Error (' . $this->mysql->errno . ') ' . + $this->mysql->error); + } + } + + function __destruct() + { + if ($this->mysql) + $this->mysql->close(); + } + + public function setContent($content) + { + $name = sha1(date('r') . rand(1000)); + + if ($config['short_results_path']) { + $urlbase = $config['short_results_path']; + } else { + $urlbase = $config['site_domain'] . $config['site_path'] . '/' . $config['results_dir']; + } + $content = $this->prepareContent($name, $urlbase . 'get.php?id=' . $name, $content); + + if ($stmt = $this->mysql->prepare( + 'INSERT INTO ? (pid, content) VALUES (?, ?)')) { + + /* bind parameters for markers */ + $stmt->bind_param("sb", $name, $content); + + /* execute query */ + $stmt->execute(); + + $stmt->close(); + } + } +} + +?> diff --git a/paste/include/storage/StorageEngine.php b/paste/include/storage/StorageEngine.php new file mode 100644 index 0000000..c32a7b6 --- /dev/null +++ b/paste/include/storage/StorageEngine.php @@ -0,0 +1,61 @@ +generateToken(), + $content); + + return $content; + } +} + +?> -- cgit v1.2.3