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

Inoken

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
Здравствуйте. Делаю первые шаги в Joomla, разрабатыва компонент и мне необходимо ограничить доступ пользователей к его контенту. В админке компонента, в форме создания элемента контента, присутствует поле типа accesslevel - список select с уровнями доступа.

Его опции таковы:
Код
<option value="1">Public</option>
<option value="5">Guest</option>
<option value="2">Registered</option>
<option value="4">Customer Access Level (Example)</option>
<option value="3">Special</option>
<option value="6">Super Users</option>

Сам механизм проверки уровня доступа я представляю себе следующим образом: сравнить значение уровня доступа, заданное при создании/редактировании элемента контента, со значением уровня доступа для текущего пользователя из класса JUser. Экспериментируя с настройками уровней доступа пользователя в админке Joomla, и просматривая изменения в распечатке объекта посредством print_r во фронт-энде, среди свойств объекта JUser я нашел свойство _authLevels с наиболее похожими значениями на значения из приведенного выше списка. Но проблема в том, что оно protected и никаких значений я увидеть не могу. Подскажите, пожалуйств, как мнеправильно реализовать эту проверку?
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Зайдите в модель com_content так будет проще всего объяснить
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Но проблема в том, что оно protected и никаких значений я увидеть не могу.
Для этого существует метод getAuthorisedViewLevels().
Зайдите в модель com_content так будет проще всего объяснить
Да, смотрите в ContentModelArticles().
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Да вот под рукой попалось
Код: php
$query->where($db->quoteName('access').' IN '.'('.implode(',', JFactory::getUser()->getAuthorisedViewLevels()).')');
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

Inoken

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
ок, спасибо вам за инфу, буду разбираться.
« Последнее редактирование: 15.06.2017, 10:20:34 от Inoken »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Условия отображения для конкретной группы пользователей Joomla 3.4.x

Автор dmik

Ответов: 15
Просмотров: 2597
Последний ответ 29.05.2020, 22:42:15
от voland
Создание релиза компонента средствами GitHub

Автор SkyAn

Ответов: 4
Просмотров: 716
Последний ответ 01.11.2019, 17:42:04
от Septdir
Ошибка при попытке получить параметры активного пункта меню в контроллере компонента

Автор Inoken

Ответов: 10
Просмотров: 1471
Последний ответ 19.06.2017, 14:29:22
от dmitry_stas
Зависимость модуля от компонента и страницы

Автор Тренд

Ответов: 34
Просмотров: 2439
Последний ответ 16.06.2017, 19:48:39
от dmitry_stas
Разработка компонента

Автор dimasan57

Ответов: 16
Просмотров: 1242
Последний ответ 23.05.2017, 14:27:42
от dimasan57