Skip to content
This repository has been archived by the owner on Sep 27, 2019. It is now read-only.
/ soda_xml_team Public archive

A ruby gem to provide a basic layer for interacting with XML Team's Sports On Demand API (SODA)

License

Notifications You must be signed in to change notification settings

seatshare/soda_xml_team

Repository files navigation

SODA XML Team Gem

Gem Version Build Status

This gem serves as an interface to the SODA (Sports On Demand API) from XML Team. It uses HTTParty and Nokogiri to retrieve and parse the data.

Installation

Add this line to your application's Gemfile:

gem 'soda_xml_team'

And then execute:

$ bundle

Or install it yourself as:

$ gem install soda_xml_team

Usage

Get a list of documents

The SODA service works by keeping revisions of various documents (schedules, news, injury reports, etc.) that you are charged pre-paid credit for downloading. It is currently does not cost any credits to obtain the list of available documents.

soda = SodaXmlTeam::Client.new('your_username', 'your_password')
listing = soda.content_finder({
  # Set sandbox to true if you are browsing the trial dataset
  sandbox: false,
  league_id: 'l.nhl.com',
  team_id: 'l.nhl.com-t.19',
  type: 'schedule-single-team',
  start_datetime: '2010-01-01 00:00:00 CDT',
  end_datetime: '2011-01-01 00:00:00 CDT'
})

# An array of documents matching your query
puts listing.inspect

Get a single document

Once you have this listing, you can obtain the individual document. As each document costs a credit per download (even if you download the same version again), it is recommended that you cache / index this data somewhere in your application to avoid quickly depleting your credit balance.

soda = SodaXmlTeam::Client.new('your_username', 'your_password')
document = soda.get_document({
  # Set sandbox to true if you are browsing the trial dataset
  sandbox: false,
  document_id: 'xt.10875359-nas-sked'
})

# A Nokogiri XML representation of the document contents
puts document.inspect

Bespoke Methods

For some of the more common data types, the gem will create a native ruby representation of the data if you run it through one of the parsing methods.

Schedule Parser

soda = SodaXmlTeam::Client.new('your_username', 'your_password')
schedule_document = soda.get_document({
  sandbox: true,
  document_id: 'xt.10875359-nas-sked'
})
schedule = SodaXmlTeam::Schedule.parse_schedule(schedule_document)

# This is now available as an array of values
puts schedule.inspect

News Parser

soda = SodaXmlTeam::Client.new('your_username', 'your_password')
news_document = soda.get_document({
  sandbox: true,
  document_id: 'xt.3329967-NAS-2005-OUTLOOK'
})
article = SodaXmlTeam::Schedule.parse_news(news_document)

# This is now available as an array of values
puts article.inspect

Standings Parser

soda = SodaXmlTeam::Client.new('your_username', 'your_password')
standings_document = soda.get_document({
  sandbox: true,
  document_id: 'xt.10878197-standings'
})
standings = SodaXmlTeam::Standings.parse_standings(standings_document)

# This is now available as an array of values
puts standings.inspect

League Directory File Parser

This gem includes an executable for parsing files from the SODA League Directory, which is useful for handling a particular sports league.

$ soda-league-directory ~/Downloads/xt.20140505T114154-0400.l.afa.ar.primera-leaguedir.xml
[{:import_key=>"o.afa.ar-t.113", :entity_name=>"Argentinos Juniors ", :status=>1, :entity_type=>"l.afa.ar.primera"}, {:import_key=>"o.afa.ar-t.92", :entity_name=>"Arsenal de Sarandi ", :status=>1, :entity_type=>"l.afa.ar.primera"}, ... ]

Contributing

  1. Fork it ( https://github.com/seatshare/soda_xml_team/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

About

A ruby gem to provide a basic layer for interacting with XML Team's Sports On Demand API (SODA)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages