]> git.mxchange.org Git - friendica.git/blob - library/Smarty/demo/plugins/resource.mysqls.php
Revert unneeded changes in third-party libraries
[friendica.git] / library / Smarty / demo / plugins / resource.mysqls.php
1 <?php
2
3 /**
4  * MySQL Resource
5  * Resource Implementation based on the Custom API to use
6  * MySQL as the storage resource for Smarty's templates and configs.
7  * Note that this MySQL implementation fetches the source and timestamps in
8  * a single database query, instead of two separate like resource.mysql.php does.
9  * Table definition:
10  * <pre>CREATE TABLE IF NOT EXISTS `templates` (
11  *   `name` varchar(100) NOT NULL,
12  *   `modified` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
13  *   `source` text,
14  *   PRIMARY KEY (`name`)
15  * ) ENGINE=InnoDB DEFAULT CHARSET=utf8;</pre>
16  * Demo data:
17  * <pre>INSERT INTO `templates` (`name`, `modified`, `source`) VALUES ('test.tpl', "2010-12-25 22:00:00", '{$x="hello world"}{$x}');</pre>
18  *
19  * @package Resource-examples
20  * @author  Rodney Rehm
21  */
22 class Smarty_Resource_Mysqls extends Smarty_Resource_Custom
23 {
24     // PDO instance
25     protected $db;
26     // prepared fetch() statement
27     protected $fetch;
28
29     public function __construct()
30     {
31         try {
32             $this->db = new PDO("mysql:dbname=test;host=127.0.0.1", "smarty");
33         }
34         catch (PDOException $e) {
35             throw new SmartyException('Mysql Resource failed: ' . $e->getMessage());
36         }
37         $this->fetch = $this->db->prepare('SELECT modified, source FROM templates WHERE name = :name');
38     }
39
40     /**
41      * Fetch a template and its modification time from database
42      *
43      * @param  string  $name   template name
44      * @param  string  $source template source
45      * @param  integer $mtime  template modification timestamp (epoch)
46      *
47      * @return void
48      */
49     protected function fetch($name, &$source, &$mtime)
50     {
51         $this->fetch->execute(array('name' => $name));
52         $row = $this->fetch->fetch();
53         $this->fetch->closeCursor();
54         if ($row) {
55             $source = $row['source'];
56             $mtime = strtotime($row['modified']);
57         } else {
58             $source = null;
59             $mtime = null;
60         }
61     }
62 }