From 8400fd1be0ac7971bd4e86f3256f4421918818b6 Mon Sep 17 00:00:00 2001 From: "Bankde@hotmail.com" Date: Wed, 18 Jan 2017 19:43:38 +0700 Subject: [PATCH] Add logout feature --- fbchat/client.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/fbchat/client.py b/fbchat/client.py index 777de09..245dcf5 100644 --- a/fbchat/client.py +++ b/fbchat/client.py @@ -39,6 +39,7 @@ StickyURL ="https://0-edge-chat.facebook.com/pull" PingURL ="https://0-channel-proxy-06-ash2.facebook.com/active_ping" UploadURL ="https://upload.facebook.com/ajax/mercury/upload.php" UserInfoURL ="https://www.facebook.com/chat/user_info/" +LogoutURL ="https://www.facebook.com/logout.php" class Client(object): """A client for the Facebook Chat (Messenger). @@ -159,6 +160,7 @@ class Client(object): r = self._get(BaseURL) soup = bs(r.text, "lxml") self.fb_dtsg = soup.find("input", {'name':'fb_dtsg'})['value'] + self.fb_h = soup.find("input", {'name':'h'})['value'] self._setttstamp() # Set default payload self.payloadDefault['__rev'] = int(r.text.split('"revision":',1)[1].split(",",1)[0]) @@ -187,6 +189,19 @@ class Client(object): else: return False + def logout(self, timeout=30): + data = {} + data['ref'] = "mb" + data['h'] = self.fb_h + payload=self._generatePayload(data) + r = self._session.get(LogoutURL, headers=self._header, params=payload, timeout=timeout) + # reset value + self.payloadDefault={} + self._session = requests.session() + self.req_counter = 1 + self.seq = "0" + return r + def listen(self): pass