Class: CampfireBot::Bot
Instance Attribute Summary collapse
-
#campfire ⇒ Object
readonly
FIXME - these will be invalid if disconnected.
-
#config ⇒ Object
readonly
FIXME - these will be invalid if disconnected.
-
#environment_name ⇒ Object
readonly
FIXME - these will be invalid if disconnected.
-
#log ⇒ Object
readonly
FIXME - these will be invalid if disconnected.
-
#rooms ⇒ Object
readonly
FIXME - these will be invalid if disconnected.
Instance Method Summary collapse
-
#connect ⇒ Object
def initialize end.
- #create(config_file, environment_name, plugin_path) ⇒ Object
- #run(interval = 5) ⇒ Object
Instance Attribute Details
#campfire ⇒ Object (readonly)
FIXME - these will be invalid if disconnected. handle this.
24 25 26 |
# File 'lib/bot.rb', line 24 def campfire @campfire end |
#config ⇒ Object (readonly)
FIXME - these will be invalid if disconnected. handle this.
24 25 26 |
# File 'lib/bot.rb', line 24 def config @config end |
#environment_name ⇒ Object (readonly)
FIXME - these will be invalid if disconnected. handle this.
24 25 26 |
# File 'lib/bot.rb', line 24 def environment_name @environment_name end |
#log ⇒ Object (readonly)
FIXME - these will be invalid if disconnected. handle this.
24 25 26 |
# File 'lib/bot.rb', line 24 def log @log end |
#rooms ⇒ Object (readonly)
FIXME - these will be invalid if disconnected. handle this.
24 25 26 |
# File 'lib/bot.rb', line 24 def rooms @rooms end |
Instance Method Details
#connect ⇒ Object
def initialize end
51 52 53 54 55 56 57 58 59 60 61 62 |
# File 'lib/bot.rb', line 51 def connect load_plugins unless !@config['enable_plugins'] begin join_rooms rescue Errno::ENETUNREACH, SocketError => e @log.fatal "We had trouble connecting to the network: #{e.class}: #{e.}" abort "We had trouble connecting to the network: #{e.class}: #{e.}" rescue Exception => e @log.fatal "Unhandled exception while joining rooms: #{e.class}: #{e.} \n #{$!.backtrace.join("\n")}" abort "Unhandled exception while joining rooms: #{e.class}: #{e.} \n #{$!.backtrace.join("\n")}" end end |
#create(config_file, environment_name, plugin_path) ⇒ Object
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/bot.rb', line 26 def create(config_file, environment_name, plugin_path) @config = YAML::load(File.read(config_file))[environment_name] @plugin_path = plugin_path @environment_name = environment_name @root_logger = Logging.logger["CampfireBot"] @log = Logging.logger[self] # TODO much of this should be configurable per environment @root_logger.add_appenders Logging.appenders.rolling_file("#{@environment_name}.log", :layout => Logging.layouts.pattern(:pattern => "%d | %-6l | %-12c | %m\n"), :age => 'daily', :keep => 7) @root_logger.level = @config['log_level'] rescue :info @timeouts = 0 @rooms = {} end |
#run(interval = 5) ⇒ Object
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 |
# File 'lib/bot.rb', line 64 def run(interval = 5) catch(:stop_listening) do trap('INT') { throw :stop_listening } # since room#listen blocks, stick it in its own thread @rooms.each_pair do |room_name, room| Thread.new do begin room.listen(:timeout => 8) do |raw_msg| (CampfireBot::Message.new(raw_msg.merge({:room => room}))) end rescue Exception => e trace = e.backtrace.join("\n") abort "something went wrong! #{e.}\n #{trace}" end end end loop do begin @rooms.each_pair do |room_name, room| # I assume if we reach here, all the network-related activity has occured successfully # and that we're outside of the retry-cycle @timeouts = 0 # Here's how I want it to look # @room.listen.each { |m| EventHandler.handle_message(m) } # EventHanlder.handle_time(optional_arg = Time.now) # Run time-oriented events Plugin.registered_intervals.each do |handler| begin handler.run(CampfireBot::Message.new(:room => room)) rescue @log.error "error running #{handler.inspect}: #{$!.class}: #{$!.} \n #{$!.backtrace.join("\n")}" end end Plugin.registered_times.each_with_index do |handler, index| begin Plugin.registered_times.delete_at(index) if handler.run rescue @log.error "error running #{handler.inspect}: #{$!.class}: #{$!.}, \n #{$!.backtrace.join("\n")}" end end end STDOUT.flush sleep interval rescue Timeout::Error => e if @timeouts < 5 sleep(5 * @timeouts) @timeouts += 1 retry else raise e. end end end end end |