Sha256: 0f5bb0a7295e2baf9c1f8a2bdba5195d86f1cc378de7de24921d7941aed30bdf

Contents?: true

Size: 1.64 KB

Versions: 3

Compression:

Stored size: 1.64 KB

Contents

#!/usr/bin/env ruby

# Trap interrupts to quit cleanly. See
# https://twitter.com/mitchellh/status/283014103189053442
Signal.trap('INT') { abort }

require 'oauth'
require 't'
require 'twitter'

# Output message to $stderr, prefixed with the program name
def pute(*args)
  first = args.shift.dup
  first.insert(0, "#{$PROGRAM_NAME}: ")
  args.unshift(first)
  abort(args.join("\n"))
end

begin
  T::CLI.start(ARGV)
rescue Interrupt
  pute 'Quitting...'
rescue OAuth::Unauthorized
  pute 'Authorization failed'
rescue Twitter::Error::TooManyRequests => error
  pute error.message,
       "The rate limit for this request will reset in #{error.rate_limit.reset_in} #{error.rate_limit.reset_in == 1 ? 'second' : 'seconds'}.",
       'While you wait, consider making a polite request for Twitter to increase the API rate limit at https://dev.twitter.com/discussions/10644'
rescue Twitter::Error::BadRequest => error
  pute error.message,
       'Run `t authorize` to authorize.'
rescue Twitter::Error::Forbidden, Twitter::Error::Unauthorized => error
  if error.message == 'Error processing your OAuth request: Read-only application cannot POST' ||
    error.message == 'This application is not allowed to access or delete your direct messages'
    $stderr.puts(%q(Make sure to set your Twitter application's Access Level to "Read, Write and Access direct messages".))
    require 'thor'
    Thor::Shell::Basic.new.ask 'Press [Enter] to open the Twitter Developer site.'
    require 'launchy'
    Launchy.open('https://dev.twitter.com/apps') { |u, o, e| $stderr.puts "Manually open #{u}" }
  else
    pute error.message
  end
rescue Twitter::Error => error
  pute error.message
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
t-2.5.0 bin/t
t-2.4.0 bin/t
t-2.3.0 bin/t