blob: 18380a0db7cd0acd4909c2fffea1edb1b0b88f0b [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Andrey Andreevccabcfd2012-01-07 19:30:47 +02008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Andrey Andreevccabcfd2012-01-07 19:30:47 +020010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * 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 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
darwinel871754a2014-02-11 17:34:57 +010021 * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020027defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000028
Derek Allard2067d1a2008-11-13 22:59:24 +000029/**
Andrey Andreev5232ba02012-10-27 15:25:05 +030030 * Config Class
Derek Allard2067d1a2008-11-13 22:59:24 +000031 *
32 * This class contains functions that enable config files to be managed
33 *
34 * @package CodeIgniter
35 * @subpackage Libraries
36 * @category Libraries
Derek Jonesf4a4bd82011-10-20 12:18:42 -050037 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000038 * @link http://codeigniter.com/user_guide/libraries/config.html
39 */
40class CI_Config {
41
David Behler2d2c9c62011-08-14 20:03:08 +020042 /**
43 * List of all loaded config values
44 *
Andrey Andreev5232ba02012-10-27 15:25:05 +030045 * @var array
David Behler2d2c9c62011-08-14 20:03:08 +020046 */
Eric Robertsaa141a52012-07-04 02:13:56 -050047 public $config = array();
Andrey Andreev92ebfb62012-05-17 12:49:24 +030048
David Behler2d2c9c62011-08-14 20:03:08 +020049 /**
50 * List of all loaded config files
51 *
Andrey Andreev5232ba02012-10-27 15:25:05 +030052 * @var array
David Behler2d2c9c62011-08-14 20:03:08 +020053 */
Timothy Warren48a7fbb2012-04-23 11:58:16 -040054 public $is_loaded = array();
Andrey Andreev92ebfb62012-05-17 12:49:24 +030055
David Behler2d2c9c62011-08-14 20:03:08 +020056 /**
Andrey Andreevccabcfd2012-01-07 19:30:47 +020057 * List of paths to search when trying to load a config file.
David Behler2d2c9c62011-08-14 20:03:08 +020058 *
Andrey Andreev1887ec62012-10-27 16:22:07 +030059 * @used-by CI_Loader
Andrey Andreev5232ba02012-10-27 15:25:05 +030060 * @var array
David Behler2d2c9c62011-08-14 20:03:08 +020061 */
Timothy Warren48a7fbb2012-04-23 11:58:16 -040062 public $_config_paths = array(APPPATH);
Derek Allard2067d1a2008-11-13 22:59:24 +000063
64 /**
Andrey Andreev5232ba02012-10-27 15:25:05 +030065 * Class constructor
Derek Allard2067d1a2008-11-13 22:59:24 +000066 *
Andrey Andreev5232ba02012-10-27 15:25:05 +030067 * Sets the $config data from the primary config.php file as a class variable.
68 *
69 * @return void
Derek Allard2067d1a2008-11-13 22:59:24 +000070 */
Andrey Andreevccabcfd2012-01-07 19:30:47 +020071 public function __construct()
Derek Allard2067d1a2008-11-13 22:59:24 +000072 {
Barry Mienydd671972010-10-04 16:33:58 +020073 $this->config =& get_config();
Andrey Andreevd52b2422012-01-07 21:28:32 +020074 log_message('debug', 'Config Class Initialized');
Phil Sturgeon4df8b222010-12-15 14:23:14 +000075
76 // Set the base_url automatically if none was provided
Taufan Aditya8749bc72012-03-11 05:43:45 +070077 if (empty($this->config['base_url']))
Phil Sturgeon4df8b222010-12-15 14:23:14 +000078 {
vlakoff7ead65b2014-04-01 02:09:25 +020079 if (isset($_SERVER['HTTP_HOST']))
80 {
Andrey Andreev4bdb6672014-10-08 00:29:26 +030081 $base_url = (is_https() ? 'https' : 'http').'://'.$_SERVER['HTTP_HOST'].'/';
82 if ( ! empty($_SERVER['DOCUMENT_ROOT']))
83 {
84 $base_url .= ltrim(str_replace('\\', '/', substr(FCPATH, strlen($_SERVER['DOCUMENT_ROOT']))), '/\\');
85 }
vlakoff7ead65b2014-04-01 02:09:25 +020086 }
87 else
88 {
89 $base_url = 'http://localhost/';
90 }
Phil Sturgeon4df8b222010-12-15 14:23:14 +000091
92 $this->set_item('base_url', $base_url);
93 }
Derek Allard2067d1a2008-11-13 22:59:24 +000094 }
Barry Mienydd671972010-10-04 16:33:58 +020095
Derek Allard2067d1a2008-11-13 22:59:24 +000096 // --------------------------------------------------------------------
97
98 /**
99 * Load Config File
100 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300101 * @param string $file Configuration file name
102 * @param bool $use_sections Whether configuration values should be loaded into their own section
103 * @param bool $fail_gracefully Whether to just return FALSE or display an error message
104 * @return bool TRUE if the file was loaded correctly or FALSE on failure
Barry Mienydd671972010-10-04 16:33:58 +0200105 */
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200106 public function load($file = '', $use_sections = FALSE, $fail_gracefully = FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000107 {
Alex Bilbieed944a32012-06-02 11:07:47 +0100108 $file = ($file === '') ? 'config' : str_replace('.php', '', $file);
Fu Xub3355192014-06-12 16:45:00 +0800109 $loaded = FALSE;
Andrey Andreev9438e262012-10-05 13:16:27 +0300110
Pascal Kriete5d5895f2011-02-14 13:27:07 -0500111 foreach ($this->_config_paths as $path)
Phil Sturgeon05fa6112011-04-06 22:57:43 +0100112 {
Fu Xu66b181e2014-06-12 16:49:11 +0800113 $found = FALSE;
Andrey Andreevdb529ca2013-01-28 11:00:02 +0200114 foreach (array(ENVIRONMENT.'/'.$file, $file) as $location)
Derek Jones6d743e22010-03-02 13:22:03 -0600115 {
Andrey Andreevd52b2422012-01-07 21:28:32 +0200116 $file_path = $path.'config/'.$location.'.php';
Phil Sturgeon05fa6112011-04-06 22:57:43 +0100117
118 if (in_array($file_path, $this->is_loaded, TRUE))
119 {
120 $loaded = TRUE;
121 continue 2;
122 }
123
124 if (file_exists($file_path))
125 {
126 $found = TRUE;
127 break;
128 }
129 }
130
131 if ($found === FALSE)
132 {
Derek Jones6d743e22010-03-02 13:22:03 -0600133 continue;
134 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000135
Derek Jones6d743e22010-03-02 13:22:03 -0600136 include($file_path);
137
138 if ( ! isset($config) OR ! is_array($config))
139 {
140 if ($fail_gracefully === TRUE)
141 {
142 return FALSE;
143 }
144 show_error('Your '.$file_path.' file does not appear to contain a valid configuration array.');
145 }
Barry Mienydd671972010-10-04 16:33:58 +0200146
Derek Jones6d743e22010-03-02 13:22:03 -0600147 if ($use_sections === TRUE)
148 {
149 if (isset($this->config[$file]))
150 {
151 $this->config[$file] = array_merge($this->config[$file], $config);
152 }
153 else
154 {
155 $this->config[$file] = $config;
156 }
157 }
158 else
159 {
160 $this->config = array_merge($this->config, $config);
161 }
Barry Mienydd671972010-10-04 16:33:58 +0200162
Derek Jones6d743e22010-03-02 13:22:03 -0600163 $this->is_loaded[] = $file_path;
164 unset($config);
Barry Mienydd671972010-10-04 16:33:58 +0200165
Derek Jones6d743e22010-03-02 13:22:03 -0600166 $loaded = TRUE;
167 log_message('debug', 'Config file loaded: '.$file_path);
katzgraud127e612011-04-22 10:59:25 -0400168 break;
Derek Jones6d743e22010-03-02 13:22:03 -0600169 }
Barry Mienydd671972010-10-04 16:33:58 +0200170
Derek Jones6d743e22010-03-02 13:22:03 -0600171 if ($loaded === FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000172 {
173 if ($fail_gracefully === TRUE)
174 {
175 return FALSE;
176 }
Eric Robertsaa141a52012-07-04 02:13:56 -0500177 show_error('The configuration file '.$file.'.php does not exist.');
Derek Allard2067d1a2008-11-13 22:59:24 +0000178 }
Phil Sturgeon05fa6112011-04-06 22:57:43 +0100179
Derek Allard2067d1a2008-11-13 22:59:24 +0000180 return TRUE;
181 }
Barry Mienydd671972010-10-04 16:33:58 +0200182
Derek Allard2067d1a2008-11-13 22:59:24 +0000183 // --------------------------------------------------------------------
184
185 /**
186 * Fetch a config file item
187 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300188 * @param string $item Config item name
189 * @param string $index Index name
vlakoff90f316a2013-07-25 04:33:56 +0200190 * @return string|null The configuration item or NULL if the item doesn't exist
Derek Allard2067d1a2008-11-13 22:59:24 +0000191 */
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200192 public function item($item, $index = '')
Barry Mienydd671972010-10-04 16:33:58 +0200193 {
Andrey Andreev9ba661b2012-06-04 14:44:34 +0300194 if ($index == '')
Barry Mienydd671972010-10-04 16:33:58 +0200195 {
vlakoff184cf1b2013-07-24 03:43:39 +0200196 return isset($this->config[$item]) ? $this->config[$item] : NULL;
Derek Allard2067d1a2008-11-13 22:59:24 +0000197 }
198
vlakoff184cf1b2013-07-24 03:43:39 +0200199 return isset($this->config[$index], $this->config[$index][$item]) ? $this->config[$index][$item] : NULL;
Derek Allard2067d1a2008-11-13 22:59:24 +0000200 }
Barry Mienydd671972010-10-04 16:33:58 +0200201
202 // --------------------------------------------------------------------
Derek Allard2067d1a2008-11-13 22:59:24 +0000203
204 /**
Andrey Andreev5232ba02012-10-27 15:25:05 +0300205 * Fetch a config file item with slash appended (if not empty)
Derek Allard2067d1a2008-11-13 22:59:24 +0000206 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300207 * @param string $item Config item name
vlakoffc1044cb2013-07-25 12:18:43 +0200208 * @return string|null The configuration item or NULL if the item doesn't exist
Derek Allard2067d1a2008-11-13 22:59:24 +0000209 */
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200210 public function slash_item($item)
Derek Allard2067d1a2008-11-13 22:59:24 +0000211 {
212 if ( ! isset($this->config[$item]))
213 {
vlakoffc1044cb2013-07-25 12:18:43 +0200214 return NULL;
Derek Allard2067d1a2008-11-13 22:59:24 +0000215 }
Alex Bilbieed944a32012-06-02 11:07:47 +0100216 elseif (trim($this->config[$item]) === '')
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800217 {
218 return '';
219 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000220
Phil Sturgeon4df8b222010-12-15 14:23:14 +0000221 return rtrim($this->config[$item], '/').'/';
Derek Allard2067d1a2008-11-13 22:59:24 +0000222 }
Barry Mienydd671972010-10-04 16:33:58 +0200223
Derek Allard2067d1a2008-11-13 22:59:24 +0000224 // --------------------------------------------------------------------
225
226 /**
227 * Site URL
Andrey Andreev5232ba02012-10-27 15:25:05 +0300228 *
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800229 * Returns base_url . index_page [. uri_string]
Derek Allard2067d1a2008-11-13 22:59:24 +0000230 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300231 * @uses CI_Config::_uri_string()
232 *
233 * @param string|string[] $uri URI string or an array of segments
vlakoff4c07fce2013-10-25 01:20:32 +0200234 * @param string $protocol
Derek Allard2067d1a2008-11-13 22:59:24 +0000235 * @return string
236 */
vlakoff4c07fce2013-10-25 01:20:32 +0200237 public function site_url($uri = '', $protocol = NULL)
Derek Allard2067d1a2008-11-13 22:59:24 +0000238 {
vlakoff4c07fce2013-10-25 01:20:32 +0200239 $base_url = $this->slash_item('base_url');
240
241 if (isset($protocol))
242 {
243 $base_url = $protocol.substr($base_url, strpos($base_url, '://'));
244 }
245
Andrey Andreev1764dd72012-06-16 18:48:19 +0300246 if (empty($uri))
Derek Allard2067d1a2008-11-13 22:59:24 +0000247 {
vlakoff4c07fce2013-10-25 01:20:32 +0200248 return $base_url.$this->item('index_page');
Derek Jones6d743e22010-03-02 13:22:03 -0600249 }
250
Andrey Andreev95d78cf2012-06-16 19:54:33 +0300251 $uri = $this->_uri_string($uri);
252
Alex Bilbieed944a32012-06-02 11:07:47 +0100253 if ($this->item('enable_query_strings') === FALSE)
Derek Jones6d743e22010-03-02 13:22:03 -0600254 {
vlakoff4d9fd192012-12-03 11:31:00 +0100255 $suffix = isset($this->config['url_suffix']) ? $this->config['url_suffix'] : '';
Andrey Andreev95d78cf2012-06-16 19:54:33 +0300256
vlakoff66cb4132012-12-03 10:43:44 +0100257 if ($suffix !== '')
Andrey Andreev95d78cf2012-06-16 19:54:33 +0300258 {
vlakoff66cb4132012-12-03 10:43:44 +0100259 if (($offset = strpos($uri, '?')) !== FALSE)
260 {
261 $uri = substr($uri, 0, $offset).$suffix.substr($uri, $offset);
262 }
263 else
264 {
265 $uri .= $suffix;
266 }
Andrey Andreev95d78cf2012-06-16 19:54:33 +0300267 }
268
vlakoff4c07fce2013-10-25 01:20:32 +0200269 return $base_url.$this->slash_item('index_page').$uri;
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800270 }
Andrey Andreev95d78cf2012-06-16 19:54:33 +0300271 elseif (strpos($uri, '?') === FALSE)
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800272 {
Andrey Andreev95d78cf2012-06-16 19:54:33 +0300273 $uri = '?'.$uri;
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800274 }
Andrey Andreev1764dd72012-06-16 18:48:19 +0300275
vlakoff4c07fce2013-10-25 01:20:32 +0200276 return $base_url.$this->item('index_page').$uri;
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800277 }
David Behler2d2c9c62011-08-14 20:03:08 +0200278
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800279 // -------------------------------------------------------------
David Behler2d2c9c62011-08-14 20:03:08 +0200280
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800281 /**
282 * Base URL
Andrey Andreev5232ba02012-10-27 15:25:05 +0300283 *
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800284 * Returns base_url [. uri_string]
David Behler2d2c9c62011-08-14 20:03:08 +0200285 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300286 * @uses CI_Config::_uri_string()
287 *
288 * @param string|string[] $uri URI string or an array of segments
vlakoff4c07fce2013-10-25 01:20:32 +0200289 * @param string $protocol
Andrey Andreev92ebfb62012-05-17 12:49:24 +0300290 * @return string
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800291 */
vlakoff4c07fce2013-10-25 01:20:32 +0200292 public function base_url($uri = '', $protocol = NULL)
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800293 {
vlakoff4c07fce2013-10-25 01:20:32 +0200294 $base_url = $this->slash_item('base_url');
295
296 if (isset($protocol))
297 {
298 $base_url = $protocol.substr($base_url, strpos($base_url, '://'));
299 }
300
301 return $base_url.ltrim($this->_uri_string($uri), '/');
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800302 }
David Behler2d2c9c62011-08-14 20:03:08 +0200303
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800304 // -------------------------------------------------------------
David Behler2d2c9c62011-08-14 20:03:08 +0200305
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800306 /**
Andrey Andreev5232ba02012-10-27 15:25:05 +0300307 * Build URI string
David Behler2d2c9c62011-08-14 20:03:08 +0200308 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300309 * @used-by CI_Config::site_url()
310 * @used-by CI_Config::base_url()
311 *
312 * @param string|string[] $uri URI string or an array of segments
Andrey Andreev92ebfb62012-05-17 12:49:24 +0300313 * @return string
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800314 */
315 protected function _uri_string($uri)
316 {
Alex Bilbieed944a32012-06-02 11:07:47 +0100317 if ($this->item('enable_query_strings') === FALSE)
anaxamaxan@blackdog.locald09c51a2011-02-02 23:00:16 -0800318 {
Derek Jones6d743e22010-03-02 13:22:03 -0600319 if (is_array($uri))
320 {
321 $uri = implode('/', $uri);
322 }
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200323 return trim($uri, '/');
Derek Allard2067d1a2008-11-13 22:59:24 +0000324 }
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200325 elseif (is_array($uri))
Derek Allard2067d1a2008-11-13 22:59:24 +0000326 {
Andrey Andreev1764dd72012-06-16 18:48:19 +0300327 return http_build_query($uri);
Derek Allard2067d1a2008-11-13 22:59:24 +0000328 }
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200329
Greg Aker03abee32011-12-25 00:31:29 -0600330 return $uri;
Derek Allard2067d1a2008-11-13 22:59:24 +0000331 }
Barry Mienydd671972010-10-04 16:33:58 +0200332
Derek Allard2067d1a2008-11-13 22:59:24 +0000333 // --------------------------------------------------------------------
David Behler2d2c9c62011-08-14 20:03:08 +0200334
Derek Allard2067d1a2008-11-13 22:59:24 +0000335 /**
336 * System URL
337 *
Andrey Andreeve4e10912014-02-08 19:58:48 +0200338 * @deprecated 3.0.0 Encourages insecure practices
Derek Allard2067d1a2008-11-13 22:59:24 +0000339 * @return string
340 */
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200341 public function system_url()
Derek Allard2067d1a2008-11-13 22:59:24 +0000342 {
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200343 $x = explode('/', preg_replace('|/*(.+?)/*$|', '\\1', BASEPATH));
Derek Allard2067d1a2008-11-13 22:59:24 +0000344 return $this->slash_item('base_url').end($x).'/';
345 }
Barry Mienydd671972010-10-04 16:33:58 +0200346
Derek Allard2067d1a2008-11-13 22:59:24 +0000347 // --------------------------------------------------------------------
348
349 /**
350 * Set a config file item
351 *
Andrey Andreev5232ba02012-10-27 15:25:05 +0300352 * @param string $item Config item key
353 * @param string $value Config item value
Derek Allard2067d1a2008-11-13 22:59:24 +0000354 * @return void
355 */
Andrey Andreevccabcfd2012-01-07 19:30:47 +0200356 public function set_item($item, $value)
Derek Allard2067d1a2008-11-13 22:59:24 +0000357 {
358 $this->config[$item] = $value;
359 }
Barry Mienydd671972010-10-04 16:33:58 +0200360
Derek Allard2067d1a2008-11-13 22:59:24 +0000361}
362
Derek Allard2067d1a2008-11-13 22:59:24 +0000363/* End of file Config.php */
Fu Xu0bd32a62014-06-12 19:58:51 +0800364/* Location: ./system/core/Config.php */