README.md in waffle-0.3.5 vs README.md in waffle-0.4.0
- old
+ new
@@ -1,26 +1,53 @@
# Waffle
An abstract flow publisher and subscriber.
-[data:image/s3,"s3://crabby-images/b73bb/b73bb1752c8cce76b746a34805c325ff5320611c" alt="Build Status"](http://travis-ci.org/peanut/waffle)
+[data:image/s3,"s3://crabby-images/bfc0d/bfc0db55ef739d8416f403eb9146607a3bc64d94" alt="Build Status"](http://travis-ci.org/undr/waffle)
-## Integration into Rails
+It supports the following transports:
-Insert in your Rails Gemfile:
+- RabbitMQ.
+- Redis.
- gem 'waffle'
+## Configuration
+Insert in your Gemfile:
+
+ gem 'waffle', :gem => 'git://github.com/undr/waffle.git'
+
and create config file:
production:
transport: rabbitmq
encoder: marshal
url: amqp://anyhost.com:5678
+and load config file:
+
+ Waffle.configure(:path => 'config/waffle.yml')
+
+You also can configure Waffle programmatically:
+
+ Waffle.configure({
+ :transport => 'redis',
+ :url => 'redis://localhost:6379/0',
+ :encoder => 'json'
+ })
+
+or:
+
+ Waffle.configure do |config|
+ config.transport = 'redis'
+ config.url = 'redis://localhost:6379/0'
+ config.encoder = 'json'
+ end
+
## Usage
+### Event
+
When you want to performan event, just insert this code in place, where it must occur:
Waffle::Event.occurred 'index_page_load'
You can attach meta data to event like this:
@@ -28,5 +55,18 @@
Waffle::Event.occurred 'index_page_load', {'user_id' => 13, 'user_name' => 'Joshua'}
or like this:
Waffle::Event.occurred 'index_page_load', 'bingo!'
+
+### Pub/Sub
+
+ Waffle.publish('event.name', message_hash_or_string)
+
+ Waffle.subscribe('event.name') do |message_type, message_hash_or_string|
+ pp message_type
+ pp message_hash_or_string
+ end
+
+### Reconnect
+
+Don't care about any reconnects when transport server is down. Waffle just waits for server ready and reconnects automatically.