Sha256: e71e91652c35c3dc31cc7b7a9ece9a0e1bae6b6b26643724b51e8ce6725ddd27
Contents?: true
Size: 1.84 KB
Versions: 1
Compression:
Stored size: 1.84 KB
Contents
# :rabbit: Cony [![Build Status](https://travis-ci.org/ninech/cony.svg)](https://travis-ci.org/ninech/cony) Cony sends notifications about the lifecycle of your models via AMQP. ## Setup ### Rails 3 & 4 In Rails 3 and 4, add this to your Gemfile and run the bundle command. ```ruby gem 'cony' ``` To configure the AMQP-Settings, use an initializer (e.g. `config/initializers/cony.rb`) with the following content. ```ruby Cony.configure do |config| config.amqp = { host: 'localhost', exchange: 'organization.application', ssl: true, user: 'username', pass: 'secret', } # config.durable = false end ``` ## Getting Started To enable the notifications for a model, you just need to include the corresponding class. For `ActiveRecord` use the following snippet. ```ruby class ExampleModel < ActiveRecord::Base include Cony::ActiveRecord end ``` ## Message Format The routing key for the messages have a format of `model_name_with_underscore.mutation.action`. It will append the id of the model and the detected changes to the payload of the message. ### Create A create for a `Example::Model` model will have a routing key of `example/model.mutation.create`. The sent JSON structure will look like this: ```json { "id": 1337, "changes": [ { "name": { "old": null, "new": "value" } }, { "description": { "old": null, "new": "value" } } ] } ``` ### Update An update for a `Example::Model` model will have a routing key of `example/model.mutation.update`. The sent JSON structure will look like this: ```json { "id": 1337, "changes": [ { "name": { "old": "old-value", "new": "new-value" } } ] } ``` ### Destroy A destroy event for a `Example::Model` model will have a routing key of `example/model.mutation.destroy`. The sent JSON structure will look like this: ```json { "id": 1337, "changes": [] } ```
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
cony-1.0.1 | README.md |