Class: Birdwatcher::Modules::Users::KloutInfluence
- Inherits:
-
Birdwatcher::Module
- Object
- Birdwatcher::Module
- Birdwatcher::Modules::Users::KloutInfluence
- Defined in:
- lib/birdwatcher/modules/users/klout_influence.rb
Constant Summary
Constants inherited from Birdwatcher::Module
Birdwatcher::Module::MODULE_PATH
Constants included from Concerns::Concurrency
Concerns::Concurrency::DEFAULT_THREAD_POOL_SIZE
Constants included from Concerns::Core
Concerns::Core::DATA_DIRECTORY
Class Method Summary collapse
Instance Method Summary collapse
Methods inherited from Birdwatcher::Module
_file_path, _file_path=, descendants, #execute, inherited, meta, meta=, module_by_path, module_paths, modules, path
Methods included from Concerns::Concurrency
Methods included from Concerns::Persistence
included, #save_status, #save_user
Methods included from Concerns::Presentation
included, #make_status_summary_output, #make_url_summary_output, #make_user_details_output, #make_user_summary_output, #output_status_summary, #output_user_details, #output_user_summary, #page_text
Methods included from Concerns::Outputting
#confirm, #error, #fatal, included, #info, #line_separator, #newline, #output, #output_formatted, #task, #warn
Methods included from Concerns::Util
#escape_html, #excerpt, included, #parse_time, #pluralize, #strip_control_characters, #strip_html, #suppress_output, #suppress_warnings, #time_ago_in_words, #unescape_html
Methods included from Concerns::Core
#console, #current_workspace, #current_workspace=, #database, included, #klout_client, #read_data_file, #twitter_client
Class Method Details
.info ⇒ Object
18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
# File 'lib/birdwatcher/modules/users/klout_influence.rb', line 18 def self.info <<-INFO The User Klout Influence module can be used to gather an influence graph of all users in the currently active workspace. The Klout Influence API can tell who users are being influenced by as well as who they are influencing. The influence graph can be generated with the #{'users/influence_graph'.bold} module when the raw data has been gathered with this module. #{'Note:'.bold} This module requires that users have been enriched with their Klout ID from the #{'users/klout_id'.bold} module. It also requires that Birdwatcher has been configured with one or more Klout API keys in order to work. INFO end |
Instance Method Details
#run ⇒ Object
33 34 35 36 37 38 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 74 75 76 77 78 79 |
# File 'lib/birdwatcher/modules/users/klout_influence.rb', line 33 def run if !klout_client error("Birdwatcher has not been configured with any Klout API keys") return false end users = current_workspace.users_dataset.where("klout_id IS NOT NULL").order(:screen_name) if users.empty? error("There are no users with Klout IDs") return false end threads = thread_pool(option_setting("THREADS").to_i) influencer_mutex = Mutex.new influencee_mutex = Mutex.new users.each do |user| threads.process do begin if influence = klout_client.get_influence(user.klout_id) influence[:influencers].each do |screen_name| db_influencer = influencer_mutex.synchronize do Birdwatcher::Models::Influencer.find_or_create(:workspace_id => current_workspace.id, :screen_name => screen_name) end if !user.influencers.include?(db_influencer) user.add_influencer(db_influencer) end end influence[:influencees].each do |screen_name| db_influencee = influencee_mutex.synchronize do Birdwatcher::Models::Influencee.find_or_create(:workspace_id => current_workspace.id, :screen_name => screen_name) end if !user.influencees.include?(db_influencee) user.add_influencee(db_influencee) end end info("User #{user.screen_name.bold} is influenced by: #{influence[:influencers].map(&:bold).join(', ')}") info("User #{user.screen_name.bold} is influencing: #{influence[:influencees].map(&:bold).join(', ')}") else error("Could not get Klout influence for #{user.screen_name.bold}") end user.save rescue => e error("Processing of #{user.screen_name.bold} failed (#{e.class})") info(e.backtrace.join("\n")) end end end threads.shutdown end |