parser.add_argument(
'-s',
'--stream',
- default="mine",
+ default="mine",
help='Default stream after program start. (Default: mine)')
parser.add_argument(
'-to',
'--image-on-term',
action='store_true',
help='Display all image on terminal.')
+ parser.add_argument(
+ '-24',
+ '--color-24bit',
+ action='store_true',
+ help='Display images using 24bit color codes.')
parser.add_argument(
'-ph',
'--proxy-host',
url = 'https://raw.githubusercontent.com/DTVD/rainbowstream/master/setup.py'
readme = requests.get(url).text
latest = readme.split('version = \'')[1].split('\'')[0]
- if current != latest:
+ g['using_latest'] = current == latest
+ if not g['using_latest']:
notice = light_magenta('RainbowStream latest version is ')
notice += light_green(latest)
notice += light_magenta(' while your current version is ')
notice += light_yellow(current) + '\n'
notice += light_magenta('You should upgrade with ')
notice += light_green('pip install -U rainbowstream')
- printNicely(notice)
else:
notice = light_yellow('You are running latest version (')
notice += light_green(current)
notice += light_yellow(')')
- printNicely(notice)
+ notice += '\n'
+ printNicely(notice)
except:
pass
c['message_dict'] = []
# Image on term
c['IMAGE_ON_TERM'] = args.image_on_term
- set_config('IMAGE_ON_TERM', str(c['IMAGE_ON_TERM']))
+ # Use 24 bit color
+ c['24BIT'] = args.color_24bit
# Check type of ONLY_LIST and IGNORE_LIST
if not isinstance(c['ONLY_LIST'], list):
printNicely(red('ONLY_LIST is not a valid list value.'))
num = c['HOME_TWEET_NUM']
if g['stuff'].isdigit():
num = int(g['stuff'])
- for tweet in reversed(t.statuses.home_timeline(count=num)):
+ for tweet in reversed(t.statuses.home_timeline(count=num, tweet_mode='extended')):
draw(t=tweet)
printNicely('')
except:
num = c['HOME_TWEET_NUM']
for tweet in reversed(
- t.statuses.user_timeline(count=num, screen_name=user[1:])):
+ t.statuses.user_timeline(count=num, screen_name=user[1:], tweet_mode='extended')):
draw(t=tweet)
printNicely('')
else:
printNicely(red('A name should begin with a \'@\''))
+def view_my_tweets():
+ """
+ Display user's recent tweets.
+ """
+ t = Twitter(auth=authen())
+ try:
+ num = int(g['stuff'])
+ except:
+ num = c['HOME_TWEET_NUM']
+ for tweet in reversed(
+ t.statuses.user_timeline(count=num, screen_name=g['original_name'], tweet_mode='extended')):
+ draw(t=tweet)
+ printNicely('')
+
+
def search():
"""
Search
Add new link to Pocket along with tweet id
"""
if not c['POCKET_SUPPORT']:
- printNicely(red('Pocket isn\'t enabled.'))
+ printNicely(yellow('Pocket isn\'t enabled.'))
+ printNicely(yellow('You need to "config POCKET_SUPPORT = true"'))
return
# Get tweet infos
tid = c['tweet_dict'][id]
user = t.statuses.show(id=tid)['user']['screen_name']
status = ' '.join(g['stuff'].split()[1:])
- status = '@' + user + ' ' + str2u(status)
+ # don't include own username for tweet chains
+ # for details see issue https://github.com/DTVD/rainbowstream/issues/163
+ if user == g['original_name']:
+ status = str2u(status)
+ else:
+ status = '@' + user + ' ' + str2u(status)
t.statuses.update(status=status, in_reply_to_status_id=tid)
return
tid = c['tweet_dict'][int(g['stuff'])]
tweet = t.statuses.show(id=tid)
- link_prefix = ('http://', 'https://')
- link_ary = [u for u in tweet['text'].split()
- if u.startswith(link_prefix)]
- if not link_ary:
+ urls = tweet['entities']['urls']
+ if not urls:
printNicely(light_magenta('No url here @.@!'))
return
- for link in link_ary:
- webbrowser.open(link)
+ else:
+ for url in urls:
+ expanded_url = url['expanded_url']
+ webbrowser.open(expanded_url)
except:
debug_option()
printNicely(red('Sorry I can\'t open url in this tweet.'))
d = {'fl': 'followers', 'fr': 'friends'}
next_cursor = -1
rel = {}
+
+ printNicely('All ' + d[target] + ':')
+
# Cursor loop
+ number_of_users = 0
while next_cursor != 0:
+
list = getattr(t, d[target]).list(
screen_name=name,
cursor=next_cursor,
skip_status=True,
include_entities=False,
)
+
for u in list['users']:
- rel[u['name']] = '@' + u['screen_name']
+
+ number_of_users += 1
+
+ # Print out result
+ printNicely( ' ' \
+ + cycle_color( u['name'] ) \
+ + color_func(c['TWEET']['nick'])( ' @' \
+ + u['screen_name'] \
+ + ' ' ) )
+
next_cursor = list['next_cursor']
- # Print out result
- printNicely('All: ' + str(len(rel)) + ' ' + d[target] + '.')
- for name in rel:
- user = ' ' + cycle_color(name)
- user += color_func(c['TWEET']['nick'])(' ' + rel[name] + ' ')
- printNicely(user)
+ # 300 users means 15 calls to the related API. The rate limit is 15
+ # calls per 15mn periods (see Twitter documentation).
+ if ( number_of_users % 300 == 0 ):
+ printNicely(light_yellow( 'We reached the limit of Twitter API.' ))
+ printNicely(light_yellow( 'You may need to wait about 15 minutes.' ))
+ break
+
+ printNicely('All: ' + str(number_of_users) + ' ' + d[target] + '.')
def follow():
"""
rel = t.mutes.users.create(screen_name=screen_name[1:])
if isinstance(rel, dict):
printNicely(green(screen_name + ' is muted.'))
- c['IGNORE_LIST'] += [unc(screen_name)]
+ c['IGNORE_LIST'] += [screen_name]
c['IGNORE_LIST'] = list(set(c['IGNORE_LIST']))
else:
printNicely(red(rel))
printNicely(light_magenta(guide))
only = raw_input('Only nicks [Ex: @xxx,@yy]: ')
ignore = raw_input('Ignore nicks [Ex: @xxx,@yy]: ')
- args.filter = filter(None, only.split(','))
- args.ignore = filter(None, ignore.split(','))
+ args.filter = list(filter(None, only.split(',')))
+ args.ignore = list(filter(None, ignore.split(',')))
except:
printNicely(red('Sorry, wrong format.'))
return
light_green('trend JP Tokyo') + '.\n'
usage += s * 2 + light_green('home') + ' will show your timeline. ' + \
light_green('home 7') + ' will show 7 tweets.\n'
+ usage += s * 2 + light_green('me') + ' will show your latest tweets. ' + \
+ light_green('me 2') + ' will show your last 2 tweets.\n'
usage += s * 2 + \
light_green('notification') + ' will show your recent notification.\n'
usage += s * 2 + light_green('mentions') + ' will show mentions timeline. ' + \
't',
'rt',
'quote',
+ 'me',
'allrt',
'conversation',
'fav',
tweet,
retweet,
quote,
+ view_my_tweets,
allretweet,
conversation,
favorite,
[], # tweet
[], # retweet
[], # quote
+ [], # view_my_tweets
[], # allretweet
[], # conversation
[], # favorite
c['lock'] = True
# Save cmd to global variable and call process
g['stuff'] = ' '.join(line.split()[1:])
+ # Check tweet length
# Process the command
process(cmd)()
# Not re-display
g['prefix'] = False
else:
g['prefix'] = True
- # Release the semaphore lock
- c['lock'] = False
except EOFError:
printNicely('')
+ except TwitterHTTPError as e:
+ detail_twitter_error(e)
except Exception:
debug_option()
- printNicely(red('OMG something is wrong with Twitter right now.'))
+ printNicely(red('OMG something is wrong with Twitter API right now.'))
+ finally:
+ # Release the semaphore lock
+ c['lock'] = False
def reconn_notice():
# Spawn stream thread
target = args.stream.split()[0]
- if target == 'mine' :
+ if target == 'mine':
spawn_personal_stream(args)
else:
try: