blob: f13e4479ffe565d16cd2cc1b734779ef71293d5c [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Anton Lindqvist1e8be292012-01-21 12:25:08 +01002/**
3 * CodeIgniter
4 *
Anton Lindqvist5ccf5ce2012-06-08 11:47:17 +02005 * An open source application development framework for PHP 5.2.4 or newer
Anton Lindqvist1e8be292012-01-21 12:25:08 +01006 *
Anton Lindqvist5a1d9532012-01-23 23:20:26 +01007 * NOTICE OF LICENSE
8 *
9 * Licensed under the Open Software License version 3.0
10 *
11 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
19 * @package CodeIgniter
20 * @author EllisLab Dev Team
Andrey Andreev80500af2013-01-01 08:16:53 +020021 * @copyright Copyright (c) 2008 - 2013, EllisLab, Inc. (http://ellislab.com/)
Anton Lindqvist5a1d9532012-01-23 23:20:26 +010022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
23 * @link http://codeigniter.com
Andrey Andreev9e674f72012-06-09 21:02:52 +030024 * @since Version 3.0
Anton Lindqvist1e8be292012-01-21 12:25:08 +010025 * @filesource
26 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020027defined('BASEPATH') OR exit('No direct script access allowed');
Anton Lindqvist1e8be292012-01-21 12:25:08 +010028
Anton Lindqvist1e8be292012-01-21 12:25:08 +010029/**
30 * CodeIgniter Redis Caching Class
31 *
32 * @package CodeIgniter
33 * @subpackage Libraries
34 * @category Core
35 * @author Anton Lindqvist <anton@qvister.se>
36 * @link
37 */
38class CI_Cache_redis extends CI_Driver
39{
Anton Lindqvist1e8be292012-01-21 12:25:08 +010040 /**
41 * Default config
42 *
Anton Lindqvist1e8be292012-01-21 12:25:08 +010043 * @static
Andrey Andreev9e674f72012-06-09 21:02:52 +030044 * @var array
Anton Lindqvist1e8be292012-01-21 12:25:08 +010045 */
Anton Lindqvist3573af82012-01-21 20:33:12 +010046 protected static $_default_config = array(
Kakysha80d663a2013-10-28 01:39:17 +040047 'socket_type' => 'tcp',
Anton Lindqvist1e8be292012-01-21 12:25:08 +010048 'host' => '127.0.0.1',
Anton Lindqvist5ccf5ce2012-06-08 11:47:17 +020049 'password' => NULL,
Anton Lindqvist1e8be292012-01-21 12:25:08 +010050 'port' => 6379,
51 'timeout' => 0
52 );
53
54 /**
55 * Redis connection
56 *
Andrey Andreev9e674f72012-06-09 21:02:52 +030057 * @var Redis
Anton Lindqvist1e8be292012-01-21 12:25:08 +010058 */
Anton Lindqvist3573af82012-01-21 20:33:12 +010059 protected $_redis;
Anton Lindqvist1e8be292012-01-21 12:25:08 +010060
Andrey Andreev9e674f72012-06-09 21:02:52 +030061 // ------------------------------------------------------------------------
Anton Lindqvist1e8be292012-01-21 12:25:08 +010062
63 /**
64 * Get cache
65 *
Andrey Andreev9e674f72012-06-09 21:02:52 +030066 * @param string Cache key identifier
67 * @return mixed
Anton Lindqvist1e8be292012-01-21 12:25:08 +010068 */
69 public function get($key)
70 {
71 return $this->_redis->get($key);
72 }
73
Andrey Andreev9e674f72012-06-09 21:02:52 +030074 // ------------------------------------------------------------------------
75
Anton Lindqvist1e8be292012-01-21 12:25:08 +010076 /**
77 * Save cache
78 *
Andrey Andreev9e674f72012-06-09 21:02:52 +030079 * @param string Cache key identifier
80 * @param mixed Data to save
81 * @param int Time to live
82 * @return bool
Anton Lindqvist1e8be292012-01-21 12:25:08 +010083 */
84 public function save($key, $value, $ttl = NULL)
85 {
86 return ($ttl)
87 ? $this->_redis->setex($key, $ttl, $value)
88 : $this->_redis->set($key, $value);
89 }
90
Andrey Andreev9e674f72012-06-09 21:02:52 +030091 // ------------------------------------------------------------------------
92
Anton Lindqvist1e8be292012-01-21 12:25:08 +010093 /**
94 * Delete from cache
95 *
Andrey Andreev9e674f72012-06-09 21:02:52 +030096 * @param string Cache key
97 * @return bool
Anton Lindqvist1e8be292012-01-21 12:25:08 +010098 */
99 public function delete($key)
100 {
101 return ($this->_redis->delete($key) === 1);
102 }
103
Andrey Andreev9e674f72012-06-09 21:02:52 +0300104 // ------------------------------------------------------------------------
105
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100106 /**
107 * Clean cache
108 *
Andrey Andreev9e674f72012-06-09 21:02:52 +0300109 * @return bool
110 * @see Redis::flushDB()
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100111 */
112 public function clean()
113 {
114 return $this->_redis->flushDB();
115 }
116
Andrey Andreev9e674f72012-06-09 21:02:52 +0300117 // ------------------------------------------------------------------------
118
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100119 /**
120 * Get cache driver info
121 *
Andrey Andreev9e674f72012-06-09 21:02:52 +0300122 * @param string Not supported in Redis.
123 * Only included in order to offer a
124 * consistent cache API.
125 * @return array
126 * @see Redis::info()
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100127 */
128 public function cache_info($type = NULL)
129 {
130 return $this->_redis->info();
131 }
132
Andrey Andreev9e674f72012-06-09 21:02:52 +0300133 // ------------------------------------------------------------------------
134
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100135 /**
136 * Get cache metadata
137 *
Andrey Andreev9e674f72012-06-09 21:02:52 +0300138 * @param string Cache key
139 * @return array
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100140 */
141 public function get_metadata($key)
142 {
143 $value = $this->get($key);
144
145 if ($value)
Andrey Andreev9e674f72012-06-09 21:02:52 +0300146 {
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100147 return array(
148 'expire' => time() + $this->_redis->ttl($key),
149 'data' => $value
150 );
151 }
Andrey Andreev9e674f72012-06-09 21:02:52 +0300152
153 return FALSE;
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100154 }
155
Andrey Andreev9e674f72012-06-09 21:02:52 +0300156 // ------------------------------------------------------------------------
157
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100158 /**
159 * Check if Redis driver is supported
160 *
Andrey Andreev9e674f72012-06-09 21:02:52 +0300161 * @return bool
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100162 */
163 public function is_supported()
164 {
165 if (extension_loaded('redis'))
Andrey Andreev9e674f72012-06-09 21:02:52 +0300166 {
Kakysha2d146732013-10-28 20:20:24 +0400167 return $this->_setup_redis();
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100168 }
169 else
170 {
Tyler Brownelld967f722013-07-29 19:06:52 -0400171 log_message('debug', 'The Redis extension must be loaded to use Redis cache.');
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100172 return FALSE;
173 }
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100174 }
175
Andrey Andreev9e674f72012-06-09 21:02:52 +0300176 // ------------------------------------------------------------------------
177
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100178 /**
179 * Setup Redis config and connection
180 *
Andrey Andreev9e674f72012-06-09 21:02:52 +0300181 * Loads Redis config file if present. Will halt execution
182 * if a Redis connection can't be established.
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100183 *
Andrey Andreev9e674f72012-06-09 21:02:52 +0300184 * @return bool
185 * @see Redis::connect()
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100186 */
Anton Lindqvist5ccf5ce2012-06-08 11:47:17 +0200187 protected function _setup_redis()
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100188 {
189 $config = array();
190 $CI =& get_instance();
191
192 if ($CI->config->load('redis', TRUE, TRUE))
Anton Lindqvist5ccf5ce2012-06-08 11:47:17 +0200193 {
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100194 $config += $CI->config->item('redis');
195 }
196
197 $config = array_merge(self::$_default_config, $config);
198
199 $this->_redis = new Redis();
200
201 try
202 {
Kakysha80d663a2013-10-28 01:39:17 +0400203 if ($config['socket_type'] === 'unix')
204 {
Kakyshaffe21302013-10-28 21:30:05 +0400205 $success = $this->_redis->connect($config['socket']);
Kakysha8f3f1f92013-10-28 23:14:08 +0400206 }
207 else // tcp socket
Kakysha80d663a2013-10-28 01:39:17 +0400208 {
Kakyshaffe21302013-10-28 21:30:05 +0400209 $success = $this->_redis->connect($config['host'], $config['port'], $config['timeout']);
Kakysha2d146732013-10-28 20:20:24 +0400210 }
Kakysha8f3f1f92013-10-28 23:14:08 +0400211
Kakyshaffe21302013-10-28 21:30:05 +0400212 if ( ! $success)
Kakysha2d146732013-10-28 20:20:24 +0400213 {
Kakysha333b69b2013-10-29 03:49:56 +0400214 log_message('debug', 'Cache: Redis connection refused. Check the config.');
Kakysha2d146732013-10-28 20:20:24 +0400215 return FALSE;
Kakysha80d663a2013-10-28 01:39:17 +0400216 }
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100217 }
218 catch (RedisException $e)
219 {
Kakysha333b69b2013-10-29 03:49:56 +0400220 log_message('debug', 'Cache: Redis connection refused ('.$e->getMessage().')');
Kakysha2d146732013-10-28 20:20:24 +0400221 return FALSE;
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100222 }
Anton Lindqvist210e6642012-04-23 10:13:46 +0200223
Anton Lindqvist5ccf5ce2012-06-08 11:47:17 +0200224 if (isset($config['password']))
225 {
Anton Lindqvist210e6642012-04-23 10:13:46 +0200226 $this->_redis->auth($config['password']);
227 }
Kakysha2d146732013-10-28 20:20:24 +0400228
229 return TRUE;
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100230 }
231
Andrey Andreev9e674f72012-06-09 21:02:52 +0300232 // ------------------------------------------------------------------------
233
234 /**
235
236 * Class destructor
237 *
238 * Closes the connection to Redis if present.
239 *
240 * @return void
241 */
242 public function __destruct()
243 {
244 if ($this->_redis)
245 {
246 $this->_redis->close();
247 }
248 }
249
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100250}
Anton Lindqvist1e8be292012-01-21 12:25:08 +0100251
252/* End of file Cache_redis.php */
253/* Location: ./system/libraries/Cache/drivers/Cache_redis.php */