0
0
mirror of https://github.com/nextcloud/server.git synced 2024-11-14 20:36:50 +00:00
nextcloud_server/lib/public/Migration/Attributes/ColumnMigrationAttribute.php
Maxence Lange a9e1dc6688 fix(migration-attributes): psalm
Signed-off-by: Maxence Lange <maxence@artificial-owl.com>
2024-07-29 12:44:52 -01:00

102 lines
1.9 KiB
PHP

<?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() ?? '',
]
);
}
}