Открытый пакет интеграций для популярных API: Telegram, VK, Viber, Twitter

17.03.24

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

Open-source набор библиотек для интеграции с API некоторых популярных мессенджеров и соц. сетей.

 

В течение некоторого времени моим хобби является создание библиотек (общих модулей с методами) для интеграции с API различных социальных сетей. Это VKEnterprise, TelegramEnterprise и ViberEnterprise. Названия говорят сами за себя. Все их я выкладывал на GitHub в качестве отдельных репозиториев, однако со временем пришел к выводу, что такая система в конце концов даст сбой по нескольким причинам:

1. У библиотек очень много пересекающихся методов

Методы, отправляющие http-запросы, формирующие JSON и многие другие необходимы для работы с любым API без исключений. Но, порой, в них необходимо вносить правки, что приводит к необходимости обновлять данные методы в каждой из библиотек - было бы странно предлагать пользователю держать у себя почти одинаковые модули инструментов для каждой библиотеки отдельно. С ростом количества библиотек процесс подобной унификации становится сложнее.

2. Чехарда отдельных релизов

Подход отдельных проектов под каждый API хорош для пользователя, когда ему необходима работа только с чем-то одним. Как только используемых библиотек из линейки становится больше, возникают неудобства с отслеживанием обновлений каждой из них. Особенно остро этот вопрос может встать тогда, когда были внесены серьезные изменения в модули инструментов. Получая эти модули с обновлением, скажем, библиотеки работы с Viber может отвалиться более старая версия библиотеки Telegram, так как она теперь вызывает измененные методы инструментов с другими параметрами или возвращаемыми значениями. 

Поэтому было решено сделать единый проект для всех моих библиотек: как прошлых, так и создаваемых в будущем. Однако это не просто скидывание старых файлов в одну кучу. Проект получил много замечательных нововведений, о которых я сейчас расскажу

 

Что сейчас из себя представляет код ОПИ?

https://github.com/Bayselonarrend/OpenIntegrations

 

ОПИ на данный момент содержит 4 отдельные библиотеки: 3 старые для работы с Telegram, VK и Viber и одну новую - для работы с Twitter

 

 

 

Как и было ранее, каждая библиотека представлена отдельным модулем. Однако, в отличии от предыдущих проектов, которые распространялись как исходники с двумя общими модулями - основным и модулем инструментов, ОПИ имеет отдельные релизы сразу в трех вариантах: как XML файлы расширения для загрузки через конфигуратор, как EDT проект расширения и как отдельный файл расширения формата cfe (версия 1С 8.3.9 и выше)

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

 

 

 

Документация

Помимо объединения кода была создана и новая модная общая документация на базе Docusaurus. Найти ее можно по адресу opi.neocities.org. В данной документации собраны как общие положения о действиях, необходимых для начала работы с каждым отдельным API...


 

...Так и описание каждого конкретного метода, присутствующего в библиотеке: с примерами кода, описанием параметров и скриншотами результатов:

 

 

Следуя инструкциям и примерам, разработчик, даже не связывавшийся с подобной работой ранее, сможет легко организовать несложную интеграцию с представленными API

 

Тестирование и качество кода

Пару слов о контроле качества и тестировании:

Во-первых, объединение библиотек позволило организовать более-менее достоверное тестирование. Никакой особой магии я тут не придумывал: просто есть стенд с кнопками для каждого метода библиотеки. Я на них нажимаю и смотрю, что происходит. Это, конечно, не гарантирует абсолютное отсутствие багов, но хотя бы исключает попадание в релиз методов с нелепыми ошибками. 

Во-вторых, разработка ведется в EDT (Ruby 2023.2.4), что позволяет производить синтаксический анализ и следить за соблюдением стандартов. Это может показаться незначительным, но те, кто использует EDT у себя, знают как неприятно ловить замечания из привнесенного кода. Я не использую strcit-type, но хотя бы замечаний в проекте не остается. + есть комментарии-описания экспортируемых методов


 

В-третьих, у ОПИ есть свой проект SonarQube, что также положительно влияет на качество кода. Посмотреть статус и сам проект можно перейдя по бэйджам на странице репозитория.

 

 

 

Новая библиотека: Twitter API

 

Не круто было бы выпускать проект совсем без обновок. Новым объектом интеграции на этот раз стал Twitter. Реализованных методов не много: все они относятся к созданию твитов. Дело в том, что бесплатный тариф для Twitter API ничего другого и не позволяет. Но есть важное замечание - под капотом библиотеки выполняются самые муторные действия, необходимые для всех запросов:

  • Авторизация OAuth 1.0a User Context для API версии 1 
  • Авторизация OAuth 2.0 для API версии 2 
  • Загрузка файлов: как одним запросом, так и чанками 

Так что если вы счастливый обладатель подписки PRO за 9999 килобаксов/мес. и вам нужны какие-либо другие методы, то реализовать их по примеру будет проще простого. Плюс, данную библиотеку можно использовать в качестве примера реализации тех же OAuth 1.0 и 2.0 для других сервисов. Подробнее можно узнать в документации

 

 

 

В заключение

Надеюсь, данный проект окажется для вас полезным. Я рассчитываю развивать его, добавляя новые методы и библиотеки. Буду очень рад, если вы поддержите его здесь и на странице репозитория GitHub. В случае нахождения багов, обязательно напишите в Issues. Это как ни что другое поможет сделать ОПИ лучше. Спасибо за внимание!

Репозиторий OPI: https://github.com/Bayselonarrend/OpenIntegrations

 

Другие статьи про Открытый пакет интеграций на Инфостарт:

 

 

 Мой GitHub:     https://gitub.com/Bayselonarrend 
 Лицензия MIT:   https://mit-license.org

API интеграция web мессенджеры telegram. viber vk twitter open-source github бот

См. также

Интеграция Альфа Авто 5 / Альфа Авто 6 и AUTOCRM / Инфотек

Сайты и интернет-магазины WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM разных брендов в одной информационной базе в ручном и автоматическом режиме.

36000 руб.

03.08.2020    16004    13    18    

13

Интеграция 1С — Битрикс24. Обмен задачами

Сайты и интернет-магазины Интеграция WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 Управленческий учет Платные (руб)

Интеграция 1С и Битрикс24. Разработка имеет двухстороннюю синхронизацию 1С и Битрикс24 задачами. Решение позволяет создавать пользователя в 1С из Битрикс24 и наоборот. Данная разработка технически подходит под все основные конфигурации линейки продуктов 1С:Предприятие 8.3 (8.3.18.1289). При приобретении предоставляется 1 месяц бесплатных обновлений разработки. Доступна демо-версия продукта с подключением Вашего Битрикс24

5040 руб.

04.05.2021    18015    10    15    

14

Модуль для обмена "1С:Предприятие 8. УАТ. ПРОФ" с FortMonitor

WEB-интеграция 8.3.8 Конфигурации 1cv8 Автомобили, автосервисы Беларусь Украина Россия Казахстан Управленческий учет Платные (руб)

Расширение предназначено для конфигурации "1С:Предприятие 8. Управление Автотранспортом. ПРОФ". Функционал модуля: 1. Заполнение регистров сведений по подсистеме "Мониторинг", а именно: события по мониторингу, координаты по мониторингу, пробег и расход по мониторингу, текущее местоположение ТС по мониторингу 2. Заполнение путевого листа: пробег по мониторингу, время выезда/заезда, табличная часть ГСМ, места стоянок по геозонам. 3. Отчеты по данным загруженным в регистры сведений. 4. Предусмотрена автоматическая загрузка данных в фоновом режиме (условия работы данной загрузке читайте в описании товара) Модуль работает без включенной константы по настройкам мониторинга. Модуль формы предоставляется с открытым кодом, общий модуль защищен. Любой заинтересованный пользователь, имеет возможность скачать демо-версию расширения.

22656 руб.

25.05.2021    12941    32    8    

12

SALE! 10%

Автоматическая загрузка файлов (например, прайс-листов) из электронной почты, FTP, HTTP, их обработка и выгрузка на FTP (на сайт) и для других целей

Прайсы WEB-интеграция Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Автомобили, автосервисы Оптовая торговля, дистрибуция, логистика Управленческий учет Платные (руб)

Программа с заданным интервалом времени (или по ручной команде) скачивает файлы (например, прайс-листы поставщиков) из различных источников: письма электронной почты, FTP или HTTP-адреса, и сохраняет их в каталог упорядоченной структуры. При этом извлекает файлы из архивов, может переименовывать файлы и менять их формат (csv, xls, txt). Можно настроить выгрузку обработанных файлов на сайт (через FTP-подключение). Программа будет полезна компаниям, у которых есть большое количество поставщиков и/или прайс-листы поставщиков обновляются часто (необязательно прайс-листы, файлы могут быть любого назначения). Собранные таким образом актуальные версии прайс-листов можно выгрузить с помощью программы себе на сайт (или на любой FTP-сервер) или выполнить другие необходимые задачи.

28000 25200 руб.

28.05.2015    85107    26    51    

50

Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС

Обмен с ГосИС WEB-интеграция Платформа 1С v8.3 Управляемые формы 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия государственного учреждения 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Обработка является альтернативой механизму, разработанному фирмой 1С и заполняющему реквизиты контрагента по ИНН или наименованию. Не требуется действующей подписки ИТС. Вызывается как внешняя дополнительная обработка, т.е. используется, непосредственно, из карточки контрагента. Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС (egrul.nalog.ru) для БП 2.0, БП 3.0, БГУ 1.0, БГУ 2.0, УТ 10.3, УТ 11.x, КА 1.1, КА 2.x, УПП 1.x, ERP 2.x, УНФ 1.5, УНФ 1.6, УНФ 3.0, ДО 2.1

2400 руб.

28.04.2016    89386    163    217    

320
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ixijixi 1802 15.01.24 12:39 Сейчас в теме
С удовольствием наблюдаю, как развивается Ваш проект. Так держать!
cleaner_it; 0x00; корум; bayselonarrend; +4 Ответить
2. Viktor_Ermakov 364 15.01.24 13:18 Сейчас в теме
Спасибо, это очень полезная библиотека, и все в одном месте! Успехов.
bayselonarrend; +1 Ответить
3. SerVer1C 766 16.01.24 10:54 Сейчас в теме
Отлично!
Но "механизм распаковки zip" изначально появился в этой публикации (это не в вашу сторону камень)
4. EgorDo 03.04.24 16:02 Сейчас в теме
Добрый день
пытаюсь реализовать механизм опубликования поста в группу в ВК
если прикрепленное фото 1 то пост создается нормально
если же фоток 2е и более валится с ошибкой
Прикрепленные файлы:
5. bayselonarrend 1209 03.04.24 16:09 Сейчас в теме
(4) Вчера буквально выкатил релиз, где поправил

Вот тут
6. EgorDo 03.04.24 16:28 Сейчас в теме
7. bayselonarrend 1209 03.04.24 16:32 Сейчас в теме
(6)Можете поставить звездочку на GH, тогда будете знать о новых релизах ;)
Оставьте свое сообщение