consolidate code & use default payload for get/post

This commit is contained in:
PidgeyL
2015-12-08 18:04:06 +01:00
parent 0e4078b26e
commit 425ecaa93c

View File

@@ -52,6 +52,7 @@ class Client(object):
self.debug = debug self.debug = debug
self._session = requests.session() self._session = requests.session()
self.req_counter = 1; self.req_counter = 1;
self.payloadDefault={}
if not user_agent: if not user_agent:
user_agent = choice(USER_AGENTS) user_agent = choice(USER_AGENTS)
@@ -71,15 +72,33 @@ class Client(object):
self.threads = [] self.threads = []
def _console(self, msg): def _console(self, msg):
if self.debug: print(msg) if self.debug: print(msg)
def _get(self, url, query=None, timeout=30): def _setttstamp(self):
for i in self.fb_dtsg:
self.ttstamp += str(ord(i))
self.ttstamp += '2'
def _generatePayload(self, query):
if query:
payload=self.payloadDefault.copy()
payload.update(query)
payload['__req'] = str_base(self.req_counter, 36)
else:
payload = None
self.req_counter+=1 self.req_counter+=1
return self._session.get(url, headers=self._header, params=query, timeout=timeout) return payload
def _get(self, url, query=None, timeout=30):
payload=self._generatePayload(query)
return self._session.get(url, headers=self._header, params=payload, timeout=timeout)
def _post(self, url, query=None, timeout=30): def _post(self, url, query=None, timeout=30):
payload=self._generatePayload(query)
return self._session.post(url, headers=self._header, data=payload, timeout=timeout)
def _cleanPost(self, url, query=None, timeout=30):
self.req_counter+=1 self.req_counter+=1
return self._session.post(url, headers=self._header, data=query, timeout=timeout) return self._session.post(url, headers=self._header, data=query, timeout=timeout)
@@ -93,8 +112,7 @@ class Client(object):
data['pass'] = self.password data['pass'] = self.password
data['login'] = 'Log In' data['login'] = 'Log In'
r = self._post(LoginURL, data) r = self._cleanPost(LoginURL, data)
self.r = r
if 'home' in r.url: if 'home' in r.url:
self.client_id = hex(int(random()*2147483648))[2:] self.client_id = hex(int(random()*2147483648))[2:]
@@ -104,15 +122,12 @@ class Client(object):
self.ttstamp = '' self.ttstamp = ''
r = self._get('https://www.facebook.com/') r = self._get('https://www.facebook.com/')
self.rev = int(r.text.split('"revision":',1)[1].split(",",1)[0]) self.payloadDefault['__rev']= int(r.text.split('"revision":',1)[1].split(",",1)[0])
#self.rev = int(random()*100000) self.payloadDefault['__user']= self.uid
soup = bs(r.text, "lxml") soup = bs(r.text, "lxml")
self.fb_dtsg = soup.find("input", {'name':'fb_dtsg'})['value'] self.fb_dtsg = soup.find("input", {'name':'fb_dtsg'})['value']
self._setttstamp()
for i in self.fb_dtsg:
self.ttstamp += str(ord(i))
self.ttstamp += '2'
self.form = { self.form = {
'channel' : self.user_channel, 'channel' : self.user_channel,
@@ -147,14 +162,10 @@ class Client(object):
'path' : "/home.php", 'path' : "/home.php",
'request_id' : str(uuid1()), 'request_id' : str(uuid1()),
'__a' : '1', '__a' : '1',
'__user' : self.uid,
'__req' : str_base(self.req_counter, 36),
'__rev' : self.rev,
} }
r = self._get(SearchURL, payload) r = self._get(SearchURL, payload)
self.j = j = get_json(r.text) self.j = j = get_json(r.text)
self.r = r
users = [] users = []
for entry in j['payload']['entries']: for entry in j['payload']['entries']:
@@ -170,9 +181,6 @@ class Client(object):
'fb_dtsg' : self.fb_dtsg, 'fb_dtsg' : self.fb_dtsg,
'ttstamp' : self.ttstamp, 'ttstamp' : self.ttstamp,
'__a' : '1', '__a' : '1',
'__user' : self.uid,
'__req' : str_base(self.req_counter, 36),
'__rev' : self.rev,
'message_batch[0][action_type]' : 'ma-type:user-generated-message', 'message_batch[0][action_type]' : 'ma-type:user-generated-message',
'message_batch[0][author]' : 'fbid:' + str(self.uid), 'message_batch[0][author]' : 'fbid:' + str(self.uid),
'message_batch[0][specific_to_list][0]' : 'fbid:' + str(thread_id), 'message_batch[0][specific_to_list][0]' : 'fbid:' + str(thread_id),
@@ -213,9 +221,6 @@ class Client(object):
'fb_dtsg' : self.fb_dtsg, 'fb_dtsg' : self.fb_dtsg,
'ttstamp' : self.ttstamp, 'ttstamp' : self.ttstamp,
'__a' : '1', '__a' : '1',
'__user' : self.uid,
'__req' : str_base(self.req_counter, 36),
'__rev' : self.rev,
'inbox[offset]' : start, 'inbox[offset]' : start,
'inbox[limit]' : end, 'inbox[limit]' : end,
} }