RLovelett/sports_data_api

View on GitHub
lib/sports_data_api/nba.rb

Summary

Maintainability
A
1 hr
Test Coverage
module SportsDataApi
  module Nba
    extend SportsDataApi::Request

    API_VERSION = 4
    BASE_URL = 'https://api.sportradar.us/nba/%{access_level}/v%{version}/en'
    SPORT = :nba
    DIR = File.join(File.dirname(__FILE__), SPORT.to_s)

    autoload :Team, File.join(DIR, 'team')
    autoload :Teams, File.join(DIR, 'teams')
    autoload :Player, File.join(DIR, 'player')
    autoload :Game, File.join(DIR, 'game')
    autoload :Games, File.join(DIR, 'games')
    autoload :Season, File.join(DIR, 'season')
    autoload :Stats, File.join(DIR, 'stats')
    autoload :Venue, File.join(DIR, 'venue')
    autoload :Broadcast, File.join(DIR, 'broadcast')

    class << self
      ##
      # Fetches NBA season schedule for a given year and season
      def schedule(year, season)
        season = season.to_s.upcase.to_sym
        raise Error.new("#{season} is not a valid season") unless Season.valid?(season)

        Season.new(response_json("/games/#{year}/#{season}/schedule.json"))
      end

      ##
      # Fetches NBA team roster
      def team_roster(team_id)
        Team.new(response_json("/teams/#{team_id}/profile.json"))
      end

      ##
      # Fetches NBA game summary for a given game
      def game_summary(game_id)
        Game.new(json: response_json("/games/#{game_id}/summary.json"))
      end

      ##
      # Fetches all NBA teams
      def teams
        Teams.new(response_json('/league/hierarchy.json'))
      end

      ##
      # Fetches NBA daily schedule for a given date
      def daily(year, month, day)
        Games.new(response_json("/games/#{year}/#{month}/#{day}/schedule.json"))
      end
    end
  end
end