Изменение имени домена для выбранных пользователей информационной базы

30.01.20

База данных - Администрирование СУБД

Предлагаю Вашему вниманию обработку используемую в реальном производственном процессе на нашем предприятии. Задача переименования доменов возникла при реорганизации предприятия, имена некоторых доменов для удобства решено было изменить, но при таком количестве пользователей изменение имен доменов штатными средствами выглядело нереально. Было решено создать обработку для изменения имен доменов Информационной базы. Обработка предназначена для работы в клиент-серверных базах и тестировалась на платформе 8.3.14.1854. Работает в режиме внешней обработки.

Файлы

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

Наименование Скачано Купить файл
Изменение имени домена для выбранных пользователей информационной базы.:
.epf 10,35Kb
8 1 850 руб. Купить

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

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

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

   Алгоритм работы обработки выглядит так:
1. При нажатии кнопки "Создать список доменов" на закладке формы появляется список доменов, на котором необходимо галочками отметить домены, предназначенные для изменения.
2. В строку ввода "Новое имя домена" необходимо записать имя домена, на которое будут изменены отмеченные домены.   
3. После нажатия кнопки "Переименовать домены" запускается процедура переименования, по окончании обработки выйдет сообщение о количестве переименованных пользователей.
 

    Перейдем к рассмотрению программного кода.
    
    Процедура "ИнструкцияПоЭксплуатации" описывает порядок действий при пользовании обработкой.    

Код процедуры:

&НаКлиенте
 Процедура ИнструкцияПоЭксплуатации(Команда)
//Процедура выводит текстовый файл Инструкция по эксплуатации	 

	Инструкция="          Инструкция для обработки переименование доменов."+Символы.ПС+" 
	|1. В строку ""Новое имя домена"" запишите новое имя домена."+Символы.ПС+" 
	|2. Нажмите кнопку ""Создать список доменов"", на экране появится список доменов для данной базы."+Символы.ПС+" 
	|   Выберите те домены которые вы хотите изменить (поставте галочки)."+Символы.ПС+" 
	|3. Нажмите кнопку ""Переименовать домены"", по окончании обработки выйдет сообщение о количестве переименованных пользователей.";
	
	Предупреждение(Инструкция);
	
КонецПроцедуры

 

    Процедура "ПриОткрытииОбработки" запускает процедуру "СозданиеСпискаДоменов", результатом работы которой является список доменов базы.

Код процедуры:
  

&НаКлиенте
Процедура ПриОткрытииОбработки(Команда)
ОчиститьСообщения();
СозданиеСпискаДоменов();	
Сообщить("Список доменов создан,выберите нужные домены для переименования.");
	
КонецПроцедуры	

  

    Процедуры "СозданиеСпискаДоменов"    и  "ЗаполняемТаблицуВсеДомены" заполняют таблицу значений "ВсеДомены", в которую вносятся все домены пользователей базы.

Код процедуры:
        

&НаСервере
Процедура СозданиеСпискаДоменов() 
//Создаем Массив пользователей Информационной Базы для создания списка доменов ************************
		ВсеДомены.Очистить();
		ТаблицаДоменов.Очистить();
      Выборка= ПользователиИнформационнойБазы.ПолучитьПользователей();                	 
	  Для Каждого ЭлементМассива Из Выборка Цикл                                       
		          ПользовательУникльныйИдентификатор=ЭлементМассива.УникальныйИдентификатор;
				  
				  ЗаполняемТаблицуВсеДомены(ПользовательУникльныйИдентификатор);
				  
	  КонецЦикла;
			  
			      ЗаполняемТаблицуТаблицаДоменов();

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

 &НаСервере
Процедура ЗаполняемТаблицуВсеДомены(ПользовательУникльныйИдентификатор)
	  УстановитьПривилегированныйРежим(Истина);
//Заполняем таблицу ВсеДомены ************************************************************************			  
              ПользовательИБ = ПользователиИнформационнойБазы.НайтиПоУникальномуИдентификатору(ПользовательУникльныйИдентификатор);
              ФИО1  = ПользовательИБ.ПолноеИмя;
			  ДоменЛогин=ПользовательИБ.ПользовательОС;
			  ДлинаДомена=СтрДлина(ДоменЛогин);
			  СчетчикБукв=3;
			  Буква="";
			  ИмяДоменаВТаблице="";
			  Буква=Сред(ДоменЛогин,СчетчикБукв,1);
			Пока НЕ Буква="\" И СчетчикБукв < ДлинаДомена Цикл
				ИмяДоменаВТаблице=ИмяДоменаВТаблице+Буква; 
				СчетчикБукв=СчетчикБукв+1;
				Буква=Сред(ДоменЛогин,СчетчикБукв,1);  
			КонецЦикла;	 
			УстановитьПривилегированныйРежим(Ложь);
			 Строка=ВсеДомены.Добавить();
	         Строка.ИменаДоменов=ИмяДоменаВТаблице;
			 
КонецПроцедуры	
	

   

  Процедура "ЗаполняемТаблицуТаблицаДоменов" заполняет таблицу значений "ТаблицаДоменов", которая выводится на закладке формы для выбора изменяемого имени домена.    

Код процедуры:
        

&НаСервере
Процедура ЗаполняемТаблицуТаблицаДоменов()
	  УстановитьПривилегированныйРежим(Истина);
//Заполняем таблицу ВсеДомены ************************************************************************			  
    ПустойДомен="";
    СчетчикДоменов=1;
	ВД = РеквизитФормыВЗначение("ВсеДомены",Тип("ТаблицаЗначений"));                 //Выгружаем Табличный реквизит формы в переменную
	Запрос = Новый Запрос;
	МВТ=Новый МенеджерВременныхТаблиц;                                               //Создаем МенеджерВременныхТаблиц
	Запрос.МенеджерВременныхТаблиц=МВТ;
	Запрос.Текст = 
	        "ВЫБРАТЬ
	        |	ВД1.ИменаДоменов КАК ИмяДомена
	        |ПОМЕСТИТЬ ВТДанные
	        |ИЗ
	        |	&ВД1 КАК ВД1
	        |;
	        |
	        |////////////////////////////////////////////////////////////////////////////////
	        |ВЫБРАТЬ
	        |	ВТДанные.ИмяДомена КАК ИмяДомена
	        |ИЗ
	        |	ВТДанные КАК ВТДанные
	        |ГДЕ
	        |	ВТДанные.ИмяДомена <> &ПустойДомен
	        |
	        |СГРУППИРОВАТЬ ПО
	        |	ВТДанные.ИмяДомена"
		     ;
			 Запрос.УстановитьПараметр("ПустойДомен",ПустойДомен);
			 Запрос.УстановитьПараметр("ВД1",ВД);
	         РезультатЗапроса = Запрос.Выполнить();
	         Выборка = РезультатЗапроса.Выбрать();                                
			 Пока Выборка.Следующий() Цикл                                            //Выбираем результат запроса в цикле
				   Строка=ТаблицаДоменов.Добавить();
				   Строка.Номер=СчетчикДоменов;
	               Строка.ИмяДомена=Выборка.ИмяДомена;
				   СчетчикДоменов=СчетчикДоменов+1;
            КонецЦикла;   

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

 

    Процедура "КнопкаВыполнить" запускает процедуру изменения имени домена "ИзменениеИмениДомена" которая собственно изменяет выбранные имена доменов пользователей.    

Код процедуры:
        

&НаКлиенте
Процедура КнопкаВыполнить(Команда)
Сообщить("Начато изменение имен доменов.");
НовоеИмяДомена=ИмяДомена;
	Если НовоеИмяДомена="" Тогда
		Сообщить("Введите Новое Имя Домена, без него программа не работает");
		Возврат;
	КонецЕсли;

ИзменениеИмениДомена(НовоеИмяДомена);

Сообщить("Имена доменов изменены.");

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

&НаСервере
Процедура ИзменениеИмениДомена(НовоеИмяДомена)
//Создаем Массив пользователей Информационной Базы для изменения доменов *****************************
		КоличествоПользователей=0;
      Выборка= ПользователиИнформационнойБазы.ПолучитьПользователей();                	 
	  Для Каждого ЭлементМассива Из Выборка Цикл                                       
		          ПользовательУникльныйИдентификатор=ЭлементМассива.УникальныйИдентификатор;
				  
				  ИзменениеИмениДомена1(ПользовательУникльныйИдентификатор,НовоеИмяДомена,КоличествоПользователей);
				  
	  КонецЦикла;
	  
  Сообщить("Изменены домены у "+КоличествоПользователей+" пользователей.");

КонецПроцедуры
	 
 &НаСервере
Процедура ИзменениеИмениДомена1(ПользовательУникльныйИдентификатор,НовоеИмяДомена,КоличествоПользователей)
	  УстановитьПривилегированныйРежим(Истина);
//Разбиваем	ДоменЛогин на ДоменПользователя и ЛогинПользователя		  
              ПользовательИБ = ПользователиИнформационнойБазы.НайтиПоУникальномуИдентификатору(ПользовательУникльныйИдентификатор);
              ФИО1  = ПользовательИБ.ПолноеИмя;
			  ДоменЛогин=ПользовательИБ.ПользовательОС;
Если НЕ	ДоменЛогин="" Тогда		  
			  ДлинаДомена=СтрДлина(ДоменЛогин);
			  ДоменПользователя="";
			  ЛогинПользователя="";
			  Буква="";
			  СчетчикБукв=3;
			  Буква=Сред(ДоменЛогин,СчетчикБукв,1);
			  ФлагДЛ="Д";
	Пока СчетчикБукв <= ДлинаДомена Цикл
		Если Буква="\" Тогда
				ФлагДЛ="Л";
				СчетчикБукв=СчетчикБукв+1;
				Буква=Сред(ДоменЛогин,СчетчикБукв,1);
			Иначе
				Если ФлагДЛ="Д" Тогда
					ДоменПользователя=ДоменПользователя+Буква; 
					СчетчикБукв=СчетчикБукв+1;
					Буква=Сред(ДоменЛогин,СчетчикБукв,1);  
				КонецЕсли;
				Если ФлагДЛ="Л" Тогда
					ЛогинПользователя=ЛогинПользователя+Буква; 
					СчетчикБукв=СчетчикБукв+1;
					Буква=Сред(ДоменЛогин,СчетчикБукв,1);  
				КонецЕсли;
		КонецЕсли;
	КонецЦикла;	 
//Смотрим стоит ли у домена галочка выбора			  
	ТД = РеквизитФормыВЗначение("ТаблицаДоменов",Тип("ТаблицаЗначений"));            //Выгружаем Табличный реквизит формы в переменную
	Запрос = Новый Запрос;
	МВТ=Новый МенеджерВременныхТаблиц;                                               //Создаем МенеджерВременныхТаблиц
	Запрос.МенеджерВременныхТаблиц=МВТ;
	Запрос.Текст = 
	        "ВЫБРАТЬ
	        |	ТД1.ИмяДомена КАК ИмяДомена,
	        |	ТД1.ОтметкаВыбора КАК ОтметкаВыбора
	        |ПОМЕСТИТЬ ВТДанные
	        |ИЗ
	        |	&ТД1 КАК ТД1
	        |;
	        |
	        |////////////////////////////////////////////////////////////////////////////////
	        |ВЫБРАТЬ
	        |	ВТДанные.ИмяДомена КАК ИмяДомена,
	        |	ВТДанные.ОтметкаВыбора КАК ОтметкаВыбора
	        |ИЗ
	        |	ВТДанные КАК ВТДанные
	        |ГДЕ
	        |	ВТДанные.ИмяДомена = &ДоменПользователя
	        |	И ВТДанные.ОтметкаВыбора = ИСТИНА"
		     ;
			 Запрос.УстановитьПараметр("ДоменПользователя",ДоменПользователя);
			 Запрос.УстановитьПараметр("ТД1",ТД);
	         РезультатЗапроса = Запрос.Выполнить();
	         Выборка = РезультатЗапроса.Выбрать();                                
			 Пока Выборка.Следующий() Цикл                                            //Выбираем результат запроса в цикле
					ДоменЛогин="\\"+НовоеИмяДомена+"\"+ЛогинПользователя;
             		ПользовательИБ.ПользовательОС =ДоменЛогин;
    		  		ПользовательИБ.Записать();
					КоличествоПользователей=КоличествоПользователей+1;
			КонецЦикла; 
КонецЕсли;				
 			УстановитьПривилегированныйРежим(Ложь);
 
КонецПроцедуры

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

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

См. также

Администрирование СУБД Программист 1С v8.3 Россия Бесплатно (free)

Ошибка реструктуризации: "Запись не найдена в менеджере имен баз данных". Диагностика и решение проблемы.

22.08.2025    1000    a13k55    0    

13

Информационная безопасность Администрирование СУБД Системный администратор Бесплатно (free)

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

11.08.2025    1403    evvakra    4    

7

Администрирование СУБД Программист 1С v8.3 1C:ERP Бесплатно (free)

Небольшая инструкция, откуда взять функциональную модель для системы 1С: СППР и как её загрузить.

06.08.2025    1224    Senator_I    2    

4

HighLoad оптимизация Администрирование СУБД Системный администратор Программист 1С v8.3 Бесплатно (free)

Сегодня мы проведем обзор изменений, касающихся работы с высоконагруженными системами 1С. Новый релиз предлагает не просто несколько точечных исправлений, а целый арсенал специализированных функций, призванных существенно ускорить выполнение типичных для 1С операций, снизить нагрузку на инфраструктуру и упростить администрирование. Спектр улучшений распространился на многие ключевые узлы производительности от оптимизации работы с временными таблицами и сложными запросами RLS (row-level security) до ускорения критически важных процессов наподобие «Закрытия месяца». Обо всем этом и пойдет речь в статье.

22.07.2025    3657    Tantor    9    

10

Администрирование СУБД Системный администратор Бесплатно (free)

Расскажем об опыте внедрения технологии CoW (Copy-On-Write). Вы узнаете, как CoW помогает экономить терабайты дискового пространства с минимальными накладными расходами, а также как интегрировать ее в рабочие процессы разработки и тестирования. Автор кратко объяснит суть CoW, поделится выбором файловой системы (xfs или btrfs?), расскажет, как его команда управляет подтомами прямо из 1С и почему они выбрали MS SQL для Linux. Отдельно он разберет влияние CoW на CI-процессы: как это помогает анализировать длительные регрессы и ускоряет развертывание баз.

22.07.2025    1608    Golovanoff    7    

15

Администрирование СУБД Linux Сервера Системный администратор Программист Бесплатно (free)

В современных Windows 10 и 11 можно использовать WSL (Windows Subsystem for Linux) для запуска Linux окружения. Возникает соблазнительная мысль: может, PostgreSQL и сервер 1С запустить в WSL. Или даже хуже: в Docker на WSL. Знал бы, что будет сложно - даже не начинал :) Сложность кроется в том, что WSL это не полноценные виртуалки, а легковестные контейнеры Hyper-V с особенностями сети и GUI. Из плюсов, наверно, только размер и скорость запуска.

21.07.2025    1546    FSerg    2    

7

Администрирование СУБД Системный администратор Программист Бесплатно (free)

В статье подробно разберем, как в компании организован процесс миграции на PostgreSQL, начиная с подготовки команды, предварительного анализа 1С-систем (с использованием специальных чек-листов и инструментов для аудита) и заканчивая тонкой настройкой PostgreSQL. Расскажем о системе автоматизированного тестирования, которая позволяет сравнивать производительность на MS SQL и PostgreSQL без трудоемких ручных проверок. Особое внимание уделим проблемам, которые возникли при миграции систем объемом 20+ ТБ, и способам их решения. А также поразмышляем о том, что нужно было бы сделать по-другому, если бы этот проект пришлось начинать заново.

10.07.2025    1572    leongl    0    

10

Администрирование СУБД Системный администратор 1С v8.3 Россия Бесплатно (free)

В очередной раз столкнулся с тем, что очередные обновления тонкого клиента 1С для Mac OS, загруженные с сайта обновления ПО 1С, не устанавливаются через стандартный инсталлятор и дают ошибку. Но можно все установить вручную без сторонних приложений. Описываю процесс ручной установки тонкого клиента для платформы 8.3.27.1559 на Маке с OS Sequoia 15.5.

02.06.2025    3973    user1914479    17    

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