Commit 7e33ec5f by Taylor Otwell

Allow the registration of custom database drivers.

parent cf29450b
...@@ -13,6 +13,13 @@ class Database { ...@@ -13,6 +13,13 @@ class Database {
public static $connections = array(); public static $connections = array();
/** /**
* The third-party driver registrar.
*
* @var array
*/
public static $registrar = array();
/**
* Get a database connection. * Get a database connection.
* *
* If no database name is specified, the default connection will be returned. * If no database name is specified, the default connection will be returned.
...@@ -66,6 +73,11 @@ class Database { ...@@ -66,6 +73,11 @@ class Database {
*/ */
protected static function connector($driver) protected static function connector($driver)
{ {
if (isset(static::$registrar[$driver]))
{
return static::$registrar[$driver]['connector']();
}
switch ($driver) switch ($driver)
{ {
case 'sqlite': case 'sqlite':
...@@ -121,6 +133,22 @@ class Database { ...@@ -121,6 +133,22 @@ class Database {
} }
/** /**
* Register a database connector and grammars.
*
* @param string $name
* @param Closure $connector
* @param Closure $query
* @param Closure $schema
* @return void
*/
public static function register($name, Closure $connector, $query = null, $schema = null)
{
if (is_null($query)) $query = '\Laravel\Database\Query\Grammars\Grammar';
static::$registrar[$name] = compact('connector', 'query', 'schema');
}
/**
* Magic Method for calling methods on the default database connection. * Magic Method for calling methods on the default database connection.
* *
* <code> * <code>
......
<?php namespace Laravel\Database; use PDO, PDOStatement, Laravel\Config, Laravel\Event; <?php namespace Laravel\Database;
use PDO, PDOStatement, Laravel\Config, Laravel\Event;
class Connection { class Connection {
...@@ -71,7 +73,12 @@ class Connection { ...@@ -71,7 +73,12 @@ class Connection {
{ {
if (isset($this->grammar)) return $this->grammar; if (isset($this->grammar)) return $this->grammar;
switch (isset($this->config['grammar']) ? $this->config['grammar'] : $this->driver()) if (isset(\Laravel\Database::$registrar[$this->driver()]))
{
\Laravel\Database::$registrar[$this->driver()]['query']();
}
switch ($this->driver())
{ {
case 'mysql': case 'mysql':
return $this->grammar = new Query\Grammars\MySQL($this); return $this->grammar = new Query\Grammars\MySQL($this);
...@@ -300,7 +307,7 @@ class Connection { ...@@ -300,7 +307,7 @@ class Connection {
*/ */
public function driver() public function driver()
{ {
return $this->pdo->getAttribute(PDO::ATTR_DRIVER_NAME); return $this->config['driver'];
} }
/** /**
......
...@@ -148,6 +148,11 @@ class Schema { ...@@ -148,6 +148,11 @@ class Schema {
{ {
$driver = $connection->driver(); $driver = $connection->driver();
if (isset(\Laravel\Database::$registrar[$driver]))
{
return \Laravel\Database::$registrar[$driver]['schema']();
}
switch ($driver) switch ($driver)
{ {
case 'mysql': case 'mysql':
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment