Derek Jones | 8ede1a2 | 2011-10-05 13:34:52 -0500 | [diff] [blame] | 1 | ############ |
| 2 | Config Class |
| 3 | ############ |
| 4 | |
| 5 | The Config class provides a means to retrieve configuration preferences. |
| 6 | These preferences can come from the default config file |
| 7 | (application/config/config.php) or from your own custom config files. |
| 8 | |
| 9 | .. note:: This class is initialized automatically by the system so there |
| 10 | is no need to do it manually. |
| 11 | |
| 12 | .. contents:: Page Contents |
| 13 | |
| 14 | Anatomy of a Config File |
| 15 | ======================== |
| 16 | |
| 17 | By default, CodeIgniter has one primary config file, located at |
| 18 | application/config/config.php. If you open the file using your text |
| 19 | editor you'll see that config items are stored in an array called |
| 20 | $config. |
| 21 | |
| 22 | You can add your own config items to this file, or if you prefer to keep |
| 23 | your configuration items separate (assuming you even need config items), |
| 24 | simply create your own file and save it in config folder. |
| 25 | |
| 26 | .. note:: If you do create your own config files use the same format as |
| 27 | the primary one, storing your items in an array called $config. |
| 28 | CodeIgniter will intelligently manage these files so there will be no |
| 29 | conflict even though the array has the same name (assuming an array |
| 30 | index is not named the same as another). |
| 31 | |
| 32 | Loading a Config File |
| 33 | ===================== |
| 34 | |
| 35 | .. note:: |
| 36 | CodeIgniter automatically loads the primary config file |
| 37 | (application/config/config.php), so you will only need to load a config |
| 38 | file if you have created your own. |
| 39 | |
| 40 | There are two ways to load a config file: |
| 41 | |
| 42 | Manual Loading |
| 43 | ************** |
| 44 | |
| 45 | To load one of your custom config files you will use the following |
| 46 | function within the :doc:`controller </general/controllers>` that |
| 47 | needs it:: |
| 48 | |
| 49 | $this->config->load('filename'); |
| 50 | |
| 51 | Where filename is the name of your config file, without the .php file |
| 52 | extension. |
| 53 | |
| 54 | If you need to load multiple config files normally they will be |
| 55 | merged into one master config array. Name collisions can occur, |
| 56 | however, if you have identically named array indexes in different |
| 57 | config files. To avoid collisions you can set the second parameter to |
| 58 | TRUE and each config file will be stored in an array index |
| 59 | corresponding to the name of the config file. Example:: |
| 60 | |
| 61 | // Stored in an array with this prototype: $this->config['blog_settings'] = $config |
| 62 | $this->config->load('blog_settings', TRUE); |
| 63 | |
| 64 | Please see the section entitled Fetching Config Items below to learn |
| 65 | how to retrieve config items set this way. |
| 66 | |
| 67 | The third parameter allows you to suppress errors in the event that a |
| 68 | config file does not exist:: |
| 69 | |
| 70 | $this->config->load('blog_settings', FALSE, TRUE); |
| 71 | |
| 72 | Auto-loading |
| 73 | ************ |
| 74 | |
| 75 | If you find that you need a particular config file globally, you can |
| 76 | have it loaded automatically by the system. To do this, open the |
| 77 | **autoload.php** file, located at application/config/autoload.php, |
| 78 | and add your config file as indicated in the file. |
| 79 | |
| 80 | |
| 81 | Fetching Config Items |
| 82 | ===================== |
| 83 | |
| 84 | To retrieve an item from your config file, use the following function:: |
| 85 | |
| 86 | $this->config->item('item name'); |
| 87 | |
| 88 | Where item name is the $config array index you want to retrieve. For |
| 89 | example, to fetch your language choice you'll do this:: |
| 90 | |
| 91 | $lang = $this->config->item('language'); |
| 92 | |
| 93 | The function returns FALSE (boolean) if the item you are trying to fetch |
| 94 | does not exist. |
| 95 | |
| 96 | If you are using the second parameter of the $this->config->load |
| 97 | function in order to assign your config items to a specific index you |
| 98 | can retrieve it by specifying the index name in the second parameter of |
| 99 | the $this->config->item() function. Example:: |
| 100 | |
| 101 | // Loads a config file named blog_settings.php and assigns it to an index named "blog_settings" |
| 102 | $this->config->load('blog_settings', TRUE); |
| 103 | |
| 104 | // Retrieve a config item named site_name contained within the blog_settings array |
| 105 | $site_name = $this->config->item('site_name', 'blog_settings'); |
| 106 | |
| 107 | // An alternate way to specify the same item: |
| 108 | $blog_config = $this->config->item('blog_settings'); |
| 109 | $site_name = $blog_config['site_name']; |
| 110 | |
| 111 | Setting a Config Item |
| 112 | ===================== |
| 113 | |
| 114 | If you would like to dynamically set a config item or change an existing |
| 115 | one, you can do so using:: |
| 116 | |
| 117 | $this->config->set_item('item_name', 'item_value'); |
| 118 | |
| 119 | Where item_name is the $config array index you want to change, and |
| 120 | item_value is its value. |
| 121 | |
| 122 | .. _config-environments: |
| 123 | |
| 124 | Environments |
| 125 | ============ |
| 126 | |
| 127 | You may load different configuration files depending on the current |
| 128 | environment. The ENVIRONMENT constant is defined in index.php, and is |
| 129 | described in detail in the :doc:`Handling |
| 130 | Environments </general/environments>` section. |
| 131 | |
| 132 | To create an environment-specific configuration file, create or copy a |
| 133 | configuration file in application/config/{ENVIRONMENT}/{FILENAME}.php |
| 134 | |
| 135 | For example, to create a production-only config.php, you would: |
| 136 | |
| 137 | #. Create the directory application/config/production/ |
| 138 | #. Copy your existing config.php into the above directory |
| 139 | #. Edit application/config/production/config.php so it contains your |
| 140 | production settings |
| 141 | |
| 142 | When you set the ENVIRONMENT constant to 'production', the settings for |
| 143 | your new production-only config.php will be loaded. |
| 144 | |
| 145 | You can place the following configuration files in environment-specific |
| 146 | folders: |
| 147 | |
| 148 | - Default CodeIgniter configuration files |
| 149 | - Your own custom configuration files |
| 150 | |
| 151 | .. note:: |
Thanasis Polychronakis | 991cfa2 | 2012-05-31 21:54:35 +0300 | [diff] [blame] | 152 | CodeIgniter always loads the global config file first (i.e., the one in application/config/), |
| 153 | then tries to load the configuration files for the current environment. |
| 154 | This means you are not obligated to place **all** of your configuration files in an |
| 155 | environment folder. Only the files that change per environment. Additionally you don't |
| 156 | have to copy **all** the config items in the environment config file. Only the config items |
| 157 | that you wish to change for your environment. The config items declared in your environment |
| 158 | folders always overwrite those in your global config files. |
Derek Jones | 8ede1a2 | 2011-10-05 13:34:52 -0500 | [diff] [blame] | 159 | |
| 160 | Helper Functions |
| 161 | ================ |
| 162 | |
| 163 | The config class has the following helper functions: |
| 164 | |
| 165 | $this->config->site_url(); |
| 166 | *************************** |
| 167 | |
| 168 | This function retrieves the URL to your site, along with the "index" |
| 169 | value you've specified in the config file. |
| 170 | |
| 171 | $this->config->base_url(); |
| 172 | *************************** |
| 173 | |
| 174 | This function retrieves the URL to your site, plus an optional path such |
| 175 | as to a stylesheet or image. |
| 176 | |
| 177 | The two functions above are normally accessed via the corresponding |
Andrey Andreev | 1764dd7 | 2012-06-16 18:48:19 +0300 | [diff] [blame] | 178 | functions in the :doc:`URL Helper <helpers/url_helper>`. |
Derek Jones | 8ede1a2 | 2011-10-05 13:34:52 -0500 | [diff] [blame] | 179 | |
| 180 | $this->config->system_url(); |
| 181 | ***************************** |
| 182 | |
| 183 | This function retrieves the URL to your system folder. |