Multiconnect
Multiconnect is a way to manage your server conenction fallbacks.
Installation
Add this line to your application's Gemfile:
gem 'multiconnect'
And then execute:
$ bundle
Or install it yourself as:
$ gem install multiconnect
Usage
Let's say you have an object that wraps JsonApiClient and you want to make sure that your client server has some level of failure tolerance.
You want your client to make a request to the server, but if it fails you want to try to pull from cache. Here's a simple way to do this:
module Zappos
module Client
class Shoe
self.site = "http://zappos.com/api"
end
end
end
class Shoe
self.client_class = Zappos::Client::Shoe
include Multiconnect::Connectable
add_connection :server, client: client_class, class: CircuitBreakerServerConnection
add_connection :cache_fallback
def self.call_client(action, *args)
request(action, *args)
end
end
You can find all these connections in the examples file
Development
After checking out the repo, run bin/setup
to install dependencies. Then, run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
to create a git tag for the version, push git commits and tags, and push the .gem
file to rubygems.org.
Contributing
- Fork it ( https://github.com/gaorlov/multiconnect/fork )
- 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 a new Pull Request