view app/models/tweet.rb @ 86:5bfc986200db

The caching becomes a bit confusing because of parameters
author nanaya <me@myconan.net>
date Mon, 27 Jun 2016 05:14:10 +0900
parents 924b3a4ed3ef
children cf9a9ce2d034
line wrap: on
line source

class Tweet
  def timeline
    start_client_config_id = @client_config_id

    begin
      @timeline ||=
        Rails.cache.fetch({ :timeline => @twitter_id }, :expires_in => 5.minutes) do
          @client.user_timeline(@twitter_id, :count => 40, :exclude_replies => false, :include_rts => true)
        end
    rescue Twitter::Error::TooManyRequests
      next_client_config_id = @client_config_id + 1
      init_client next_client_config_id

      if @client_config_id == start_client_config_id
        raise
      else
        retry
      end
    end
  end

  def user
    @user ||=
      if timeline.any?
        timeline.first.user
      else
        Rails.cache.fetch({ :user => @twitter_id }, :expires_in => 5.minutes) do
          @client.user(@twitter_id)
        end
      end
  end

  def initialize(twitter_id)
    @client = init_client
    @twitter_id = twitter_id
  end

  def init_client(config_id = 0)
    @client_config_id = config_id
    config_hash_key = "twitter#{config_id}".to_sym

    return init_client(0) if $cfg[config_hash_key].nil? && config_id != 0

    @client = Twitter::REST::Client.new do |config|
      $cfg[config_hash_key].each do |cfg_key, cfg_value|
        config.public_send("#{cfg_key}=", cfg_value)
      end
    end
  end
end