예제 #1
0
파일: qsession.py 프로젝트: yuerthe9/qqbot
 def fetchSimpleGroupMemberTable(self, group):
     memberTable = QContactTable('group-member')
     try:
         r = self.smartRequest(
             url='http://qun.qq.com/cgi-bin/qun_mgr/search_group_members',
             Referer='http://qun.qq.com/member.html',
             data={
                 'gc': group.qq,
                 'st': '0',
                 'end': '20',
                 'sort': '0',
                 'bkn': self.bkn
             },
             repeateOnDeny=5)
     except RequestError:
         return memberTable
     except:
         DEBUG('', exc_info=True)
         return memberTable
     else:
         for m in r['mems']:
             qq, nick, card = \
                 str(m['uin']), str(m['nick']), str(m.get('card', ''))
             memberTable.Add(qq=qq,
                             name=(card or nick),
                             nick=nick,
                             card=card)
         memberTable.lastUpdateTime = time.time()
         return memberTable
예제 #2
0
    def fetchGroupMemberTable(self, group):
        # 没有现在必要获取成员的 uin,也没有必要现在将 uin 和 qq 绑定起来。
        # 需要的时候再绑定就可以了
        memberTable = QContactTable('group-member')

        r = self.smartRequest(
            url='http://qun.qq.com/cgi-bin/qun_mgr/search_group_members',
            Referer='http://qun.qq.com/member.html',
            data={
                'gc': group.qq,
                'st': '0',
                'end': '2000',
                'sort': '0',
                'bkn': self.bkn
            })

        for m in r['mems']:
            qq = str(m['uin'])
            nick = HTMLUnescape(str(m['nick']))
            card = HTMLUnescape(str(m.get('card', '')))
            memberTable.Add(name=(card or nick), nick=nick, qq=qq, card=card)

        memberTable.lastUpdateTime = time.time()

        return memberTable
예제 #3
0
    def fetchGroupMemberTable(self, group):
        # 没有现在必要获取成员的 uin,也没有必要现在将 uin 和 qq 绑定起来。
        # 需要的时候再绑定就可以了

        memberTable = QContactTable('group-member')

        r = self.smartRequest(
            url=
            'http://qinfo.clt.qq.com/cgi-bin/qun_info/get_group_members_new',
            Referer='http://qinfo.clt.qq.com/member.html',
            data={
                'gc': group.qq,
                'u': self.uin,
                'bkn': self.bkn
            })

        for m in r['mems']:
            qq = str(m['u'])
            nick = HTMLUnescape(m['n'])
            card = HTMLUnescape(r.get('cards', {}).get(qq, ''))
            mark = HTMLUnescape(r.get('remarks', {}).get(qq, ''))
            join_time = r.get('join', {}).get(qq, 0)
            last_speak_time = r.get('times', {}).get(qq, 0)
            is_buddy = m['u'] in r.get('friends', [])

            if r['owner'] == m['u']:
                role, role_id = '群主', 0
            elif m['u'] in r.get('adm', []):
                role, role_id = '管理员', 1
            else:
                role, role_id = '成员', 2

            level = r.get('lv', {}).get(qq, {}).get('l', 0)
            levelname = HTMLUnescape(
                r.get('levelname', {}).get('lvln' + str(level), ''))
            point = r.get('lv', {}).get(qq, {}).get('p', 0)

            memberTable.Add(name=(card or nick),
                            nick=nick,
                            qq=qq,
                            card=card,
                            join_time=join_time,
                            last_speak_time=last_speak_time,
                            role=role,
                            role_id=role_id,
                            mark=mark,
                            is_buddy=is_buddy,
                            level=level,
                            levelname=levelname,
                            point=point)

        memberTable.lastUpdateTime = time.time()

        return memberTable
        '''
예제 #4
0
    def fetchBuddyTable(self):
        buddyTable = QContactTable('buddy')

        result = self.smartRequest(
            url='http://s.web2.qq.com/api/get_user_friends2',
            data={
                'r': JsonDumps({
                    'vfwebqq': self.vfwebqq,
                    'hash': self.hash
                })
            },
            Referer=('http://d1.web2.qq.com/proxy.html?v=20151105001&'
                     'callback=1&id=2'),
            expectedKey='marknames',
            repeatOnDeny=4)

        markDict = dict(
            (str(d['uin']), str(d['markname'])) for d in result['marknames'])

        qqResult = self.smartRequest(
            url='http://qun.qq.com/cgi-bin/qun_mgr/get_friend_list',
            data={'bkn': self.bkn},
            Referer='http://qun.qq.com/member.html')
        qqDict = collections.defaultdict(list)
        for blist in list(qqResult.values()):
            for d in blist.get('mems', []):
                name = HTMLUnescape(d['name'])
                qqDict[name].append(str(d['uin']))

        for info in result['info']:
            uin = str(info['uin'])
            nick = str(info['nick'])
            mark = markDict.get(uin, '')

            if PY3:
                nick = nick.replace('\xa0', ' ')
                mark = mark.replace('\xa0', ' ')

            name = mark or nick
            qqlist = qqDict.get(name, [])
            if len(qqlist) == 1:
                qq = qqlist.pop()
            else:
                qq = self.fetchBuddyQQ(uin)
                try:
                    qqlist.remove(qq)
                except ValueError:
                    pass

            buddyTable.Add(uin=uin, name=name, qq=qq, mark=mark, nick=nick)

        buddyTable.lastUpdateTime = time.time()

        return buddyTable
예제 #5
0
    def fetchGroupTable(self):        
        groupTable = QContactTable('group')

        result = self.smartRequest(
            url = 'http://s.web2.qq.com/api/get_group_name_list_mask2',
            data = {
                'r': JsonDumps({'vfwebqq':self.vfwebqq, 'hash':self.hash})
            },
            Referer = ('http://d1.web2.qq.com/proxy.html?v=20151105001&'
                       'callback=1&id=2'),
            expectedKey = 'gmarklist',
            repeateOnDeny = 3
        )
        
        markDict = dict((str(d['uin']), str(d['markname'])) \
                   for d in result['gmarklist'])

        qqResult = self.smartRequest(
            url = 'http://qun.qq.com/cgi-bin/qun_mgr/get_group_list',
            data = {'bkn': self.bkn},
            Referer = 'http://qun.qq.com/member.html'
        )
        
        qqDict = collections.defaultdict(list)
        for k in ('create', 'manage', 'join'):
            for d in qqResult.get(k, []):
                name = d['gn'].replace(' ', ' ').replace('&', '&')
                qqDict[name].append(str(d['gc']))

        for info in result['gnamelist']:
            uin = str(info['gid'])
            name = str(info['name'])
            mark = markDict.get(uin, '')

            qqlist = qqDict.get(name, [])
            if len(qqlist) == 1:
                qq = qqlist.pop()
            else:
                qq = self.fetchGroupQQ(uin)
                for x in qqlist:
                    if qq[-6:] == x[-6:]:
                        qq = x
                        break
                try:
                    qqlist.remove(qq)
                except ValueError:
                    pass

            groupTable.Add(uin=uin, name=(mark or name), nick=name, qq=qq,
                           mark=mark, gcode=str(info['code']))
        
        groupTable.lastUpdateTime = time.time()
        
        return groupTable
예제 #6
0
파일: qsession.py 프로젝트: blackmady/qqbot
    def fetchBuddyTable(self):
        buddyTable = QContactTable('buddy')

        result = self.smartRequest(
            url = 'http://s.web2.qq.com/api/get_user_friends2',
            data = {
                'r': JsonDumps({'vfwebqq':self.vfwebqq, 'hash':self.hash})
            },
            Referer = ('http://d1.web2.qq.com/proxy.html?v=20151105001&'
                       'callback=1&id=2'),
            expectedKey = 'marknames',
            repeateOnDeny = 4
        )

        markDict = dict((str(d['uin']), str(d['markname']))
                        for d in result['marknames'])
        
        qqResult = self.smartRequest(
            url = 'http://qun.qq.com/cgi-bin/qun_mgr/get_friend_list',
            data = {'bkn': self.bkn},
            Referer = 'http://qun.qq.com/member.html'
        )
        qqDict = collections.defaultdict(list)
        for blist in list(qqResult.values()):
            for d in blist.get('mems', []):
                # name = d['name'].replace(' ', ' ').replace('&', '&')
                name = HTMLUnescape(d['name'])
                qqDict[name].append(str(d['uin']))

        for info in result['info']:
            uin = str(info['uin'])
            nick = str(info['nick'])
            mark = markDict.get(uin, '')
            name = mark or nick
            qqlist = qqDict.get(name, [])
            if len(qqlist) == 1:
                qq = qqlist.pop()
            else:
                qq = self.fetchBuddyQQ(uin)
                try:
                    qqlist.remove(qq)
                except ValueError:
                    pass
                
            buddyTable.Add(uin=uin, name=name, qq=qq, mark=mark, nick=nick)
        
        buddyTable.lastUpdateTime = time.time()
        
        return buddyTable
예제 #7
0
 def fetchDiscussMemberTable(self, discuss):
     memberTable = QContactTable('discuss-member')
     result = self.smartRequest(
         url=('http://d1.web2.qq.com/channel/get_discu_info?'
              'did=%s&psessionid=%s&vfwebqq=%s&clientid=%s&t={rand}') %
         (discuss.uin, self.psessionid, self.vfwebqq, self.clientid),
         Referer=('http://d1.web2.qq.com/proxy.html?v=20151105001'
                  '&callback=1&id=2'))
     for m in result['mem_info']:
         uin = str(m['uin'])
         name = str(m['nick'])
         qq = self.fetchBuddyQQ(uin)
         memberTable.Add(uin=uin, name=name, qq=qq)
     memberTable.lastUpdateTime = time.time()
     return memberTable
예제 #8
0
파일: qsession.py 프로젝트: blackmady/qqbot
 def fetchDiscussMemberTable(self, discuss):        
     memberTable = QContactTable('discuss-member')
     result = self.smartRequest(
         url = ('http://d1.web2.qq.com/channel/get_discu_info?'
                'did=%s&psessionid=%s&vfwebqq=%s&clientid=%s&t={rand}') %
               (discuss.uin, self.psessionid, self.vfwebqq, self.clientid),
         Referer = ('http://d1.web2.qq.com/proxy.html?v=20151105001'
                    '&callback=1&id=2')
     )
     for m in result['mem_info']:
         uin = str(m['uin'])
         name = str(m['nick'])
         qq = self.fetchBuddyQQ(uin)
         memberTable.Add(uin=uin, name=name, qq=qq)
     memberTable.lastUpdateTime = time.time()
     return memberTable
예제 #9
0
    def fetchGroupMemberTable(self, group):
        # 没有现在必要获取成员的 uin,也没有必要现在将 uin 和 qq 绑定起来。
        # 需要的时候再绑定就可以了
        memberTable = QContactTable('group-member')

        r = self.smartRequest(
            url='http://qun.qq.com/cgi-bin/qun_mgr/search_group_members',
            Referer='http://qun.qq.com/member.html',
            data={
                'gc': group.qq,
                'st': '0',
                'end': '2000',
                'sort': '0',
                'bkn': self.bkn
            })

        for m in r['mems']:
            qq = str(m['uin'])
            nick = HTMLUnescape(str(m['nick']))
            card = HTMLUnescape(str(m.get('card', '')))
            role = ['群主', '管理员', '普通成员'][m.get('role', 2)]

            join_time = m.get('join_time', 0)
            last_speak_time = m.get('last_speak_time', 0)
            level = m.get('level', 0)
            levelname = r.get('levelname', {}).get(level, 'NULL')
            point = r.get('point', 0)
            qage = r.get('qage', 0)

            memberTable.Add(name=(card or nick),
                            nick=nick,
                            qq=qq,
                            card=card,
                            role=role,
                            join_time=join_time,
                            level=level,
                            levelname=levelname,
                            point=point,
                            last_speak_time=last_speak_time,
                            qage=qage)

        memberTable.lastUpdateTime = time.time()

        return memberTable
예제 #10
0
    def fetchDiscussTable(self):
        discussTable = QContactTable('discuss')

        result = self.smartRequest(
            url=('http://s.web2.qq.com/api/get_discus_list?clientid=%s&'
                 'psessionid=%s&vfwebqq=%s&t={rand}') %
            (self.clientid, self.psessionid, self.vfwebqq),
            Referer=('http://d1.web2.qq.com/proxy.html?v=20151105001'
                     '&callback=1&id=2'),
            # expectedCodes = (0, 100003),
            expectedKey='dnamelist',
            repeatOnDeny=5)['dnamelist']

        for info in result:
            discussTable.Add(uin=str(info['did']),
                             name=str(info['name']),
                             qq=str(info['did']))
        discussTable.lastUpdateTime = time.time()
        return discussTable
예제 #11
0
파일: qsession.py 프로젝트: blackmady/qqbot
    def fetchDiscussTable(self):
        discussTable = QContactTable('discuss')

        result = self.smartRequest(
            url = ('http://s.web2.qq.com/api/get_discus_list?clientid=%s&'
                   'psessionid=%s&vfwebqq=%s&t={rand}') % 
                  (self.clientid, self.psessionid, self.vfwebqq),
            Referer = ('http://d1.web2.qq.com/proxy.html?v=20151105001'
                       '&callback=1&id=2'),
            # expectedCodes = (0, 100003),
            expectedKey = 'dnamelist',
            repeateOnDeny = 5
        )['dnamelist']

        for info in result:
            discussTable.Add(uin=str(info['did']), name=str(info['name']),
                             qq=str(info['did']))
        discussTable.lastUpdateTime = time.time()
        return discussTable
예제 #12
0
파일: qsession.py 프로젝트: yuerthe9/qqbot
    def fetchDiscussTable(self):
        discussTable = QContactTable('discuss')

        def extractor(result):
            retcode = result.get('retcode', -1)
            result = result.get('result', result)
            if retcode in (0, 100003) and 'dnamelist' in result:
                return result

        result = self.smartRequest(
            url=('http://s.web2.qq.com/api/get_discus_list?clientid=%s&'
                 'psessionid=%s&vfwebqq=%s&t={rand}') %
            (self.clientid, self.psessionid, self.vfwebqq),
            Referer=('http://d1.web2.qq.com/proxy.html?v=20151105001'
                     '&callback=1&id=2'),
            resultExtractor=extractor,
            repeateOnDeny=5)['dnamelist']

        for info in result:
            discussTable.Add(uin=str(info['did']),
                             name=str(info['name']),
                             qq=str(info['did']))
        discussTable.lastUpdateTime = time.time()
        return discussTable
예제 #13
0
    def fetchGroupTable(self):
        groupTable = QContactTable('group')

        qqResult = self.smartRequest(
            url='http://qun.qq.com/cgi-bin/qun_mgr/get_group_list',
            data={'bkn': self.bkn},
            Referer='http://qun.qq.com/member.html')

        result = self.smartRequest(
            url='http://s.web2.qq.com/api/get_group_name_list_mask2',
            data={
                'r': JsonDumps({
                    'vfwebqq': self.vfwebqq,
                    'hash': self.hash
                })
            },
            Referer=('http://d1.web2.qq.com/proxy.html?v=20151105001&'
                     'callback=1&id=2'),
            expectedKey='gmarklist',
            repeatOnDeny=6)

        markDict = dict((str(d['uin']), str(d['markname'])) \
                   for d in result['gmarklist'])

        qqDict = collections.defaultdict(list)
        for k in ('create', 'manage', 'join'):
            for d in qqResult.get(k, []):
                qqDict[HTMLUnescape(d['gn'])].append(str(d['gc']))

        unresolved = []
        for info in result['gnamelist']:
            uin = str(info['gid'])
            name = str(info['name'])
            mark = markDict.get(uin, '')

            if PY3:
                name = name.replace('\xa0', ' ')
                mark = mark.replace('\xa0', ' ')

            qqlist = qqDict.get(name, [])
            if len(qqlist) == 1:
                # 没有重名现象
                qq = qqlist[0]
                qqDict.pop(name)
            elif len(qqlist) > 1:
                # 有重名现象
                qq = self.fetchGroupQQ(uin)  # 这里返回的qq号可能只有最后6位是对的
                for trueQQ in qqlist[:]:
                    if qq[-6:] == trueQQ[-6:]:
                        qq = trueQQ
                        qqlist.remove(trueQQ)
                        break
            else:
                # 可能是 qun.qq.com 返回的 name 和 w.qq.com 返回的 name 不一致
                # 比如: “x x” 和 “x x” ,尽管经过前面的转义处理,但可能还是
                # 有没有转过来的
                # 也可能是两次请求的空隙期间加入了一个新群(理论上有这种可能)
                unresolved.append((uin, name, mark))
                continue

            groupTable.Add(uin=uin,
                           name=(mark or name),
                           nick=name,
                           qq=qq,
                           mark=mark,
                           gcode=str(info['code']))

        for uin, name, mark in unresolved:
            qq = self.fetchGroupQQ(uin)  # 这里返回的qq号可能只有最后6位是对的

            for xname, qqlist in list(qqDict.items()):
                for trueQQ in qqlist[:]:
                    if qq[-6:] == trueQQ[-6:]:
                        qq = trueQQ
                        if len(qqlist) == 1:
                            qqDict.pop(xname)
                        else:
                            qqlist.remove(qq)
                        break
                else:
                    continue

                break

            groupTable.Add(uin=uin,
                           name=(mark or name),
                           nick=name,
                           qq=qq,
                           mark=mark,
                           gcode=str(info['code']))

        groupTable.lastUpdateTime = time.time()

        return groupTable
예제 #14
0
    def fetchGroupMemberTable(self, group):
        memberTable = QContactTable('group-member')
        
        result = self.smartRequest(
            url = ('http://s.web2.qq.com/api/get_group_info_ext2?gcode=%s'
                   '&vfwebqq=%s&t={rand}') % (group.gcode, self.vfwebqq),
            Referer = ('http://s.web2.qq.com/proxy.html?v=20130916001'
                       '&callback=1&id=1'),
            # expectedCodes = (0, 100003, 6, 15),
            expectedKey = 'ginfo',
            repeateOnDeny = 5
        )

        r = self.smartRequest(
            url = 'http://qun.qq.com/cgi-bin/qun_mgr/search_group_members',
            Referer = 'http://qun.qq.com/member.html',
            data = {'gc': group.qq, 'st': '0', 'end': '20',
                    'sort': '0', 'bkn': self.bkn}
        )
        
        qqDict, nickDict = {}, collections.defaultdict(list)
        for m in r['mems']:
            qq, nick, card = \
                str(m['uin']), str(m['nick']), str(m.get('card', ''))
            memb = [qq, nick, card]
            qqDict[qq] = memb
            nickDict[nick].append(memb)
        
        if 'minfo' in result:
            for m, inf in zip(result['ginfo']['members'], result['minfo']):
                uin, nick = str(m['muin']), str(inf['nick'])
                membs = nickDict.get(nick, [])
                if len(membs) == 1:
                    qq, card = membs[0][0], membs[0][2]
                else:
                    qq = self.fetchBuddyQQ(uin)
                    if qq in qqDict:
                        card = qqDict[qq][2]                    
                        try:
                            membs.remove(qqDict[qq])
                        except ValueError:
                            pass
                    else:
                        card = ''
                memberTable.Add(uin=uin, name=(card or nick),
                                nick=nick, qq=qq, card=card)
  
        else:
            for m in result['ginfo']['members']:                    
                uin = str(m['muin'])
                qq = self.fetchBuddyQQ(uin)
                if qq in qqDict:
                    nick, card = qqDict[qq][1], qqDict[qq][2]
                else:
                    nick, card = '##UNKOWN', ''
                memberTable.Add(uin=uin, name=(card or nick),
                                nick=nick, qq=qq, card=card)
        
        memberTable.lastUpdateTime = time.time()
        
        return memberTable
예제 #15
0
파일: qsession.py 프로젝트: blackmady/qqbot
    def fetchGroupMemberTable(self, group):
        memberTable = QContactTable('group-member')
        
        result = self.smartRequest(
            url = ('http://s.web2.qq.com/api/get_group_info_ext2?gcode=%s'
                   '&vfwebqq=%s&t={rand}') % (group.gcode, self.vfwebqq),
            Referer = ('http://s.web2.qq.com/proxy.html?v=20130916001'
                       '&callback=1&id=1'),
            # expectedCodes = (0, 100003, 6, 15),
            expectedKey = 'ginfo',
            repeateOnDeny = 5
        )

        r = self.smartRequest(
            url = 'http://qun.qq.com/cgi-bin/qun_mgr/search_group_members',
            Referer = 'http://qun.qq.com/member.html',
            data = {'gc': group.qq, 'st': '0', 'end': '20',
                    'sort': '0', 'bkn': self.bkn}
        )
        
        qqDict, nickDict = {}, collections.defaultdict(list)
        for m in r['mems']:
            qq, nick, card = \
                str(m['uin']), str(m['nick']), str(m.get('card', ''))
            nick = HTMLUnescape(nick)
            card = HTMLUnescape(card)
            memb = [qq, nick, card]
            qqDict[qq] = memb
            nickDict[nick].append(memb)
        
        if 'minfo' in result:
            for m, inf in zip(result['ginfo']['members'], result['minfo']):
                uin, nick = str(m['muin']), str(inf['nick'])
                membs = nickDict.get(nick, [])
                if len(membs) == 1:
                    qq, card = membs[0][0], membs[0][2]
                else:
                    qq = self.fetchBuddyQQ(uin)
                    if qq in qqDict:
                        card = qqDict[qq][2]                    
                        try:
                            membs.remove(qqDict[qq])
                        except ValueError:
                            pass
                    else:
                        card = ''
                memberTable.Add(uin=uin, name=(card or nick),
                                nick=nick, qq=qq, card=card)
  
        else:
            for m in result['ginfo']['members']:                    
                uin = str(m['muin'])
                qq = self.fetchBuddyQQ(uin)
                if qq in qqDict:
                    nick, card = qqDict[qq][1], qqDict[qq][2]
                else:
                    nick, card = '##UNKOWN', ''
                memberTable.Add(uin=uin, name=(card or nick),
                                nick=nick, qq=qq, card=card)
        
        memberTable.lastUpdateTime = time.time()
        
        return memberTable
예제 #16
0
파일: qsession.py 프로젝트: blackmady/qqbot
    def fetchGroupTable(self):        
        groupTable = QContactTable('group')

        result = self.smartRequest(
            url = 'http://s.web2.qq.com/api/get_group_name_list_mask2',
            data = {
                'r': JsonDumps({'vfwebqq':self.vfwebqq, 'hash':self.hash})
            },
            Referer = ('http://d1.web2.qq.com/proxy.html?v=20151105001&'
                       'callback=1&id=2'),
            expectedKey = 'gmarklist',
            repeateOnDeny = 3
        )
        
        markDict = dict((str(d['uin']), str(d['markname'])) \
                   for d in result['gmarklist'])

        qqResult = self.smartRequest(
            url = 'http://qun.qq.com/cgi-bin/qun_mgr/get_group_list',
            data = {'bkn': self.bkn},
            Referer = 'http://qun.qq.com/member.html'
        )
        
        qqDict = collections.defaultdict(list)
        for k in ('create', 'manage', 'join'):
            for d in qqResult.get(k, []):
                # name = d['gn'].replace(' ', ' ').replace('&', '&')
                qqDict[HTMLUnescape(d['gn'])].append(str(d['gc']))

        for info in result['gnamelist']:
            uin = str(info['gid'])
            name = str(info['name'])
            mark = markDict.get(uin, '')

            qqlist = qqDict.get(name, [])
            if len(qqlist) == 1:
                qq = qqlist[0]
                qqDict.pop(name)
            elif len(qqlist) == 0:
                qq = self.fetchGroupQQ(uin)
                for xname, qqlist in qqDict.items():
                    for trueQQ in qqlist:
                        if qq[-6:] == trueQQ[-6:]:
                            qq = trueQQ
                            if len(qqlist) == 1:
                                qqDict.pop(xname)
                            else:
                                qqlist.remove(qq)
                            break
            else:
                qq = self.fetchGroupQQ(uin)
                for trueQQ in qqlist:
                    if qq[-6:] == trueQQ[-6:]:
                        qq = trueQQ
                        qqlist.remove(qq)
                        break

            groupTable.Add(uin=uin, name=(mark or name), nick=name, qq=qq,
                           mark=mark, gcode=str(info['code']))
        
        groupTable.lastUpdateTime = time.time()
        
        return groupTable