Spaces:
No application file
No application file
File size: 2,229 Bytes
d2897cd |
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 |
<?php
declare(strict_types=1);
namespace Mautic\CoreBundle\Doctrine\GeneratedColumn;
final class GeneratedColumn implements GeneratedColumnInterface
{
/**
* @var string
*/
private $tablePrefix = '';
private string $columnName;
private ?string $originalDateColumn = null;
private ?string $timeUnit = null;
private array $indexColumns = [];
public function __construct(
private string $tableName,
string $columnName,
private string $columnType,
private string $as
) {
$this->indexColumns[] = $columnName;
$this->tablePrefix = MAUTIC_TABLE_PREFIX;
$this->columnName = $columnName;
}
public function getTableName(): string
{
return $this->tablePrefix.$this->tableName;
}
public function getColumnName(): string
{
return $this->columnName;
}
public function addIndexColumn(string $indexColumn): void
{
$this->indexColumns[] = $indexColumn;
}
public function setOriginalDateColumn(string $originalDateColumn, string $timeUnit): void
{
$this->originalDateColumn = $originalDateColumn;
$this->timeUnit = $timeUnit;
}
public function getOriginalDateColumn(): ?string
{
return $this->originalDateColumn;
}
public function getTimeUnit(): string
{
return $this->timeUnit;
}
public function getAlterTableSql(): string
{
return "ALTER TABLE {$this->getTableName()} ADD {$this->getColumnName()} {$this->getColumnDefinition()};
ALTER TABLE {$this->getTableName()} ADD INDEX `{$this->getIndexName()}`({$this->indexColumnsToString()})";
}
public function getColumnDefinition(): string
{
return "{$this->columnType} AS ({$this->as}) COMMENT '(DC2Type:generated)'";
}
public function getIndexColumns(): array
{
return $this->indexColumns;
}
public function getIndexName(): string
{
return $this->tablePrefix.$this->indexColumnsToString('_');
}
private function indexColumnsToString(string $separator = ', '): string
{
return implode($separator, $this->indexColumns);
}
}
|