====== Использование переменных окружения для настройки системных параметров ====== В Limb3 выработавшейся практикой стало использование переменных окружения для настройки определенных системных параметров. Все переменные начинаются с ключевого слова LIMB_(единственное исключение - константы шаблонизатора WACT, которые имеют префикс WACT_). Для работы с переменными используются функции [[..ru:packages:core:global_functions#функции_для_работы_с_переменными_окружения_lmb_env|lmb_env_set(), lmb_env_setor(), lmb_env_get(), lmb_env_has(), lmb_env_remove()]], для отладки [[..ru:packages:core:global_functions#функции_для_работы_с_переменными_окружения_lmb_env|lmb_env_trace(), lmb_env_trace_has(), lmb_env_trace_show()]]. Использование собственных функций, а так же наличие функций для отладки, избавляет от единственного их минуса - "беззащитности" перед плохим кодом. Мы не отказываемся от настроечных файлов, однако считаем, что низкоуровневые параметры намного проще конфигурировать с помощью низкоуровневых средств. Для обслуживания переменных используется всего 100 строк кода, тогда как настроечные файлы тянут за собой определенные зависимости(например, класс, который осуществляет парсинг настроечных файлов). Сравните: Используем переменную: require_once(lmb_env_get('LIMB_VAR_DIR') . '/foo.php'); Используем некую подсистему для получения параметров: require_once(Toolkit::instanse()->getConf('common')->get('var_dir') . '/foo.php');//вводим зависимость от пакетов toolkit и conf ===== Поддержка механизма констант ===== Механизм констант, использованный ранее, поддерживается и сейчас. Константы просто транслируются в переменные. Например: define('LIMB_VAR_DIR', '/tmp/'); echo lmb_env_get('LIMB_VAR_DIR'); //'/tmp/' lmb_env_set('LIMB_VAR_DIR', '/tmp/limb/'); echo lmb_env_get('LIMB_VAR_DIR'); //'/tmp/limb/' ===== "Сокращения" для часто используемых констант ===== Некоторые переменные очень часто используются внутри фреймворка. Чтобы не писать один и тот же скучный для них существует "обертка" в виде функций. Пока такая функция одна **lmb_var_dir()**: lmb_var_dir('/tmp'); //установка echo lmb_var_dir(); //получение значения ===== Список наиболее часто используемых переменных ===== Документацию на не перечисленные здесь константы стоит искать в описании конкретного пакета. **LIMB_APP_MODE**(string) - указывает на режим в котором функционирует приложение. Может принимать два значения: 'devel' и 'production'. Используется фильтром lmbErrorHandlerFilter из пакета web_app. В режиме 'devel' приложение выводит все сообщения об ошибках на экран. В режиме production только пишет их в лог. **LIMB_CACHE_DB_META_IN_FILE**(boolean) - объявляет, стоит ли кешировать метаданные структуры базы данных. По умолчанию имеет значение false. Используется в пакете DBAL. Строить метаданные структуры БД при каждом запросе - довольно обременительная задача, поэтому имеет смысл эти данные кешировать(они хранятся в директории LIMB_VAR_DIR в файле db_info.xxx.cache). Отменять кеширование имеет смысл только во время разработки, но не на продукционных серверах. Пример использования: lmb_env_set('LIMB_CACHE_DB_META_IN_FILE', true);//включаем кеширование **LIMB_CONF_INCLUDE_PATH**(string)- список путей через ";" указывающих директории относительно include_path, в которых стоит производить поиск *.conf.php и *.ini настроечных файлов. По умолчанию 'settings;limb/*/settings'. Используется в пакете CONFIG. Обычно полезно переопределять эту константу в тестах. Пример использования: lmb_env_set('LIMB_CONF_INCLUDE_PATH', 'tests/settings;settings'); **LIMB_CONTROLLERS_INCLUDE_PATH**(string) - список путей через ";" указывающих директории относительно include_path, в которых стоит производить поиск контроллеров. По умолчанию 'src/controller;limb/*/src/controller'. Используется в пакете WEB_APP. **LIMB_SUPPORTED_VIEW_TYPES**(string) - список пар **<расширение файла шаблона>=<класс view>** через ";". Задает список поддерживаемых view-классов и их ассоциации с файлами-шаблонами. Например: lmb_env_set('LIMB_SUPPORTED_VIEW_TYPES', '.phtml=lmbMacroView;.html=lmbBlitzView;'); //поддерживаются macro-шаблоны с расширениями .phtml и blitz-шаблоны с расширениями .html :!: Поиск шаблонов происходит слева-направо, т.е. если, в примере, будет найден macro-шаблон, то [[http://alexeyrybak.com/blitz/blitz_ru.html|Blitz]]-шаблон искаться не будет. **LIMB_VAR_DIR**(string) - указывает на некоторую доступную на запись директорию. Обычно в проекте эта директория имеет название **var** и находится в корневой директории проекта. Все временные данные, кеши, логи, т.е все то, что может быть безболезненно удалено хранится в этой директории. Эта директория должна всегда находиться в списке svn:ignore системы версионного контроля. Пример использования: lmb_env_set('LIMB_VAR_DIR', dirname(__FILE__) . '/var'); lmb_var_dir(dirname(__FILE__) . '/var'); //"обертка" для быстрого доступа **LIMB_UNDEFINED** (string) - Константа! Значение "отсутствие значения". Обычно используется для обозначения отсутствия значения, в случаях, когда null является значащей величиной. Например: /** * Получение свойства по имени * @param string property имя * @param mixed значение, которое нужно вернуть, если свойство не установленно * @return mixed */ function get($property, $default = LIMB_UNDEFINED) { if(property_exists($this, $property)) return $this->$property; if($default !== LIMB_UNDEFINED) return $default; } :!: LIMB_UNDEFINED уникально и неизменно на протяжении всего времени работы скрипта. ===== Список остальных констант ===== * **LIMB_ENABLE_MOD_REWRITE**(bool) - использовать настройки для mod_rewrite * **LIMB_FCKEDITOR_DIR** - директория FCK Editor. Используется в пакете WYSIWYG. * **LIMB_HTTP_GATEWAY_PATH** * **LIMB_HTTP_OFFSET_PATH** - путь limb-приложения относительно DOCUMENT_ROOT. Без слешей вначале и конце. Например, если index.php limb-приложения расположен DOCUMENT_ROOT/limb-app/index.php, то LIMB_HTTP_OFFSET_PATH должен быть равен 'limb-app' * **LIMB_HTTP_SHARED_PATH** - путь [[.:packages:web_app:app_installation#shared-файлы|shared-ресурсов]] относительно DOCUMENT_ROOT * **LIMB_JS_INCLUDE_PATH** * **LIMB_LOCALE_INCLUDE_PATH** * **LIMB_LOG_ENABLE** * **LIMB_RULES_INCLUDE_PATH** * **LIMB_TRANSLATIONS_INCLUDE_PATH** * **LIMB_UTF** * **LIMB_WEB_AGENT_REQUEST** * **LIMB_WYSIWYG_DIR** ==== Константы testman'а ==== * **LIMB_TEST_DB_DSN** * **LIMB_TEST_RUNNER_CLASS_FORMAT** * **LIMB_TESTS_RUNNER_CONFIG** * **LIMB_TESTS_RUNNER_COVERAGE_REPORT_DIR** * **LIMB_TESTS_RUNNER_FILE_FILTER** ===== Список устаревших констант ===== Константы из этого списка не выставляются, но их значения поддерживаются, чтобы сохранить обратную совместимость. * **LIMB_SMTP_AUTH** * **LIMB_SMTP_HOST** * **LIMB_SMTP_PASSWORD** * **LIMB_SMTP_PORT** * **LIMB_SMTP_USER** * **LIMB_USE_PHPMAIL** * **LIMB_MACRO_FILTERS_INCLUDE_PATH** * **LIMB_MACRO_TAGS_INCLUDE_PATH**