mirror of
https://github.com/brian8544/turtle-wow.git
synced 2025-01-07 15:21:45 +00:00
181 lines
5.2 KiB
PHP
181 lines
5.2 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace App\Voyager;
|
||
|
|
||
|
use Doctrine\DBAL\Schema\SchemaException;
|
||
|
use Doctrine\DBAL\Schema\Table as DoctrineTable;
|
||
|
use Illuminate\Support\Facades\DB;
|
||
|
use TCG\Voyager\Database\Schema\Column;
|
||
|
use TCG\Voyager\Database\Schema\Index;
|
||
|
use TCG\Voyager\Database\Types\Type;
|
||
|
use TCG\Voyager\Database\Schema\Table;
|
||
|
|
||
|
abstract class SchemaManager
|
||
|
{
|
||
|
// todo: trim parameters
|
||
|
static $connections = ['mysql', 'mysql2'];
|
||
|
|
||
|
public static function __callStatic($method, $args)
|
||
|
{
|
||
|
return static::manager()->$method(...$args);
|
||
|
}
|
||
|
|
||
|
public static function manager($connection = null)
|
||
|
{
|
||
|
return DB::connection($connection)->getDoctrineSchemaManager();
|
||
|
}
|
||
|
|
||
|
public static function getDatabaseConnection($connection = null)
|
||
|
{
|
||
|
return DB::connection($connection)->getDoctrineConnection();
|
||
|
}
|
||
|
|
||
|
public static function tableExists($table)
|
||
|
{
|
||
|
if (!is_array($table)) {
|
||
|
$table = [$table];
|
||
|
}
|
||
|
|
||
|
$matches = false;
|
||
|
foreach (static::$connections as $connection) {
|
||
|
$matches = $matches || static::manager($connection)->tablesExist($table);
|
||
|
}
|
||
|
|
||
|
// return static::tablesExist($table);
|
||
|
return $matches;
|
||
|
}
|
||
|
|
||
|
public static function listTables()
|
||
|
{
|
||
|
$tables = [];
|
||
|
|
||
|
foreach (static::listTableNames() as $tableName) {
|
||
|
$tables[$tableName] = static::listTableDetails($tableName);
|
||
|
}
|
||
|
|
||
|
return $tables;
|
||
|
}
|
||
|
|
||
|
public static function listTableNames()
|
||
|
{
|
||
|
$tableNames = [];
|
||
|
foreach (static::$connections as $connection) {
|
||
|
$tableNames = array_merge(
|
||
|
$tableNames,
|
||
|
static::manager($connection)->listTableNames()
|
||
|
);
|
||
|
}
|
||
|
return $tableNames;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $tableName
|
||
|
*
|
||
|
* @return \TCG\Voyager\Database\Schema\Table
|
||
|
*/
|
||
|
public static function listTableDetails($tableName)
|
||
|
{
|
||
|
$tableConnection = null;
|
||
|
foreach (static::$connections as $connection) {
|
||
|
if (static::manager($connection)->tablesExist([$tableName])) {
|
||
|
$tableConnection = $connection;
|
||
|
}
|
||
|
}
|
||
|
if (!$tableConnection) {
|
||
|
throw new \Exception("No acceptable connection for table $tableName");
|
||
|
}
|
||
|
|
||
|
|
||
|
$columns = static::manager($tableConnection)->listTableColumns($tableName);
|
||
|
|
||
|
$foreignKeys = [];
|
||
|
if (static::manager($tableConnection)->getDatabasePlatform()->supportsForeignKeyConstraints()) {
|
||
|
$foreignKeys = static::manager($tableConnection)->listTableForeignKeys($tableName);
|
||
|
}
|
||
|
|
||
|
$indexes = static::manager($tableConnection)->listTableIndexes($tableName);
|
||
|
|
||
|
return new Table($tableName, $columns, $indexes, [], $foreignKeys, []);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Describes given table.
|
||
|
*
|
||
|
* @param string $tableName
|
||
|
*
|
||
|
* @return \Illuminate\Support\Collection
|
||
|
*/
|
||
|
public static function describeTable($tableName)
|
||
|
{
|
||
|
Type::registerCustomPlatformTypes();
|
||
|
|
||
|
$table = static::listTableDetails($tableName);
|
||
|
|
||
|
return collect($table->columns)->map(function ($column) use ($table) {
|
||
|
$columnArr = Column::toArray($column);
|
||
|
|
||
|
$columnArr['field'] = $columnArr['name'];
|
||
|
$columnArr['type'] = $columnArr['type']['name'];
|
||
|
|
||
|
// Set the indexes and key
|
||
|
$columnArr['indexes'] = [];
|
||
|
$columnArr['key'] = null;
|
||
|
if ($columnArr['indexes'] = $table->getColumnsIndexes($columnArr['name'], true)) {
|
||
|
// Convert indexes to Array
|
||
|
foreach ($columnArr['indexes'] as $name => $index) {
|
||
|
$columnArr['indexes'][$name] = Index::toArray($index);
|
||
|
}
|
||
|
|
||
|
// If there are multiple indexes for the column
|
||
|
// the Key will be one with highest priority
|
||
|
$indexType = array_values($columnArr['indexes'])[0]['type'];
|
||
|
$columnArr['key'] = substr($indexType, 0, 3);
|
||
|
}
|
||
|
|
||
|
return $columnArr;
|
||
|
});
|
||
|
}
|
||
|
|
||
|
public static function listTableColumnNames($tableName)
|
||
|
{
|
||
|
Type::registerCustomPlatformTypes();
|
||
|
|
||
|
$tableConnection = null;
|
||
|
foreach (static::$connections as $connection) {
|
||
|
if (static::manager($connection)->tablesExist([$tableName])) {
|
||
|
$tableConnection = $connection;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
foreach (static::manager($tableConnection)->listTableColumns($tableName) as $column) {
|
||
|
$columnNames[] = $column->getName();
|
||
|
}
|
||
|
return $columnNames;
|
||
|
}
|
||
|
|
||
|
public static function createTable($table)
|
||
|
{
|
||
|
if (!($table instanceof DoctrineTable)) {
|
||
|
$table = Table::make($table);
|
||
|
}
|
||
|
|
||
|
static::manager()->createTable($table);
|
||
|
}
|
||
|
|
||
|
public static function getDoctrineTable($table)
|
||
|
{
|
||
|
$table = trim($table);
|
||
|
|
||
|
if (!static::tableExists($table)) {
|
||
|
throw SchemaException::tableDoesNotExist($table);
|
||
|
}
|
||
|
|
||
|
return static::manager()->listTableDetails($table);
|
||
|
}
|
||
|
|
||
|
public static function getDoctrineColumn($table, $column)
|
||
|
{
|
||
|
return static::getDoctrineTable($table)->getColumn($column);
|
||
|
}
|
||
|
}
|