<?php // Полная загрузка сервисных книжек, создан 2025-01-05 12:44:55
global $wpdb2;
global $failure;
global $file_hist;
///// echo '<H2><b>Старт загрузки</b></H2><br>';
$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
///// echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}
$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
///// echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}
/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
///// echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
///// echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist); ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7]; ////получаем размер файла
$m_mtime_file=$masiv_data_file[9]; ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file
///// echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
///// echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
///// echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);
if ($results)
{ foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));
////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
///// echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
///// echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}
////загружаем данные
$table='vin_history'; // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация // (путь от корня web-сервера)
$delim=';'; // Разделитель полей в CSV файле
$enclosed='"'; // Кавычки для содержимого полей
$escaped='\
Спасибо за труд — будет очень кстати 🙂
Знаю, как тяжело раскопать это всё в БСП, поэтому очень плюсую и респектую!
Помню как в свое время копал БСП-шную систему RLS, внимательно читал их шаблоны. Понравилось, хороший труд у них получился. Единственное что не нравится, что управление в основном через администратора, хотя можно и допилить (впрочем ты об этом написал).
(0) можно еще описать параметры RLS. В шаблонах конечно описание норм, но блин, пока до конца поймешь :))))
Однозначный плюс.
ЗЫ. Очень надеюсь, что в очередной версии БСП все не перевернут с ног на голову..
(0) Очень хорошо. В начале осени занимался доводкой нашей конфигурации в части прав доступа. До всего дощупывался сам.
(0) Забыли про процедуру ПриЗаполненииВидовОграниченийПравОбъектовМетаданных в модуле УправлениеДоступомПереопределяемый
Показать
(6) Поручик, спасибо за подсказку, внес в публикацию необходимые исправления.
(7) Строка
лишняя. Смотрите типовые конфигурации и описание к процедуре.
я бы не трогал типовой модуль. Отдельная подписка, отдельный модуль — и меньше проблем при последующих обновлениях
(8) Поручик, Исправил, еще раз спасибо за внимательность! =)
(9) Stim213, модуль «УправлениеДоступомПереопределяемый» все равно придется трогать, а вот подписку, да, вместо типовой можно создать свою, она обращается к модулю «УправлениеДоступомСлужебный» (в этот модуль мы и не вносили изменений). Учел ваше замечание.
(9) Модули с суффиксом Переопределяемый предусмотрены для того, чтобы их трогали в определённых местах. Этакая
пародия на абстрактные методыэмуляция абстрактных методов классов в 1С Предприятии.Спасибо.
Не так давно все это раскапывать пришлось самому. Была мысль подобный пост написать 🙂 Вы меня опередили и описали все очень даже сжато и хорошо!
(14) У меня тоже было намерение, но не хватало времени и писательских способностей, поэтому забил.
спасибо за статью. будет полезна
А сколько еще всего осталось за кадром… Но спасибо за проделанную работу.
Было бы здорово, если бы расписали, как пользоваться другими БСП-шными шаблонами, не только #ПоЗначениям))
(18) alina0587, это уже совсем другая история =) В этой статье в общем то не описываются возможности использования БСП-шных шаблонов, в ней описано использование БСП-шной подсистемы, в которой применяются эти шаблоны (сами шаблоны независимо от подсистемы применять не получится), использование части возможностей одного из шаблонов, я думаю, из статьи понятно, но описание всех возможностей этих шаблонов — это уже отдельная статья.
(11)
>>> г. Подписка на событие «ОбновитьГруппыЗначенийДоступа» (вместо этого можно также создать свою собственную подписку).
Создать свою подписку можно, но при обновлении конфигурации программа завершится с ошибкой. Вчера обжёгся сам, поэтому пришлось удалить свою подписку и назначить обработку своих объектов на штатную.
(11)
>>> г. Подписка на событие «ОбновитьГруппыЗначенийДоступа» (вместо этого можно также создать свою собственную подписку).
Создать свою подписку можно, но при обновлении конфигурации программа завершится с ошибкой. Вчера обжёгся сам, поэтому пришлось удалить свою подписку и назначить обработку своих объектов на штатную.
(20) Поручик, а как такое может быть, если штатная и наша собственная подписки вызывают одну и ту же процедуру по одному и тому же событию «Перед записью» элемента справочника (конечно, как вариант, в какой-нибудь процедуре штатной подписки идет обращение к ее метаданным и уже на основании состава ее источников выполняется обновление)? Причину ошибки обновления получилось выяснить? Если ошибка точно из-за собственной подписки — то уберу из статьи касающейся этой проблемы текст.
p.s. Я сам не пробовал делать это с собственной подпиской, я изначально правил штатную подписку.
(22) Ошибка из-за того, что в программе при обновлении используется именно штатная ОбновитьГруппыЗначенийДоступа. Свою подписку использовать можно, но до первого обновления.
(22) Вот именно так — в модуле менеджера какой-то константы идет обращение к метаданным «ОбновитьГруппыЗначенийДоступа» и уже на основании состава ее источников выполняется обновление.
Ну воссоздавать вчерашнюю ситуации лениво.
(24) Поручик, убрал из статьи касающийся этой проблемы текст, еще раз спасибо за корректировку публикации! =)
Подскажите, сделал все как указанно, но в виды доступа не добавляется «группы номенклатуры». При этом у пользователя, которому назначена указанная роль, ограничен доступ ко всем контрагентам
(26) ASZub, честно говоря, не видя картины в живую, сложно что-то сказать что сделано не так, могу лишь посоветовать попробовать еще раз пройтись внимательно по всем пунктам публикации и проверить у себя в конфигурации все ли эти пункты были выполнены.
Как вариант — проверьте правильно ли заполнена процедура «ПриЗаполненииВидовДоступа».
Да, статья помогла, спасибо. По документации БСП не очень просто разобраться, плюс в ней есть ошибки, что затрудняет разработку…
На БСП 2.2.5.30 не получилось добиться результата..
(29) kasper076, А что именно не получилось? Делал все по статье, со своими нюансами, изредка подглядывая в шаблоны ERP — все заработало.
(29) Или руки не там вставлены, или в БСП 2.2.5 есть различия от предыдущей 2.2.4. Не думаю, чтобы отличия были большими.
(30) necropunk, Создал новую конфу со справочником «Контрагенты», далее все делал по статье. Справочник «Профили пользователей» имеет несколько другой вид. В итоге пользователь вообще не видит справочник «Контрагенты».
(31) Поручик, на счет рук спорить не буду. Возможно, что именно в них причина.
Какой источник указать для Подписки «ЗаписатьНаборыЗначенийДоступа»?
В демо-базе БСП 2.2.5.30 новые «ВидыДоступа» являются предопределенными элементами ПВХ ВидыДоступа.
Есть какая-нибудь таблица соответствия версии БСП с последним релизом типовой конфигурации?
(33) Какой именно типовой? Их целая куча типовых, открою тебе секрет. Только никому не говори.
(34) Поручик, спасибо за секрет )) Например, УТ11, БП3, Розница, ЗУП3. В этих конфигурациях разные или одинаковые БСП?
Разбираюсь с БСП. Вижу, что в моей конфигурации есть СтандартныеПодсистемы, нужная мне подсистема ПрисоединенныеФайлы — тоже есть.
Как узнать — какая версия этих подсистем?
Ведь для каждой версии по-своему настраивается работа…
(36) СтандартныеПодсистемыСервер
// Возвращает номер версии Библиотеки стандартных подсистем.
//
Функция ВерсияБиблиотеки() Экспорт
Возврат «1.2.1.15»;
КонецФункции
(36) user_2010, Версию БСП можно просмотреть в регистре сведений «Версии подсистем».
(38) Спасибо! Все нашла!
Еще вопрос: имеем нетиповую конфигурацию на 8.2. В ней есть некоторые подсистемы из БСП. Версия Стандартных подсистем 2.1.3.50.
Подсистема «Присоединенные файлы» есть. Начинаю настраивать и вижу, что недостает РегистраСведений.ПрисоединенныеФайлы…? Т.е. внедрили подсистему «Присоединенные файлы» не полностью?
На сайте обновлений такой версии БСП 2.1.3.50 нет (хотела посмотреть — может в этой версии еще не было РегистраСведений.ПрисоединенныеФайлы). На сайте обновлений есть 2.1.3.51, в ней этот регистр сведений есть.
Значит мне нужно обновить нужные мне подсистемы БСП?
Или просто добавить недостающие объекты?
Можно ли обновлять сразу на самую последнюю версию? Или нужно последовательно ставить все обновления?
(40) user_2010, честно говоря от себя не могу что-то посоветовать, боюсь ошибиться, но я бы просто обновил БСП через сравнение/объединение с 2.1.3.51, т.к. она ближе всего к версии текущей вашей БСП, с последующей проверкой основных функций подсистемы «Присоединенные файлы».
Понятно! Спасибо!
Кажется поняла почему подсистема «Присоединенные файлы» загружена не полностью.
В Регистре сведений «Версии подсистем» указаны:
БиблиотекаЭлектронныхДокументов 1.1.17.6
СтандартныеПодсистемы 2.1.3.50
Почитала про БиблиотекаЭлектронныхДокументов — она содержит в себе функциональность «Присоединенные файлы»… может быть грузили именно ее, а присоединенные файлы попали прицепом… и болтаются там необновленные…
Выяснилось, что это в типовой 1С.БухгалтерияПредприятия.2.0 — так странно загружены подсистемы БСП…
Никто не пытался использовать БСП в 1С.Бухгалтерии.2.0?
Отличная статья — сильно помогла! Может посоветует кто — у меня ограничение «все разрешены, кроме …» замечательно работают. А вот «все разрешены, кроме …» не отрабатывает — пустой справочник показывает. Причем можно создать элемент с разрешенной группой, и этот элемент виден в справочнике. Пока не понял, в чем дело…
Добрый день. БСП 2.2.5.33
Пытаюсь реализовать доступ к документу _ДемоПоступлениеТоваров с ограничением по статусам.
Создал Справочник ДоступПоСтатусам
Добавил реквизит «СтатусДоступа» в документ _ДемоПоступлениеТоваров
Дальше добавил в УправлениеДоступомПереопределяемый строки кода
Показать
При запуске обработки ИнструментыРазработчикаОбновлениеВспомогательныхДанных выдаёт ошибку:
{Константа.ПараметрыОграниченияДоступа.МодульМенеджераЗначения(461)}: Ошибка в процедуре ЗаполнитьСвойстваВидаДоступа
общего модуля УправлениеДоступомПереопределяемый.
Тип значений доступа «Доступ по статусам» вида доступа «ДоступПоСтатусам»
не указан в определяемом типе «Значение доступа».
ВызватьИсключение СтроковыеФункцииКлиентСервер.ПодставитьПараметрыВСтроку(
Подскажите пожалуйста, что не так делаю?
Всё разобрался. Забыл добавить в Определяемые типы — ЗначенияДоступа справочник СтатусыДоступа.
(29) kasper076, +1
Не работает на 3.0.40.38 БСП 2.2.5.35
Не выводит список контрагентов вообще, все сделано по инструкции. Проверено,что все сделано по инструкции еще 5 раз.
(47) buy_sale, возможно, что в БСП 2.2.5 присутствуют какие-нибудь не глобальные изменения по отношению к предыдущим версиям библиотеки, значит нужно копать глубже.
БСП 2.3.1.79
Инфа из статьи (из ИТС, кстати, тоже) не помогла. Мой справочник для целевого пользователя оказался пуст. Одолжите выпрямитель рук:
1. Включил подсистему в конфу сравнением/объединением
2. Планируется использовать шаблон «ПоЗначениям». Добавил вид доступа, писал необходимые процедуры:
Показать
3. Включил шаблон для Роли ЧтениеПодразделений на право Чтение: #ПоЗначениям(«Справочник.Подразделения», «», «», «ГруппыДоступаПодразделений», «ГруппаДоступа», «», «», «»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»,»»).
Реквизит справочника Подразделения типа СправочникСсылка.ГруппыДоступаПодразделений называется «ГруппаДоступа»
4. Запустил базу с параметром /C ЗапуститьОбновлениеИнформационнойБазы
5. Добавил пользователя в группу ОбычныйПользователь. Группа связана с профилем ОсновнойПрофильПользователя, для которого установлен вид доступа. В группе ОбычныйПользователь назначил резрешенные подразделения.
Админ всё видит. Пользователь не видит. ЧЯНТД?
Вчитываюсь в текст шаблона. Сравниваю с текстом запроса, полученным из ТЖ… Пока не разобрался.
(49) Покурил демобазу БСП. Обнаружил нюансы, о которых не прочитал в статье:
1. Проблема вылечилась изменением параметров в шаблоне доступа:
БЫЛО: #ПоЗначениям(«Справочник.Подразделения», «», «», «ГруппыДоступаПодразделений», «ГруппаДоступа«…
СТАЛО: #ПоЗначениям(«Справочник.Подразделения», «», «», «ГруппыДоступаПодразделений», «Ссылка«…
2. В демобазе в модуле объекта справочника, группирующего ограничения, тоже установлен реквизит. В моем случае для справочника ГруппыДоступаПодразделений я добавил реквизит ГруппаДоступа типа СправочникСсылка.ГруппыДоступаПодразделений. И поставил RLS с шаблоном:
#ПоЗначениям(«Справочник.ГруппыДоступаПодразделений«, «», «», «ГруппыДоступаПодразделений», «Ссылка«..
3. В демобазе на справочник групп доступа навешивается обработчик ПередЗаписью. Где автоматически заполняется реквизит ГруппаДоступа.
Возможно я не докурил подсистему, и ляпнул что-то лишнего. Но с учетом всего вышесказанного у меня справочник заработал.
Буду разбираться с другими шаблонами.
Очень полезная статья, спасибо!
От себя хочу добавить, что в инструкцию можно добавить ещё один пункт:
В константу «ПараметрыОграниченияДоступа» в процедуру «ЗаполнитьЗначенияДоступаСГруппами» нужно добавить:
Если что — я не программист и даже не знаю что этот код означает, но без него не проходило обновление базы.
51. dkxtitan
Спасибо! После этой врезки обновление прошло
Люди Добрые помогите
Пытаюсь по тексту статьи сделать ограничение доступа по складам.
1.Создал справочник ГруппыДоступаСклады
2. В справочнике Склады добавил реквизит ГруппаДоступаПоСкладу
3. Для подписки на событие «ОбновитьГруппыЗначенийДоступа» в качестве источника также указал справочник «Склады».
4. В общий модуль «УправлениеДоступомПереопределяемый» и вставил в три его процедуры фрагменты кода, приведенные ниже.
Показать
После всего этого захожу в 1с УТ11.1 В настройки пользователей и ролей в ограничения данные о Группе доступа склады не добавляются
Подскажите где ошибаюсь
Протестил этот метод в конф. БГУ2 — все норм, все работает. Спасибо!
Подскажите плиз кто знает как сделать ограничение к справочнику, к примеру по значениям самого справочника?
Т.е. не привязывать элементы справочника к группам доступа а в настройках групп сразу указывать в качестве значения ограничения — элементы справочника (указать в настройках доступа конкретных контрагентов).
Подскажите, пожалуйста, зачем нужна фунция
ПриЗаполненииВидовОграниченийПравОбъектовМетаданных
?
Я вроде пустой её оставил, и ограничение прав работает как надо.
Здравствуйте, есть вопросик. Все сделал, как у Вас. Все заработало. Делал для справочника «Номенклатура», в нем реквизит «ГруппаДоступа», а вид доступа называется «ГруппыНоменклатуры». В справочнике номенклатура все верно ограничивается. Хотел бы ещё это применить для связанного справочника «ХарактеристикиНоменклатуры». У характеристики, соответственно, номенклатура в поле владелец. У Вас написано,что необходимо в процедуре добавить:
Показать
Но в списке справочника «ХарактеристикиНоменклатуры» остались записи с владельцем «Объект не найден». Ограничение не сработало, что ещё необходимо добавить?
(56) Скорее всего у пользователя есть роли, которые предоставляют ему право на чтение данных из справочника характеристик без использования ваших RLS, поэтому он видит все характеристики, но вот прочитать их владельцев он не может, т.к. на справочник номенклатуры успешно отрабатывает RLS.
Возможно Вы забыли добавить в имеющиеся роли, которые предоставляют право на чтение справочника характеристик, ваш шаблон RLS вида: #ПоЗначениям(«Справочник.ХарактеристикиНоменклатуры», «Чтение», «ГруппыНоменклатуры», «Владелец»)
(57) Добавил, у меня получился пустой список «Характеристик». А тут я правильно добавил:
Показать
(58) Что-то мне подсказывает, что вместо
следует указать
т.е. данный запрос указывает подсистеме, что:
1. «Справочник.ХарактеристикиНоменклатуры» — в этом справочнике
2. «Чтение» — следует ограничить доступ на чтение
3. «ГруппыНоменклатуры» — при помощи этого вида доступа
Реквизит же (в данном случае «Владелец»), по которому уже следует ограничить доступ к объекту, указывается в шаблоне RLS — #ПоЗначениям(«Справочник.ХарактеристикиНоменклатуры», «Чтение», «ГруппыНоменклатуры», «Владелец«), т.е. в шаблоне фактически указана та же самая информация, что и в запросе, за исключением уточнения реквизита, по которому следует ограничить доступ к объекту.
Попробуйте, уверен, все должно получиться!
Попробовал, все равно пустой список, к сожалению. Для наглядности — это в процедуре:
Показать
Это в ограничениях доступа к данным в роли для справочника ХарактеристикиНоменклатуры:
(60) Обратите внимание еще на пункты 5 и 6, возможно справочник характеристик следует включить в состав определяемого типа и в подписку на событие, и запустить конфигурацию в режиме обновления ИБ (пункт 9), попробуйте, других вариантов мне пока в голову больше не приходит.
(61) Реализовал пункты 5 и 6, произвел обновление, но все равно список остался пустым. Возникла ещё мысль по этому поводу. А в процедуру «ПриЗаполненииВидовДоступа» не нужно добавлять характеристики?
(62) По идее нет, но чем черт не шутит, поэкспериментировать не навредит 😉
(63) Последнюю вещь даже не стал пробовать, которую сам предложил, какая то всё-таки она не логичная… Вернул всё как было, что отображались в итоге и элементы справочника характеристик с «объект не найден». Можно будет просто у пользователя отбор настроить… А в общем спасибо за статью, рабочая, можно пользоваться!!!
Не очень понял зачем
источником для данной подписки является только ОпределяемыйТип.ЗначениеДоступаСГруппамиЗначенийДоступаОбъект
а для него соответствует только одно значение
СправочникОбъект.ИдентификаторыОбъектовМетаданных
у меня версия 2.4.3.61, нет 2.2 что бы сравнить, разбираюсь сам, еще в процессе, вот наткнулся на статью, теперь вопросы
(65) Возможно в БСП 2.4 принцип настройки механизма немного изменился (надеюсь, не кардинально) и включать интересующий справочник в определяемый тип требуется (хотя я сомневаюсь что это так), в версии 2.2, на сколько помню, такого определяемого типа не было. Я бы на вашем месте с этим вопросом просто поэкспериментировал — сначала как есть, если желаемого результата не будет, то включить справочник в определяемый тип.
Пункт 9. Запустить конфигурацию в режиме «Предприятия» с параметром запуска «ЗапуститьОбновлениеИнформационнойБазы»:
— Если вам потребовалось обновить идентификаторы объектов метаданных в 1С, то сапое простое это запустить базу с ключом:
/c ЗапуститьОбновлениеИнформационнойБазы
(67) Это дополнение к п.9 или замечание к нему? 🙂
дополнение) потратил время на поиск данного нюанса, если включюте в публикацию будет замечательно
(69) Это уже относится к использованию БСП в целом, а не к конкретной подсистеме, данный параметр запуска системы не только обновляет данные в справочнике идентификаторов объектов, но также инициирует запуск ряда других обработчиков, необходимых для полноценного обновления ИБ, поэтому я не стал в данной статье расшифровывать назначение данного параметра, а просто прописал это как инструкцию к выполнению.
Теперь вопрос на засыпку, что если необходимо ограничить доступ к справочнику не только по группам, но еще и по элементам, как реализовать такую возможность?
На данный момент получилось сделать либо по элементам, либо по группам
Приведу пример зачем это нужно, один пользователь входит в базу — внешний клиент — ему доступно видеть только свои контрагенты от 1 до 5 шт, другой пользователь — менеджер ему доступны контрагенты у которых установлена группа контрагентов — «регион север», причем внешник может попадать в группу «регион север».
Думаю единственный способ ставить группу доступа как табличную часть и в ней настраивать две группы контрагентов списком — «регион север» и «клиент№15». Или есть какой то более продвинутый способ.
Спасибо, очень помогло для понимания 🙂
Спасибо, за статью. Очень помогла.
Дополнение от меня.
Если вы назначаете пользователю несколько ролей, работающих с одним и тем же документом или справочником, то нужно прописать ограничение во всех ролях где используется документ или справочник.
У меня ограничение выглядит вот так:
#ПоЗначениям(«Документ.уатСливГСМ», «чтение», «», «Организации», «Организация», «Подразделения», «Подразделение», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»», «»,»»)
Иначе, если укажите только в одной роли а в другой не укажите, то документ НЕ скроется, а скроются только подразделение — будет написано что объект не найден. см. картинку.
(73) Да, верно, так и есть, именно так и работает платформенный механизм ограничения прав на уровне записей таблиц (RLS) и настройка доступа через роли — если право предоставлено одной из ролей, то запреты других ролей игнорируются.
(74) я думаю тебе стоит это указать в статье, т.к. я это не сразу сообразил, уже хотел здоровый комент писать.
Большое спасибо, очень полезная инфо!
Благодаря этой публикации, когда-то, легко применил новые требуемые виды доступа в УНФ 1.6.7.43. На днях апнул её до актуальной на сегодня 1.6.13.48, БСП в ней 2.4.4.124 — по прежнему всё прекрасно робит!
(шаблоны, правда, поменялись с тех пор — пришлось переписать свои ограничения)
Скажите пожаааалуйста..а если задача состоит в том, чтобы привязать к одному партнеру НЕСКОЛЬКО групп доступа партнеров, а не одну. Как быть? Создаю табличную часть в справочнике Партнеры: ГруппыДоступа, в которой есть реквизит «ГруппаДоступа» с типом «СправочникСсылка.ГруппыДоступаПартнеров». Как в этом случае построить ограничение доступа?
(77)Все так же. Только необходимо ещё добавить в определяемый тип ЗначениеДоступаСГруппамиЗначенийДоступаОбъект справочник Партнеры. А в процедуре «ПриЗаполненииВидовДоступа» модуля «УправлениеДоступомПереопределяемый» добавить строку ВидДоступа.НесколькоГруппЗначений = Истина;
(6) А как бы понять на что влияет эта процедура? Чего мы лишимся если здесь ничего не указать? Ведь шаблоны RLS все равно сработают если они заданы в роли?
Искал по РЛС что то так долго, в итоге сам разобрался и сделал статью, а тут вашу нашел, и тут именно то же самое))) от блин, аж стыдно теперь)))
А может кто пробовал без изменения конфигурации, а только используя Расширение?
(74) Извиняюсь, что обращаюсь, но может подскажите.
Тут суть такая: делал всё строго по инструкции, вид доступа добавился.
Создал нового пользователя с минимальным кол-ом ролей.
Все роли проверил, но суть в том, что отбор не происходит.
Получается я создал новый справочник с ссылкой на другой справочник. В нём (новом спр.) создал (в режиме предприятия уже) запись с владельцем из типового справочника.
Роли все проверял — везде всё ограничено, но вполне возможно, как то не верно настроил ограничения.
Какие варианты могут быть?
(74)в частности меня интересует данный пункт:
Заполнить только что добавленный в систему справочник «Группы доступа контрагентов».
У элементов справочника «Контрагенты» заполнить необходимым образом реквизит «Группа доступа».
Как данный реквизит необходимо заполнить?