2017-09-21 17:54:06 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\Core\Manifest;
|
|
|
|
|
|
|
|
use InvalidArgumentException;
|
|
|
|
use SilverStripe\Core\Injector\Injector;
|
2018-01-12 16:25:02 +13:00
|
|
|
use SilverStripe\Core\Path;
|
2017-09-21 17:54:06 +12:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This object represents a single resource file attached to a module, and can be used
|
|
|
|
* as a reference to this to be later turned into either a URL or file path.
|
|
|
|
*/
|
|
|
|
class ModuleResource
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var Module
|
|
|
|
*/
|
|
|
|
protected $module = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Path to this resource relative to the module (no leading slash)
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $relativePath = null;
|
|
|
|
|
2017-10-04 16:08:33 +13:00
|
|
|
/**
|
|
|
|
* Nested resources for this parent resource
|
|
|
|
*
|
|
|
|
* @var ModuleResource[]
|
|
|
|
*/
|
|
|
|
protected $resources = [];
|
|
|
|
|
2017-09-21 17:54:06 +12:00
|
|
|
/**
|
|
|
|
* ModuleResource constructor.
|
|
|
|
*
|
|
|
|
* @param Module $module
|
|
|
|
* @param string $relativePath
|
|
|
|
*/
|
|
|
|
public function __construct(Module $module, $relativePath)
|
|
|
|
{
|
|
|
|
$this->module = $module;
|
2018-01-12 16:25:02 +13:00
|
|
|
$this->relativePath = Path::normalise($relativePath, true);
|
2017-09-21 17:54:06 +12:00
|
|
|
if (empty($this->relativePath)) {
|
|
|
|
throw new InvalidArgumentException("Resource cannot have empty path");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the full filesystem path to this resource.
|
|
|
|
*
|
2019-01-09 15:35:45 +13:00
|
|
|
* Note: In the case that this resource is mapped to the `_resources` folder, this will
|
2017-09-21 17:54:06 +12:00
|
|
|
* return the original rather than the copy / symlink.
|
|
|
|
*
|
|
|
|
* @return string Path with no trailing slash E.g. /var/www/module
|
|
|
|
*/
|
|
|
|
public function getPath()
|
|
|
|
{
|
2018-01-12 16:25:02 +13:00
|
|
|
return Path::join($this->module->getPath(), $this->relativePath);
|
2017-09-21 17:54:06 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the path of this resource relative to the base path.
|
|
|
|
*
|
2019-01-09 15:35:45 +13:00
|
|
|
* Note: In the case that this resource is mapped to the `_resources` folder, this will
|
2017-09-21 17:54:06 +12:00
|
|
|
* return the original rather than the copy / symlink.
|
|
|
|
*
|
|
|
|
* @return string Relative path (no leading /)
|
|
|
|
*/
|
|
|
|
public function getRelativePath()
|
|
|
|
{
|
2018-01-12 16:25:02 +13:00
|
|
|
// Root module
|
|
|
|
$parent = $this->module->getRelativePath();
|
|
|
|
if (!$parent) {
|
|
|
|
return $this->relativePath;
|
|
|
|
}
|
|
|
|
return Path::join($parent, $this->relativePath);
|
2017-09-21 17:54:06 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Public URL to this resource.
|
|
|
|
* Note: May be either absolute url, or root-relative url
|
|
|
|
*
|
2019-01-09 15:35:45 +13:00
|
|
|
* In the case that this resource is mapped to the `_resources` folder this
|
2017-09-21 17:54:06 +12:00
|
|
|
* will be the mapped url rather than the original path.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getURL()
|
|
|
|
{
|
|
|
|
/** @var ResourceURLGenerator $generator */
|
|
|
|
$generator = Injector::inst()->get(ResourceURLGenerator::class);
|
2017-10-04 16:08:33 +13:00
|
|
|
return $generator->urlForResource($this);
|
2017-09-21 17:54:06 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Synonym for getURL() for APIs that expect a Link method
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function Link()
|
|
|
|
{
|
|
|
|
return $this->getURL();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if this resource exists
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function exists()
|
|
|
|
{
|
|
|
|
return file_exists($this->getPath());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get relative path
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function __toString()
|
|
|
|
{
|
|
|
|
return $this->getRelativePath();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Module
|
|
|
|
*/
|
|
|
|
public function getModule()
|
|
|
|
{
|
|
|
|
return $this->module;
|
|
|
|
}
|
2017-10-04 16:08:33 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get nested resource relative to this.
|
|
|
|
* Note: Doesn't support `..` or `.` relative syntax
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @return ModuleResource
|
|
|
|
*/
|
|
|
|
public function getRelativeResource($path)
|
|
|
|
{
|
2018-01-12 16:25:02 +13:00
|
|
|
// Defer to parent module
|
|
|
|
$relativeToModule = Path::join($this->relativePath, $path);
|
|
|
|
return $this->getModule()->getResource($relativeToModule);
|
2017-10-04 16:08:33 +13:00
|
|
|
}
|
2017-09-21 17:54:06 +12:00
|
|
|
}
|