Sqlite.php 4.89 KB
Newer Older
1
<?php
lsmith's avatar
lsmith committed
2
/*
zYne's avatar
zYne committed
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
 *  $Id$
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * This software consists of voluntary contributions made by many individuals
 * and is licensed under the LGPL. For more information, see
 * <http://www.phpdoctrine.com>.
 */
zYne's avatar
zYne committed
21
Doctrine::autoload('Doctrine_Connection_Module');
zYne's avatar
zYne committed
22 23 24 25 26 27 28 29 30 31 32
/**
 * Doctrine_Cache_Query_Sqlite
 *
 * @package     Doctrine
 * @license     http://www.opensource.org/licenses/lgpl-license.php LGPL
 * @category    Object Relational Mapping
 * @link        www.phpdoctrine.com
 * @since       1.0
 * @version     $Revision$
 * @author      Konsta Vesterinen <kvesteri@cc.hut.fi>
 */
zYne's avatar
zYne committed
33
class Doctrine_Cache_Query_Sqlite extends Doctrine_Connection_Module implements Countable
lsmith's avatar
lsmith committed
34
{
35 36 37 38 39 40
    /**
     * doctrine cache
     */
    const CACHE_TABLE = 'doctrine_query_cache';
    /**
     * constructor
zYne's avatar
zYne committed
41
     *
zYne's avatar
zYne committed
42
     * @param Doctrine_Connection|null $conn
43
     */
zYne's avatar
zYne committed
44
    public function __construct($conn = null)
lsmith's avatar
lsmith committed
45
    {
zYne's avatar
zYne committed
46 47
        parent::__construct($conn);

zYne's avatar
zYne committed
48
        $dir = 'cache';
49

zYne's avatar
zYne committed
50
        $this->path = $dir . DIRECTORY_SEPARATOR;
51 52

        try {
lsmith's avatar
lsmith committed
53
            if ($this->session->getAttribute(Doctrine::ATTR_CREATE_TABLES) === true) {
54 55
                $columns = array();

zYne's avatar
zYne committed
56 57 58 59 60 61 62 63 64 65 66
                $columns['query_md5']       = array('type'      => 'string',
                                                    'length'    => 32,
                                                    'notnull'   => true);
                $columns['query_result']    = array('type'      => 'array',
                                                    'length'    => 100000,
                                                    'notnull'   => true);
                $columns['expires']         = array('type'      => 'integer',
                                                    'length'    => 11,
                                                    'notnull'   => true);

                $this->conn->createTable(self::CACHE_TABLE, $columns);
67 68 69 70 71 72 73 74 75 76 77 78 79 80
            }
        } catch(PDOException $e) {

        }
    }
    /**
     * store
     * stores a query in cache
     *
     * @param string $query
     * @param array $result
     * @param integer $lifespan
     * @return void
     */
lsmith's avatar
lsmith committed
81 82
    public function store($query, array $result, $lifespan)
    {
zYne's avatar
zYne committed
83
        $sql    = 'INSERT INTO ' . self::CACHE_TABLE . ' (query_md5, query_result, expires) VALUES (?,?,?)';
84
        $params = array(md5($query), serialize($result), (time() + $lifespan));
zYne's avatar
zYne committed
85 86

        $this->conn->execute($sql, $params);
87 88 89 90 91 92 93
    }
    /**
     * fetch
     *
     * @param string $md5
     * @return array
     */
lsmith's avatar
lsmith committed
94 95
    public function fetch($md5)
    {
zYne's avatar
zYne committed
96 97 98
        $sql    = 'SELECT query_result, expires FROM ' . self::CACHE_TABLE . ' WHERE query_md5 = ?';

        $result = $this->conn->fetchAssoc($sql, array($md5));
99 100 101 102 103 104 105 106
        return unserialize($result['query_result']);
    }
    /**
     * deleteAll
     * returns the number of deleted rows
     *
     * @return integer
     */
lsmith's avatar
lsmith committed
107 108
    public function deleteAll()
    {
zYne's avatar
zYne committed
109 110
        $sql    = 'DELETE FROM '.self::CACHE_TABLE;
        return $this->conn->exec($sql);
111
    }
zYne's avatar
zYne committed
112 113 114 115 116 117
    /**
     * deleteExpired
     * returns the number of deleted rows
     *
     * @return integer
     */
lsmith's avatar
lsmith committed
118 119
    public function deleteExpired()
    {
zYne's avatar
zYne committed
120
        $sql    = 'DELETE FROM ' . self::CACHE_TABLE . ' WHERE expired < ?';
zYne's avatar
zYne committed
121
        $stmt   = $this->dbh->prepare($sql);
zYne's avatar
zYne committed
122

zYne's avatar
zYne committed
123 124
        $stmt->execute(array(time()));
    }
125 126
    /**
     * delete
lsmith's avatar
lsmith committed
127
     * returns whether or not the given
128 129 130
     * query was succesfully deleted
     *
     * @param string $md5
zYne's avatar
zYne committed
131
     * @return boolean          whether or not the row was successfully deleted
132
     */
lsmith's avatar
lsmith committed
133 134
    public function delete($md5)
    {
zYne's avatar
zYne committed
135 136 137
        $sql    = 'DELETE FROM ' . self::CACHE_TABLE . ' WHERE query_md5 = ?';

        return (bool) $this->conn->exec($sql, array($md5));
138 139 140 141 142 143
    }
    /**
     * count
     *
     * @return integer
     */
lsmith's avatar
lsmith committed
144 145
    public function count()
    {
zYne's avatar
zYne committed
146
        $stmt = $this->dbh->query('SELECT COUNT(*) FROM ' . self::CACHE_TABLE);
147 148 149 150 151 152
        $data = $stmt->fetch(PDO::FETCH_NUM);

        // table has three columns so we have to divide the count by two
        return $data[0];
    }
}