+ # Get name
+ try:
+ name = g['stuff'].split()[1]
+ if name.startswith('@'):
+ name = name[1:]
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+ raise Exception('Invalid name')
+ except:
+ name = g['original_name']
+ # Get list followers or friends
+ try:
+ target = g['stuff'].split()[0]
+ except:
+ printNicely(red('Omg some syntax is wrong.'))
+ # Init cursor
+ d = {'fl': 'followers', 'fr': 'friends'}
+ next_cursor = -1
+ rel = {}
+ # Cursor loop
+ 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']
+ next_cursor = list['next_cursor']
+ # Print out result
+ printNicely('All: ' + str(len(rel)) + ' people.')
+ for name in rel:
+ user = ' ' + cycle_color(name) + grey(' ' + rel[name] + ' ')
+ printNicely(user)
+
+
+def inbox():
+ """
+ Inbox direct messages
+ """
+ t = Twitter(auth=authen())
+ num = c['MESSAGES_DISPLAY']
+ rel = []
+ if g['stuff'].isdigit():
+ num = g['stuff']
+ cur_page = 1
+ # Max message per page is 20 so we have to loop
+ while num > 20:
+ rel = rel + t.direct_messages(
+ count=20,
+ page=cur_page,
+ include_entities=False,
+ skip_status=False
+ )
+ num -= 20
+ cur_page += 1
+ rel = rel + t.direct_messages(
+ count=num,
+ page=cur_page,
+ include_entities=False,
+ skip_status=False
+ )
+ # Display
+ printNicely('Inbox: newest ' + str(len(rel)) + ' messages.')
+ for m in reversed(rel):
+ print_message(m)
+ printNicely('')
+
+
+def sent():
+ """
+ Sent direct messages
+ """
+ t = Twitter(auth=authen())
+ num = c['MESSAGES_DISPLAY']
+ rel = []
+ if g['stuff'].isdigit():
+ num = int(g['stuff'])
+ cur_page = 1
+ # Max message per page is 20 so we have to loop
+ while num > 20:
+ rel = rel + t.direct_messages.sent(
+ count=20,
+ page=cur_page,
+ include_entities=False,
+ skip_status=False
+ )
+ num -= 20
+ cur_page += 1
+ rel = rel + t.direct_messages.sent(
+ count=num,
+ page=cur_page,
+ include_entities=False,
+ skip_status=False
+ )
+ # Display
+ printNicely('Sent: newest ' + str(len(rel)) + ' messages.')
+ for m in reversed(rel):
+ print_message(m)
+ printNicely('')
+
+
+def trash():
+ """
+ Remove message
+ """
+ t = Twitter(auth=authen())
+ try:
+ rid = int(g['stuff'].split()[0])
+ except:
+ printNicely(red('Sorry I can\'t understand.'))
+ mid = db.rainbow_to_message_query(rid)[0].message_id
+ t.direct_messages.destroy(id=mid)
+ printNicely(green('Message deleted.'))
+
+
+def whois():
+ """
+ Show profile of a specific user
+ """
+ t = Twitter(auth=authen())
+ screen_name = g['stuff'].split()[0]
+ if screen_name.startswith('@'):
+ try:
+ user = t.users.show(
+ screen_name=screen_name[1:],
+ include_entities=False)
+ show_profile(user, g['iot'])
+ except:
+ printNicely(red('Omg no user.'))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def follow():
+ """
+ Follow a user
+ """
+ t = Twitter(auth=authen())
+ screen_name = g['stuff'].split()[0]
+ if screen_name.startswith('@'):
+ t.friendships.create(screen_name=screen_name[1:], follow=True)
+ printNicely(green('You are following ' + screen_name + ' now!'))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def unfollow():
+ """
+ Unfollow a user
+ """
+ t = Twitter(auth=authen())
+ screen_name = g['stuff'].split()[0]
+ if screen_name.startswith('@'):
+ t.friendships.destroy(
+ screen_name=screen_name[1:],
+ include_entities=False)
+ printNicely(green('Unfollow ' + screen_name + ' success!'))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def mute():
+ """
+ Mute a user
+ """
+ t = Twitter(auth=authen())
+ try:
+ screen_name = g['stuff'].split()[0]
+ except:
+ printNicely(red('A name should be specified. '))
+ return
+ if screen_name.startswith('@'):
+ rel = t.mutes.users.create(screen_name=screen_name[1:])
+ if isinstance(rel, dict):
+ printNicely(green(screen_name + ' is muted.'))
+ else:
+ printNicely(red(rel))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def unmute():
+ """
+ Unmute a user
+ """
+ t = Twitter(auth=authen())
+ try:
+ screen_name = g['stuff'].split()[0]
+ except:
+ printNicely(red('A name should be specified. '))
+ return
+ if screen_name.startswith('@'):
+ rel = t.mutes.users.destroy(screen_name=screen_name[1:])
+ if isinstance(rel, dict):
+ printNicely(green(screen_name + ' is unmuted.'))
+ else:
+ printNicely(red(rel))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def muting():
+ """
+ List muting user
+ """
+ t = Twitter(auth=authen())
+ # Init cursor
+ next_cursor = -1
+ rel = {}
+ # Cursor loop
+ while next_cursor != 0:
+ list = t.mutes.users.list(
+ screen_name=g['original_name'],
+ cursor=next_cursor,
+ skip_status=True,
+ include_entities=False,
+ )
+ for u in list['users']:
+ rel[u['name']] = '@' + u['screen_name']
+ next_cursor = list['next_cursor']
+ # Print out result
+ printNicely('All: ' + str(len(rel)) + ' people.')
+ for name in rel:
+ user = ' ' + cycle_color(name) + grey(' ' + rel[name] + ' ')
+ printNicely(user)
+
+
+def block():
+ """
+ Block a user
+ """
+ t = Twitter(auth=authen())
+ screen_name = g['stuff'].split()[0]
+ if screen_name.startswith('@'):
+ t.blocks.create(
+ screen_name=screen_name[1:],
+ include_entities=False,
+ skip_status=True)
+ printNicely(green('You blocked ' + screen_name + '.'))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def unblock():
+ """
+ Unblock a user
+ """
+ t = Twitter(auth=authen())
+ screen_name = g['stuff'].split()[0]
+ if screen_name.startswith('@'):
+ t.blocks.destroy(
+ screen_name=screen_name[1:],
+ include_entities=False,
+ skip_status=True)
+ printNicely(green('Unblock ' + screen_name + ' success!'))
+ else:
+ printNicely(red('A name should begin with a \'@\''))
+
+
+def report():
+ """
+ Report a user as a spam account
+ """
+ t = Twitter(auth=authen())
+ screen_name = g['stuff'].split()[0]
+ if screen_name.startswith('@'):
+ t.users.report_spam(
+ screen_name=screen_name[1:])
+ printNicely(green('You reported ' + screen_name + '.'))
+ else:
+ printNicely(red('Sorry I can\'t understand.'))
+
+
+def cal():
+ """
+ Unix's command `cal`
+ """
+ # Format
+ rel = os.popen('cal').read().split('\n')
+ month = rel.pop(0)
+ month = random_rainbow(month)
+ date = rel.pop(0)
+ date = ' '.join([cycle_color(i) for i in date.split(' ')])
+ today = str(int(os.popen('date +\'%d\'').read().strip()))
+ # Display
+ printNicely(month)
+ printNicely(date)
+ for line in rel:
+ ary = line.split(' ')
+ ary = map(lambda x: on_grey(x) if x == today else grey(x), ary)
+ printNicely(' '.join(ary))
+
+
+def theme():
+ """
+ List and change theme
+ """
+ if not g['stuff']:
+ # List themes
+ for theme in g['themes']:
+ line = ''
+ # Detect custom config
+ if theme == 'custom':
+ line += light_magenta('custom')
+ custom_path = os.environ.get(
+ 'HOME',
+ os.environ.get('USERPROFILE',
+ '')) + os.sep + '.rainbow_config.json'
+ if not os.path.exists(custom_path):
+ line += light_magenta(' (create your own config file at ~/.rainbow_config.json)')
+ else:
+ line += light_magenta(' (loaded)')
+ else:
+ line += light_magenta(theme)
+ if c['theme'] == theme :
+ line = ' '*2 + light_yellow('* ') + line
+ else:
+ line = ' '*4 + line
+ printNicely(line)
+ else:
+ # Change theme
+ try:
+ # Load new config
+ if g['stuff'] != 'custom':
+ new_config = 'rainbowstream/colorset/' + g['stuff'] + '.json'
+ else:
+ new_config = os.environ.get(
+ 'HOME',os.environ.get(
+ 'USERPROFILE',
+ '')) + os.sep + '.rainbow_config.json'
+ new_config = load_config(new_config)
+ if new_config:
+ for nc in new_config:
+ c[nc] = new_config[nc]
+ # Update db and reset colors
+ db.theme_update(g['stuff'])
+ c['theme'] = g['stuff']
+ notify_cycle()
+ g['decorated_name'] = color_func(
+ c['DECORATED_NAME'])(
+ '[@' + g['original_name'] + ']: ')
+ printNicely(green('Theme changed.'))
+ except:
+ if g['stuff'] == 'custom':
+ printNicely(red('~/.rainbow_config.json is not exists!'))
+ else:
+ printNicely(red('No such theme exists.'))