diff --git a/docs/en/md/Instructions/FTP.md b/docs/en/md/Instructions/FTP.md
index 346ac3034d..adceb057bb 100644
--- a/docs/en/md/Instructions/FTP.md
+++ b/docs/en/md/Instructions/FTP.md
@@ -10,6 +10,13 @@ keywords: [1C, 1C:Enterprise, 1C:Enterprise 8.3, API, Integration, Services, Dat
This section is dedicated to the library for working with FTP(s). On this page, all the steps necessary to start working are described
+
+
+
.default})
+
An external component is used to implement some functions in this library
+Please review the ["About external components"](/docs/Start/Component-requirements) section before getting started
+
+
## Getting Started
This library provides various methods for working with FTP(s) on the client side. Each method accepts a `Connection` as its first parameter, which can be initialized in one of two ways:
diff --git a/docs/en/md/Instructions/SFTP.md b/docs/en/md/Instructions/SFTP.md
index c03855215d..5fd3032866 100644
--- a/docs/en/md/Instructions/SFTP.md
+++ b/docs/en/md/Instructions/SFTP.md
@@ -8,6 +8,60 @@ keywords: [1C, 1C:Enterprise, 1C:Enterprise 8.3, API, Integration, Services, Dat
# SFTP
-This section is dedicated to the library for working with FTP(s). On this page, all the steps necessary to start working are described
+This section is dedicated to the library for working with SFTP. On this page, all the steps necessary to start working are described
+
+
+
+
.default})
+
An external component is used to implement some functions in this library
+Please review the ["About external components"](/docs/Start/Component-requirements) section before getting started
+
+
+
+
+
.default})
+
+
## Getting Started
+
+This library provides various methods for working with SFTP on the client side. Each method accepts a `Connection` as its first parameter, which can be initialized in one of two ways:
+
+1. Using the `OpenConnection` function. In this case, a component object is returned that supports a single connection for multiple requests.
+2. Using the `GetConnectionConfiguration` function. In this case, only a connection description structure is returned. Each function receiving this structure as the `Connection` parameter will internally create a new connection and close it upon completion
+
+When performing multiple sequential requests to an SFTP server, it is recommended to use a full connection obtained via the `OpenConnection` function
+
+Once a connection is established, it can be used with the library's other methods to perform specific tasks
+
+## Proxy Usage
+
+The client supports establishing connections through a proxy server. Proxy settings can be obtained using the `GetProxySettings` function. The resulting structure must then be passed to either `OpenConnection` or `GetConnectionConfiguration` when initiating work
+
+```bsl
+
+ ...
+
+ ProxyType = "http"; // http, socks5, socks4
+
+ ProxyAddress = FunctionParameters["Proxy_IP"];
+ ProxyPort = FunctionParameters["Proxy_Port"];
+ ProxyLogin = FunctionParameters["Proxy_User"];
+ ProxyPassword = FunctionParameters["Proxy_Password"];
+
+ ProxySettings = OPI_SFTP.GetProxySettings(ProxyAddress, ProxyPort, ProxyType, ProxyLogin, ProxyPassword);
+
+ Connection = OPI_SFTP.CreateConnection(SFTPSettings, ProxySettings);
+
+```
+
+Support is provided for socks4, socks5, and http proxy servers
+
+:::warning
+Operation via http-proxy is experimental and may be unstable depending on the proxy server’s implementation, configuration, and capabilities. It is recommended to use socks-proxy whenever possible for stable traffic transmission
+:::
+
+## Compatibility with the SSH Library
+
+The SFTP and SSH libraries share a common connection format. This means that when working with SFTP, you can also execute `sh` commands by passing the existing connection object to the SSH library methods.
diff --git a/docs/en/md/Instructions/SSH.md b/docs/en/md/Instructions/SSH.md
index 04e21e8cc9..2da2a8e23c 100644
--- a/docs/en/md/Instructions/SSH.md
+++ b/docs/en/md/Instructions/SSH.md
@@ -8,6 +8,60 @@ keywords: [1C, 1C:Enterprise, 1C:Enterprise 8.3, API, Integration, Services, Dat
# SSH
-This section is dedicated to the library for working with FTP(s). On this page, all the steps necessary to start working are described
+This section is dedicated to the library for working with SSH. On this page, all the steps necessary to start working are described
+
+
+
+
.default})
+
An external component is used to implement some functions in this library
+Please review the ["About external components"](/docs/Start/Component-requirements) section before getting started
+
+
+
+
+
.default})
+
+
## Getting Started
+
+This library provides various methods for working with SSH on the client side. Each method accepts a `Connection` as its first parameter, which can be initialized in one of two ways:
+
+1. Using the `OpenConnection` function. In this case, a component object is returned that supports a single connection for multiple requests.
+2. Using the `GetConnectionConfiguration` function. In this case, only a connection description structure is returned. Each function receiving this structure as the `Connection` parameter will internally create a new connection and close it upon completion
+
+When performing multiple sequential requests to an SSH server, it is recommended to use a full connection obtained via the `OpenConnection` function
+
+After establishing a connection, `sh` commands can be executed using the `ExecuteCommand` function.
+
+:::important
+Commands are run in `execute` mode. This means that execution context, such as changing the current working directory or setting environment variables, is not preserved between calls. To execute multiple sequential commands, they must be included in a single call to the `ExecuteCommand` function.
+:::
+
+## Proxy Usage
+
+The client supports establishing connections through a proxy server. Proxy settings can be obtained using the `GetProxySettings` function. The resulting structure must then be passed to either `OpenConnection` or `GetConnectionConfiguration` when initiating work
+
+```bsl
+
+ ...
+
+ ProxyType = "http"; // http, socks5, socks4
+
+ ProxyAddress = FunctionParameters["Proxy_IP"];
+ ProxyPort = FunctionParameters["Proxy_Port"];
+ ProxyLogin = FunctionParameters["Proxy_User"];
+ ProxyPassword = FunctionParameters["Proxy_Password"];
+
+ ProxySettings = OPI_SSH.GetProxySettings(ProxyAddress, ProxyPort, ProxyType, ProxyLogin, ProxyPassword);
+
+ Connection = OPI_SSH.CreateConnection(SSHSettings, ProxySettings);
+
+```
+
+Support is provided for socks4, socks5, and http proxy servers
+
+:::warning
+Operation via http-proxy is experimental and may be unstable depending on the proxy server’s implementation, configuration, and capabilities. It is recommended to use socks-proxy whenever possible for stable traffic transmission
+:::
diff --git a/docs/ru/md/Instructions/FTP.md b/docs/ru/md/Instructions/FTP.md
index 4c1443ba15..9cc35ffbb6 100644
--- a/docs/ru/md/Instructions/FTP.md
+++ b/docs/ru/md/Instructions/FTP.md
@@ -10,6 +10,13 @@ keywords: [1C, 1С, 1С:Предприятие, 1С:Предприятие 8.3,
Этот раздел посвящен библиотеке для работы с протоколом FTP(s) в 1С:Предприятие, OneScript и CLI. На данной странице описаны все действия, необходимые для полноценного начала работы
+
+
+
.default})
+
Для реализации некоторых функции в этой библиотеке используется внешняя компонента
+Пожалуйста, ознакомьтесь с разделом ["О внешних компонентах"](/docs/Start/Component-requirements) перед началом работы
+
+
## Начало работы
Данная библиотека предоставляет различные методы работы с FTP(s) на стороне клиента. Каждый из них принимает в качестве первого параметра `Соединение`, значение которого может быть получено одним из двух способов:
diff --git a/docs/ru/md/Instructions/SFTP.md b/docs/ru/md/Instructions/SFTP.md
index 370b02abad..203afa980d 100644
--- a/docs/ru/md/Instructions/SFTP.md
+++ b/docs/ru/md/Instructions/SFTP.md
@@ -10,4 +10,60 @@ keywords: [1C, 1С, 1С:Предприятие, 1С:Предприятие 8.3,
Этот раздел посвящен библиотеке для работы с протоколом SFTP в 1С:Предприятие, OneScript и CLI. На данной странице описаны все действия, необходимые для полноценного начала работы
+
+
+
.default})
+
Для реализации некоторых функции в этой библиотеке используется внешняя компонента
+Пожалуйста, ознакомьтесь с разделом ["О внешних компонентах"](/docs/Start/Component-requirements) перед началом работы
+
+
+
+
+
.default})
+
+
+
+
## Начало работы
+
+Данная библиотека предоставляет различные методы работы с SFTP на стороне клиента. Каждый из них принимает в качестве первого параметра `Соединение`, значение которого может быть получено одним из двух способов:
+
+1. При помощи функции `ОткрытьСоединение`. В этом случае возвращается объект компоненты, поддерживающий единое соединение для множества запросов
+2. При помощи функции `ПолучитьКонфигурациюСоединения`. В этом случае возвращается лишь структура описания соединения. Каждая функция, в которую эта структура будет передана в качестве `Соединения`, будет создавать новое подключение внутри себя и закрывать его по окончании работы
+
+При выполнении множественных последовательных запросов к серверу FTP рекомендуется использовать полноценное соединение, получаемое при помощи функции `ОткрытьСоединение`
+
+После формирования соединения, оно может быть использовано при работе с остальными методами библиотеки для выполнения конкретных задач
+
+## Использование прокси
+
+Данный клиент поддерживает создание соединения через прокси сервер. Получить структуру настроек прокси можно при помощи функции `ПолучитьНастройкиПрокси`. Полученная структура, далее, должна быть передана в функцию `ОткрытьСоединение` или `ПолучитьКонфигурациюСоединения` при начале работы
+
+```bsl
+
+ ...
+
+ ТипПрокси = "http"; // http, socks5, socks4
+
+ АдресПрокси = "127.0.0.1";
+ ПортПрокси = "8071";
+ ЛогинПрокси = "proxyuser";
+ ПарольПрокси = "12we...";
+
+ НастройкиПрокси = OPI_SFTP.ПолучитьНастройкиПрокси(АдресПрокси, ПортПрокси, ТипПрокси, ЛогинПрокси, ПарольПрокси);
+
+ Соединение = OPI_SFTP.ОткрытьСоединение(НастройкиSFTP, НастройкиПрокси);
+
+```
+
+Поддерживается работа через SOCKS4, SOCKS5 и HTTP-прокси серверы
+
+:::warning
+Работа через http-прокси является экспериментальной и может быть нестабильной в зависимости от реализации прокси-сервера, его настроек и возможностей. Рекомендуется по возможности использовать SOCKS-прокси для стабильной передачи трафика
+:::
+
+## Совместимость с библиотекой SSH
+
+Библиотеки SFTP и SSH имеют общий формат соединения. Это значит, что при работе с SFTP вы также можете вызывать команды `sh`, передавая в методы библиотеки SSH уже существующий объект соединения
+
diff --git a/docs/ru/md/Instructions/SSH.md b/docs/ru/md/Instructions/SSH.md
index 28c7c6748b..b9a268e008 100644
--- a/docs/ru/md/Instructions/SSH.md
+++ b/docs/ru/md/Instructions/SSH.md
@@ -10,4 +10,58 @@ keywords: [1C, 1С, 1С:Предприятие, 1С:Предприятие 8.3,
Этот раздел посвящен библиотеке для работы с протоколом SSH в 1С:Предприятие, OneScript и CLI. На данной странице описаны все действия, необходимые для полноценного начала работы
+
+
+
.default})
+
Для реализации некоторых функции в этой библиотеке используется внешняя компонента
+Пожалуйста, ознакомьтесь с разделом ["О внешних компонентах"](/docs/Start/Component-requirements) перед началом работы
+
+
+
+
+
.default})
+
+
+
## Начало работы
+
+Данная библиотека предоставляет различные методы работы с SSH на стороне клиента. Каждый из них принимает в качестве первого параметра `Соединение`, значение которого может быть получено одним из двух способов:
+
+1. При помощи функции `ОткрытьСоединение`. В этом случае возвращается объект компоненты, поддерживающий единое соединение для множества запросов
+2. При помощи функции `ПолучитьКонфигурациюСоединения`. В этом случае возвращается лишь структура описания соединения. Каждая функция, в которую эта структура будет передана в качестве `Соединения`, будет создавать новое подключение внутри себя и закрывать его по окончании работы
+
+При выполнении множественных последовательных запросов к серверу SSH рекомендуется использовать полноценное соединение, получаемое при помощи функции `ОткрытьСоединение`
+
+После установки соединения, вызов команд `sh` можно осуществлять при помощи `ВыполнитьКоманду`
+
+:::important
+Команды выполняются в режиме `execute`, а не в режиме `shell`. Это означает, что контекст выполнения, вроде смены текущей директории или переменных окружения, не сохраняется между вызовами. Для выполнения нескольких последовательных команд они должны находится в одном вызове функции `ВыполнитьКоманду`
+:::
+
+## Использование прокси
+
+Данный клиент поддерживает создание соединения через прокси сервер. Получить структуру настроек прокси можно при помощи функции `ПолучитьНастройкиПрокси`. Полученная структура, далее, должна быть передана в функцию `ОткрытьСоединение` или `ПолучитьКонфигурациюСоединения` при начале работы
+
+```bsl
+
+ ...
+
+ ТипПрокси = "http"; // http, socks5, socks4
+
+ АдресПрокси = "127.0.0.1";
+ ПортПрокси = "8071";
+ ЛогинПрокси = "proxyuser";
+ ПарольПрокси = "12we...";
+
+ НастройкиПрокси = OPI_SSH.ПолучитьНастройкиПрокси(АдресПрокси, ПортПрокси, ТипПрокси, ЛогинПрокси, ПарольПрокси);
+
+ Соединение = OPI_SSH.ОткрытьСоединение(НастройкиSSH, НастройкиПрокси);
+
+```
+
+Поддерживается работа через SOCKS4, SOCKS5 и HTTP-прокси серверы
+
+:::warning
+Работа через http-прокси является экспериментальной и может быть нестабильной в зависимости от реализации прокси-сервера, его настроек и возможностей. Рекомендуется по возможности использовать SOCKS-прокси для стабильной передачи трафика
+:::
diff --git a/src/addins/ssh/Cargo.lock b/src/addins/ssh/Cargo.lock
index 25478d68b2..6bc72624b7 100644
--- a/src/addins/ssh/Cargo.lock
+++ b/src/addins/ssh/Cargo.lock
@@ -128,6 +128,15 @@ version = "2.7.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "32a282da65faaf38286cf3be983213fcf1d2e2a58700e808f83f4ea9a4804bc0"
+[[package]]
+name = "openssl-src"
+version = "300.4.2+3.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "168ce4e058f975fe43e89d9ccf78ca668601887ae736090aacc23ae353c298e2"
+dependencies = [
+ "cc",
+]
+
[[package]]
name = "openssl-sys"
version = "0.9.109"
@@ -136,6 +145,7 @@ checksum = "90096e2e47630d78b7d1c20952dc621f957103f8bc2c8359ec81290d75238571"
dependencies = [
"cc",
"libc",
+ "openssl-src",
"pkg-config",
"vcpkg",
]
diff --git a/src/addins/ssh/Cargo.toml b/src/addins/ssh/Cargo.toml
index 2b0afd8720..6c91d46e96 100644
--- a/src/addins/ssh/Cargo.toml
+++ b/src/addins/ssh/Cargo.toml
@@ -17,5 +17,12 @@ opt-level = "z"
addin1c = "0.5.0"
serde_json = "1.0.140"
serde = { version = "1.0.219", features = ["derive"] }
-ssh2 = { version = "0.9.5", features = ["openssl-on-win32"] }
common-tcp = { path = "../!commons/common-tcp" }
+
+[target.'cfg(all(windows, target_env = "msvc"))'.dependencies.ssh2]
+version = "0.9.5"
+features = ["vendored-openssl", "openssl-on-win32"]
+
+# Для всех остальных платформ (Linux, macOS, Windows GNU)
+[target.'cfg(not(all(windows, target_env = "msvc")))'.dependencies.ssh2]
+version = "0.9.5"
diff --git a/src/addins/ssh/dependencies.log b/src/addins/ssh/dependencies.log
index 6e8385aef8..5a1d8c5eba 100644
--- a/src/addins/ssh/dependencies.log
+++ b/src/addins/ssh/dependencies.log
@@ -1,14 +1,9 @@
"MAIN ---"
- linux-vdso.so.1 (0x00007ffc92f7c000)
- libssl.so.3 => /lib64/libssl.so.3 (0x00007d7cede00000)
- libcrypto.so.3 => /lib64/libcrypto.so.3 (0x00007d7ced600000)
- libpthread.so.0 => /lib64/libpthread.so.0 (0x00007d7ced200000)
- libc.so.6 => /lib64/libc.so.6 (0x00007d7cece00000)
- libdl.so.2 => /lib64/libdl.so.2 (0x00007d7ceca00000)
- /lib64/ld-linux-x86-64.so.2 (0x00007d7cee200000)
- libz.so.1 => /lib64/libz.so.1 (0x00007d7cec600000)
-GLIBC_2.2.5
-GLIBC_2.3
-GLIBC_2.3.4
-GLIBC_2.14
-GLIBC_2.17
+ linux-vdso.so.1 (0x00007ffed8be2000)
+ libssl.so.3 => /lib64/libssl.so.3 (0x00007e8e49a00000)
+ libcrypto.so.3 => /lib64/libcrypto.so.3 (0x00007e8e49200000)
+ libpthread.so.0 => /lib64/libpthread.so.0 (0x00007e8e48e00000)
+ libc.so.6 => /lib64/libc.so.6 (0x00007e8e48a00000)
+ libdl.so.2 => /lib64/libdl.so.2 (0x00007e8e48600000)
+ /lib64/ld-linux-x86-64.so.2 (0x00007e8e49e00000)
+ libz.so.1 => /lib64/libz.so.1 (0x00007e8e48200000)
diff --git a/src/en/OInt/addins/OPI_SSH.zip b/src/en/OInt/addins/OPI_SSH.zip
index 1a3674f2a3..76d2376926 100644
Binary files a/src/en/OInt/addins/OPI_SSH.zip and b/src/en/OInt/addins/OPI_SSH.zip differ
diff --git a/src/en/OPI/src/CommonTemplates/OPI_SSH/Template.addin b/src/en/OPI/src/CommonTemplates/OPI_SSH/Template.addin
index 1a3674f2a3..76d2376926 100644
Binary files a/src/en/OPI/src/CommonTemplates/OPI_SSH/Template.addin and b/src/en/OPI/src/CommonTemplates/OPI_SSH/Template.addin differ
diff --git a/src/ru/OInt/addins/OPI_SSH.zip b/src/ru/OInt/addins/OPI_SSH.zip
index 1a3674f2a3..76d2376926 100644
Binary files a/src/ru/OInt/addins/OPI_SSH.zip and b/src/ru/OInt/addins/OPI_SSH.zip differ
diff --git a/src/ru/OPI/src/CommonTemplates/OPI_SSH/Template.addin b/src/ru/OPI/src/CommonTemplates/OPI_SSH/Template.addin
index 1a3674f2a3..76d2376926 100644
Binary files a/src/ru/OPI/src/CommonTemplates/OPI_SSH/Template.addin and b/src/ru/OPI/src/CommonTemplates/OPI_SSH/Template.addin differ