summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--protocols/FacebookRM/src/client.h3
-rw-r--r--protocols/FacebookRM/src/communication.cpp6
2 files changed, 5 insertions, 4 deletions
diff --git a/protocols/FacebookRM/src/client.h b/protocols/FacebookRM/src/client.h
index 2b3157617c..1a99885826 100644
--- a/protocols/FacebookRM/src/client.h
+++ b/protocols/FacebookRM/src/client.h
@@ -41,7 +41,6 @@ public:
hChannelCon = nullptr;
hMessagesCon = nullptr;
hFcbCon = nullptr;
- fcb_conn_lock_ = nullptr;
handle_ = nullptr;
parent = nullptr;
@@ -52,7 +51,7 @@ public:
HNETLIBCONN hChannelCon;
HNETLIBCONN hMessagesCon;
HNETLIBCONN hFcbCon;
- HANDLE fcb_conn_lock_;
+ mir_cs fcb_conn_lock_;
// Random generator value for this client
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp
index 8b987063d9..d2ea31ddd1 100644
--- a/protocols/FacebookRM/src/communication.cpp
+++ b/protocols/FacebookRM/src/communication.cpp
@@ -54,6 +54,8 @@ http::response facebook_client::sendRequest(HttpRequest *request)
if (request->requestType == REQUEST_POST)
request->Headers << CHAR_PARAM("Content-Type", "application/x-www-form-urlencoded; charset=utf-8");
+ mir_cslockfull s(fcb_conn_lock_); s.unlock();
+
// Set persistent connection (or not)
switch (request->Persistent) {
case ChannelRequest::NONE:
@@ -69,7 +71,7 @@ http::response facebook_client::sendRequest(HttpRequest *request)
request->flags |= NLHRF_PERSISTENT;
break;
case ChannelRequest::DEFAULT:
- WaitForSingleObject(fcb_conn_lock_, INFINITE);
+ s.lock();
request->nlc = hFcbCon;
request->flags |= NLHRF_PERSISTENT;
break;
@@ -91,7 +93,7 @@ http::response facebook_client::sendRequest(HttpRequest *request)
hMessagesCon = pnlhr ? pnlhr->nlc : nullptr;
break;
case ChannelRequest::DEFAULT:
- ReleaseMutex(fcb_conn_lock_);
+ s.unlock();
hFcbCon = pnlhr ? pnlhr->nlc : nullptr;
break;
}