mirror of
https://github.com/BookStackApp/BookStack.git
synced 2026-02-25 11:19:39 +03:00
57 lines
1.7 KiB
PHP
57 lines
1.7 KiB
PHP
<?php
|
|
|
|
namespace BookStack\Theming;
|
|
|
|
use BookStack\Exceptions\ThemeException;
|
|
|
|
class ThemeModule
|
|
{
|
|
public function __construct(
|
|
public readonly string $name,
|
|
public readonly string $description,
|
|
public readonly string $folderName,
|
|
public readonly string $version,
|
|
) {
|
|
}
|
|
|
|
/**
|
|
* Create a ThemeModule instance from JSON data.
|
|
*
|
|
* @throws ThemeException
|
|
*/
|
|
public static function fromJson(array $data, string $folderName): self
|
|
{
|
|
if (empty($data['name']) || !is_string($data['name'])) {
|
|
throw new ThemeException("Module in folder \"{$folderName}\" is missing a valid 'name' property");
|
|
}
|
|
|
|
if (!isset($data['description']) || !is_string($data['description'])) {
|
|
throw new ThemeException("Module in folder \"{$folderName}\" is missing a valid 'description' property");
|
|
}
|
|
|
|
if (!isset($data['version']) || !is_string($data['version'])) {
|
|
throw new ThemeException("Module in folder \"{$folderName}\" is missing a valid 'version' property");
|
|
}
|
|
|
|
if (!preg_match('/^v?\d+\.\d+\.\d+(-.*)?$/', $data['version'])) {
|
|
throw new ThemeException("Module in folder \"{$folderName}\" has an invalid 'version' format. Expected semantic version format like '1.0.0' or 'v1.0.0'");
|
|
}
|
|
|
|
return new self(
|
|
name: $data['name'],
|
|
description: $data['description'],
|
|
folderName: $folderName,
|
|
version: $data['version'],
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get a path for a file within this module.
|
|
*/
|
|
public function path($path = ''): string
|
|
{
|
|
$component = trim($path, '/');
|
|
return theme_path("modules/{$this->folderName}/{$component}");
|
|
}
|
|
}
|