A gem for handling Serf events.
(ka-hoo-na) Hawaiian term for a man that surfs usually with a degree of skill. from rippinh2o.com
Add this line to your application's Gemfile:
gem 'kahuna'
And then execute:
$ bundle
Or install it yourself as:
$ gem install kahuna
Create a file named handler
like the file below.
#!/usr/bin/env ruby
require 'kahuna'
data = ''
while line = Readline.readline('', true)
data += "#{line}\n"
end
Kahuna::Handler.new(data) do |event, members|
# Code to execute in response to event
end.execute
exit 0
Note: Kahuna expects each line to be separated by a newline (\n) character.
Make the file executable
$ chmod +x handler
Then pass the file to serf as a handler.
serf agent -event-handler ./handler
Kahuna::Handler yields Kahuna::Event and Kahuna::MemberCollection objects to the block passed to new. The Event object contains all the information about the event parsed from the data sent from Serf and the ENV vars set by Serf.
Serf membership events contain information about the members that participated in the Serf event. This information is the payload for the Serf event, but for Serf user events, the payload is arbitrary. In the case of user events, the current implementation yields nil
for the members variable.
You can always get to the raw data sent from Serf through the event object, regardless of whether it is a user event or a membership event.
event.raw_data #=> "deploy all the things!"
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request