Esempio n. 1
0
def get_followers(handle_name):
    global SLEEP_TIME
    url = 'https://api.twitter.com/1.1/followers/ids.json'
    cursor = -1
    users = []
    ids = True  

    while cursor:
        params = {'screen_name': handle_name, 'cursor': str(cursor)}
        info, response = oauth_req(url, params)

        if info['status'] == '429':
            sleep_til = float(info.get('x-rate-limit-reset', time.time() + 120))
            SLEEP_TIME = sleep_til - time.time()
            if SLEEP_TIME < 10:
                SLEEP_TIME = 10
            logger.error('Hit rate limit, sleeping for %s until %s', SLEEP_TIME, sleep_til)
            return []
        elif info['status'] != '200':   
            logger.error('got a %s error trying to get followers %s',
                         info['status'], handle_name)
            logger.error(info)
            logger.error(response)

            return []

        loaded = json.loads(response)
        ids = loaded.get('ids')
        users.extend(ids)
        cursor = info.get('next_cursor_str')

    return users
Esempio n. 2
0
def get_user_info(handle_ids):
    url = 'https://api.twitter.com/1.1/users/lookup.json?user_id=%s'

    orig_handle_ids = handle_ids
    handle_ids = ','.join([str(x) for x in handle_ids])
    params = {}
    url = url % handle_ids
    info, response = oauth_req(url, params)

    if info['status'] == '404':
        # 404 for suspended accounts
        for id_ in orig_handle_ids:
            yield 'SUSPENDED', id_
        return
    elif info['status'] != '200':   
        logger.error(info)
        logger.error(response)
        logger.error('get a %s error trying to get user info for %s',
                     info['status'], handle_ids)
        return

    people = json.loads(response)
    for peep in people:
        id = peep.get('id')
        name = peep.get('screen_name')
        yield name, id
Esempio n. 3
0
def follow_id(handle_id):
    url = 'https://api.twitter.com/1.1/friendships/create.json'
    params = {'user_id': str(handle_id), 'follow': True}

    logger.debug('Following user_id: %s', handle_id)
    info, response = oauth_req(url, params, 'POST')

    if info['status'] != '200':   
        logger.error('get a %s error trying to follow %s',
                     info['status'], handle_id)
        logger.error(info)
        logger.error(response)
        return False

    return True
Esempio n. 4
0
def create_tweet(tweet):
    url = 'http://api.twitter.com/1.1/statuses/update.json'
    params = {
        'status': tweet
    }

    while True:
        info, response = oauth_req(url, params, 'POST')

        if info['status'] == '429':
            sleep_til = float(info.get('x-rate-limit-reset', time.time() + 120))
            time_to_sleep = sleep_til - time.time()
            logger.error('Hit rate limit while tweeting, sleeping for %s until %s', SLEEP_TIME, sleep_til)
            time.sleep(time_to_sleep)
            logger.error('Trying to tweet again...')
        elif info['status'] != '200':
            logger.error(info)
            logger.error(response)
            logger.error('got a %s error trying to tweet %r',
                         info['status'], tweet)
        else:
            logger.info('Successfully tweeted: %s', tweet)
            break