Class: Tweetlr::Core

Inherits:
Object
  • Object
show all
Includes:
LogAware
Defined in:
lib/tweetlr/core.rb

Class Method Summary collapse

Instance Method Summary collapse

Methods included from LogAware

log=

Constructor Details

#initialize(args) ⇒ Core

Returns a new instance of Core.



17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# File 'lib/tweetlr/core.rb', line 17

def initialize(args)
  log = Logger.new(STDOUT)
  if (Logger::DEBUG..Logger::UNKNOWN).to_a.index(args[:loglevel])
    log.level = args[:loglevel] 
  else
    log.level = Logger::INFO
  end
  log.debug "log level set to #{log.level}"
  Tweetlr::LogAware.log=log
  
  @email = args[:tumblr_email]
  @password = args[:tumblr_password]
  @cookie = args[:cookie]
  @api_endpoint_twitter = args[:api_endpoint_twitter] || Tweetlr::API_ENDPOINT_TWITTER
  @api_endpoint_tumblr = args[:api_endpoint_tumblr] || Tweetlr::API_ENDPOINT_TUMBLR
  @whitelist = args[:whitelist]
  @shouts = args[:shouts]
  @update_period = args[:update_period] || Tweetlr::UPDATE_PERIOD
  @whitelist.each {|entry| entry.downcase!} if @whitelist
  log.info "Tweetlr #{Tweetlr::VERSION} initialized. Ready to roll."
end

Class Method Details

.crawl(config) ⇒ Object



39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
# File 'lib/tweetlr/core.rb', line 39

def self.crawl(config)
  log.debug "#{self}.crawl() using config: #{config.inspect}"
  twitter_config = prepare_twitter_config config
  tumblr_config = prepare_tumblr_config config
  twitter_config[:search_term] = URI::escape(twitter_config[:search_term]) if twitter_config[:search_term]
  log.info "starting tweetlr crawl..."
  response = {}
  response = Tweetlr::Processors::Twitter::lazy_search(twitter_config)
  if response
    tweets = response['results']
    if tweets
    tweets.each do |tweet|
      tumblr_post = Tweetlr::Combinators::TwitterTumblr::generate_photo_post_from_tweet(tweet, {:whitelist => config[:whitelist], :embedly_key => config[:embedly_key], :group => config[:group]}) 
      if tumblr_post.nil? ||  tumblr_post[:source].nil?
        log.warn "could not get image source: tweet: #{tweet} --- tumblr post: #{tumblr_post.inspect}"
      else
        log.debug "tumblr post: #{tumblr_post}"
        res = Tweetlr::Processors::Tumblr.post tumblr_post.merge(tumblr_config)
        log.debug "tumblr response: #{res}"
        if res.code == "201"
          log.info "tumblr post created (tumblr response: #{res.header} #{res.body}"
        else
          log.warn "tumblr response: #{res.header} #{res.body}"
        end
      end
     end
      # store the highest tweet id
      config[:since_id] = response['max_id']
    end
  else
    log.error "twitter search returned no response. hail the failwhale!"
  end
  log.info "finished tweetlr crawl."
  return config
end

.logObject



13
14
15
# File 'lib/tweetlr/core.rb', line 13

def self.log
  Tweetlr::LogAware.log #TODO why doesn't the include make the log method accessible?
end