mirror of
https://github.com/BookStackApp/BookStack.git
synced 2025-01-19 08:42:48 +08:00
92cfde495e
Reduced import data will now be stored on the import itself, instead of storing a set of totals.
58 lines
1.8 KiB
PHP
58 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace BookStack\Exports\ZipExports\Models;
|
|
|
|
use BookStack\Exports\ZipExports\ZipValidationHelper;
|
|
use JsonSerializable;
|
|
|
|
abstract class ZipExportModel implements JsonSerializable
|
|
{
|
|
/**
|
|
* Handle the serialization to JSON.
|
|
* For these exports, we filter out optional (represented as nullable) fields
|
|
* just to clean things up and prevent confusion to avoid null states in the
|
|
* resulting export format itself.
|
|
*/
|
|
public function jsonSerialize(): array
|
|
{
|
|
$publicProps = get_object_vars(...)->__invoke($this);
|
|
return array_filter($publicProps, fn ($value) => $value !== null);
|
|
}
|
|
|
|
/**
|
|
* Validate the given array of data intended for this model.
|
|
* Return an array of validation errors messages.
|
|
* Child items can be considered in the validation result by returning a keyed
|
|
* item in the array for its own validation messages.
|
|
*/
|
|
abstract public static function validate(ZipValidationHelper $context, array $data): array;
|
|
|
|
/**
|
|
* Decode the array of data into this export model.
|
|
*/
|
|
abstract public static function fromArray(array $data): self;
|
|
|
|
/**
|
|
* Decode an array of array data into an array of export models.
|
|
* @param array[] $data
|
|
* @return self[]
|
|
*/
|
|
public static function fromManyArray(array $data): array
|
|
{
|
|
$results = [];
|
|
foreach ($data as $item) {
|
|
$results[] = static::fromArray($item);
|
|
}
|
|
return $results;
|
|
}
|
|
|
|
/**
|
|
* Remove additional content in this model to reduce it down
|
|
* to just essential id/name values for identification.
|
|
*
|
|
* The result of this may be something that does not pass validation, but is
|
|
* simple for the purpose of creating a contents.
|
|
*/
|
|
abstract public function metadataOnly(): void;
|
|
}
|