README.md in ruby_ami-1.3.4 vs README.md in ruby_ami-2.0.0
- old
+ new
@@ -1,42 +1,41 @@
# RubyAMI [![Build Status](https://secure.travis-ci.org/adhearsion/ruby_ami.png?branch=master)](http://travis-ci.org/adhearsion/ruby_ami)
-RubyAMI is an AMI client library in Ruby and based on EventMachine with the sole purpose of providing an connection to the Asterisk Manager Interface. RubyAMI does not provide any features beyond connection management and protocol parsing. Actions are sent over the wire, and responses come back via callbacks. It's up to you to match these up into something useful. In this regard, RubyAMI is very similar to [Blather](https://github.com/sprsquish/blather) for XMPP or [Punchblock](https://github.com/adhearsion/punchblock), the Ruby 3PCC library. In fact, Punchblock uses RubyAMI under the covers for its Asterisk implementation, including an implementation of AsyncAGI.
+RubyAMI is an AMI client library in Ruby and based on EventMachine with the sole purpose of providing a connection to the Asterisk Manager Interface. RubyAMI does not provide any features beyond connection management and protocol parsing. Actions are sent over the wire, and responses are returned. Events are passed to a callback you define. It's up to you to match these up into something useful. In this regard, RubyAMI is very similar to [Blather](https://github.com/sprsquish/blather) for XMPP or [Punchblock](https://github.com/adhearsion/punchblock), the Ruby 3PCC library. In fact, Punchblock uses RubyAMI under the covers for its Asterisk implementation, including an implementation of AsyncAGI.
NB: If you're looking to develop an application on Asterisk, you should take a look at the [Adhearsion](http://adhearsion.com) framework first. This library is much lower level.
## Installation
gem install ruby_ami
## Usage
```ruby
require 'ruby_ami'
-include RubyAMI
+client = RubyAMI::Client.new username: 'test',
+ password: 'test',
+ host: '127.0.0.1',
+ port: 5038,
+ event_handler: ->(e) { handle_event e },
+ logger: Logger.new(STDOUT),
+ log_level: Logger::DEBUG,
+ timeout: 10
-client = Client.new :username => 'test',
- :password => 'test',
- :host => '127.0.0.1',
- :port => 5038,
- :event_handler => lambda { |e| handle_event e },
- :logger => Logger.new(STDOUT),
- :log_level => Logger::DEBUG,
- :timeout => 10
-
def handle_event(event)
case event.name
when 'FullyBooted'
- client.send_action 'Originate', 'Channel' => 'SIP/foo'
+ client.async.send_action 'Originate', 'Channel' => 'SIP/foo'
end
end
client.start
+
+Celluloid::Actor.join client
```
## Development Requirements
-ruby_ami uses [ragel](http://www.complang.org/ragel/) to generate some of it's
-files.
+ruby_ami uses [ragel](http://www.complang.org/ragel/) to generate some of it's files.
On OS X (if you use homebrew):
brew install ragel
@@ -62,6 +61,6 @@
* If you want to have your own version, that is fine but bump version in a commit by itself so I can ignore when I pull
* Send me a pull request. Bonus points for topic branches.
## Copyright
-Copyright (c) 2011 Ben Langfeld, Jay Phillips. MIT licence (see LICENSE for details).
+Copyright (c) 2013 Ben Langfeld, Jay Phillips. MIT licence (see LICENSE for details).