Новости Joomla

Свои типы полей в Joomla.

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

Это большая тема, о которой можно говорить очень много. Самое главное, что возможности применения ограничиваются только вашей больной фантазией. Вы строите интерфейс своего модуля или плагина и вам нужно подтянуть данные из сторонней системы (список чего-нибудь по какому-нибудь API), чтобы сохранить выбранный id в Joomla. Или сделать какую-то проверку и в зависимости от неё показать то или иное сообщение пользователю. Для этого подойдут свои пользовательские типы полей. Интерфейс Joomla по большей части описан в XML-файлах. У каждого из них свои параметры. Некоторые не описаны в документации (manual.joomla.org), поэтому самым любопытным будет полезно заглянуть в собственно файлы фреймворка по пути

libraries/src/Form/FormField.php, а так же в
libraries/src/Form/Fields. У каждого класса поля перечислены его специфические свойства, которые можно описывать в XML. А в своём типе поля вы можете устанавливать эти значения программно. В моём модуле WT Quick links под капотом происходят изменения. Теперь для работы (в админке) ему нужен вспомогательный плагин. А в самом модуле нам бы проверить, а не выключен ли он? В Joomla есть тип поля Note - заметка. Его можно использовать для вывода примечаний.

<field type="note" name="your_note_for_user" label="Заголовок примечания" title="Альтернативный способ для заголовка" description="Текст примечания" class="col-12 alert alert-info" heading="h1" close="true" />

heading - указывать уровень заголовка.
close - позволяет закрыть это примечание. В классе поля
libraries/src/Form/Field/NoteField.php описана логика вывода. И в принципе оно нам подходит для нашей задачи. Но оно будет выводить сообщение всегда, а нам нужно только тогда, когда плагин отключён. Поэтому берём и создаём свой класс поля, который мы унаследуем от
NoteField. Это значит, что у нас в руках будет весь инструментарий стандартного поля
Note + то, что мы сами добавим. В XML-манифест добавляем наше поле

<field type="systempluginstatus" name="systempluginstatus" addfieldprefix="Joomla\Module\Wtquicklinks\Site\Fields"/>

-

type - имя файла и класса,-
addfieldprefix - указываем namespace к нашему классу, может быть любой нам нужный-
name - нельзя полю без имени...Это означает, что Joomla будет использовать класс поля из файла
modules/mod_wt_quick_links/src/Fields/SystempluginstatusField.php.А в классе поля будет написано следующее:

<?php // namespace для атрибута addfieldprefix namespace Joomla\Module\Wtquicklinks\Site\Fields; // нельзя напрямую обращаться к этому файлу defined('_JEXEC') or die; // подключаем родительский класс для переопределения use Joomla\CMS\Form\Field\NoteField; use Joomla\CMS\Language\Text; use Joomla\CMS\Plugin\PluginHelper; // имя класса и имя файла точь-в-точь class SystempluginstatusField extends NoteField { protected $type = 'Systempluginstatus'; protected function getLabel() { // если плагин не включён if(PluginHelper::isEnabled('system','wtquicklinks')) { // меняем свойства родительского класса $this->class = 'alert alert-danger w-100'; $this->element['label'] = '⚠️ А-а-а-а!'; $this->element['description'] = 'Плагин не включён!!'; // и просто рендерим его с нашими свойствами return parent::getLabel(); } // А иначе всё хорошо, скрываем поле из виду. $this->parentclass = 'd-none'; return ''; } }

Просто и удобно. И людям приятно, что о них позаботились и рассказали почему что-то не работает. @webtolkru#joomla #php #webdev #разработка

0 Пользователей и 1 Гость просматривают эту тему.
  • 7 Ответов
  • 2311 Просмотров
*

kit_andrei

  • Осваиваюсь на форуме
  • 21
  • 0 / 0
jSecure Lite
« : 08.08.2017, 13:35:13 »
Всем привет.
Установил компонент jSecure Lite, раньше проблем у меня с этим компонентом не было, а сейчас появилась вот такая надпись, как это можно исправить?

Warning: Declaration of jsecureliteControllerjsecurelite::display() should be compatible with JControllerLegacy::display($cachable = false, $urlparams = Array) in /administrator/components/com_jsecurelite/controller.php on line 36


кто нибудь сталкивался с такои проблемой?
с уважением Андрей
*

Avarus

  • Осваиваюсь на форуме
  • 33
  • 8 / 1
Re: jSecure Lite
« Ответ #1 : 08.08.2017, 13:53:54 »
Либо скачать самую последнюю версию, поскольку разработчики скорее всего доработали компонент под новую версию фреймворка Joomla.
Либо в файле /administrator/components/com_jsecurelite/controller.php, в строке 36, сделать замену:
Код
public function display()
на:
Код
public function display($cachable = false, $urlparams = array())
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: jSecure Lite
« Ответ #2 : 08.08.2017, 14:05:40 »
Не хочется флудить и философствовать, но... kit_andrei, зачем вам этот компонент? Вы думаете, вы спрячете админку? Поверьте, она никому не нужна ) Если только школьники настроят брут пароля и возможно их третье-пятое поколение наконец то увидит ответ.... Смысла в этом нет, т.к. во первых сам движок легко детектится, не нужно для этого никаких программ. А во вторых, сайты ломают не через админку.

Вместо этого компонента лучше бы настроили дополнительную авторизацию через .htpassword, больше прока было бы. Имхо.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

kit_andrei

  • Осваиваюсь на форуме
  • 21
  • 0 / 0
Re: jSecure Lite
« Ответ #3 : 08.08.2017, 15:16:57 »
Либо скачать самую последнюю версию, поскольку разработчики скорее всего доработали компонент под новую версию фреймворка Joomla.
Либо в файле /administrator/components/com_jsecurelite/controller.php, в строке 36, сделать замену:
Код
public function display()
на:
Код
public function display($cachable = false, $urlparams = array())


спасибо большое )))) помогло )
*

kit_andrei

  • Осваиваюсь на форуме
  • 21
  • 0 / 0
Re: jSecure Lite
« Ответ #4 : 08.08.2017, 15:20:24 »
SeBun я согласен с тобой, но если админка закрыта, как то спокоино на душе )))
за совет спасибо,
а как сделать дополнительную авторизацию через .htpassword ?
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: jSecure Lite
« Ответ #5 : 08.08.2017, 15:38:33 »
а как сделать дополнительную авторизацию через .htpassword ?
См. тут
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

kit_andrei

  • Осваиваюсь на форуме
  • 21
  • 0 / 0
Re: jSecure Lite
« Ответ #6 : 08.08.2017, 15:55:11 »
См. тут

спасибо большое.
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: jSecure Lite
« Ответ #7 : 09.08.2017, 08:46:44 »
спасибо большое.
Пожалуйста.

Если сделаете так, как я предложил, то получите следующее: ваша CMS будет детектится в любом случае, и путь к админке тоже известен, но теперь она имеет дополнительную защиту. Если при входе в админку будет выводиться форма запроса, от этого толка больше, чем если бы просто тупо перекидывало плагином на главную, т.к. в этом случае защищается ваша сессия. Еще раз подчеркну, что взломщику ваша админка как козе баян.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться