XF 2.1 Template error: Cannot call method isMemberOf on a non-object (NULL)

Статус
В этой теме нельзя размещать новые ответы.
Версия XenForo
2.1.10

kaz

Проверенные
Сообщения
869
Реакции
381
Баллы
11,065
В админке сыпят гроздьями такие ошибки:

1602914867752.png

Код:
Журнал ошибок сервера
ErrorException: Template error: Cannot call method isMemberOf on a non-object (NULL) src/XF/Template/Templater.php:984
Сгенерирована пользователем: Неизвестная учётная запись 17 Окт 2020 в 10:50
Трассировка стека
#0 [internal function]: XF\Template\Templater->handleTemplateError(512, 'Cannot call met...', '/home/site/w...', 984, Array)
#1 src/XF/Template/Templater.php(984): trigger_error('Cannot call met...', 512)
#2 internal_data/code_cache/templates/l2/s3/public/message_macros.php(81): XF\Template\Templater->method(NULL, 'isMemberOf', Array)
#3 src/XF/Template/Templater.php(701): XF\Template\Templater->{closure}(Object(XF\Template\Templater), Array, Array)
#4 internal_data/code_cache/templates/l2/s3/public/post_macros.php(142): XF\Template\Templater->callMacro('message_macros', 'user_info', Array, Array)
#5 src/XF/Template/Templater.php(701): XF\Template\Templater->{closure}(Object(XF\Template\Templater), Array, Array)
#6 internal_data/code_cache/templates/l2/s3/public/thread_view.php(606): XF\Template\Templater->callMacro('post_macros', 'post', Array, Array)
#7 src/XF/Template/Templater.php(1315): XF\Template\Templater->{closure}(Object(XF\Template\Templater), Array)
#8 src/XF/Template/Template.php(24): XF\Template\Templater->renderTemplate('thread_view', Array)
#9 src/XF/Mvc/Renderer/Html.php(48): XF\Template\Template->render()
#10 src/XF/Mvc/Dispatcher.php(458): XF\Mvc\Renderer\Html->renderView('XF:Thread\\View', 'public:thread_v...', Array)
#11 src/XF/Mvc/Dispatcher.php(440): XF\Mvc\Dispatcher->renderView(Object(XF\Mvc\Renderer\Html), Object(XF\Mvc\Reply\View))
#12 src/XF/Mvc/Dispatcher.php(400): XF\Mvc\Dispatcher->renderReply(Object(XF\Mvc\Renderer\Html), Object(XF\Mvc\Reply\View))
#13 src/XF/Mvc/Dispatcher.php(58): XF\Mvc\Dispatcher->render(Object(XF\Mvc\Reply\View), 'html')
#14 src/XF/App.php(2190): XF\Mvc\Dispatcher->run()
#15 src/XF.php(391): XF\App->run()
#16 index.php(20): XF::runApp('XF\\Pub\\App')
#17 {main}
Содержимое запроса
array(4) {
  ["url"] => string(69) "/threads/frolov-volosy-i-kozha-golovy-mini-infoprodukt-no3-2014.4097/"
  ["referrer"] => string(18) "https://yandex.ru/"
  ["_GET"] => array(1) {
    ["/threads/frolov-volosy-i-kozha-golovy-mini-infoprodukt-no3-2014_4097/"] => string(0) ""
  }
  ["_POST"] => array(0) {
  }
}

Как это победить?

Видел похожую тему, но решения там так и не нашёл.
 
Тут какой-то плагин чудит или стиль не содержит нужных элеметов... Где-то переменная $user не является объектом, содержащим метод isMemberOf. Стиль используется под Вашу версию движка? Плагины все у Вас совместимы с 2.1?
 
Насколько я понял, проблема может быть в этой модификации:

Код:
<xf:if is="{$user.isMemberOf(9)} AND !{$user.isMemberOf(4)}">
        <xf:if is="{$user.isMemberOf(9)} AND {$user.isMemberOf(12)}">
            <span class="usersvip"></span>
            <xf:else /><span class="uservip"></span>
        </xf:if>
    </xf:if>
    <xf:if is="!{$user.isMemberOf(9)} AND {$user.isMemberOf(12)} AND !{$user.isMemberOf(4)}">
                <span class="usersvip"></span>
    </xf:if>

Что не так в этом коде?...
 
Статус
В этой теме нельзя размещать новые ответы.
Современный облачный хостинг провайдер | Aéza
Назад
Сверху Снизу