123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- <?php
- declare(strict_types=1);
- /**
- * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCP\Migration\Attributes;
- use JsonSerializable;
- /**
- * generic class related to migration attribute about column changes
- *
- * @since 30.0.0
- */
- class ColumnMigrationAttribute extends MigrationAttribute implements JsonSerializable {
- /**
- * @param string $table name of the database table
- * @param string $name name of the column
- * @param ColumnType|null $type type of the column
- * @param string $description description of the migration
- * @param array $notes notes about the migration/column
- * @since 30.0.0
- */
- public function __construct(
- string $table,
- private string $name = '',
- private ?ColumnType $type = null,
- string $description = '',
- array $notes = [],
- ) {
- parent::__construct($table, $description, $notes);
- }
- /**
- * @param string $name
- *
- * @return $this
- * @since 30.0.0
- */
- public function setName(string $name): self {
- $this->name = $name;
- return $this;
- }
- /**
- * @return string
- * @since 30.0.0
- */
- public function getName(): string {
- return $this->name;
- }
- /**
- * @param ColumnType|null $type
- *
- * @return $this
- * @since 30.0.0
- */
- public function setType(?ColumnType $type): self {
- $this->type = $type;
- return $this;
- }
- /**
- * @return ColumnType|null
- * @since 30.0.0
- */
- public function getType(): ?ColumnType {
- return $this->type;
- }
- /**
- * @param array $data
- *
- * @return $this
- * @since 30.0.0
- */
- public function import(array $data): self {
- parent::import($data);
- $this->setName($data['name'] ?? '');
- $this->setType(ColumnType::tryFrom($data['type'] ?? ''));
- return $this;
- }
- /**
- * @return array
- * @since 30.0.0
- */
- public function jsonSerialize(): array {
- return array_merge(
- parent::jsonSerialize(),
- [
- 'name' => $this->getName(),
- 'type' => $this->getType() ?? '',
- ]
- );
- }
- }
|