From e7a87b3c82204e048f23750a18b456e567a6f436 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Wed, 28 Dec 2016 16:57:55 +0300 Subject: http framework --- protocols/Discord/src/proto.cpp | 30 ++++++++++++++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) (limited to 'protocols/Discord/src/proto.cpp') diff --git a/protocols/Discord/src/proto.cpp b/protocols/Discord/src/proto.cpp index 1c557daaa7..c44cab39bc 100644 --- a/protocols/Discord/src/proto.cpp +++ b/protocols/Discord/src/proto.cpp @@ -17,8 +17,15 @@ along with this program. If not, see . #include "stdafx.h" +static int compareRequests(const AsyncHttpRequest *p1, const AsyncHttpRequest *p2) +{ + return p1->m_iReqNum - p2->m_iReqNum; +} + CDiscordProto::CDiscordProto(const char *proto_name, const wchar_t *username) : - PROTO(proto_name, username) + PROTO(proto_name, username), + m_arHttpQueue(10, compareRequests), + m_evRequestsQueue(CreateEvent(NULL, FALSE, FALSE, NULL)) { // Services CreateProtoService(PS_GETNAME, &CDiscordProto::GetName); @@ -26,10 +33,25 @@ CDiscordProto::CDiscordProto(const char *proto_name, const wchar_t *username) : // Events HookProtoEvent(ME_OPT_INITIALISE, &CDiscordProto::OnOptionsInit); + + // Network initialization + CMStringW descr(FORMAT, TranslateT("%s server connection"), m_tszUserName); + + NETLIBUSER nlu = { sizeof(nlu) }; + nlu.flags = NUF_INCOMING | NUF_OUTGOING | NUF_HTTPCONNS | NUF_UNICODE; + nlu.szSettingsModule = m_szModuleName; + nlu.ptszDescriptiveName = descr.GetBuffer(); + m_hNetlibUser = (HANDLE)CallService(MS_NETLIB_REGISTERUSER, 0, (LPARAM)&nlu); } CDiscordProto::~CDiscordProto() { + debugLogA("CDiscordProto::~CDiscordProto"); + Netlib_CloseHandle(m_hNetlibUser); + m_hNetlibUser = NULL; + + m_arHttpQueue.destroy(); + ::CloseHandle(m_evRequestsQueue); } DWORD_PTR CDiscordProto::GetCaps(int type, MCONTACT) @@ -84,7 +106,7 @@ int CDiscordProto::SetStatus(int iNewStatus) m_iStatus = ID_STATUS_CONNECTING; ProtoBroadcastAck(0, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)iOldStatus, m_iStatus); - ForkThread(&CDiscordProto::ServerThread, this); + m_hWorkerThread = ForkThreadEx(&CDiscordProto::ServerThread, NULL, NULL); } else if (iNewStatus == ID_STATUS_OFFLINE) { m_iStatus = m_iDesiredStatus; @@ -105,6 +127,10 @@ int CDiscordProto::OnModulesLoaded(WPARAM, LPARAM) int CDiscordProto::OnPreShutdown(WPARAM, LPARAM) { + debugLogA("CDiscordProto::OnPreShutdown"); + + m_bTerminated = true; + SetEvent(m_evRequestsQueue); return 0; } -- cgit v1.2.3