blob: 344736c24b9fd996e3212ef32d3025bc2f83fc44 [file] [log] [blame]
admin7e75a7e2006-10-04 18:43:24 +00001<?php if (!defined('BASEPATH')) exit('No direct script access allowed');
2/**
3 * Code Igniter
4 *
5 * An open source application development framework for PHP 4.3.2 or newer
6 *
7 * @package CodeIgniter
8 * @author Rick Ellis
9 * @copyright Copyright (c) 2006, pMachine, Inc.
10 * @license http://www.codeignitor.com/user_guide/license.html
11 * @link http://www.codeigniter.com
12 * @since Version 1.0
13 * @filesource
14 */
15
16// ------------------------------------------------------------------------
17
18/**
19 * Database Cache Class
20 *
21 * @category Database
22 * @author Rick Ellis
23 * @link http://www.codeigniter.com/user_guide/database/
24 */
25class CI_DB_Cache {
26
27 var $obj;
28
29 /**
30 * Constructor
31 *
32 * Grabs the CI super object instance so we can access it.
33 *
34 */
35 function CI_DB_Cache()
36 {
37 // Assign the main CI object to $this->obj
38 // and load the file helper since we use it a lot
39 $this->obj =& get_instance();
40 $this->obj->load->helper('file');
41 }
42
43 // --------------------------------------------------------------------
44
45 /**
46 * Set Cache Directory Path
47 *
48 * @access public
49 * @param string the path to the cache directory
50 * @return bool
51 */
52 function check_path($path = '')
53 {
54 if ($path == '')
55 {
56 if ($this->obj->db->cachedir == '')
57 {
58 return $this->obj->db->cache_off();
59 }
60
61 $path = $this->obj->db->cachedir;
62 }
63
64 // Add a trailing slash to the path if needed
65 $path = preg_replace("/(.+?)\/*$/", "\\1/", $path);
66
67 if ( ! is_dir($path) OR ! is_writable($path))
68 {
69 if ($this->obj->db->db_debug)
70 {
71 return $this->obj->db->display_error('db_invalid_cache_path');
72 }
73
74 // If the path is wrong we'll turn off caching
75 return $this->obj->db->cache_off();
76 }
77
78 $this->obj->db->cachedir = $path;
79 return TRUE;
80 }
81
82 // --------------------------------------------------------------------
83
84 /**
85 * Retreive a cached query
86 *
87 * The URI being requested will become the name of the cache sub-folder.
88 * An MD5 hash of the SQL statement will become the cache file name
89 *
90 * @access public
91 * @return string
92 */
93 function read($sql)
94 {
95 if ( ! $this->check_path())
96 {
97 return $this->obj->db->cache_off();
98 }
99
admina0564c02006-10-05 22:18:11 +0000100 $uri = ($this->obj->uri->segment(1) == FALSE) ? 'default_' : $this->obj->uri->segment(1).'_';
101 $uri .= ($this->obj->uri->segment(2) == FALSE) ? 'index' : $this->obj->uri->segment(2);
admin7e75a7e2006-10-04 18:43:24 +0000102
admina0564c02006-10-05 22:18:11 +0000103 $filepath = $uri.'/'.md5($sql);
admin7e75a7e2006-10-04 18:43:24 +0000104
105 if (FALSE === ($cachedata = read_file($this->obj->db->cachedir.$filepath)))
106 {
107 return FALSE;
108 }
109
110 return unserialize($cachedata);
111 }
112
113 // --------------------------------------------------------------------
114
115 /**
116 * Write a query to a cache file
117 *
118 * @access public
119 * @return bool
120 */
121 function write($sql, $object)
122 {
123 if ( ! $this->check_path())
124 {
125 return $this->obj->db->cache_off();
126 }
127
admina0564c02006-10-05 22:18:11 +0000128 $uri = ($this->obj->uri->segment(1) == FALSE) ? 'default_' : $this->obj->uri->segment(1).'_';
129 $uri .= ($this->obj->uri->segment(2) == FALSE) ? 'index' : $this->obj->uri->segment(2);
admin7e75a7e2006-10-04 18:43:24 +0000130
admina0564c02006-10-05 22:18:11 +0000131 $dir_path = $this->obj->db->cachedir.$uri.'/';
admin7e75a7e2006-10-04 18:43:24 +0000132
133 $filename = md5($sql);
134
135 if ( ! @is_dir($dir_path))
136 {
137 if ( ! @mkdir($dir_path, 0777))
138 {
139 return FALSE;
140 }
141
142 @chmod($dir_path, 0777);
143 }
144
145 if (write_file($dir_path.$filename, serialize($object)) === FALSE)
146 {
147 return FALSE;
148 }
149
150 @chmod($dir_path.$filename, 0777);
151 return TRUE;
152 }
153
154 // --------------------------------------------------------------------
155
156 /**
157 * Delete cache files within a particular directory
158 *
159 * @access public
160 * @return bool
161 */
162 function delete()
163 {
164 $uri = ($this->obj->uri->segment(1) == FALSE) ? 'base' : $this->obj->uri->segment(2);
165 $uri .= ($this->obj->uri->segment(2) == FALSE) ? 'index' : $this->obj->uri->segment(2);
166
167 $dir_path = $this->obj->db->cachedir.md5($uri).'/';
168
169 delete_files($dir_path, TRUE);
170 }
171
172 // --------------------------------------------------------------------
173
174 /**
175 * Delete all existing cache files
176 *
177 * @access public
178 * @return bool
179 */
180 function delete_all()
181 {
182 delete_files($this->obj->db->cachedir, TRUE);
183 }
184
185}
186
187?>