2009-11-04 Update: Gem version released
For TouchLocal I am currently reworking some of the internal advertising systems to use OpenX. That way we get better reporting and better reliability, but we can use things like OpenX Direct Selection to make the best use of our existing infrastructure.
While there are 2 Ruby projects (1 a more recent fork of the other), both are oriented around the API for administering OpenX rather than serving ads via the API. So, here is the minimum you need to do from Ruby to get a banner served:
(Based on http://www.openx.org/en/docs/tutorials/Advanced+XML-RPC)
require 'xmlrpc/client' # The settings are the HTTP Headers - the PHP client sets many, but this is the minimum requirement settings = {:cookies => [], :remote_addr => 'localhost'} # 'what' in our case is a Direct Selection params = [ what = 'Plumber', campaignId = 0, target = '', source = '', withText = false, xmlContext = [{'!=' => 'campaignid:2'}] ] b = nil begin server = XMLRPC::Client.new2("http://www.example.com/www/delivery/axmlrpc.php") b = server.call('openads.view', settings, *params) b['html'] rescue Exception => e puts e.message end
In particular, note the content of the xmlContext parameter – that took me quite a few hours of digging through the PHP to work out. It’s an array of hashes, that use the keys “==” and “!=” to include or exclude banners based on the values. The values must be of the form “type:id”, with type being one of “campaignid”, “clientid”, “companionid”, and “bannerdid” (although technically, anything other than the first 3 is treated as a banner ID as of version 2.8.1 of OpenX)
I hope that saves someone the pain that I just went through to discover it!