Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Next »

The V3 Integration Service supports a number of message types that can be selectively activated to deliver precisely the set of information required to support the contracted services; you will receive only the messages you need. The core message types are:
Fixture: describes the fixture and includes the information (name, date, sport, competition, competitors etc.) required to allow you to create the fixture in your trading platform.
MarketSet: a collection of one or more Market elements containing market information (name, type, selections, prices, trading status etc.) to allow you to create markets in your trading platform and associate them with a particular event.
ResultSet: when the outcome of a market is known, for example because the event has finished, a Result will be sent for each market. This message will contain all the information you need to result the market and settle bets.
Between them, these three message types allow for sports books to receive all the information they require to create fixtures and markets, update those fixtures and markets and then to result them once the outcomes become known.
There are also additional messages that can be activated as required to support the services that you wish to use.
Coverage: once a fixture has been booked for in-play coverage, the Coverage command will be sent to update changes in the availability of match state feed or the trading state feeds or to confirm that the booking state has changed.
Match State : for each InPlay modelled sport, a comprehensive match state service is provided in two message types, Summary and Details. These messages describe the current state of a fixture. Details of the match state service can be found in document GEN-1290.

Service and Message Types

The table below shows the messages that are delivered for each service offered.

Service

Fixture

MarketSet

ResultSet

Coverage

Match State

Match Data

Yes

No

No

Optional

Yes

PreMatch Manager

Yes

Yes

Yes

No

No

InPlay Manager

Yes

Yes

Yes

Optional

Optional





Receiving Update Messages

We will push update messages to your endpoint. The messages will typically be XML delivered over the public internet by HTTPS. Other protocols, for example HTTP or FTP (not recommended), or other message technologies can be supported if necessary.
Message delivery requires:

  1. Customer will deploy a Data Receiver that exposes the methods (ProcessMessage and Heartbeat) as described above,
  2. Customer will provide a URL of the data receiver,
  3. We will deploy an Integration Service to push messages in the agreed format to your specified URL,
  4. Customer will receive and process messages.

All our traffic originates from within the following IP address range: 185.107.196.0/22 (185.107.196.1 - 185.107.199.254).

Message Sizes

The first Updategram sent for an event could include, depending on user's configuration of the system, Market elements for over 100 markets. This can result in large messages and your client application should be able to handle messages up to 2Mb in size.

Handling the Commands

Updategram messages will be pushed to your Data Receiver as required to support the contracted services. Each of these messages should be processed by the Data Receiver and appropriate updates should be passed to the Trading Platform. All messages must be processed and acted upon.
Once a message has been received by your Data Receiver you should respond with a successful delivery acknowledgement message. This can be as simple as a 200 response. The response should be sent as quickly as possible after the message is received.

Entity IDs

Most of the entities we use – fixture, team, competitor, competition, season, market type etc. – will have an identifying number as well as a descriptive string. The descriptions and names are not guaranteed to be unique or to remain unchanged and must not be used for mapping.
Always use the ID number for mapping or matching purposes.

Updategram Header

Every Updategram will be sent with a header element that contains additional information that is not related to an individual fixture but to the message itself.
<Header>
<MessageGuid>c64c3a47-4f34-427c-ba67-3bc031208849</MessageGuid>
<TimeStampUtc>2015-10-22T09:27:19.2654001Z</TimeStampUtc>
<Retry>0</Retry>
<CustomerId>6012</CustomerId>
<MessageFixtureOrder>215</MessageFixtureOrder>
</Header>

Element

Type

Description

MessageGuid

GUID

A unique identifier for the message to allow discovery of the message within log files or services

TimeStampUtc

DateTime

The time that the message was generated for despatch

Retry

Integer

The number of times that delivery of this message has been attempted. This field will increment with each attempt; the TimeStampUtc field will not be updated for retries.

CustomerId

Integer, optional

A unique identifier for the customer. Can be used to differentiate between service instances in a multi-channel system. Off by default; activated on request.

MessageFixtureOrder

Integer, optional

A counter indicating the message order.



Fixture

Purpose: Fixture is used to pass information about a sporting event to the Data Receiver. This data allows a new fixture to be inserted into the Trading Platform or an existing fixture to be updated (for example because the start time has changed). Fixture will always be the first command sent for a particular match. Each Fixture message will describe precisely one fixture.
Processing: when Fixture message is received you should either:

  1. Insert a new fixture into the Trading Platform using the details provided, or
  2. Update a fixture that already exists in Trading Platform.

Any messages relating to a particular fixture will include the ID number held in the Fixture.Id element.

Fixture

An object that describes a fixture. The following message describes a football match from round 7 of the 2015-2016 season of the Albanian Kategoria Superiore competition between KS Skënderbeu Korçë and KS Teuta Durrës.

<Fixture>
<Id>3221097</Id>
<Name>KS Skënderbeu Korçë v KS Teuta Durrës</Name>
<FixtureType>Match</FixtureType>
<Status>Scheduled</Status>
<StartTimeUtc>2015-10-16T16:00:00Z</StartTimeUtc>
<Sport>
<Id>10</Id>
<Name>Football</Name>
</Sport>
<Competition>
<Id>115</Id>
<Name>Kategoria Superiore</Name>
<Region>
<Id>218</Id>
<Name>Albania</Name>
</Region>
<Gender>Male</Gender>
</Competition>
<Season>
<Id>46344</Id>
<Name>Kategoria Superiore 2015-2016</Name>
</Season>
<Round>
<Id>221896</Id>
<Name>Round 7</Name>
</Round>
<Venue>
<Id>1970</Id>
<Name>Stadiumi Skënderbeu</Name>
<Region>
<Id>3181898</Id>
<Name>Korçë</Name>
</Region>
</Venue>
<Competitors>
<Competitor>
<Id>127134</Id>
<Name>KS Skënderbeu Korçë</Name>
<HomeAway>Home</HomeAway>
</Competitor>
<Competitor>
<Id>117373</Id>
<Name>KS Teuta Durrës</Name>
<HomeAway>Away</HomeAway>
</Competitor>
</Competitors>
<ExternalIds>
<ExternalId>
<Source>5153</Source>
<Id>548412135485</Id>
</ExternalId >
<ExternalId>
<Source>8411</Source>
<Id>1254-2244</Id>
</ExternalId >
</ExternalIds >
</Fixture>

The following message describes a doubles tennis match from the quarter finals of the 2015 season of the BGL BNP Paribas Luxembourg Open Doubles competition between Coin, J/Minella, M and Bertens, K/Larsson, J.
<Fixture>
<Id>3474238</Id>
<Name>Coin, J/Minella, M v Bertens, K/Larsson, J</Name>
<FixtureType>Match</FixtureType>
<Status>Scheduled</Status>
<StartTimeUtc>2015-10-22T13:30:00Z</StartTimeUtc>
<Sport>
<Id>24</Id>
<Name>Tennis</Name>
</Sport>
<Competition>
<Id>5409</Id>
<Name>BGL BNP Paribas Luxembourg Open Doubles</Name>
<Region>
<Id>239</Id>
<Name>Luxembourg</Name>
</Region>
<Gender>Male</Gender>
</Competition>
<Season>
<Id>48628</Id>
<Name>BGL BNP Paribas Luxembourg Open Doubles 2015</Name>
</Season>
<Round>
<Id>239363</Id>
<Name>Quarterfinals</Name>
</Round>
<Competitors>
<Competitor>
<Id>840577</Id>
<Name>Coin, J/Minella, M</Name>
<HomeAway>Home</HomeAway>
<Competitors>
<Competitor>
<Id>130569</Id>
<Name>Coin, J</Name>
<HomeAway>Home</HomeAway>
<FirstName>Julie</FirstName>
<LastName>Coin</LastName>
</Competitor>
<Competitor>
<Id>131306</Id>
<Name>Minella, M</Name>
<HomeAway>Home</HomeAway>
<FirstName>Mandy</FirstName>
<LastName>Minella</LastName>
</Competitor>
</Competitors>
</Competitor>
<Competitor>
<Id>130569</Id>
<Name>Coin, J</Name>
<HomeAway>Home</HomeAway>
<FirstName>Julie</FirstName>
<LastName>Coin</LastName>
</Competitor>
<Competitor>
<Id>131306</Id>
<Name>Minella, M</Name>
<HomeAway>Home</HomeAway>
<FirstName>Mandy</FirstName>
<LastName>Minella</LastName>
</Competitor>
<Competitor>
<Id>757045</Id>
<Name>Bertens, K/Larsson, J</Name>
<HomeAway>Away</HomeAway>
<Competitors>
<Competitor>
<Id>561541</Id>
<Name>Bertens, K</Name>
<HomeAway>Away</HomeAway>
<FirstName>Kiki</FirstName>
<LastName>Bertens</LastName>
</Competitor>
<Competitor>
<Id>131095</Id>
<Name>Larsson, J</Name>
<HomeAway>Away</HomeAway>
<FirstName>Johanna</FirstName>
<LastName>Larsson</LastName>
</Competitor>
</Competitors>
</Competitor>
<Competitor>
<Id>561541</Id>
<Name>Bertens, K</Name>
<HomeAway>Away</HomeAway>
<FirstName>Kiki</FirstName>
<LastName>Bertens</LastName>
</Competitor>
<Competitor>
<Id>131095</Id>
<Name>Larsson, J</Name>
<HomeAway>Away</HomeAway>
<FirstName>Johanna</FirstName>
<LastName>Larsson</LastName>
</Competitor>
</Competitors>
</Fixture>

Element

Type

Description

Id

Integer

An immutable identifier for the fixture

Name

String

The name of the fixture

FixtureType

FixtureType

An Enum describing the type of fixture. Possible values:
Match
Outright
Aggregate
Virtual

Status

FixtureStatus

An Enum describing the status of the fixture. Possible values:
Scheduled
Deleted

StartTimeUtc

DateTime

The start time of the fixture in UTC

Sport

Sport

An object describing the sport within which the fixture is played

Competition

Competition

An object describing the competition within which the fixture is played

Season

Season

An object describing a season within a competition

TourSeason

Season, optional

An object describing the tour within which the fixture is played, if applicable

Round

Round, optional

An object describing a round within a season

Venue

Venue, optional

An object describing the venue at which the fixture is played

Competitors

Competitor

A collection of objects describing the competitors

AggregateEventInfo

AggregateEventInfo, optional

An object that holds additional information about an aggregate event

ExternalIds

Array of ExternalId

An object that holds Client fixture information in an array

ExternalId

String, optional

An object that holds Client fixture information

Source

String, optional

Customer's fixture Source ID, if available and required

Id

String, optional

Customer's fixture ID, if available and required

TennisProperties

TennisProperties, optional

An object containing information specific to a tennis match; no populated for sports other than tennis

AssociationFixtureId

String, optional

Where appropriate, the fixture ID used to build a link to a fixture's streaming feed

IsOff

Boolean, optional

Used only for horse races. False until the race has started, then True.



ExternalIds

We can supply a fixture matching service. This can help if, for example, you wish to consume our in-play services and match our fixtures to those that might already exist within your trading platform. When the fixture matching service is active, the ExternalIds element will be populated with an array of your fixture IDs.

Sport

An object that describes a sport.
<Sport>
<Id>10</Id>
<Name>Football</Name>
</Sport>

Element

Type

Description

Id

Integer

An immutable identifier for the sport

Name

String

The name of the sport


Sport IDs and Names:

ID

Name

17

American Football

2

Australian Rules

271554

Badminton

3

Baseball

4

Basketball

7950337

Beach Volleyball

5

Boxing

6

Cricket

7

Cycling

8

Darts

10915624

eSports

10

Football

491393

Futsal

6463040

Gaelic Football

12

Golf

99614

Handball

208627

Hockey

6463041

Hurling

15

Ice Hockey

300115

Martial Arts/UFC

16

Motor Sport

73743

Rugby League

73744

Rugby Union

22

Snooker

269467

Table Tennis

24

Tennis

91189

Volleyball



Competition

An object that describes a competition.
<Competition>
<Id>115</Id>
<Name>Kategoria Superiore</Name>
<Region>
<Id>218</Id>
<Name>Albania</Name>
</Region>
<Gender>Male</Gender>
</Competition>

Element

Type

Description

Id

Integer

An immutable identifier for the competition

Name

String

The name of the competition

Region

Region

An object that describes the region within which the competition is held

Gender

Gender, optional

An enum describing the gender of the competitors. Possible values:
Male
Female
Mixed


Region

An object that describes a region.
<Region>
<Id>218</Id>
<Name>Albania</Name>
</Region>

Element

Type

Description

Id

Integer

An immutable identifier for the region

Name

String

The name of the region


Season

An object that describes a season.
<Season>
<Id>46344</Id>
<Name>Kategoria Superiore 2015-2016</Name>
</Season>

Element

Type

Description

Id

Integer

An immutable identifier for the season

Name

String

The name of the season


Round

An object that describes a round.
<Round>
<Id>221896</Id>
<Name>Round 7</Name>
</Round>

Element

Type

Description

Id

Integer

An immutable identifier for the round

Name

String

The name of the round


Venue

An object that describes a venue.
<Venue>
<Id>1970</Id>
<Name>Stadiumi Skënderbeu</Name>
<Region>
<Id>3181898</Id>
<Name>Korçë</Name>
</Region>
</Venue>

Element

Type

Description

Id

Integer

An immutable identifier for the venue

Name

String

The name of the venue

Region

Region

An object that describes the region within which the venue is located



Competitor

An object that describes a competitor. This can be a team or an individual player.
<Competitor>
<Id>127134</Id>
<Name>KS Skënderbeu Korçë</Name>
<HomeAway>Home</HomeAway>
</Competitor>

Element

Type

Description

Id

Integer

An immutable identifier for the competitor

Name

String

The name of the competitor

CompetitorType

CompetitorType

An Enum describing the competitor type. Possible values:
NotSpecified
Other
Person
Team
DoublesPartnership
Abstract
Horse
Jockey
Trainer
HorseOwner
Dog

HomeAway

HomeAway, optional

An Enum describing the home or away status of the competitor. Possible values:
Home
Away

Competitors

Competitor, optional

An array of competitors

FirstName

String, optional

When the competitor is a player, this is the first name of the player

LastName

String, optional

When the competitor is a player, this is the last name of the player

SquadNumber

String, optional

In some sports, the player's squad number

Position

String, optional

In some sports, a description of the player's position within the team

Gender

Gender, optional

Indicator of a player's gender

AgeCategory

String, optional

Not yet used. Describes the age of the competitors. Possible values include:
Youth
U15
U16
U17
U18
U19
U20
U21
U22
U23
Senior
This list is not definitive and care should be taken to ensure that assumptions about values in this field do not fail when new age categories are added.

ExternalId

String, optional

A customer's competitor ID, if available and required


AggregateEventInfo

An object that describes a season.
<AggregateEventInfo>
<CurrentHomeTeamFirstLegScore>1</CurrentHomeTeamFirstLegScore>
<CurrentAwayTeamFirstLegScore>0</CurrentAwayTeamFirstLegScore>
</AggregateEventInfo>

Element

Type

Description

CurrentHomeTeamFirstLegScore

Integer

The current home team's first leg score

CurrentAwayTeamFirstLegScore

Integer

The current away team's first leg score



BasketballProperties

An object that provides basketball-specific details for a basketball match.
<BasketballProperties>
<BasketballAssociation>FIBA</BasketballAssociation>
</BasketballProperties>

Element

Type

Description

BasketballAssociation

String

The name of the association under whose rules the fixture is to be played


FootballProperties

An object that provides tennis-specific details for a football match.
<FootballProperties>
<ExtraTimeProperties/>
<MatchDuration>PT1H30M</MatchDuration>
<ExtraTimeDuration>PT30M</ExtraTimeDuration>
</FootballProperties>

Element

Type

Description

ExtraTimeProperties

FootballExtraTimeProperties

An object that describes how (and if) the fixture might go to extra time

MatchDuration

Timespan

The scheduled duration of the fixture

ExtraTimeDuration

Timespan

The scheduled duration of extra time, if played












FootballExtraTimeProperties

An object that provides football-specific details for a football match.
<ExtraTimeProperties>
<IsExtraTime>True</IsExtraTime>
<IsSecondLeg>True</IsSecondLeg>
<FirstLegId>54876512</FirstLegId>
<GoesStraightToPenalties>False</GoesStraightToPenalties>
<AwayGoalsAfterNormalTime>True</AwayGoalsAfterNormalTime>
<AwayGoalsAfterExtraTime>True</AwayGoalsAfterExtraTime>
</ExtraTimeProperties>

Element

Type

Description

IsExtraTime

Boolean

True if the fixture could go to extra time, False otherwise

IsSecondLeg

Boolean

True if this is the second leg of a two leg match, False otherwise

FirstLegId

Integer

The fixture ID of the first leg if this is the second leg of a two leg match

GoesStraightToPenalties

Boolean

True if the fixture will go straight to penalties in the event of a full-time draw, False otherwise

AwayGoalsAfterNormalTime

Boolean

True if the "Away Goal Rule" applies after normal time

AwayGoalsAfterExtraTime

Boolean

True if the "Away Goal Rule" applies after Extra time



TennisProperties

An object that provides tennis-specific details for a tennis match.
<TennisProperties>
<NumberOfSets>3</NumberOfSets>
<FinalSet>TieBreak</FinalSet>
<ScoringSystemForServiceGames>StandardAdvantage</ScoringSystemForServiceGames>
<CourtSurface> Unset</CourtSurface>
</TennisProperties>

Element

Type

Description

NumberOfSets

Integer

The maximum number of sets to be played in the match

FinalSet

FinalSet

An Enum describing the type of the final set of the match. Values:
Unset
TieBreak
Advantage
MatchTieBreak

ScoringSystemForServiceGames

ScoringSystemForServiceGames

An Enum describing the scoring systemfor service (as opposed to Tie Break) games. Values:
Unset
NoAd (first player to reach 4 points wins the game)
StandardAdvantage (first player to reach 4 points with 2 points clear wins the game)

CourtSurface

CourtSurface

An Enum describing the court surface upon which the match is to be played. Values:
Unset
Clay
Grass
Hard
Carpet
Wood


MarketSet

Purpose: MarketSet holds a collection of Market instructions for a specified fixture. MarketSet may include one or many Market objects, each of which will create or update precisely one market instance.
Processing: when Market is received a new market should be created in the Trading Platform (or an existing market updated) in the fixture referenced by MarketSet.FixtureId using the details provided. Market includes selections, market type and other information required to allow you to insert or update a market in your trading platform.

Example Message – MarketSet

The example below shows a MarketSet for fixture 3476056. Some elements have been truncated.
<MarketSet>
<FixtureId>3476056</FixtureId>
<Markets>
<Market>
<Id>100001331</Id>
<Sequence>0</Sequence>
<TradingStatus>Suspended</TradingStatus>
<Name>Match Result</Name>
<ExpiryUtc>2015-10-24T09:59:59Z</ExpiryUtc>
<MarketType>
<Id>2</Id>
<Name>Match Result</Name>
<IsHandicap>false</IsHandicap>
</MarketType>
<InPlay>true</InPlay>
<Selections>
... Selections truncated for readability
</Selections>
</Market>
... Markets truncated for readability
</Markets>
</MarketSet>
Each MarketSet will contain one or more Market elements.

Example Message – Market, Match Result

Exhaustive markets, like Match Result, include an Outcome element that provides additional information about the selection.
<Market>
<Id>100001331</Id>
<Sequence>0</Sequence>
<TradingStatus>Suspended</TradingStatus>
<Name>Match Result</Name>
<ExpiryUtc>2015-10-24T09:59:59Z</ExpiryUtc>
<MarketType>
<Id>2</Id>
<Name>Match Result</Name>
<IsHandicap>false</IsHandicap>
</MarketType>
<InPlay>true</InPlay>
<Selections>
<Selection>
<Id>300002720</Id>
<TradingStatus>Trading</TradingStatus>
<Name>FK Sementchi Farg'ona</Name>
<CompetitorId>810068</CompetitorId>
<Outcome>
<Id>1</Id>
<Name>Home</Name>
</Outcome>
<Numerator>1</Numerator>
<Denominator>20</Denominator>
<Decimal>1.05</Decimal>
</Selection>
<Selection>
<Id>300002721</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Draw</Name>
<Outcome>
<Id>2</Id>
<Name>Draw</Name>
</Outcome>
<Numerator>15</Numerator>
<Denominator>2</Denominator>
<Decimal>8.5</Decimal>
</Selection>
<Selection>
<Id>300002722</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Xorazm Urganch</Name>
<CompetitorId>475759</CompetitorId>
<Outcome>
<Id>3</Id>
<Name>Away</Name>
</Outcome>
<Numerator>24</Numerator>
<Denominator>1</Denominator>
<Decimal>25.0</Decimal>
</Selection>
</Selections>
</Market>

Example Message – Market, Asian Handicap

Handicap markets, like Asian Handicap or Total Goals Over/Under, will include a Handicap element that provides details of the handicap line.
<Market>
<Id>100001332</Id>
<Sequence>0</Sequence>
<TradingStatus>Suspended</TradingStatus>
<Name>Asian Handicap</Name>
<ExpiryUtc>2015-10-24T09:59:59Z</ExpiryUtc>
<Handicap>2.5</Handicap>
<MarketType>
<Id>82</Id>
<Name>Asian Handicap</Name>
<IsHandicap>true</IsHandicap>
</MarketType>
<InPlay>true</InPlay>
<Selections>
<Selection>
<Id>300002723</Id>
<TradingStatus>Trading</TradingStatus>
<Name>FK Sementchi Farg'ona</Name>
<CompetitorId>810068</CompetitorId>
<Outcome>
<Id>1</Id>
<Name>Home</Name>
</Outcome>
<Numerator>23</Numerator>
<Denominator>20</Denominator>
<Decimal>2.15</Decimal>
</Selection>
<Selection>
<Id>300002724</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Xorazm Urganch</Name>
<CompetitorId>475759</CompetitorId>
<Outcome>
<Id>3</Id>
<Name>Away</Name>
</Outcome>
<Numerator>37</Numerator>
<Denominator>50</Denominator>
<Decimal>1.74</Decimal>
</Selection>
</Selections>
</Market>

Example Message – Correct Score

Correct Score market types (as in this example from FK Sementchi Farg'ona v Xorazm Urganch) include a Range element that encodes the score necessary for the selection to be the winning outcome. Range.Low is always the first value in the score, Range.High the second, so the following element represents a score of 3-1.
<Range>
<High>1.0</High>
<Low>3.0</Low>
</Range>
The Correct Score market looks like this:
<Market>
<Id>100001333</Id>
<Sequence>0</Sequence>
<TradingStatus>Suspended</TradingStatus>
<Name>Correct Score</Name>
<ExpiryUtc>2015-10-24T09:59:59Z</ExpiryUtc>
<MarketType>
<Id>91</Id>
<Name>Correct Score</Name>
<IsHandicap>false</IsHandicap>
</MarketType>
<InPlay>true</InPlay>
<Selections>
<Selection>
<Id>300002731</Id>
<TradingStatus>Trading</TradingStatus>
<Name>FK Sementchi Farg'ona 2-0</Name>
<CompetitorId>810068</CompetitorId>
<Range>
<High>0.0</High>
<Low>2.0</Low>
</Range>
<Numerator>22</Numerator>
<Denominator>5</Denominator>
<Decimal>5.4</Decimal>
</Selection>
<Selection>
<Id>300002732</Id>
<TradingStatus>Trading</TradingStatus>
<Name>FK Sementchi Farg'ona 2-1</Name>
<CompetitorId>810068</CompetitorId>
<Range>
<High>1.0</High>
<Low>2.0</Low>
</Range>
<Numerator>23</Numerator>
<Denominator>4</Denominator>
<Decimal>6.75</Decimal>
</Selection>
... Selections truncated for readability
</Selections>
</Market>

Example Message – Tennis Game Correct Score

Unlike most Correct Score market types, the Game Correct Score (as in this example from Knapp, K v Stosur, S) in tennis has only a one populated element within Range because the winning player's game point score in tennis is never used. In these market types the "Home" player's score (Knapp, K) will represented by Range.Low and the "Away" player's score (Stosur, S) by Range.High.
<Id>100001359</Id>
<Sequence>9</Sequence>
<TradingStatus>Open</TradingStatus>
<Name>Game Score (Game 9)</Name>
<ExpiryUtc>2015-10-24T13:34:59Z</ExpiryUtc>
<Handicap i:nil="true" />
<MarketType>
<Id>11103</Id>
<Name>Numbered Game Score</Name>
<IsHandicap>false</IsHandicap>
</MarketType>
<InPlay>true</InPlay>
<Selections>
<Selection>
<Id>300002817</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Kasatkina, D/Vesnina, E to 15</Name>
<CompetitorId>840539</CompetitorId>
<Range>
<High>15.0</High>
</Range>
<Numerator>13</Numerator>
<Denominator>10</Denominator>
<Decimal>2.3</Decimal>
</Selection>
<Selection>
<Id>300002818</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Kasatkina, D/Vesnina, E to 30</Name>
<CompetitorId>840539</CompetitorId>
<Range>
<High>30.0</High>
</Range>
<Numerator>19</Numerator>
<Denominator>10</Denominator>
<Decimal>2.9</Decimal>
</Selection>
... Selections truncated for readability
</Selections>
</Market>

MarketSet

An object that contains a number of market objects.
<MarketSet>
<FixtureId>3476056</FixtureId>
<Markets>
... Markets truncated for readability
</Markets>
</MarketSet>

Element

Type

Description

FixtureId

Integer

An immutable identifier for a fixture

Markets

Market

An array of market objects, each describing a market within the identified fixture



Market

An object that describes a market.
<Market>
<Id>100013200</Id>
<Sequence>0</Sequence>
<TradingStatus>Open</TradingStatus>
<Name>Match Result</Name>
<ExpiryUtc>2016-04-29T09:35:00Z</ExpiryUtc>
<MarketType>
<Id>322</Id>
<Name>Match</Name>
<IsHandicap>false</IsHandicap>
</MarketType>
<InPlay>true</InPlay>
<Selections>
<Selection>
<Id>300053291</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Schwartzman, DS</Name>
<CompetitorId>567116</CompetitorId>
<Outcome>
<Id>25</Id>
<Name>Player 1</Name>
</Outcome>
<Numerator>47</Numerator>
<Denominator>50</Denominator>
<Decimal>1.94</Decimal>
<Probability>0.49278</Probability>
</Selection>
<Selection>
<Id>300053292</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Dzumhur, D</Name>
<CompetitorId>700304</CompetitorId>
<Outcome>
<Id>26</Id>
<Name>Player 2</Name>
</Outcome>
<Numerator>87</Numerator>
<Denominator>100</Denominator>
<Decimal>1.87</Decimal>
<Probability>0.50722/Probability>
</Selection>
</Selections>
<CashOutStatus>Closed</CashOutStatus>
</Market>

Element

Type

Description

Id

Integer

An immutable identifier for a market

Sequence

Integer, optional

The sequence number for an InPlay market

TradingStatus

MarketStatus

An enum that describes the trading status of the market. Possible values:
Open
Suspended
Closed
Only markets with a TradingStatus of Open can be offered to customers. Markets with TradingStatus of Suspended and Closed must not be offered but are expected to reopen at some point.

Name

String

The name of the market

ExpiryUtc

DateTime

The time that the market expires

Handicap

Decimal, optional

For handicap markets, the handicap line

MarketType

MarketType

An object that describes the market's type

InPlay

Boolean

True if the market contains an in-play price, False if the market contains a pre-match price

Selections

Selection

An array of Selection objects

ExternalId

String, optional

A customer's market ID, if available and required

CashOutStatus

CashOutStatus, optional

Optional feature, off by default. An enum that describes the cash-out status of the market:
Open
Suspended
Closed

EachWayTerm

EachWayTerm, optional

For horse racing only, an object that describes the market's each way terms


MarketType

An object that describes the type of a market.
<MarketType>
<Id>82</Id>
<Name>Asian Handicap</Name>
<IsHandicap>true</IsHandicap>
</MarketType>

Element

Type

Description

Id

Integer

An immutable identifier for the market type

Name

String

The name of the market type

IsHandicap

Boolean

True if the market type has a handicap, False otherwise


Selection

An object that describes a selection.
<Selection>
<Id>300053292</Id>
<TradingStatus>Trading</TradingStatus>
<Name>Dzumhur, D</Name>
<CompetitorId>700304</CompetitorId>
<Outcome>
<Id>26</Id>
<Name>Player 2</Name>
</Outcome>
<Numerator>87</Numerator>
<Denominator>100</Denominator>
<Decimal>1.87</Decimal>
<Probability>0.50721</Probability>
</Selection>

Element

Type

Description

Id

Integer

An immutable identifier for the market type

TradingStatus

SelectionStatus

An Enum describing the trading state of the selection. Possible values:
Unpriced
Trading
Suspended
NonRunner
Only selections with a TradingStatus of Trading can be offered to customers. Selections with a TradingStatus of Unpriced will not have a price and cannot be offered. Selections with a TradingStatus of Suspended are not safe to be offered for some reason.
NonRunner is used only in horse races to indicate a selection that will no longer compete

Name

String

The name of the market type

CompetitorId

Integer, optional

The ID of the competitor if the selection is a competitor within the parent fixture

Outcome

Outcome, optional

An object describing the selection's outcome type

Range

Range, optional

An object describing the range of outcomes for which the selection is a winner

Numerator

Integer

The numerator of the price of the selection

Denominator

Integer

The denominator of the price of the selection

Decimal

Decimal

The price of the selection in decimal format

Probability

Decimal, optional

The probability of the selection. Off by default, activated on request.

ExternalId

String, optional

A customer's market ID, if available and required


Outcome

An object that describes the outcome type of a selection.
<Outcome>
<Id>2</Id>
<Name>Draw</Name>
</Outcome>

Element

Type

Description

Id

Integer

An immutable identifier for the outcome type

Name

String

The name of the outcome type


A list of outcome types can be found in Appendix A

Range

An object that describes the range parameters of a selection.
<Range>
<High>0.0</High>
<Low>2.0</Low>
</Range>

Element

Type

Description

High

Decimal, optional

The high value of a range

Low

Decimal, optional

The low value of a range


EachWayTerm

For horse racing markets only, an object that describes the market's each way terms.
<EachWayTerm>
<Places>5</Places>
<Numerator>1</Numerator>
<Denominator>2</Denominator>
</EachWayTerm>

Element

Type

Description

Places

Integer

The number of places over which each-way terms are to be applied

Numerator

Integer

Numerator of fraction of odds to be applied for each-way terms

Denominator

Integer

Denominator of fraction of odds to be applied for each-way terms



Sequence Number – Football and Basketball

Markets that are created by the in-play system will have a sequence number within the market element with Football markets incrementing up from 0 and other Inplay sports from 1 (only for the Openbet platform, all sports begin at 1). Served Sports disciplines include further customisation, detailed below. An example sequence for Football:
<Sequence>0</Sequence>
This number will increment from 0 as the index described by the market increases. In action, a Next Goalscorer market will begin with index 0 and increment upwards after each goal.

Sequence Number – Served Sports

For Set Markets such as Current Set Winner or Next Set Correct Score the sequence number is the number of the Set. So for Set Winner (Set 3) then the Sequence number would be 3. For Game Markets there are two different indexing systems:

  1. Index on Set and Game: e.g. Game Winner (Set 1, Game 3)For these markets we calculate the sequence number by adding the Set Number to 1000 times the Game Number in the Set so Game Winner (Set 1, Game 3) would have a sequence number of 3001.
  2. Index on Game in the match: e.g. Game Winner (Game 20)For these markets we calculate the sequence number as the Game Number in the match so Game Winner (Game 20) would have a sequence number of 20.

For Point Markets there are also two options but the point number is also taken into account. This is done by adding 1000000 times the point number to the game sequence number.
The following table illustrates how that works:

Market

 

Sequence Number

 

Example

 

11328

Current Service Game Point Winner (Game, Point)

 

Game + (1000000 * Point)

 

(Game, Point) (Game 3, Point 2)
2000003

 

11329

Next Service Game Point Winner (Game, Point)

 

 

 

 

 

11335

Numbered Service Game Point Winner (Game, Point)

 

 

 

 

 

11336

Current Service Game Point Winner (Set, Game, Point)

 

Set + (Game*1000) + (Point * 1000000)

 

(Set2, Game 3, Point 4)
4003002

 

11337

Next Service Game Point Winner (Set, Game, Point)

 

 

 

 

 

11340

Numbered Service Game Point Winner (Set, Game, Point)

 

 

 

 

 

Current, Next and Numbered Market Type Variants

In Tennis, indexed market types are split into two categories:

  • Current/Next, and
  • Numbered

These market type variants are equivalent, so Current/Next Set Winner is functionally identical to Numbered Set Winner. The Numbered variants are used by all customers except those with OpenBet trading platforms, who use the Current/Next variants (OpenBet allows only one index to be active in a market at a time and so two market types are required so that, for example, Current Set Winner and Next Set Winner can be offered concurrently).

ResultSet

Purpose: ResultSet holds a collection of Result objects for a specified fixture. ResultSet may include one or more Result objects, each of which will hold a result for precisely one market instance.
Processing: when Result is received the market referenced by Market.Id should be resulted within your trading platform. Once resulted you can also settle bets.
The example message below shows a ResultSet for a Handicap market in event 90090201.

Example Message - ResultSet

<ResultSet>
<FixtureId>3474167</FixtureId>
<Results>
<MarketResult>
... Markets truncated for readability
</MarketResult>
</Results>

Element

Type

Description

FixtureId

Integer

An immutable identifier for a fixture

Results

MarketResult

An array of market result objects, each describing the outcome of a market within the identified fixture



MarketResult

An object that describes a result for a market.
<MarketResult>
<MarketId>100001358</MarketId>
<MarketSequence>14</MarketSequence>
<Results>
<SelectionResult>
<AdditionalResultData i:nil="true" />
<ResultStatus>Loser</ResultStatus>
<SelectionId>300002810</SelectionId>
</SelectionResult>
<SelectionResult>
<AdditionalResultData i:nil="true" />
<ResultStatus>Winner</ResultStatus>
<SelectionId>300002811</SelectionId>
</SelectionResult>
</Results>
<MarketResultScore>
<First>0</First>
<Second>1</Second>
<MarketResultScore>
</MarketResult>

Element

Type

Description

MarketId

Integer

The identifier of the market to which this result applies

MarketSequence

Integer, optional

For an in-play market, the sequence number being resulted

Results

SelectionResult

An array of selection result objects


SelectionResult

An object that describes the outcome of a selection.
<SelectionResult>
<AdditionalResultData i:nil="true" />
<ResultStatus>Loser</ResultStatus>
<SelectionId>300002810</SelectionId>
</SelectionResult>

Element

Type

Description

SelectionId

Integer

The identifier of the selection to which this result applies

ResultStatus

ResultStatus

An Enum that describes the selection's outcomes. Possible values:
None
Winner
Pushed
Loser
Placed
Partial

AdditionalResultData

AdditonalResultData, optional

Contains additional information that may be required to result some selections where the outcome isn't win/lose.

AdditionalResultData

An object that contains additional data necessary to settle bets placed on a selection where Selection.ResultStatus is either Placed or Partial.
<AdditionalResultData>
<PercentageWin>50.0</PercentageWin>
<PercentagePush>50.0</PercentagePush>
<Place>0</Place>
<CountInPlace>0</CountInPlace>
</AdditionalResultData>

Element

Type

Description

PercentageWin

Integer

A number that describes what proportion of the bet should be paid

PercentagePush

ResultStatus

A number that describes what proportion of the bet should be pushed

Place

Integer

The placed position of the selection

CountInPlace

Integer

The counted place position of the selection


MarketResultScore

An optional object that will provide you with event scores through select market type resulting messages for both Prematch and Inplay Manager.
<MarketResultScore>
<First>0</First>
<Second>1</Second>
<MarketResultScore>

Element

Type

Description

First

Integer

A number describing the first or Home selection score

Second

Integer

A number describing the second or Away selection score


Sports and markets that currently include this object are displayed by the following table. Each market includes the score at the resulting time, so as an example, Half Time Result provides the score at the end of the first half whilst Match Result includes the full-time score.

Sport

Market Id

Market Name

PreMatch

InPlay

Football

2

Match Result

Yes

Yes

Football

6832

Half Time Result

Yes

Yes

Football

7591

2nd Half Result

Yes

 

Football

10502

Result At Extra Time Half-time (including normal time goals)

 

Yes

Football

10986

Extra Time Half Time Result (excluding normal time goals)

 

Yes

Football

10498

Match Result After extra time (including normal time goals)

 

Yes

Football

10982

Extra Time Result (excluding normal time goals)

 

Yes

Basketball

306

Match Result (excluding overtime)

Yes

Yes

Basketball

5

Half-Time Result

Yes

Yes

Basketball

6950

First-Quarter Result

Yes

Yes

Basketball

9766

Second-Quarter Result

 

Yes

Basketball

9767

Third-Quarter Result

 

Yes

Basketball

9768

Fourth-Quarter Result

 

Yes


Additional sports are scheduled to be equipped with the MarketResultScore element. Please contact Genius Sports Support for further information.

Coverage

Purpose: Coverage holds information that describes the current expectations regarding the availability of an in-play trading service for a fixture.
Coverage will be sent when an event is booked on the Inplay Manager and when either the feed availability or booking state of a fixture has been changed.
Processing: Coverage tells you the about the match state and trading states of the fixtures and whether you are licensed to receive an in-play service. If IsLicensed is true for both MatchState and TradingState then we will be able to trade the fixture in-play.
The example message below shows Coverage for fixture 3025747.  
<Coverage>
  <FixtureId>3025747</FixtureId>
   <ExternalFixtureIdi:nil="true" />
  <IsBooked>true</IsBooked>
<AvailableFeeds>
...
  </AvailableFeeds>
</CoverageCommand>

Element

Type

Description

FixtureId

Int

An immutable identifier for the fixture

ExternalFixtureId

String, optional

Customer's fixture ID, if available and required

IsBooked

Boolean

True if you have booked the fixture, false otherwise

AvailableFeeds

Feed

An array of objects describing the feeds available for this fixture.


Feeds

An object that describes a data feed in a fixture.
    <Feed>
      <IsLicensed>true</IsLicensed>
      <Type>MatchState</Type>
    </Feed>

Element

Type

Description

IsLicensed

Boolean

True if you are licensed to receive data from this feed for this fixture, false otherwise.

Type

String

A description of the feed.





  • No labels