1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Database\Designer;
use PhpMyAdmin\Utils\ForeignKey;
/**
* Common functions for Designer
*/
class DesignerTable
{
/** @var string */
private $tableName;
/** @var string */
private $databaseName;
/** @var string */
private $tableEngine;
/** @var string|null */
private $displayField;
/**
* Create a new DesignerTable
*
* @param string $databaseName The database name
* @param string $tableName The table name
* @param string $tableEngine The table engine
* @param string|null $displayField The display field if available
*/
public function __construct(
string $databaseName,
string $tableName,
string $tableEngine,
?string $displayField
) {
$this->databaseName = $databaseName;
$this->tableName = $tableName;
$this->tableEngine = $tableEngine;
$this->displayField = $displayField;
}
/**
* The table engine supports or not foreign keys
*/
public function supportsForeignkeys(): bool
{
return ForeignKey::isSupported($this->tableEngine);
}
/**
* Get the database name
*/
public function getDatabaseName(): string
{
return $this->databaseName;
}
/**
* Get the table name
*/
public function getTableName(): string
{
return $this->tableName;
}
/**
* Get the table engine
*/
public function getTableEngine(): string
{
return $this->tableEngine;
}
/**
* Get the displayed field
*/
public function getDisplayField(): ?string
{
return $this->displayField;
}
/**
* Get the db and table separated with a dot
*/
public function getDbTableString(): string
{
return $this->databaseName . '.' . $this->tableName;
}
}
|