123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- <?php
- /**
- * Encapsulates directories structure of a Magento module
- *
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Framework\Module;
- use Magento\Framework\Component\ComponentRegistrar;
- use Magento\Framework\Component\ComponentRegistrarInterface;
- class Dir
- {
- /**#@+
- * Directories within modules
- */
- const MODULE_ETC_DIR = 'etc';
- const MODULE_I18N_DIR = 'i18n';
- const MODULE_VIEW_DIR = 'view';
- const MODULE_CONTROLLER_DIR = 'Controller';
- const MODULE_SETUP_DIR = 'Setup';
- /**#@-*/
- /**#@-*/
- private $componentRegistrar;
- /**
- * @param ComponentRegistrarInterface $componentRegistrar
- */
- public function __construct(ComponentRegistrarInterface $componentRegistrar)
- {
- $this->componentRegistrar = $componentRegistrar;
- }
- /**
- * Retrieve full path to a directory of certain type within a module
- *
- * @param string $moduleName Fully-qualified module name
- * @param string $type Type of module's directory to retrieve
- * @return string
- * @throws \InvalidArgumentException
- */
- public function getDir($moduleName, $type = '')
- {
- $path = $this->componentRegistrar->getPath(ComponentRegistrar::MODULE, $moduleName);
- // An empty $type means it's getting the directory of the module itself.
- if (empty($type) && !isset($path)) {
- // Note: do not throw \LogicException, as it would break backwards-compatibility.
- throw new \InvalidArgumentException("Module '$moduleName' is not correctly registered.");
- }
- if ($type) {
- if (!in_array($type, [
- self::MODULE_ETC_DIR,
- self::MODULE_I18N_DIR,
- self::MODULE_VIEW_DIR,
- self::MODULE_CONTROLLER_DIR,
- self::MODULE_SETUP_DIR
- ])) {
- throw new \InvalidArgumentException("Directory type '{$type}' is not recognized.");
- }
- $path .= '/' . $type;
- }
- return $path;
- }
- }
|