Скрипт для определения существования ролей в хранилищах конфигураций

07.05.24

Администрирование - Роли и права

В работе мы часто сталкиваемся с повседневными задачами. Когда их не так много, мы можем выполнять их вручную, но по мере увеличения их количества мы задумываемся об автоматизации. В этом нам помогают скрипты. На этом сайте уже есть много примеров скриптов, и я тоже хочу поделиться своим опытом создания скрипта на платформе 8.3.22.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Скрипт для определения существования ролей
.os 25,57Kb ver:1.1
0 1 850 руб. Купить
ВыгрузитьJSON
.epf 8,12Kb
0 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Предисловие

По мере моего роста в разработке на 1С я сталкивался со многими трудностями, одной из которых стала задача анализа наличия регламентированных ролей компании в большом количестве конфигураций. Разработка конфигураций происходит с помощью хранилищ конфигураций на выделенном сервере. Подключение к каждой конфигурации, а далее поиск по дереву метаданных может занимать большое количество времени, особенно, если конфигурации объемные.

Именно в этот момент у меня в голове появилась идея на основании моего опыта по разработке на OneScript создать скрипт, позволяющий избавить меня от страданий, который сформирует документ с конфигурациями и отметках наличия ролей.

Скрипт позволяет на основании списка конфигураций сформировать word документ, с отметками по ролям:

 

Результат работы скрипта

 

Параметры скрипта

Разберем параметры скрипта, которые необходимы для его работы:

 

Параметры

 

json_path

Необходимо указать путь к файлу описания конфигураций, в формате:

{
    "configurations_options": [
        {
            "name": "<Имя конфигурации>",
            "eng_name": "<Английское наименование>",
            "code": "<Код карточки конфигурации>",
            "storage_adress": "<Путь к хранилищу конфигурации>"
        },
   ... (Неограниченное количество конфигураций)
    ]
}

save_path

Каталог в который будут сохраняться .cf файлы конфигураций хранилища, для дальнешейго поиска ролей.

login & password

В каждой из хранилищ должен присутствовать технический пользователь с правами на просмотр, так как с помощью него мы будем подключаться к конфигурациям и искать роли.

К остальным параметрам комментарий не требуется.

 

Зависимости библиотек

Для корректной работы скрипта необходимы следующие библиотеки OneScript:

Важно!

В классе МенеджерХранилищаКонфиуграции необходимо прописать процедуру:

// Устанавливает используемую версию и разрядность платформы 1С
//
// Параметры:
//   МаскаВерсии - Строка - маска версии платформы 1С
//   Разрядность - РазрядностьПлатформы \ Неопределено - разрядность платформы 1C 
//
Процедура ИспользоватьВерсиюПлатформы(МаскаВерсии, Разрядность = Неопределено) Экспорт

	УправлениеКонфигураторомХранилища.ИспользоватьВерсиюПлатформы(МаскаВерсии, Разрядность);

КонецПроцедуры

Это необходимо для того, если на машине откуда собираетесь запускать скрипт установлено несколько платформ. Например версии хранилищ у вас работают на 8.3.22, а у вас установлена 8.3.24. v8storage автоматически берет последнюю версию. Если же у вас все версии совпадают, то можно не модернизировать v8storage. И при запуске скрипта в параметр -version нечего передавать не надо.

Выбор проверяемых ролей

Настройка переопределения проверяемых ролей выполняется в функции:

// Получает имена проверяемых ролей
// Есть возможность заполнения своми именами ролей
Функция ПолучитьИменаПроверяемыхРолей()
	
	Лог.Отладка("Получение имен проверяемых ролей");
	
	ИменаРолей = Новый Массив;
	
	ИменаРолей.Добавить("МояКомпания_Роль1");
	ИменаРолей.Добавить("МояКомпания_Роль2");
	ИменаРолей.Добавить("МояКомпания_Роль3");
	
	Возврат ИменаРолей;
	
КонецФункции

 

Формирование JSON структуры конфигураций

У нас ведется учет конфигураций и для выгрузки JSON файла я пользовался самописной обработкой ВыгрузитьJSON.epf.

 

РаботаОбработки

 

По итогу был получен JSON файл следующего вида:

 

JSON

 

В случае если на какой-то из конфигураций скрипт упал, формируется файл temp_results.json, в котором можно посмотреть, на каком хранилище мы освободились, и продолжить загрузку.

По окончании рабочего дня оставляем скрипт в работе и с утра радуемся выполненной работе :)

 

От автора

Со временем, если интерес к статье возрастет, я опубликую еще интересных скриптов. Если статья оказалась Вам полезной - пожалуйста, нажмите на "звездочку" и скачайте прилагаемый .os файл.

Вступайте в нашу телеграмм-группу Инфостарт

скрипт onescript 1script script роли проверка поиск

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    220235    1205    413    

1061

Зарплата Роли и права Системный администратор Бухгалтер 1С v8.3 Бухгалтерский учет Управление правами 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Комплексная автоматизация 2.х Молдова Россия Казахстан Бухгалтерский учет Платные (руб)

Расширение позволяет максимально полно ограничить доступ пользователей к данным по заработной плате, а именно закрывает доступ к документам начисления и выплаты заработной платы, не позволяет просматривать бухгалтерские отчеты по счету учета зарплаты а также убирает зарплатные проводки из журнала проводок. Расширение запрещает просматривать платежные документы на выплату зарплаты, так же не доступны регламентные отчеты в ПФР и ИФНС. Расширение предлагает готовые настроенные профили "Бухгалтер без зарплаты", "Только просмотр без зарплаты".

5940 руб.

27.05.2021    47221    365    111    

288

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

16000 руб.

10.11.2023    19897    76    39    

92

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 17.06.2025, версия 1.3

20400 руб.

06.12.2023    17933    67    10    

101

Роли и права Системный администратор Бухгалтер Пользователь 1С v8.3 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение предназначено для Бухгалтерии предприятия (версии ПРОФ и КОРП). Типовая конфигурация остается на поддержке. С помощью расширения менеджер по продажам будет иметь доступ к контрагентам и списку их документов только в случае, если он является для них ответственным. Пользователю с полными правами также доступна обработка «Назначение ответственных» для группового добавления/удаления ответственного в карточке контрагента. Есть версия данного расширения для клиентов Fresh - в магазине расширений (Fresh)

9360 руб.

14.09.2022    7701    13    6    

15

Роли и права Системный администратор Программист 1С v8.3 Управляемые формы Управление правами 1C:Бухгалтерия Платные (руб)

Получение необходимой информации по правам доступа в разрезе групп доступа, профилей групп доступа, пользователей / групп пользователей, объектов конфигурации и ролей. Легко можно настроить состав и порядок вывода информации по правам, настроить необходимые фильтры и получить более детальную расшифровку по группировкам отчета.

5000 руб.

16.11.2015    51933    97    46    

159

Ценообразование, анализ цен Роли и права Системный администратор 1С v8.3 Управление правами 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Расширение возможностей программы 1С:УНФ 1.6 и 3.0. Функционал расширения - разграничение всевозможных прав пользователей и контроль при совершении различных действий.

5016 руб.

23.02.2018    63769    177    264    

168
Для отправки сообщения требуется регистрация/авторизация