Новости Joomla

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

bokus

  • Осваиваюсь на форуме
  • 12
  • 1 / 0
Здравствуйте делаю свой компонент для внутреннего сайта организации и не могу осмыслить следующую проблему, есть некая таблица SQL запросов к ораклячей базе
Код
CREATE TABLE #__rosreestr_sqlrequests (
  id int(11) NOT NULL AUTO_INCREMENT,
  asset_id int(10) unsigned NOT NULL DEFAULT '0',
  title varchar(255) DEFAULT NULL COMMENT 'Название запроса',
  sqlreq mediumtext NOT NULL COMMENT 'SQL запрос',
    ...
    ...

Данные во front-end вытаскиваю
Код
	<field
name="idsql"
type="sql"
multiple="false"
size="1"
label="SQL запрос"
query="SELECT * FROM #__rosreestr_sqlrequests order by 2"
key_field="id"
value_field="title"
required="true"
onchange = "$('#jform_gosqlreq').val('0'); submit()"
>
<option value="" disabled="true">-= Выберите SQL запрос =-</option>
</field>


также для таблицы в back-end задано право на запуск


проблема в том как вывести список из базы с учетом права на запуск, т.е. если нет права то в список они не попадают.
« Последнее редактирование: 30.10.2012, 13:30:47 от bokus »
*

bokus

  • Осваиваюсь на форуме
  • 12
  • 1 / 0
Re: Использование ACL во front-end
« Ответ #1 : 26.10.2012, 10:17:01 »
Решено! Нашел решение данного вопроса, делюсь со всеми кто столкнется с данной ситуацией

после сёрфинга по инету наткнулся на статью http://docs.joomla.org/Creating_a_custom_form_field_type и сделал следующие действия

1) скопировал и переименовал необходимый тип поля (т.е. sql) из libraries\joomla\form\fields\sql.php в свой компонент \components\com_rosreestr\models\fields\SQLRunSQL.php

2) в скопированном файле добавил условие If (JFactory::getUser()->authorise('rosreestr.runsqlreq', 'com_rosreestr.sqlrequest.' . $item->id)) т.е. получилось

Код
....
if (!empty($items)){
foreach ($items as $item){
If (JFactory::getUser()->authorise('rosreestr.runsqlreq', 'com_rosreestr.sqlrequest.' . $item->id)) {
if ($translate == true)
$options[] = JHtml::_('select.option', $item->$key, JText::_($item->$value));
else
$options[] = JHtml::_('select.option', $item->$key, $item->$value);
}
}
}
....


3) в описании формы переименовал тип поля
Код
	<field
name="idsql"
type="sqlrunsql"
multiple="false"
....
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Использование ACL во front-end
« Ответ #2 : 26.10.2012, 11:43:44 »
Вот, пример хорошего пользователя - поделился решением, причем полезным. Плюсанул ;)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] title category

Автор spirit1086

Ответов: 4
Просмотров: 1465
Последний ответ 17.08.2015, 16:42:04
от spirit1086
[Решено] Программная регистрация пользователя во внешней бд

Автор DimkaJack

Ответов: 8
Просмотров: 2209
Последний ответ 06.08.2014, 18:32:39
от DimkaJack
[Решено] Вставить визуальный редактор в модуль

Автор mat.konstantin

Ответов: 6
Просмотров: 4307
Последний ответ 10.03.2014, 14:33:05
от mat.konstantin
Использование иконок на FrontEnd

Автор Xiss

Ответов: 6
Просмотров: 1412
Последний ответ 16.02.2014, 00:57:18
от Xiss
[Решено] Как разобрать JURI::current() при помощи route.php?

Автор platonische

Ответов: 17
Просмотров: 3479
Последний ответ 10.01.2014, 20:55:19
от Arkadiy