Project

cottus

0.0
Repository is archived
No commit activity in last 3 years
No release in over 3 years
HTTP client for making requests against a set of hosts
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

>= 0
 Project Readme

cottus

Build Status Coverage Status Gem Version

Cottus, a multi limb HTTP client with an aim of making the use of multiple hosts providing the same service easier with regards to timeouts and automatic fail-over.

Sure enough, if you don't mind using an ELB in EC2 and making your service public, or setting up something like HAProxy, then this is not a client library for you.

Initialize a client with a list of hosts and it will happily round-robin load-balance requests among them. You could very well define your own strategy if you feel like it and inject it into Cottus, more on that further down.

Installation

gem install cottus

Usage

require 'cottus'

client = Cottus::Client.new(['http://n1.com', 'http://n2.com', 'http://n3.com'])

# This request will be made against http://n1.com
response = client.get('/any/path', :query => {:id => 1337})
puts response.status, response.body, response.headers.inspect

# This request will be made against http://n2.com
response = client.post('/any/path', :query => {:id => 1337}, :body => {:attribute => 'cool'}.to_json)
puts response.status, response.body, response.headers.inspect

That's about it! Cottus exposes almost all of the same methods with similar semantics as Excon does.

Strategy

A "Strategy" is merely a class implementing an execute method that is responsible for carrying out the action specified by the passed meth argument.

The Strategy class must however also implement an #initialize method which takes two parameters: connections and an options hash:

class SomeStrategy
  def initialize(connections, options={})
  end

  def execute(meth, path, options={})
    # do something funky here
  end
end

If you don't mind inheritance there's a base class (Cottus::Strategy) that you can inherit from and the above class would instead become:

class SomeStrategy < Strategy
  def execute(meth, path, options={})
    # do something funky here
  end
end

If you'd like to do some initialization on your own and override #initialize make sure to call #super or set the required instance variable (@connections) on your own.

It should be noted that I haven't decided on how strategies should be working to a 100% yet, so this might change in future releases.

See lib/cottus/strategies.rb for further examples.

Using your own strategy

In order to use your own Strategy class, supply the name of the class in the options hash as you create your instance, as such:

require 'cottus'

client = Cottus::Client.new(['http://n1.com', 'http://n2.com'], :strategy => MyStrategy)

Want some additional options passed when your strategy is initialized?

No problem! Pass them into the strategy_options sub-hash of the options hash to the client.

require 'cottus'

options = {
  :strategy => MyStrategy,
  :strategy_options => {
    :an_option => 'cool stuff!'
  }
}

client = Cottus::Client.new(['http://n1.com', 'http://n2.com'], options)

The options will be passed as an options hash to the strategy, as explained above.

Boom! That's all there is, for the moment.

cottus?

Cottus was one of the Hecatonchires of Greek mythology. The Hecatonchires, "Hundred-Handed Ones" (also with 50 heads) were figures in an archaic stage of Greek mythology. Three giants of incredible strength and ferocity that surpassed that of all Titans whom they helped overthrow.

Copyright

Copyright :: 2013-2014 Mathias Söderberg

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.