blob: 02e0e1d39a84da8fa134b441c5c1e992f7473ee8 [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Andrey Andreevfe9309d2015-01-09 17:48:58 +02005 * An open source application development framework for PHP
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +02007 * This content is released under the MIT License (MIT)
Andrey Andreev24276a32012-01-08 02:44:38 +02008 *
Instructor, BCIT0e59db62019-01-01 08:34:36 -08009 * Copyright (c) 2014 - 2019, British Columbia Institute of Technology
Andrey Andreev24276a32012-01-08 02:44:38 +020010 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020011 * Permission is hereby granted, free of charge, to any person obtaining a copy
12 * of this software and associated documentation files (the "Software"), to deal
13 * in the Software without restriction, including without limitation the rights
14 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
15 * copies of the Software, and to permit persons to whom the Software is
16 * furnished to do so, subject to the following conditions:
Derek Jonesf4a4bd82011-10-20 12:18:42 -050017 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020018 * The above copyright notice and this permission notice shall be included in
19 * all copies or substantial portions of the Software.
20 *
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
27 * THE SOFTWARE.
28 *
29 * @package CodeIgniter
30 * @author EllisLab Dev Team
Andrey Andreev1924e872016-01-11 12:55:34 +020031 * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/)
Instructor, BCIT0e59db62019-01-01 08:34:36 -080032 * @copyright Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/)
33 * @license https://opensource.org/licenses/MIT MIT License
Andrey Andreevbd202c92016-01-11 12:50:18 +020034 * @link https://codeigniter.com
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020035 * @since Version 1.0.0
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @filesource
37 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020038defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000039
Derek Allard2067d1a2008-11-13 22:59:24 +000040/**
41 * Initialize the database
42 *
43 * @category Database
Andrey Andreev75546112012-07-05 11:01:29 +030044 * @author EllisLab Dev Team
Andrey Andreevbd202c92016-01-11 12:50:18 +020045 * @link https://codeigniter.com/user_guide/database/
Andrey Andreevae85eb42012-11-02 01:42:31 +020046 *
47 * @param string|string[] $params
48 * @param bool $query_builder_override
49 * Determines if query builder should be used or not
Derek Allard2067d1a2008-11-13 22:59:24 +000050 */
Jamie Rumbelow7efad202012-02-19 12:37:00 +000051function &DB($params = '', $query_builder_override = NULL)
Derek Allard2067d1a2008-11-13 22:59:24 +000052{
53 // Load the DB config file if a DSN string wasn't passed
Andrey Andreevc2697db2012-03-26 13:05:24 +030054 if (is_string($params) && strpos($params, '://') === FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +000055 {
Phil Sturgeon05fa6112011-04-06 22:57:43 +010056 // Is the config file in the environment folder?
Andrey Andreevdb529ca2013-01-28 11:00:02 +020057 if ( ! file_exists($file_path = APPPATH.'config/'.ENVIRONMENT.'/database.php')
Andrey Andreevc2697db2012-03-26 13:05:24 +030058 && ! file_exists($file_path = APPPATH.'config/database.php'))
joelcoxe3da4282011-01-16 15:00:04 +010059 {
Andrey Andreev24276a32012-01-08 02:44:38 +020060 show_error('The configuration file database.php does not exist.');
joelcoxe3da4282011-01-16 15:00:04 +010061 }
David Behler07b53422011-08-15 00:25:06 +020062
joelcoxe3da4282011-01-16 15:00:04 +010063 include($file_path);
Andrey Andreev74d0e232015-02-05 13:36:00 +020064
65 // Make packages contain database config files,
66 // given that the controller instance already exists
67 if (class_exists('CI_Controller', FALSE))
Rene Brokholmf5a85302012-07-05 09:05:32 +020068 {
Andrey Andreev74d0e232015-02-05 13:36:00 +020069 foreach (get_instance()->load->get_package_paths() as $path)
Rene Brokholmf5a85302012-07-05 09:05:32 +020070 {
Andrey Andreev74d0e232015-02-05 13:36:00 +020071 if ($path !== APPPATH)
Rene Brokholmf5a85302012-07-05 09:05:32 +020072 {
Andrey Andreev74d0e232015-02-05 13:36:00 +020073 if (file_exists($file_path = $path.'config/'.ENVIRONMENT.'/database.php'))
74 {
75 include($file_path);
76 }
77 elseif (file_exists($file_path = $path.'config/database.php'))
78 {
79 include($file_path);
80 }
Rene Brokholmf5a85302012-07-05 09:05:32 +020081 }
82 }
83 }
Barry Mienydd671972010-10-04 16:33:58 +020084
Andrey Andreev24276a32012-01-08 02:44:38 +020085 if ( ! isset($db) OR count($db) === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +000086 {
87 show_error('No database connection settings were found in the database config file.');
88 }
Barry Mienydd671972010-10-04 16:33:58 +020089
Alex Bilbie48a2baf2012-06-02 11:09:54 +010090 if ($params !== '')
Derek Allard2067d1a2008-11-13 22:59:24 +000091 {
92 $active_group = $params;
93 }
Barry Mienydd671972010-10-04 16:33:58 +020094
Andrey Andreevf46b16b2013-07-18 19:36:24 +030095 if ( ! isset($active_group))
Derek Allard2067d1a2008-11-13 22:59:24 +000096 {
Andrey Andreevf46b16b2013-07-18 19:36:24 +030097 show_error('You have not specified a database connection group via $active_group in your config/database.php file.');
98 }
99 elseif ( ! isset($db[$active_group]))
100 {
101 show_error('You have specified an invalid database connection group ('.$active_group.') in your config/database.php file.');
Derek Allard2067d1a2008-11-13 22:59:24 +0000102 }
Barry Mienydd671972010-10-04 16:33:58 +0200103
Derek Allard2067d1a2008-11-13 22:59:24 +0000104 $params = $db[$active_group];
105 }
106 elseif (is_string($params))
107 {
vkeranovd008c972012-11-12 14:29:49 +0200108 /**
109 * Parse the URL from the DSN string
110 * Database settings can be passed as discreet
111 * parameters or as a data source name in the first
112 * parameter. DSNs must have this prototype:
113 * $dsn = 'driver://username:password@hostname/database';
Barry Mienydd671972010-10-04 16:33:58 +0200114 */
Andrey Andreevc2697db2012-03-26 13:05:24 +0300115 if (($dsn = @parse_url($params)) === FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000116 {
117 show_error('Invalid DB Connection String');
118 }
Barry Mienydd671972010-10-04 16:33:58 +0200119
Derek Allard2067d1a2008-11-13 22:59:24 +0000120 $params = array(
Andrey Andreev7e963512014-02-27 15:43:24 +0200121 'dbdriver' => $dsn['scheme'],
122 'hostname' => isset($dsn['host']) ? rawurldecode($dsn['host']) : '',
123 'port' => isset($dsn['port']) ? rawurldecode($dsn['port']) : '',
124 'username' => isset($dsn['user']) ? rawurldecode($dsn['user']) : '',
125 'password' => isset($dsn['pass']) ? rawurldecode($dsn['pass']) : '',
126 'database' => isset($dsn['path']) ? rawurldecode(substr($dsn['path'], 1)) : ''
127 );
Barry Mienydd671972010-10-04 16:33:58 +0200128
vkeranovd008c972012-11-12 14:29:49 +0200129 // Were additional config items set?
Andrey Andreevc2697db2012-03-26 13:05:24 +0300130 if (isset($dsn['query']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000131 {
Andrey Andreevc2697db2012-03-26 13:05:24 +0300132 parse_str($dsn['query'], $extra);
Taufan Adityaee2f5d02012-03-30 06:29:11 +0700133
Pascal Krietec3a4a8d2011-02-14 13:40:08 -0500134 foreach ($extra as $key => $val)
Derek Allard2067d1a2008-11-13 22:59:24 +0000135 {
Taufan Adityaee2f5d02012-03-30 06:29:11 +0700136 if (is_string($val) && in_array(strtoupper($val), array('TRUE', 'FALSE', 'NULL')))
Derek Allard2067d1a2008-11-13 22:59:24 +0000137 {
Joãobe676852015-01-14 09:10:41 +0000138 $val = var_export($val, TRUE);
Derek Allard2067d1a2008-11-13 22:59:24 +0000139 }
140
141 $params[$key] = $val;
142 }
143 }
144 }
Barry Mienydd671972010-10-04 16:33:58 +0200145
Andrey Andreev24276a32012-01-08 02:44:38 +0200146 // No DB specified yet? Beat them senseless...
Andrey Andreeve4c30192012-06-04 15:08:24 +0300147 if (empty($params['dbdriver']))
Derek Allard2067d1a2008-11-13 22:59:24 +0000148 {
149 show_error('You have not selected a database type to connect to.');
150 }
151
Jamie Rumbelow7efad202012-02-19 12:37:00 +0000152 // Load the DB classes. Note: Since the query builder class is optional
Derek Allard2067d1a2008-11-13 22:59:24 +0000153 // we need to dynamically create a class that extends proper parent class
Jamie Rumbelow7efad202012-02-19 12:37:00 +0000154 // based on whether we're using the query builder class or not.
155 if ($query_builder_override !== NULL)
Derek Allard2067d1a2008-11-13 22:59:24 +0000156 {
Jamie Rumbelow7efad202012-02-19 12:37:00 +0000157 $query_builder = $query_builder_override;
Derek Allard2067d1a2008-11-13 22:59:24 +0000158 }
Andrey Andreevd45f9502012-05-24 19:31:39 +0300159 // Backwards compatibility work-around for keeping the
160 // $active_record config variable working. Should be
161 // removed in v3.1
162 elseif ( ! isset($query_builder) && isset($active_record))
163 {
164 $query_builder = $active_record;
165 }
Barry Mienydd671972010-10-04 16:33:58 +0200166
Greg Aker3a746652011-04-19 10:59:47 -0500167 require_once(BASEPATH.'database/DB_driver.php');
Derek Allard2067d1a2008-11-13 22:59:24 +0000168
Alex Bilbie48a2baf2012-06-02 11:09:54 +0100169 if ( ! isset($query_builder) OR $query_builder === TRUE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000170 {
Jamie Rumbelow7efad202012-02-19 12:37:00 +0000171 require_once(BASEPATH.'database/DB_query_builder.php');
Andrey Andreev49e68de2013-02-21 16:30:55 +0200172 if ( ! class_exists('CI_DB', FALSE))
Derek Allard2067d1a2008-11-13 22:59:24 +0000173 {
Andrey Andreevae85eb42012-11-02 01:42:31 +0200174 /**
175 * CI_DB
176 *
177 * Acts as an alias for both CI_DB_driver and CI_DB_query_builder.
178 *
179 * @see CI_DB_query_builder
180 * @see CI_DB_driver
181 */
Jamie Rumbelow7efad202012-02-19 12:37:00 +0000182 class CI_DB extends CI_DB_query_builder { }
Derek Allard2067d1a2008-11-13 22:59:24 +0000183 }
184 }
Andrey Andreev49e68de2013-02-21 16:30:55 +0200185 elseif ( ! class_exists('CI_DB', FALSE))
Derek Allard2067d1a2008-11-13 22:59:24 +0000186 {
Andrey Andreevae85eb42012-11-02 01:42:31 +0200187 /**
188 * @ignore
189 */
Andrey Andreev24276a32012-01-08 02:44:38 +0200190 class CI_DB extends CI_DB_driver { }
Derek Allard2067d1a2008-11-13 22:59:24 +0000191 }
Barry Mienydd671972010-10-04 16:33:58 +0200192
Taufan Adityaa8a2e332012-03-29 03:56:46 +0700193 // Load the DB driver
194 $driver_file = BASEPATH.'database/drivers/'.$params['dbdriver'].'/'.$params['dbdriver'].'_driver.php';
195
Andrey Andreev7e963512014-02-27 15:43:24 +0200196 file_exists($driver_file) OR show_error('Invalid DB driver');
Taufan Adityaa8a2e332012-03-29 03:56:46 +0700197 require_once($driver_file);
Derek Allard2067d1a2008-11-13 22:59:24 +0000198
199 // Instantiate the DB adapter
200 $driver = 'CI_DB_'.$params['dbdriver'].'_driver';
Pascal Kriete58560022010-11-10 16:01:20 -0500201 $DB = new $driver($params);
Barry Mienydd671972010-10-04 16:33:58 +0200202
Andrey Andreev3345ee52012-06-23 20:51:47 +0300203 // Check for a subdriver
Andrey Andreev754e2212012-06-23 20:54:06 +0300204 if ( ! empty($DB->subdriver))
Andrey Andreev3345ee52012-06-23 20:51:47 +0300205 {
Andrey Andreev44107772012-06-25 18:38:34 +0300206 $driver_file = BASEPATH.'database/drivers/'.$DB->dbdriver.'/subdrivers/'.$DB->dbdriver.'_'.$DB->subdriver.'_driver.php';
Andrey Andreev3345ee52012-06-23 20:51:47 +0300207
208 if (file_exists($driver_file))
209 {
210 require_once($driver_file);
Andrey Andreev44107772012-06-25 18:38:34 +0300211 $driver = 'CI_DB_'.$DB->dbdriver.'_'.$DB->subdriver.'_driver';
Andrey Andreev3345ee52012-06-23 20:51:47 +0300212 $DB = new $driver($params);
213 }
214 }
215
Andrey Andreev1a367562015-02-19 16:48:23 +0200216 $DB->initialize();
Derek Allard2067d1a2008-11-13 22:59:24 +0000217 return $DB;
Barry Mienydd671972010-10-04 16:33:58 +0200218}