module = $module; $this->relativePath = ltrim($relativePath, Module::TRIM_CHARS); if (empty($this->relativePath)) { throw new InvalidArgumentException("Resource cannot have empty path"); } } /** * Return the full filesystem path to this resource. * * Note: In the case that this resource is mapped to the `resources` folder, this will * return the original rather than the copy / symlink. * * @return string Path with no trailing slash E.g. /var/www/module */ public function getPath() { return $this->module->getPath() . '/' . $this->relativePath; } /** * Get the path of this resource relative to the base path. * * Note: In the case that this resource is mapped to the `resources` folder, this will * return the original rather than the copy / symlink. * * @return string Relative path (no leading /) */ public function getRelativePath() { $path = $this->module->getRelativePath() . '/' . $this->relativePath; return ltrim($path, Module::TRIM_CHARS); } /** * Public URL to this resource. * Note: May be either absolute url, or root-relative url * * In the case that this resource is mapped to the `resources` folder this * will be the mapped url rather than the original path. * * @return string */ public function getURL() { /** @var ResourceURLGenerator $generator */ $generator = Injector::inst()->get(ResourceURLGenerator::class); return $generator->urlForResource($this); } /** * 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; } /** * Get nested resource relative to this. * Note: Doesn't support `..` or `.` relative syntax * * @param string $path * @return ModuleResource */ public function getRelativeResource($path) { // Check cache $path = trim($path, Module::TRIM_CHARS); if (isset($this->resources[$path])) { return $this->resources[$path]; } // Build new relative path $relativeBase = rtrim($this->relativePath, Module::TRIM_CHARS); $relativePath = "{$relativeBase}/{$path}"; return $this->resources[$path] = new ModuleResource($this->getModule(), $relativePath); } }