1С 7.7. Разрешительный режим на кассах. Честный знак. Онлайн проверка с 01.04.2024. Три варианта отправки API запросов, два из них работают на старых Windows

17.06.24

Интеграция - WEB-интеграция

В связи с нововведением Разрешительного Режима Онлайн проверки, написал механизм взаимодействия 1С 7.7 с Честным знаком. Использовал три варианта отправки запросов.

Скачать файл

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

Наименование SM По подписке [?] Купить один файл
Архив с данными 002
.zip 3,47Mb
11
11
3 SM
Скачать Купить за 2 450 руб.

Согласно документации, находящейся по ссылке:
https://честныйзнак.рф/business/projects/retail/checkout/regulations/ описал методику работы. Учел временные блокировки серверов (по умолчанию на 15 мин.), то, что запросы доступных площадок нужно делать раз в шесть часов, то, что может быть аварийный режим в самом ЦРПТ,...... , все эти ситуации работают в автоматическом режиме:

//****************************************************************************** 
Процедура глУстановитьАварийнуюБлокировкуСервераОнлайнПроверкиЦРПТ(ПроверитьБлокировку=0,КолДнейБлокировки=0) Экспорт        //Позволяется устанавливать блокировку! По умолчанию устанавливаем блокировку на сутки.
	Если ПроверитьБлокировку=1 Тогда
		Если ТекущаяДата()>Константа.ДатаВременнойБлокировкиОнлайнПроверокМарокЧерезЦРПТ Тогда
			Константа.АварийнаяБлокировкаОнлайнПроверокМарокЧерезЦРПТ		= 0;
			Константа.ДатаВременнойБлокировкиОнлайнПроверокМарокЧерезЦРПТ	= "";		
		КонецЕсли;
	Иначе
		Если КолДнейБлокировки<=0 Тогда
			КолДнейБлокировки	= 1;
		КонецЕсли;
.................  и т.д.



//****************************************************************************** 
Процедура глУстановитьБлокировкуСервераОнлайнПроверкиЦРПТ(АдресПлощадки,ВремяБлокировкиЦРПТ=0) Экспорт  
	Если ВремяБлокировкиЦРПТ<=0 Тогда
		ВремяБлокировкиЦРПТ	= 15; //По умолчанию блокируем на 15 мин.
	КонецЕсли;   	
	ТекДатаБлокировки	= ТекущаяДата(); 
	ТекЧасПроверки	= 0;	        
	ТекМинПроверки	= 0;	        
	ТекущееВремя(ТекЧасПроверки,ТекМинПроверки);
	ТекМинБлокировки	= ТекЧасПроверки*60+ТекМинПроверки+ВремяБлокировкиЦРПТ;	
	КолДнейПлюсом		= Цел(ТекМинБлокировки/1440);
	Если КолДнейПлюсом>0 Тогда
		ТекДатаБлокировки	= ТекДатаБлокировки+КолДнейПлюсом;
		ТекМинБлокировки	= ТекМинБлокировки-КолДнейПлюсом*1440;
	КонецЕсли;  	
.................  и т.д.


//****************************************************************************** 
Функция ВернутьТекущийСерверОнлайнПроверкиЦРПТ(ТекДатаПроверки,ТекЧасПроверки,ТекМинПроверки) Экспорт
	глКоличествоДоступныхСерверовОнлайнПроверкиЦРПТ	= 0;
	ВыбТекСервЦРПТ	= "";
	СпрСервераДляОнлайнПроверкиВЦРПТ	= СоздатьОбъект("Справочник.СервераДляОнлайнПроверкиВЦРПТ");
	СпрСервераДляОнлайнПроверкиВЦРПТ.ПорядокРеквизита("Приоритет");
	СпрСервераДляОнлайнПроверкиВЦРПТ.ВыбратьЭлементы();
	Пока  СпрСервераДляОнлайнПроверкиВЦРПТ.ПолучитьЭлемент() = 1 Цикл		
		Если ТекДатаПроверки=СпрСервераДляОнлайнПроверкиВЦРПТ.ДатаПровеки Тогда 
			Если (ТекЧасПроверки-СпрСервераДляОнлайнПроверкиВЦРПТ.ЧасПроверки)<6 Тогда //Проверка серверов еще не требуется				
				врЕстьБлокировкаЦРПТ	=0;
				Если ПустоеЗначение(СпрСервераДляОнлайнПроверкиВЦРПТ.ДатаБлокировкиДо)=0 Тогда //Проверяем, а не заблокирован ли временно сервер!
					Если (ТекДатаПроверки<СпрСервераДляОнлайнПроверкиВЦРПТ.ДатаБлокировкиДо) Тогда
						врЕстьБлокировкаЦРПТ	=1;
					ИначеЕсли (ТекДатаПроверки=СпрСервераДляОнлайнПроверкиВЦРПТ.ДатаБлокировкиДо) и ((ТекЧасПроверки*60+ТекМинПроверки)<СпрСервераДляОнлайнПроверкиВЦРПТ.ВремяБлокировкиДо) Тогда
.................  и т.д.

Функция  глОбновитьДанныеПлощадокCDN(ПринудительноОбновить=0,ВывестиСообщение=0) Экспорт	                     	
	Рез = СоздатьОбъект("СписокЗначений");
	Рез.Установить("ТекстОшибки","");
	Рез.Установить("КодОтвета",0);		
	ТекЧасПроверки	= 0;	        
	ТекМинПроверки	= 0;	        
	ТекущееВремя(ТекЧасПроверки,ТекМинПроверки);
	ТекДатаПроверки	= ТекущаяДата();                                                                                                
	Если ПринудительноОбновить=0 Тогда
		глТекущийСерверОнлайнПроверкиЦРПТ	= ВернутьТекущийСерверОнлайнПроверкиЦРПТ(ТекДатаПроверки,ТекЧасПроверки,ТекМинПроверки);		
		Если ПустоеЗначение(глТекущийСерверОнлайнПроверкиЦРПТ)=0 Тогда
			Возврат Рез;
		КонецЕсли;
	КонецЕсли;	
	РезЗапроса 	= глЗапроситьДанныеПлощадокCDN(ВывестиСообщение); 			
	ТекстОшибки	= СокрЛП(РезЗапроса.Получить("ТекстОшибки"));  		
	КодОтвета	= РезЗапроса.Получить("КодОтвета");
	Рез.Установить("КодОтвета",КодОтвета);
	Рез.Установить("ТекстОшибки",ТекстОшибки);
	Если КодОтвета=203 Тогда //Включена Аварийная ситуация!
		Если ВывестиСообщение=1 Тогда
			Сообщить("Текст ошибки: Включена аварийная ситуация в ЦРПТ! Код ошибки: 203");	
		КонецЕсли;		
		Возврат Рез;
	ИначеЕсли (КодОтвета=401) или (ПустоеЗначение(КодОтвета)=1) Тогда
		Возврат Рез;
	КонецЕсли;	
	ЕстьОшибки	= 0;
	Если ПустоеЗначение(ТекстОшибки)=1 Тогда //Ошибок нет
		ВыбраннаяПлощадка	= РезЗапроса.Получить("ВыбраннаяПлощадка");
		Если ВыбраннаяПлощадка<>"" Тогда
			глТекущийСерверОнлайнПроверкиЦРПТ 	= ВыбраннаяПлощадка;			
		Иначе
			ЕстьОшибки	= 1;
			Если ВывестиСообщение=1 Тогда
				Сообщить("Текст ошибки: Не определен оптимальный сервер в ЦРПТ!");	
			КонецЕсли;		
		КонецЕсли;		

                ...................... и т.д.


Функция ВыполнитьОнлайнПроверкуЦРПТ(ТекНом,текКМ,РезОнлайнПроверкиЦРПТ,ТекНомерФН="",ПовторЗапроса=0)
	Рез	= 1;      
    Если (Константа.ОнлайнПроверкаМарокЧерезЦРПТ=1) и (Константа.АварийнаяБлокировкаОнлайнПроверокМарокЧерезЦРПТ<>1) Тогда		
		//Если ПроверитьТипМаркируемойПродукцииДляОнлайнПроверкиВЦРПТ(ТекНом)=1 Тогда    //Здесь проверяем, а нужно ли вообще делать проверку данного типа продукции
			Токен	= СокрЛП(Константа.ТокенДляОнлайнПроверкиВЦРПТ);
			Если ПустоеЗначение(Токен)=1 Тогда       			
				ОписаниеРезультата = "Ошибка! Не заполнен Токен в Константах для онлайн проверки ЦРПТ!";
				Рез	= 0;
			Иначе   
				КодОтвета	= 0;  
				ТекстОшибки	= "";
				Если ПустоеЗначение(глТекущийСерверОнлайнПроверкиЦРПТ)=1 Тогда
					РезПроверки	= глОбновитьДанныеПлощадокCDN();			
					КодОтвета	= РезПроверки.Получить("КодОтвета");					
					ТекстОшибки	= РезПроверки.Получить("ТекстОшибки");
				КонецЕсли; 
				Если КодОтвета=203 Тогда
					//Включили аварийный режим!
				ИначеЕсли КодОтвета=401 Тогда					
					ОписаниеРезультата = ТекстОшибки;
					Рез	= 0;
				ИначеЕсли ПустоеЗначение(глТекущийСерверОнлайнПроверкиЦРПТ)=1 Тогда
					ОписаниеРезультата = "Ошибка! Нет доступных серверов для онлайн проверки в ЦРПТ!";
					Рез	= 0;
				Иначе
					РезПроверки = глВыполнитьОнлайнКонтрольМаркиЧестныйЗнак(СокрЛП(текКМ),ТекНомерФН);				
					ТекстОшибки	= РезПроверки.Получить("ТекстОшибки");					
					Если ПустоеЗначение(ТекстОшибки)=0 Тогда          
						Рез	= 0;
						КодОтвета	= РезПроверки.Получить("КодОтвета");
						ОписаниеРезультата = ТекстОшибки;						
						Если ПустоеЗначение(КодОтвета)=1 Тогда //сервер не ответил
							Если (глКоличествоДоступныхСерверовОнлайнПроверкиЦРПТ>1) и (ПовторЗапроса =0) Тогда
								ПовторЗапроса	= 1;
								глУстановитьБлокировкуСервераОнлайнПроверкиЦРПТ(глТекущийСерверОнлайнПроверкиЦРПТ,15);     
								глОбновитьДанныеПлощадокCDN();								
								Рез =ВыполнитьОнлайнПроверкуЦРПТ(ТекНом,текКМ,РезОнлайнПроверкиЦРПТ,ТекНомерФН,ПовторЗапроса); //Повторная проверка
								Если Рез=1 Тогда
									ОписаниеРезультата = "";
								КонецЕсли;
							КонецЕсли;							     						
						ИначеЕсли (КодОтвета=203) или (КодОтвета=429) или (КодОтвета>=500) Тогда     							
							ЗаписатьЛогОшибкиОнлайнПроверкиЦРПТ(ТекНом,текКМ,ТекстОшибки,КодОтвета);
							Если (КодОтвета=203) или ((КодОтвета=5000) и (ПовторЗапроса=1)) Тогда //203 - Включена Аварийная ситуация!   5000 - просто можно пробивать далее без проверки!
								Если (КодОтвета=203) Тогда
									глУстановитьАварийнуюБлокировкуСервераОнлайнПроверкиЦРПТ();
								КонецЕсли;	
								Рез	= 1;
								ОписаниеРезультата = "";
							Иначе                                                           
								Если ПовторЗапроса	= 0 Тогда
									ПовторЗапроса	= 1;
								Иначе                    
									ПовторЗапроса	= 0;
									глУстановитьБлокировкуСервераОнлайнПроверкиЦРПТ(глТекущийСерверОнлайнПроверкиЦРПТ,15);     
									глОбновитьДанныеПлощадокCDN();
.................  и т.д.

Сделал три варианта отправки API запросов (марки экранируются, проблем с двойными кавычками внутри я не увидел - проходят корректно):

1) WinHttp.WinHttpRequest.5.1 - за описание этого метода, огромное спасибо: Кириллу Логинову
(kirlog). Но этот метод работает только на свежих операционках Windows. Два способа ниже работают и на старых операционках;
        

        HTTPЗапрос = СоздатьОбъект("WinHttp.WinHttpRequest.5.1");
        HTTPЗапрос.Option(2,"utf-8");
        HTTPЗапрос.SetTimeouts(1500, 1500, 1500, 1500);    
        HTTPЗапрос.Open("POST",АдресРесурса,1);    
        HTTPЗапрос.SetRequestHeader("X-API-KEY", СокрЛП(Токен));
        HTTPЗапрос.SetRequestHeader("Accept-Charset", "utf-8");
        HTTPЗапрос.SetRequestHeader("Content-Type", "application/json; charset=utf-8");    
                ...................... и т.д.


2) Curl1С.dll - через внешнюю компоненту, визуально, по ощущениям, скорость работы аналогична первому варианту. Проблем с запросами я не увидел. 
        

        глКарлик.УстановитьПараметр("URL",АдресРесурса);              
        глКарлик.УстановитьПараметр("TIMEOUT",ТаймаутОжидания);
        глКарлик.УстановитьПараметр("HTTPHEADER","Content-Type: application/json;charset=utf-8");
        глКарлик.УстановитьПараметр("HTTPHEADER","Accept-Charset: utf-8");
        глКарлик.УстановитьПараметр("HTTPHEADER","X-API-KEY: "+СокрЛП(Токен)); 
        глКарлик.УстановитьПараметр("CUSTOMREQUEST","POST");   
    
                ...................... и т.д.


3) Curl.exe -  бросаемся командами на экзешник. Визуально работает чуть медленней двух предыдущих вариантов, т.к. все делаем через файлы (запись, удаление). Но, несмотря на чуть медленную работу, для меня этот вариант весьма рабочий, т.к. еще несколько лет назад сделал работу с ЕГАИСом по аналогичной схеме и до сих пор работает все замечательно.
                  

КомандаСистемыСкрипт( КаталогИБ()+"curl.exe -d ""@"+ПутьКТелуЗапроса+""" -s -w \nRespCode:%{response_code} -H ""X-API-KEY: "+СокрЛП(Токен)+..................................... и т.д.

В архиве находятся все необходимые файлы, включая MD, в котором реализовано описанное выше. Код полностью открыт. 

Тестировалось все на платформе: 7.70.027. Конфигурация: любая!!!

Данный механизм можно взять как готовую основу для внедрения в свою программу. Логика работы с ЦРПТ реализована (согласно документации), думаю, почти вся.  Как минимум можно сэкономить немало времени на внедрении.

 

Обновление: 14.04.2024 - Архив с данными 002.zip

Улучшен механизм обработки результата ответа от ЦРПТ.

Устранены выявленные ошибки.

См. также

Оптовая торговля Розничная торговля ККМ ЭДО и ОФД Обмен с ГосИС Системный администратор Программист Оперативный учет 7.7 Бухгалтерский учет 7.7 1С:Бухгалтерия 7.7 1С:Комплексная 7.7 1С:Торговля и склад 7.7 Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Россия Платные (руб)

Подключение фискального регистратора к 1С 7.7 в режиме онлайн-кассы (в соответствии с 54-ФЗ). Поддержка крайних версий драйверов ККТ: ДТО 10 и ДТО 8 для Атол, 4.15, 5.16 для Штрих-М. Поддержка протоколов ФФД 1.0, 1.05, 1.1 и 1.2, развитые настройки для применения частичных оплат и авансов в оптовой и розничной торговле. Поддержка чеков коррекции всех версий. Поддержка розничной продажи маркированной продукции (ЕГАИС, табак, обувь, лекарства, шины, одежда, белье, парфюмерия, молочная продукция, вода и пр.). Вывод электронного чека (на е-майл, телефон) по требованию покупателя, поддерживаются комбинированные типы оплаты, режим эмуляции печати чека на ФР. Полный цикл работы из 1С 7.7 с маркировкой Честный ЗНАК (ГИСМТ, ЦРПТ) из 1С 7.7. ЭДО (табак, обувь, шины, одежда, молочная продукция, вода и прочие группы товаров) для розницы и опта (приемка и оптовая отгрузка маркированной продукции). Поддерживается как объемно-сортовой учет (ОСУ) так и поштучный (поэкземплярный) учет.

2000 руб.

28.03.2017    472288    4334    3474    

2443

Разработка внешних компонент WEB-интеграция Программист Платформа 1С v7.7 Конфигурации 1cv7 Платные (руб)

Компонента HttpSrv7 позволяет создавать веб-сервисы в среде 1С 7.7 и даже, используя файлы HTML, несложные веб-сайты. С помощью нее можно обеспечить доступ к данным 1С 7.7 из браузера. Дополнительно используя компоненту HTTP_Async или синхронный клиент HTTP для 1С 7.7 (публикация № 1152364) можно наладить обмен данными между удаленными информационными базами. С помощью компоненты HTTP_Async можно сначала послать несколько запросов к сайтам, веб-сервисам (в т.ч. к HttpSrv7), а затем обрабатывать данные по мере их поступления. Компонента GISMT в дополнение к HTTP_Async имеет функцию цифровой подписи и, таким образом, имеет все возможности для работы с API ГИС МТ "Честный знак" непосредственно из среды 1С 7.7.

2000 руб.

27.05.2022    8267    21    17    

32

Оптовая торговля Розничная торговля Обмен с ГосИС Бухгалтер Оперативный учет 7.7 Бухгалтерский учет 7.7 1С:Бухгалтерия 7.7 1С:Комплексная 7.7 1С:Торговля и склад 7.7 Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Россия Бухгалтерский учет Управленческий учет Акцизы Платные (руб)

Полностью автоматизированный обмен данными между конфигурациями 1С 7.7 и универсальным транспортным модулем (УТМ) ЕГАИС для всех видов деятельности (Опт, Розница, Производство, Импорт). Для организации обмена с ЕГАИС требуется минимальная доработка конфигураций (поддерживается 1С: "Торговля и склад ред. 9.2", 1С: "Бухгалтерия 7.7", 1С: "УСН 7.7", другие конфигурации по заказу, включая нетиповые). В данном программном продукте реализованы все технические требования ФСРАР по обмену с УТМ ЕГАИС (включая отправку чеков розничных продаж в ЕГАИС - требование с 01.07.16). Поддержана фиксация чеков ЕГАИС на онлайн-кассах (в соответствии с 54-ФЗ). Поддержана версия 3 документооборота и поштучный (помарочный) учет. Поддержан эксперимент Татарстана по маркировке нефасованного (кегового) пива.

3000 руб.

13.12.2015    136840    169    400    

146

Обмен с ГосИС Программист Платформа 1С v7.7 Платформа 1С v8.3 1С:Управление торговлей 10 Россия Абонемент ($m)

Уже с 01.04.2024 вводится так называемый "разрешительный" режим продажи маркированной продукции в розницу. Это значит, что перед продажей нужно запрашивать у сервиса ЦРПТ разрешение на реализацию каждой марки. Здесь кратко опишу, как это делается, и приложу примеры для 1С 8 и 7.7.

1 стартмани

15.03.2024    4951    56    kirlog    73    

21

Обмен с ГосИС Программист Платформа 1С v7.7 1С:Комплексная 7.7 1С:Торговля и склад 7.7 Ювелирная промышленность и торговля Россия Бухгалтерский учет Абонемент ($m)

Интеграция 1С 7.7 с ГИИС ДМДК (маркировка ювелирных изделий и драгоценных камней). Данная публикация является попыткой выяснения спроса на полноценную интеграцию конфигураций на базе платформы 1С 7.7 с ГИИС ДМДК (https://dmdk.ru/). На текущий момент реализована печать ценников-бирок, содержащие УИН продукции в формате ШК Datamatrix. Имеются планы разработки решения для учета розничных продаж через УТМ (Универсальный Транспортный Модуль) из 1С 7.7.

1 стартмани

01.03.2022    5812    1    victuan    0    

17

WEB-интеграция Мастера заполнения Программист Пользователь Платформа 1С v7.7 1С:Торговля и склад 7.7 Россия Абонемент ($m)

Обработка для заполнения контрагента по ИНН с сайта DAData для Торговли.

2 стартмани

17.02.2022    4583    11    lazarsr    0    

1

Обмен с ГосИС Программист Платформа 1С v7.7 Конфигурации 1cv7 Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Россия Абонемент ($m)

Конец 2021 и начало 2022 года принесло много увлекательной работы в связи с переходом на ГИИС ДМДК. Все движения драгоценных металлов и камней должны отражаться в ГИИС. Для этого есть два пути: ручной ввод или интеграция существующей учетной системы с ГИИС. Ручной ввод не подходит тем организациям, которые имеют большое количество движений, а интеграция слишком дорога для небольших магазинчиков. Но самое неприятное в том, что в настоящий момент для интеграции требуется обезличенная ЭЦП, а выдавать ее никто не может или не имеет права. Это и привело меня к разработке продукта, который бы позволил автоматизировать часть работы с помощью эмуляции действий пользователя в личном кабинете.

1 стартмани

04.02.2022    4994    0    aldan    0    

3
Оставьте свое сообщение