Magento для PHP MVC розробників – Конфігурація системи за замовчуванням (ч.11/11)

Ця стаття є певним доповненням до попередніх статей щодо конфігурації системи, а не цілком окремою новою статтею. Якщо вам багато чого видається не зрозумілим, будь ласка, поверніться і прочитайте попередні статті.

 

Коли ви створюєте новий вузол конфігурації системи, Magento не зберігає значення за замовчуванням. Це справедливо навіть для конфігурації всієї системи за замовчуванням. Ви можете переконатися в цьому, подивившись на таблицю core_config_data.

У цій таблиці будуть зберігатися лише значення, які були явним чином встановлені за допомогою Консолі адміністратора або інших програмних засобів.

 

Якщо ви будете робити запит значення шляху конфігурації системи, яке не має явного значення, Magento перевірить глобальне дерево конфігурації за замовчуванням. Хоча це і не вимагається, рекомендується встановлювати значення за замовчуванням для своїх користувацьких змінних конфігурації. Це досить простий крок і він гарантує, що не відбудеться чогось несподіваного, коли будуть завантажуватись порожні значення для ваших змінних конфігурації.

 

 

Налаштування значень за замовчуванням

Як було зазначено раніше, значення за замовчуванням зберігаються у глобальному дереві конфігурації (вузол global). Це трохи збиває з пантелику, оскільки більше очікується, що ці значення зберігатимуться в тому ж файлі system.xml, де налаштовані шляхи. Але тут працює, як і у більшості речах Magento, принцип

 

Нам не варто ставити під сумнів чому, нам або робити або померти

 

який виступає найкращим варіантом вирішення цього. Спробуйте подумати про глобальну конфігурацію як місце для зберігання часто використовуваних значень, а system.xml – як місце, яким ви налаштовуєте UI для зміни цих значень.

 

Тож, продовжимо.

 

У файлі config.xml модуля додайте розділ верхнього рівня з назвою <default/>.

 

<!-- Файл: app/code/local/Packagename/Modulename/etc/config.xml -->

<config>
  <!-- ... -->
  <default>
  </default>
  <!-- ... -->
</config>

 

Це вузол верхнього рівня, в якому ви будете зберігати значення за замовчуванням. Далі, візьміть шлях до конфігурації та конвертуйте його у вузол XML дерева. Наприклад, якщо ви встановлюєте значення за замовчуванням для наступного ноду конфігурації:

design/header/welcome

 

ваша конфігурація буде виглядати приблизно так:

 

<!-- Файл: app/code/local/Packagename/Modulename/etc/config.xml -->

<config>
  <!-- ... -->
  <default>
    <design>
      <header>
        <welcome>Default welcome msg!</welcome>
      </header>
    </design>
  </default>
  <!-- ... -->
</config>

 

 

За допомогою налаштування конфігурації, подібної до наведеної вище, запити до

design/header/welcome

 

повертатимуть, якщо значення не перевизначились деінде, дефолтний текст «Default welcome msg!».

 

Цей приклад заснований на існуючому налаштуванні конфігурації у складі інсталяції Magento. Пам’ятайте, що більшість функцій Magento створено за допомогою тієї самої системи модулів, яку ви використовуєте для налаштування системи. Давайте подивимося на фактичну конфігурацію design/header/welcome значення.

 

<!-- Файл: app/code/core/Mage/Page/etc/config.xml -->
<default>
 <design>
  <head translate="default_description" module="page">
    <default_title>Magento Commerce</default_title>
    <default_description>Default Description</default_description>
    <default_keywords>Magento, Varien, E-commerce</default_keywords>
    <default_robots>*</default_robots>
    <default_media_type>text/html</default_media_type>
    <default_charset>utf-8</default_charset>
  </head>
  <header translate="welcome" module="page">
   <logo_src>images/logo.gif</logo_src>
   <logo_alt>Magento Commerce</logo_alt>
   <welcome>Default welcome msg!</welcome>
  </header>
  <footer translate="copyright" module="page">
    <copyright>&amp;copy; 2008 Magento Demo Store. All Rights Reserved.</copyright>
  </footer>
 </design>
</default>

 

Це повна конфігурація за замовчуванням для

design/*

 

ієрархії конфігурації. Різниця з нашими попередніми прикладами – це додаткові атрибути перекладу.

 

<header translate="welcome" module="page">

 

Атрибути “translate” та “module” вказують системі, які вузли потрібно перекласти, і який Помічник даних модуля слід використовувати для перекладу. У наведеному вище прикладі це означає, що вузол для привітання буде перекладено:

Mage::helper('page')->__(...);

 

Пам’ятайте: якщо ви викликаєте фабрику Помічника без іншої частини URI, Magento буде надавати дані Помічника за замовчуванням.

 

//одне і те ж
Mage::helper('page')->__(...);
Mage::helper('page/data')->__(...);

 

Якщо ви хочете перекласти декілька під-вузлів, просто розділіть імена за допомогою ком:

 

<example translate="foo,baz,bar" module="page">

 

 

Підсумок

Незважаючи на те, що це не є необхідним, рекомендується встановлювати шляхи конфігурації системи зі значеннями за замовчуванням. Встановивши дані за замовчуванням на початку, ви будете завжди отримувати певне логічне значення, і вам не доведеться турбуватися про випадки, коли користувач може випадково зберегти значення з порожнім рядком.

 

 

 

Автор: Alan Storm (https://alanstorm.com/magento_default_system_configuration_values/)

Переклад українською: SebWeo

 
 

 

Share
Теги: Magento

Останні пости

Федір Достоєвський

Жити потрібно для тих — кому ти потрібен, Дружити лише з тими — в кому… Читати далі

19/09/2021

Том Гіддлстон

Людина має два життя, і друге починається тоді, коли ми розуміємо, що життя всього одне… Читати далі

12/09/2021

Еріх Марія Ремарк

В темні часи добре видно світлих людей Еріх Марія Ремарк   Читати далі

07/09/2021

Юрій Нікулін

Ніколи не мстіть підлим людям. Просто станьте щасливими, — І вони цього не переживуть... Юрій… Читати далі

02/09/2021

Конфуцій

Стався до всіх з добром та повагою, навіть до тих, хто з тобою грубий. Не… Читати далі

29/08/2021

Створи справжнє дзеркало суспільства: найкращі WordPress шаблони для новинного порталу

Створення новинного порталу може здатися важкою справою, враховуючи розмір та охоплення таких великих компаній як… Читати далі

21/08/2021