summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--protocols/FacebookRM/src/chat.cpp12
-rw-r--r--protocols/FacebookRM/src/client.h2
-rw-r--r--protocols/FacebookRM/src/messages.cpp20
3 files changed, 33 insertions, 1 deletions
diff --git a/protocols/FacebookRM/src/chat.cpp b/protocols/FacebookRM/src/chat.cpp
index 7ccaef2459..266818d1af 100644
--- a/protocols/FacebookRM/src/chat.cpp
+++ b/protocols/FacebookRM/src/chat.cpp
@@ -26,7 +26,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
enum ChatMenuItems
{
- IDM_INVITE = 10, IDM_EXIT,
+ IDM_INVITE = 10, IDM_EXIT, IDM_DESTROY,
IDM_DETAILS = 20, IDM_HISTORY
};
@@ -35,6 +35,7 @@ static const struct gc_item LogMenuItems[] =
{
{ LPGENW("&Invite user..."), IDM_INVITE, MENU_ITEM, FALSE },
{ LPGENW("E&xit chat session"), IDM_EXIT, MENU_ITEM, FALSE },
+ { LPGENW("&Destroy chat session"), IDM_DESTROY, MENU_ITEM, FALSE },
};
static const struct gc_item NickMenuItems[] =
@@ -125,6 +126,15 @@ int FacebookProto::OnGCEvent(WPARAM, LPARAM lParam)
facy.sendRequest(facy.exitThreadRequest(it->second));
}
break;
+
+ case IDM_DESTROY:
+ {
+ std::string thread_id = _T2A(hook->ptszID, CP_UTF8);
+ auto it = facy.chat_rooms.find(thread_id);
+ if (it != facy.chat_rooms.end())
+ if (IDOK == MessageBoxW(nullptr, TranslateT("Delete conversation"), TranslateT("This will permanently delete the conversation history"), MB_OKCANCEL))
+ facy.sendRequest(facy.destroyThreadRequest(it->second));
+ }
}
break;
diff --git a/protocols/FacebookRM/src/client.h b/protocols/FacebookRM/src/client.h
index 67c1298854..d6c1fcb137 100644
--- a/protocols/FacebookRM/src/client.h
+++ b/protocols/FacebookRM/src/client.h
@@ -239,6 +239,8 @@ public:
HttpRequest* sendMessageRequest(const char *userId, const char *threadId, const char *messageId, const char *messageText, bool isChat, const char *captcha, const char *captchaPersistData);
HttpRequest* sendTypingRequest(const char *userId, bool isChat, bool isTyping);
HttpRequest* markMessageReadRequest(const LIST<char> &ids);
+
+ HttpRequest* destroyThreadRequest(facebook_chatroom *fbc);
HttpRequest* exitThreadRequest(facebook_chatroom *fbc);
// notifications.cpp
diff --git a/protocols/FacebookRM/src/messages.cpp b/protocols/FacebookRM/src/messages.cpp
index 9970d9be2c..5c128d5bb2 100644
--- a/protocols/FacebookRM/src/messages.cpp
+++ b/protocols/FacebookRM/src/messages.cpp
@@ -344,6 +344,26 @@ HttpRequest* facebook_client::markMessageReadRequest(const LIST<char> &ids)
/////////////////////////////////////////////////////////////////////////////////////////
+HttpRequest* facebook_client::destroyThreadRequest(facebook_chatroom *fbc)
+{
+ HttpRequest *p = new HttpRequest(REQUEST_POST, FACEBOOK_SERVER_REGULAR "/ajax/mercury/delete_thread.php");
+
+ p->Url << INT_PARAM("dpr", 1);
+
+ p->Body
+ << CHAR_PARAM("ids[0]", fbc->thread_id.substr(3).c_str())
+ << CHAR_PARAM("__user", self_.user_id.c_str())
+ << CHAR_PARAM("fb_dtsg", dtsg_.c_str())
+ << CHAR_PARAM("__dyn", __dyn())
+ << CHAR_PARAM("__req", __req())
+ << CHAR_PARAM("__rev", __rev())
+ << CHAR_PARAM("__pc", "PHASED:DEFAULT")
+ << INT_PARAM("__a", 1)
+ << INT_PARAM("__be", 1);
+
+ return p;
+}
+
HttpRequest* facebook_client::exitThreadRequest(facebook_chatroom *fbc)
{
HttpRequest *p = new HttpRequest(REQUEST_POST, FACEBOOK_SERVER_REGULAR "/messaging/send/");