From 22f9f9460967114c70a6c3a516ea8b24c7d42bd7 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Thu, 30 Nov 2023 18:38:25 +0300 Subject: =?UTF-8?q?fixes=20#3992=20(Telegram:=20=D0=BE=D1=82=D1=81=D1=83?= =?UTF-8?q?=D1=82=D1=81=D1=82=D0=B2=D1=83=D0=B5=D1=82=20=D0=B2=D0=BE=D0=B7?= =?UTF-8?q?=D0=BC=D0=BE=D0=B6=D0=BD=D0=BE=D1=81=D1=82=D1=8C=20=D1=83=D0=BA?= =?UTF-8?q?=D0=B0=D0=B7=D0=B0=D1=82=D1=8C=20=D0=BF=D1=80=D0=BE=D0=BA=D1=81?= =?UTF-8?q?=D0=B8)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- protocols/Telegram/src/proto.cpp | 2 +- protocols/Telegram/src/server.cpp | 17 +++++++++++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) (limited to 'protocols/Telegram/src') diff --git a/protocols/Telegram/src/proto.cpp b/protocols/Telegram/src/proto.cpp index 9222617a7a..08f7f102ad 100644 --- a/protocols/Telegram/src/proto.cpp +++ b/protocols/Telegram/src/proto.cpp @@ -84,7 +84,7 @@ CTelegramProto::CTelegramProto(const char* protoName, const wchar_t* userName) : // create standard network connection NETLIBUSER nlu = {}; - nlu.flags = NUF_UNICODE; + nlu.flags = NUF_OUTGOING | NUF_UNICODE; nlu.szSettingsModule = m_szModuleName; nlu.szDescriptiveName.w = m_tszUserName; m_hNetlibUser = Netlib_RegisterUser(&nlu); diff --git a/protocols/Telegram/src/server.cpp b/protocols/Telegram/src/server.cpp index d9dde02216..181631f4cc 100644 --- a/protocols/Telegram/src/server.cpp +++ b/protocols/Telegram/src/server.cpp @@ -32,6 +32,23 @@ void __cdecl CTelegramProto::ServerThread(void *) SendQuery(new TD::getOption("version")); + NETLIBUSERSETTINGS nluSettings; + Netlib_GetUserSettings(m_hNetlibUser, &nluSettings); + if (nluSettings.useProxy) { + TD::object_ptr proxyType; + switch (nluSettings.proxyType) { + case PROXYTYPE_SOCKS4: + case PROXYTYPE_SOCKS5: + proxyType = TD::make_object(); + break; + case PROXYTYPE_HTTP: + case PROXYTYPE_HTTPS: + proxyType = TD::make_object(); + break; + } + SendQuery(new TD::addProxy(nluSettings.szProxyServer, nluSettings.wProxyPort, true, std::move(proxyType))); + } + while (!m_bTerminated) { ProcessResponse(m_pClientManager->receive(1)); } -- cgit v1.2.3