API Guacamole на 1C или RDP в ПолеHTML

24.08.23

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

Изначально задумка была в том, чтобы авторизоваться на guacomole под одним пользователем и давать доступ множеству сотрудников к RDP клиентов прям в 1С. У этого одного пользователя должны быть права на создание групп, подключений и профилей общего доступа в guacamole. Профили общего доступа позволяют вытащить общую ссылку, которую можно было бы поместить в html поле 1С, но оказалось, что достать эту ссылку через API нельзя. Можно начать сессию в HTML поле и она отлично работает, но сотрудник в этом варианте может получить в доступ ко всем подключениям, а также посмотреть их пароли. Вывод - придётся заводить пользователей в guacamole и получать токены для сессий от лица заведённых пользователей. В таком случае 1С в этой схеме лишняя, так как мы просто будем дублировать функционал guacamole. Конкретно в моём случае, для нашей конторы хватит и голой гуаки. Тем не менее, опыт оказался интересным, RDP в ПолеHTML отлично работает (буфер обмена, комбинация Ctrl+Alt+Shift).

Скачать файлы

Наименование Файл Версия Размер
: Расширение ГуакаМоль
.cfe 32,47Kb
3
.cfe 32,47Kb 3 Скачать

Guacamole

Сначала подымем guacamole. Используем docker compose:

version: "2"
services:
  guacamole:
    image: jwetzell/guacamole
    container_name: guacamole
    volumes:
      - postgres:/config
    ports:
      - 3114:8080
    environment:
      - EXTENSIONS=auth-totp
    restart: always
volumes:
  postgres:
    driver: local

Логин и пароль по умолчанию: guacadmin guacadmin
Заходим, создаём пользователя 1C, даём права:

 

 

Выключаем двойную аутентификацию для пользователя 1C:
1С никак двойную аутентификацию не пройдёт.
https://issues.apache.org/jira/browse/GUACAMOLE-1164

su postgres
psql
\c guacamole_db
select * from guacamole_user_attribute;
update guacamole_user_attribute set attribute_value='totpdisabled' where user_id=<userid> and attribute_name='guac-totp-key-secret';

Всё это надо выполнить внутри docker контейнера. Чтобы попасть туда: 

docker exec -it <mycontainer> bash

Посмотреть, как называется контейнер:

docker ps

Далее я задаю внутреннее и внешнее доменное имя, нацеливаю их на Nginx Proxy Manager, и последний вешает SSL замки на соединение и делает доступным по доменному имени guacamole.example.org. Guacamole в итоге, похоже, будем использовать в чистом виде, без 1С.

 

Заполняем настройки в расширении:


 

Создаём сервер:

 

 

Вводим данные о подключении, нажимаем подключиться:


 

Подключение работает:


 

Окно отлично реагирует на изменение размера окна, работает буфер обмена. Сразу срабатывает комбинация Alt+Ctrl+Shift

С её помощью вы можете попасть в опции:

 

 

А там будет возможность изменить удалить подключение и даже посмотреть пароль. Мы ведь получили токен от лица пользователя 1С, а владелец этих подключений - он. То есть без допиливания апи по правам и выключения TOTP для этих пользователей - не обойтись. То есть сделать можно, если нужно. Гуака умеет ещё ssh, vnc и надеюсь в ней появится spice.

При создании подключения формируются два профиля. По выданной ссылке ваша гуакамоль позволит всем обладателям ссылки (без авторизации на guacamole) иметь полный доступ одновременно (Типа как общая ссылка на файл, только на сессию):


 

Ссылка будет действовать до завершения или переподключения основной сессии.

В общем, guacamole - вещь! Хвала Апачам, Гуакамолям, Докерам и Вам, потому что дочитали. Аминь!


Расширение тестировалось на платформе 8.3.22.2143.

См. также

Интеграция с сервисом vetmanager

WEB-интеграция Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бытовые услуги, сервис Платные (руб)

Данная обработка разрабатывалась для загрузки документов из Ветменеджер в 1С: Бухгалтерия 3.

6000 руб.

02.02.2021    15134    42    49    

21

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

Обмен с ГосИС 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    86488    153    211    

308

Merlion Commander Версия 1.3.9.2 - июль 2022 г. (Интеграция с 1С: УT, редакция 11.4, 1С:Розница 2.3,1С:ERP Управление предприятием 2, УТ 10.3, редакция веб-сервиса MERLION API 3.0 от 18.08.2021)

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

Расширении конфигурации "Управление торговлей, редакция 11" для работы с веб-сервисом Мерлион с помощью Merlion API. Расширение и набор подключаемых дополнительных обработок позволяет без изменения конфигурации получить возможность работы с API крупнейшего российского дистрибьютора http://merlion.com. Логика работы максимально приближена к работе веб-сервиса b2b. Вы сможете создать и исправить заказ, зарезервировать товар прямо из 1С, посмотреть актуальные остатки и цены, импортировать штрихкода EAN13 товаров, загружать заказ c автоматическим созданием номенклатуры в 1С и корректности создания. Можно выбирать характеристики по товарным группам и загружать товар с выбранными характеристиками, загружать изображения товара. Не требуется установки дополнительного ПО для работы с веб-сервисом. Кроссплатформенное решение для ОС Windows и Linux. Весь код модулей открыт и доступен для просмотра и внесения изменений.

8280 руб.

02.05.2017    38141    42    64    

49

Sync1C: Синхронизация 1С и OpenCart

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

Внешняя обработка для обмена данными с интернет-магазином OpenCart. Позволяет быстро наполнить магазин товарами, затем обновлять цены и добавлять новые товары. Далее можно средствами OpenCart настраивать и дополнять карточки товаров как надо для магазина, при этом связь товаров с 1С не теряется.

3840 руб.

30.03.2018    42622    80    137    

84
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. TuneSoft 246 26.08.23 10:19 Сейчас в теме
Добрый день.

По расходу трафика сравнивали например со стандартным MS RDP или NoMachine ?

Был опыт использования NoMachine под Alt Linux, трафик у него значительно выше чем у MS RDP, на мобильном интернете часто подвисало, но точные замеры не делал.
cleaner_it; +1 Ответить
3. ЕСТЬNULL 200 30.08.23 03:12 Сейчас в теме
(1)
Здравствуйте.

Под капотом у гуаки freerdp. На данный момент это лучшая реализация RDP клиента на unix подобных ос.

У меня нет никаких оснований полагать, что FreeRDP ест больше трафика, чем виндовый RDP клиент. Это больше зависит от настроек RDP подключения на стороне клиента и сервера. Вы пишете про NoMachine vs RDP, тут речь о RDP vs RDP. Да, скорее всего NM более прожорлив, чем RDP, но это не удивительно. RDP - пока самый топчик для VDI. Ближайший конкурент - spice, думаю жрёт больше. Но... будем посмотреть, в душе я больше болею за spice. Гуака spice пока не умеет.
2. metmetmet 81 27.08.23 18:02 Сейчас в теме
Итнресная, статья!
А какой конкретно сценарий использования?
4. ЕСТЬNULL 200 30.08.23 03:24 Сейчас в теме
(2) Здравствуйте, спасибо!

В нашем случае нужен доступ к рабочим серверам клиентов для своих специалистов. Guacamole позволяет централизованно выдавать доступ спецам под выполнение задач (1С) без установки VPN и настройки RDP. (+ есть история подключений и возможность записывать терминальные сессии на видео). Для франчайзи конторы это может быть очень полезно.

Возможно кто-то допилит эту разработку для автоматизации доступа сотрудников предприятия к своим рабочим местам. API позволит автоматизировать процесс заполнения базы доступов. Руками в чистой гуаке - заколебёшься вводить множество доступов, централизованно и массово что-то менять...

Я пока ещё не понял всю силу гуаки честно говоря. Можно разруливать доступы в 1С франчайзи, можно давать доступ к рабочим местам через RDP, если у вас парк на винде, через VNC если на линуксе. Шарить ссылки на доступ - это вообще турбо возможность, всю силу которой я ещё не осознал.
as; Sonnya1909; metmetmet; +3 Ответить
5. ЕСТЬNULL 200 30.08.23 06:49 Сейчас в теме
(4) И всё это без VPN. В текущих реалиях это может быть очень важно + двухфакторка есть.
6. blackhole321 1300 30.08.23 18:10 Сейчас в теме
(5) Все так, только по крайней мере год тому назад, в нем была куча уязвимостей. Так, что надо быть аккуратнее без vpn :)
7. ЕСТЬNULL 200 31.08.23 09:17 Сейчас в теме
(6) Двухфакторка должна подсобить. Проект живой.
А без или с VPN, нас с вами и не спросят.
8. smit1c 106 31.08.23 15:00 Сейчас в теме
Обычно RDP нужно чтобы к 1С подключиться, а тут наоборот... ))
misha226; as; mark_oilbass; +3 Ответить
Оставьте свое сообщение