Обмен сообщениями "Системы взаимодействия 1С" с "НЕ 1С" системой. Где хранятся файлы вложений и как получить их местоположение в хранилище s3?

31.05.22

Интеграция - Внешние источники данных

Вы когда-нибудь задавались вопросом: где хранятся сообщение и их прикрепления «Системы взаимодействия 1С»? Мне пришлось!

Решили мы запилить интеграцию обмена сообщениями с не 1С системой (и даже не с одной). Причем мы на тот момент уже использовали "Систему взаимодействия1С", поэтому решили не пилить функциональность с нуля, а "просто" интегрировать "Систему взаимодействия 1С" и "не 1С". Одни ребята из изъявивших желание обмениваться с нами сообщениями уже имели с нами интеграцию по soap, другие по http. Соответственно мы на своей стороне реализовали новые ws и http сервисы и написали код по дерганью их за их аналогичные места))). Далее задача усложнилась, потому что возникла потребность обмениваться файлами. И завертелось. Возникла куча вопросов:

Продолжать ли на нашей стороне пользоваться «Системой взаимодействия 1С»?

Если да, то как положить и еще интереснее, как достать файлы?

Как при этом минимизировать передачу по сети?

Как обеспечить одно место хранения файлов?

Оказалось, что на другой стороне умеют общаться с s3 хранилищами файлов. Тогда, проведя «мозговой штурм», придумали следующую схему:

1С --> не 1С

  1. Перехватываем управление ПослеОтправкиСообщения()
  2. Получаем данные ИД обсуждения и ИД сообщения
  3. Далее по ним каким-то образом находим адрес файла в хранилище s3
  4. Передаем полученные адреса файлов при вызове сервиса.

Не 1С --> 1С

  1. При вызове нашего сервиса создаем сообщение
  2. Из полученных параметров вызова понимаем, с каким расширением файл планируется получить (то есть нам в сервис передают только имя и расширение файлов, но не сами файлы).
  3. Мы, зная имя и расширение, прикрепляем к сообщению файлы пустышки с нужным именем и расширением.
  4. Получаем их адреса в хранилище s3 и передаем эти адреса в ответе на вызов нашего сервиса.
  5. На той стороне, получив адреса, меняют наши файлы пустышки на реальные.

Как же получить путь к файлам в хранилище s3.Все просто:

лсТекстЗапроса = "

                |SELECT DISTINCT
                |    s_file.prefix AS Catalog_file,
                |    s_file.id::varchar AS Name_file,
                |    att.name AS Name_file_real
                |FROM vb_subscriber_ХХ_ХХ.conversation_message con_m
                |    INNER JOIN vb_subscriber_ХХ_ХХ.attachment AS att
                |    ON con_m.id = att.message_id
                |    INNER JOIN vb_subscriber_ХХ_ХХ.stored_file AS s_file
                |    ON att.file_id = s_file.id
                |    AND att.subscriber_id = s_file.subscriber_id
                |WHERE
                |    con_m.conversation_id = '" + асИДОбсуждения + "'
                |    AND con_m.id = '" + асИДСообщенияб + "';
                |";    

Мы обращаемся к таблице conversation_message (сообщения обсуждений), устанавливаем отбор по ИД нашего обсуждения и ИД нашего сообщения. Далее соединяемся с таблицей attachment (прикрепления) по ИД сообщения. Из нее мы возьмем реальное имя файла (это важно, в тот момент, когда мы свой файл хотим кому-то передать) и также отсюда берем имя файла в хранилище s3. Далее по нему мы соединяемся с таблицей stored_file (хранилище файлов), из которой мы берем каталог, где лежат наши прикрепления. Вот, собственно, и все: мы знаем, где лежат, как называются в хранилище и как называются реально наши прикрепления.

Если интересно, могу расширить статью следующей информацией:

  1. Выложить ws и http, реализованный на нашей стороне
  2. Код по перехвату события ПослеОтправкиСообщения() и код дальнейших действий по вызову другой стороны для передачи сообщения с прикреплениями или без.
  3. Также могу выложить полный код обращения к PG SQL, для получения адресов прикреплений (если в этом есть необходимость).
  4. Отдельно могу описать структуру таблиц PG SQL «Системы взаимодействия 1С», если это кому-то нужно

Потребности пишите в комментариях. Ну и, конечно же, ставьте лайк, подписывайтесь на канал!))))

См. также

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 руб.

12.06.2017    143332    821    297    

428

SALE! 10%

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

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

55778 50200 руб.

04.08.2015    168368    344    279    

380

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.20.x), также подходят для релиза 11.5 (11.5.19.x).

35000 31500 руб.

23.07.2020    53427    236    73    

192

Внешние источники данных Программист Бизнес-аналитик Пользователь Платформа 1С v8.3 Управляемые формы Анализ и прогнозирование Конфигурации 1cv8 Узбекистан Беларусь Кыргызстан Молдова Россия Казахстан Платные (руб)

Готовое решение для автоматической выгрузки данных из 1С 8.3 в базу данных ClickHouse, PostgreSQL или Microsoft SQL для работы с данными 1С в BI-системах. «Экстрактор данных 1С в BI» работает со всеми типовыми и нестандартными конфигурациями 1С 8.3 и упрощает работу бизнес-аналитиков. Благодаря этому решению, специалистам не требуется быть программистами, чтобы легко получать данные из 1С в вашей BI-системе.

28500 руб.

15.11.2022    21615    22    49    

39

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.237.x) и БП 3.0 (3.0.166.x). Правила подходят для версии ПРОФ и КОРП.

35000 31500 руб.

15.12.2021    24828    174    51    

132

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    37247    99    66    

95

Внешние источники данных Зарплата Бюджетный учет Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактическим удержаниям, НДФЛ, вычетам, страховым взносам из базы Парус 7.хх учреждений (далее Парус) в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

84000 руб.

24.04.2017    51862    104    165    

91

Перенос данных 1C Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет НДФЛ ФОМС, ЕФС Платные (руб)

Обработки для быстрого перехода с конфигураций «КАМИН:Расчет заработной платы 3.0», «КАМИН:Зарплата для бизнеса 4.0» и «КАМИН:Зарплата 5.0» на конфигурацию «Зарплата и управление персоналом» версии 3.1.

12000 руб.

25.09.2016    81568    324    253    

276
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Dmitrij-2 48 31.05.22 07:12 Сейчас в теме
Отдельно могу описать структуру таблиц PG SQL «Системы взаимодействия 1С», если это кому-то нужно

Было бы неплохо. Или это есть в документации?
2. Zlohobbit 272 31.05.22 07:35 Сейчас в теме
(1) Мне найти не удалась.((( Если у Вас получится, киньте сюда ссылку, плиз!
3. vandalsvq 1592 03.06.22 12:29 Сейчас в теме
(2) тогда в отдельную статью было бы круто +++
4. serg33rus 32 15.09.22 21:58 Сейчас в теме
Круто. Спасибо. Очень полезная инфа. И практически на блюдечке.
Еще раз огромное спасибо.
5. Zlohobbit 272 15.09.22 22:03 Сейчас в теме
(4)
(4) Рад что информация оказалось полезной! На ближайшем Инфостарт евент буду делать доклад на эту тему. Если интересно приходите! В первый день ближе к вечеру.
6. user1956479 11.01.24 10:26 Сейчас в теме
могу расширить статью следующей информацией

Дополните, пожалуйста
user1749632; user1603288; +2 Ответить
Оставьте свое сообщение