Displays statistics information for live events.
Syntax
https://api.sportradar.com/snooker/{access_level}/stream/statistics/subscribe?api_key={your_api_key} |
Parameters
Parameter | Description |
---|---|
access_level | Defines the access level of your API keyproduction , trial |
your_api_key | Your API key |
Optional Query String Parameters
By default, a Push feed will provide all data available for all in progress games. If needed, you can filter the data returned by including query strings.
Optional query string parameters must be added after your API key with an ampersand (&
). If you are filtering for more than one result, separate the results with a comma (,
) and no spaces.
URL Parameters | Description |
---|---|
channel | Channel type Example: channel=snooker |
competition_id | Competition id Example: competition_id=sr:competition:20508 |
event_id | Event id Example: event_id=535536474 |
format | Format typejson , xml |
season_id | Season id Example: season_id=sr:season:63867 |
sport_event_id | Sport event id Example: sport_event_id=sr:sport_event:17738118 |
sport_id | Sport id Example: sport_id=sr:sport:19 |
Code Samples
require 'uri'
require 'net/http'
require 'openssl'
url = URI("https://api.sportradar.com/snooker/trial/stream/statistics/subscribe?api_key={your_api_key}")
http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true
http.verify_mode = OpenSSL::SSL::VERIFY_NONE
request = Net::HTTP::Get.new(url)
response = http.request(request)
puts response.read_body
import requests
import json
r = requests.get("https://api.sportradar.com/snooker/trial/stream/statistics/subscribe",
params = {'api_key': 'your_api_key'},
allow_redirects=False)
redirect_url = r.headers['Location']
r = requests.get(redirect_url, stream=True)
for line in r.iter_lines():
# filter out keep-alive new lines
if line:
decoded_line = line.decode('utf-8')
print(json.loads(decoded_line))
curl -L "GET api.sportradar.com/snooker/trial/stream/statistics/subscribe?api_key={your_api_key}"
Samples with Query String Params
require 'uri'
require 'net/http'
require 'openssl'
url = URI("https://api.sportradar.com/snooker/trial/v2/stream/statistics/subscribe?api_key={your_api_key}&format=json&sport_event_id=sr:match:16519273")
http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true
http.verify_mode = OpenSSL::SSL::VERIFY_NONE
request = Net::HTTP::Get.new(url)
response = http.request(request)
puts response.read_body
import requests
import json
r = requests.get("https://api.sportradar.com/snooker/trial/v2/stream/statistics/subscribe",
params = {'api_key': 'your_api_key', 'format': 'json', 'sport_event_id': 'sr:match:16519273'},
allow_redirects=False)
redirect_url = r.headers['Location']
r = requests.get(redirect_url, stream=True)
for line in r.iter_lines():
# filter out keep-alive new lines
if line:
decoded_line = line.decode('utf-8')
print(json.loads(decoded_line))
curl -L GET 'https://api.sportradar.com/snooker/trial/v2/stream/statistics/subscribe?api_key={your_api_key}&format=json&sport_event_id=sr:match:16519273'
Response Sample
The above commands return json like this.
Data Points
Metadata:
Attribute | Parent Element | Type | Description |
---|---|---|---|
channel | metadata | String | Sport of the stream connection ex. snooker |
competition_id | metadata | String | Unique Id of a competition ex. sr:competition:2055 |
event_id | metadata | String | Type of timeline event ex. match_started , score_change , frame_started , change_of_possession , ball_pot See our FAQ for a complete list of timeline event values |
format | metadata | String | Format type of the responsejson , xml |
season_id | metadata | String | Unique Id of a season ex. sr:season:104989 |
sport_event_id | metadata | String | Unique Id of a sport event ex. sr:sport_event_id:49877723 |
sport_id | metadata | String | Unique Id of a sport ex. sr:sport:12 |
from | heartbeat | Integer | Unix timestamp of the beginning of a heartbeat message ex. 1713804799 |
to | heartbeat | Integer | Unix timestamp of the end of a heartbeat message ex. 1713804804 |
interval | heartbeat | Integer | Interval of a heartbeat message in seconds |
type | heartbeat | String | Type of heartbeat message ex. events , statistics |
package | heartbeat | String | Package of a heartbeat message ex. snooker-v2 |
Competitor:
Attribute | Parent Element | Type | Description |
---|---|---|---|
abbreviation | statistics - competitors | String | Abbreviation for a competitor name ex. JON (Jones, Jak) |
id | statistics - competitors | String | Unique ID for a competitor ex. sr:competitor:130248 |
name | statistics - competitors | String | Name for a competitor ex. Jones, Jak |
qualifier | statistics - competitors | String | Designation of a competitor for a matchhome , away |
Sport Event Status:
Attribute | Parent Element | Type | Description |
---|---|---|---|
away_score | sport_event_status | Integer | Total score for the away competitor in a match |
home_score | sport_event_status | Integer | Total score for the home competitor in a match |
match_status | sport_event_status | String | Status within a match (sport event). Provides more detail on the state of a match when live than status ex. not_started , interrupted , in_progress , ended See our FAQ for a complete list of statuses and their definitions. |
scount_abandoned | sport_event_status | Boolean | Signifies a match was abandoned by a scout when true |
status | sport_event_status | String | Status of a sport event ex. not_started , live , ended , closed See our FAQ for a complete list of statuses and their definitions. |
winner_id | sport_event_status | String | Unique ID of the match winner ex. sr:competitor:120814 |
Period Scores:
Attribute | Parent Element | Type | Description |
---|---|---|---|
away_score | sport_event_status - period_scores | Integer | Away competitor period score |
home_score | sport_event_status - period_scores | Integer | Home competitor period score |
number | sport_event_status - period_scores | Integer | Period number |
type | sport_event_status - period_scores | String | Period type ex. regular_period , snooker_session_break |
Match Stats (Competitor):
Attribute | Parent Element | Type | Description |
---|---|---|---|
balls_potted | competitors - statistics | Integer | Number of balls potted for a competitor in a match |
black_balls_potted | competitors - statistics | Integer | Number of black balls potted for a competitor in a match |
blue_balls_potted | competitors - statistics | Integer | Number of blue balls potted for a competitor in a match |
breaks_100_plus | competitors - statistics | Integer | Number of 100+ point breaks for a competitor in a match |
breaks_50_plus | competitors - statistics | Integer | Number of 50+ point breaks for a competitor in a match |
brown_balls_potted | competitors - statistics | Integer | Number of brown balls potted for a competitor in a match |
fouls_conceded | competitors - statistics | Integer | Number of fouls conceded for a competitor in a match |
green_balls_potted | competitors - statistics | Integer | Number of green balls potted for a competitor in a match |
highest_break | competitors - statistics | Integer | Highest break number for a competitor in a match |
pink_balls_potted | competitors - statistics | Integer | Number of pink balls potted for a competitor in a match |
points | competitors - statistics | Integer | Number of total points for a competitor in a match |
red_balls_potted | competitors - statistics | Integer | Number of red balls potted for a competitor in a match |
shots_taken | competitors - statistics | Integer | Number of total shots taken for a competitor in a match |
time_on_table_percentage | competitors - statistics | Double | Percentage of time on the table for a competitor in a match ex. 0.49958207083899 |
time_on_table_seconds | competitors - statistics | Integer | Amount of time on the table in seconds for a competitor in a match |
yellow_balls_potted | competitors - statistics | Integer | Number of yellow balls potted for a competitor in a match |