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 »

Ably American Football Match State V2

Introduction

The document describes the American Football V2 Match state contract and provides examples of using it.

American Football Match State

Differences from V1

Section Explanations

1. firstHalf

The firstHalf section contains information about the coin toss results, all drives of the half, timeouts taken by the teams during this half and remaining timeouts for each team.

{
  "drives": [{}], 
  "timeouts": [{}], 
  "timeoutsRemaining": {}, 
  "coinToss": {} 
}

drives

Contains the array of drives happened in this half of the match.

timeouts

Contains the array of timeouts that either home or away team took during this half

timeoutsRemaining

Contains the number of how many timeouts remained for both home and away teams at this half

coinToss

Contains information about coin toss that happened at the beginning of this half

Use case: It’s the beginning of the match, a coin toss has been completed, a winner team is about to kick the football - all this information is reflected under this “firstHalf” section.

Real example:

1.1 drives

The drives array contains drive objects that contain information about team who was in possession of that drive, indication was it a kickoff drive or not, list of all plays and conversion plays happened during the drive as well as basic information about the scores and indication if it is a finished drive or not.

{
  "teamInPossession": "Home", 
  "isKickOff": true, 
  "plays": [{}], 
  "conversionPlays": [{}], 
  "score": [{}], 
  "isFinished": true 
}

teamInPossession

Indicates which team was in possession of this drive. Possible options: [None, Away, Home]

isKickOff

Indicates whether this drive was a kickoff or not

plays

Contains the array of plays happened during this drive

conversionPlays

Contains information about any conversion play happened during this drive

score

Contains the array of scoring events happened during this drive

isFinished

Indicates if this drive has been completed or still ongoing

Use case: Home team gained a possession of the football. They start their 4 attempts to cross the 10 yards. Drive will contain information about all of those attempts until the team either scores or loses the possession of the ball.

Real example:

1.1.1 plays

The plays array contains play objects that contain general information about the play as well as list of all play actions and list of penalties associated with the play.

{
  "sequence": 2,
  "downNumber": 1,
  "yardsToGo": 10, 
  "scrimmageLocation": {},
  "snap": {},
  "isVoid": false,
  "isConfirmed": true,
  "isFinished": false,
  "period": {},
  "actions": [{}],
  "penalties": [{}],
  "startedAtGameTime": "00:12:43", 
  "endedAtGameTime": "00:12:11", 
  "startedAtUtc": "2021-06-02T20:31:36.955Z", 
  "endedAtUtc": "2021-06-02T20:31:36.955Z",
  "description": "(12:43) K.Cousins pass deep left to A.Thielen to HST 49 for 18 yards (E.Murray).",
  "sourcePlayId": "360"
}

sequence

Indicates the number of attempt team is conducting during the drive

downNumber

Indicates the number of attempt (out of 4) the team to cross the first down line

yardsToGo

Indicates the yards the team has remaining to go till the first down line

scrimmageLocation

Indicates the location of football from where the play is started

snap

Indicates whether the play has been started and the ball has been snapped

isVoid

Indicates whether the play has been cancelled

isConfirmed

Indicates if the play with all its actions has been confirmed

isFinished

Indicates if the play has ended

period

Contains information which period is it in a match when this play was happening

actions

Contains all the actions that belong to this specific play

penalties

Contains a list of penalties that happened during this specific play

startedAtGameTime

Indicates at what time of the game this play has started

endedAtGameTime

Indicates at what time of the game this play has ended

startedAtUtc

Timestamp indicates the exact time when this play has started

endedAtUtc

Timestamp indicates the exact time when this play has ended

description

Play description

sourcePlayId

Associates this play with a play in NFL feed

Use case: The home team has the possession, snaps the ball and attempts to reach and cross the first down line by rushing through opponents defense.

Real example:

1.1.2 conversionPlays

The conversionPlays array contains conversionPlay objects that contain similar information to regular play object, but is used either for one point or two point conversions.

{
  "teamInPossession": "Home", 
  "type": "OnePoint", 
  "isVoid": false, 
  "isConfirmed": true, 
  "isFinished": false, 
  "period": {}, 
  "actions": [{}], 
  "penalties": [{}], 
  "startedAtGameTime": "00:07:06", 
  "endedAtGameTime": null, 
  "startedAtUtc": "2021-06-02T20:31:36.955Z", 
  "endedAtUtc": null, 
  "description": "R.Blankenship extra point is GOOD, Center-L.Rhodes, Holder-R.Sanchez.",
  "sourcePlayId": "500"
}

teamInPossession

Indicates which team is in possession of this conversion play

type

Indicates the type of the conversion play. Available options: [Unknown, OnePoint, TwoPoints]

isVoid

Indicates whether this conversion play has been cancelled

isConfirmed

Indicates if the conversion play with all its actions has been confirmed

isFinished

Indicates if the conversion play has ended

period

Contains information which period is it in a match when this conversion play was happening

actions

Contains all the actions that belong to this specific conversion play

penalties

Contains a list of penalties that happened during this specific conversion play

startedAtGameTime

Indicates at what time of the game this conversion play has started

endedAtGameTime

Indicates at what time of the game this conversion play has ended

startedAtUtc

Timestamp indicates the exact time when this conversion play has started

endedAtUtc

Timestamp indicates the exact time when this conversion play has ended

description

Conversion play description

sourcePlayId

Associates this play with a play in NFL feed

Use case: The home team scored a touchdown. They have the possession for the conversion play and they are attempting an extra point kick.

Real example:

1.1.3 score

The score array contains score object that contains information about how the score was gained, which team scored, how many points and period when it happened.

{
	"period": {
		"number": 1,
		"type": "Regular"
	},
	"type": "Touchdown",
	"team": "Away",
	"points": 6,
	"isConfirmed": true,
	"utcTimestamp": "2022-05-19T19:23:09.6933189Z"
}

period

Contains information about the period this scoring action happened

type

Indicates the type of the scoring play. Available options: [Touchdown, OnePointConversion, TwoPointConversion, FieldGoal, Safety, OnePointSafety]

team

Indicates the team who scored. Available options: [None, Home, Away]

points

Indicates how many points the team gained

isConfirmed

Indicates if it is confirmed or not

utcTimestamp

Timestamp indicates the exact time of this scoring action

Use case: A home team has scored a touchdown and successfully made an extra point in a conversion play.

1.1.4 scrimmageLocation

The scrimmageLocation section contains basic information about the line of scrimmage.

{
  "scrimmageYard": 30,
  "sideOfPitch", "Home"
}

scrimmageYard

Indicates the yard line where the football is placed at the start of the play

sideOfPitch

Indicates side of the yard. Available options: [None, Home, Away]

Use case: A ball for the play will be placed on 30 yards line of home team side.

1.1.5 snap

The snap section contains basic information about the snap action - time when it happened and whether it’s confirmed.

{
	"isConfirmed": true,
	"timestampUtc": "2020-10-11T22:07:32Z"
}

Use case: A scout notes that the ball has been snapped.

1.1.6 period

The period section contains basic information about the period number and if it’s a regular period or an overtime. Here period is for the specific play - in which period the specific play happened.

{
  "number": 2,
  "type": "Regular"
}

number

Indicates the number of the quarter

type

Indicates whether this period is during a regular time or an overtime. Available options: [Regular, Overtime]

Use case: This specific play happens in the 2nd quarter of the regular game time.

1.1.7 actions

The actions array contains action objects that contain information about specific action of the play - which team made the action, what kind of action was it, players involved.

{
	"sequence": 1,
	"team": "Away",
	"type": "Run",
	"players": [
		{
			"playerType": "Runner",
			"id": "121463"
		}
	],
	"yards": -1,
	"isNullified": false,
	"activeUnits": {
		"home": "Unknown",
		"away": "Unknown"
	}
},
{
	"sequence": 2,
	"team": "Home",
	"type": "Tackle",
	"players": [],
	"yards": null,
	"isNullified": false,
	"activeUnits": {
		"home": "Unknown",
		"away": "Unknown"
	}
}

sequence

Indicates the sequence of actions within the play

team

Indicates which team made that action

type

Indicates the type of action. Available options: [Kickoff, Touchback, FairCatch, Run, Tackle, Sack, OutOfBounds, PassAttempt, CompletePass, IncompletePass, Interception, Punt, Fumble, Return, Safety, Touchdown, FieldGoalAttempt, FieldGoalMade, FieldGoalMissed, ConversionAttempt, ConversionMade, ConversionMissed, OnePointSafety, Muff, Recovery, FieldGoalBlocked, ConversionBlocked, DeadBall]

yards

Indicates the amount of yards gained or lost (it’s shown or not depending on the action).

isNullified

Indicates whether this action was nullified (for example by penalty)

activeUnits

Currently not provided.

Use case: A player from away team decided to run and was tackled 1 yard behind line of scrimmage.

Difference from v1: New action “type” introduced: Muff, Recovery, FieldGoalBlocked, ConversionBlocked, DeadBall

1.1.8 penalties

The penalties array contains penalty objects that contain information about the given penalty - which team got the penalty, which player, what kind of penalty and penalty yards. Penalties are per play.

{
	"team": "Home",
	"playerId": "719522",
	"type": "DefensiveOffside",
	"outcome": "Accepted",
	"yards": 5,
	"activeUnits": {
		"home": "Unknown",
		"away": "Unknown"
	},
	"utcTimestamp": "2022-05-19T20:40:48.8290673Z"
}

team

Indicates which team was charged with the penalty

playerId

Indicates which player was charged with penalty

type

Indicates type of the penalty. Available options: [Unknown, OffensiveHolding, FalseStart, DefensivePassInterference, OffensivePassInterference, DefensiveHolding, UnnecessaryRoughness, DefensiveOffside, DelayOfGame, IllegalBlockAboveTheWaist, NeutralZoneInfraction, FaceMask, IllegalUseOfHands, RoughingThePasser, UnsportsmanlikeConduct, IllegalFormation, Encroachment, IllegalContact, Defensive12OnField, IllegalShift, IntentionalGrounding, Taunting, OffsideOnFreeKick, IneligibleDownfieldPass, HorseCollarTackle, Leverage, RoughingTheKicker, IllegalMotion, ChopBlock, IllegalTouchKick, RunningIntoTheKicker, Disqualification, InterferenceWithOpportunityToCatch, Offensive12OnField, PlayerOutOfBoundsOnPunt, IllegalSubstitution, OffensiveOffside, IllegalTouchPass, FairCatchInterference, Clipping, IllegalForwardPass, IllegalBlindsideBlock, Tripping, Leaping, IneligibleDownfieldKick, InvalidFairCatchSignal, IllegalCrackback, LowBlock, DelayOfKickoff, DefensiveDelayOfGame, IllegalBat, IllegallyKickingBall, KickoffOutOfBounds, IllegalCut]

outcome

Indicates the outcome of the penalty. Available options: [Unknown, Accepted, Declined, Offsetting, Superseded]

yards

Indicates penalty yards

activeUnits

Currently not provided

utcTimestamp

Timestamp of the penalty

Use case: Home team was charged with the penalty “Defensive Offside” that they accepted. Home team was penalized of 5 yards.

Difference from v1: New penalty type introduced: “IllegalCut”

1.1.9 players

The players array contains player object that contains basic information about the player.

{
  "playerType": "Tackler",
  "id": "1003063"
}

playerType

Indicates the type of the player. Available options: [Unknown, Tackled, Tackler, Scorer, Assist, Receiver, Passer, OutOfBounds, Fumbled, Fumbler, Recoverer, Kicker, Runner, Returner, Interceptor, Blocker, QbHitter, PassDefender, Muffed]

id

Indicates an id of the to which this player is mapped

Use case: Player who specified as a “Tackler“ in an “OutOfBounds” action had an id of “1003063".

Difference from v1: New player types introduced: Interceptor, Blocker, QbHitter, PassDefender, Muffed

1.1.10 activeUnits

The activeUnits section contains information about what kind of players were involved on the field - defense, offense or special team.

{
  "home": "Offensive",
  "away": "Defensive"
}

Currently not available.

1.2 timeouts

The timeouts array contains timeout objects that contain general information about each timeout taken during the half of the match.

{
	"team": "Away",
	"gameTime": "00:02:35",
	"period": {
		"number": 4,
		"type": "Regular"
	},
	"utcTimestamp": "2022-05-19T21:48:01.7258484Z",
	"isConfirmed": true
}

team

Indicates which team took the timeout

gameTime

Indicates game time at what the timeout was taken

period

Indicates the period when the timeout was taken

utcTimestamp

Timestamp indicates exact time of the timeout

isConfirmed

Indicates is timeout has been officially confirmed

Use case: A timeout was taken by the away team at 4th quarter of the regular match time when clock was showing 2 minutes and 35 seconds left.

1.3 timeoutsRemaining

The timeoutsRemaining section contains basic information - how many timeouts are remaining for each team in the half.

			{
				"away": 2,
				"home": 1
			}

away

Indicates how many timeouts are left for the away team in the half

home

Indicates how many timeouts are left for the home team in the half

Use case: In this half away team has 2 timeouts remaining whereas home team has 1.

1.4 coinToss

The coinToss section contains information about the outcome of coin toss in the beginning of each half.

{
	"winnerTeam": "Away",
	"wasDeferred": true,
	"awayChoice": "WestEndZone",
	"homeChoice": "Receive"
}

winnerTeam

Indicates the team who won the coin toss

wasDeferred

Indicates whether the winner team decided to defer or not

awayChoice

Indicates the away team choice. Available options: [Kick, Receive, EndZone, NorthEndZone, EastEndZone, SouthEndZone, WestEndZone]

homeChoice

Indicates the home team choice. Available options: [Kick, Receive, EndZone, NorthEndZone, EastEndZone, SouthEndZone, WestEndZone]

Use case: Away team won the coin toss and decided to defer. They chose the west end zone for kicking whereas home team chose to receive the ball after the kick.

2. secondHalf

The secondHalf section is identical to the firstHalf section structure described above.

3. overtimePeriods

The overtimePeriods array contains overtimePeriod objects that contain information about each overtime. It has identical structure to halfs with one exception - in addition it has “period” property.

{
  "period": 1,
  "drives": [{}],
  "timeouts": [{}],
  "timeoutsRemaining": {},
  "coinToss": {}
}

period

Indicates which overtime period it is

drives

Contains the array of drives happened in this overtime

timeouts

Contains the array of timeouts that either home or away team took during this overtime period

timeoutsRemaining

Contains the number of how many timeouts remained for both home and away teams at this overtime period

coinToss

Contains information about coin toss that happened at the beginning of overtime period

Use case: There were no winning team during the regular match time hence game moved into the overtime.

4. challenges

The challenges array contains challenge objects that contain general information about challenge - which team challenged, when and what was the result.

{
  "team": "Away",
  "gameTime": "00:11:04,
  "period": {},
  "utcTimestamp": "2021-06-02T20:31:36.956Z",
  "result": "Lost"
}

team

Indicates the team whose coach initiated the challenge

gameTime

Indicates the game time when the challenge was initiated

period

Indicates the period in which the challenge was initiated

utcTimestamp

Timestamp of the challenge

result

Indicates the result of the challenge. Available options: [Unknown, Won, Lost]

Use case: Head coach of away team initiated a challenge when remaining time was 11 minutes and 4 seconds and lost it.

5. gameTime

The gameTime section contains information about the game clock - what’s the clock value, when was it last updated and is it running at the moment.

{
  "clock": "00:04:11",
  "lastUpdatedUtc": "2021-06-02T20:31:36.956Z",
  "isRunning": true
}

clock

Reflects the game clock

lastUpdatedUtc

Timestamp of the latest game clock value update

isRunning

Indicates whether or not the game clock is running

Use case: Game clock of the match is showing 4 minutes and 11 seconds left. Clock is still running.

6. matchStatus

The matchStatus property reflects the current match status.

"matchStatus": "InProgress"

matchStatus

Indicates the overall match status. Available options: [Unknown, NotStarted, Warmup, InProgress, Postponed, Finished, Interrupted, CoverageStopped, Abandoned, Cancelled, Delayed]

Use case: The match is currently in progress.

7. period

The period section contains basic information about the period number and if it’s a regular period or an overtime. This period section reflects the current period in the match.

{
  "number": 3,
  "type": "Regular"
}

number

Indicates the number of the quarter

type

Indicates whether this period is during a regular time or an overtime. Available options: [Regular, Overtime]

Use case: The match is now in the 3rd quarter of the regular game time.

8. periodWithStatus

The periodWithStatus section contains basic information about the current situation with the match - current period number and if it’s a regular period or an overtime and its status.

"periodWithStatus": {
	"status": "Finished",
	"number": 4,
	"type": "Regular"
}

status

Indicates the status of the period. Available options: [NotStarted, InProgress, Finished]

number

Indicates the number of the quarter

type

Indicates whether this period is during a regular time or an overtime. Available options: [Regular, Overtime]

Use case: A match happens in the 4th quarter of the regular game time and has finished. Note: Period with status is available in one place for the whole match state.

9. score

The score section contains information about the latest score of the whole match.

{
  "home": 13,
  "away": 20,
  "isConfirmed": true
}

home

Indicates how many points has the home team scored in the whole match

away

Indicates how many points has the away team scored in the whole match

isConfirmed

Indicates whether or not these scores of the teams are confirmed

Use case: Home team has scored 13 points and away team has scored 20 points in the match so far. These scores are confirmed.

10. homeTeam/awayTeam sections

The homeTeam and awayTeam sections contain list of players who are playing as part of offensive, defensive or special teams in the match.

{
  "offensive": [{}],
  "defensive": [{}],
  "special": [{}]
}

offensive

Contains the list of offensive players for either home or away team

defensive

Contains the list of defensive players for either home or away team

special

Contains the list of special players for either home or away team

Example:

10.1 offensive/defensive/special sub-sections

The offensive/defensive/special arrays contain lineupPlayer object that contains information about the players (lineup) - player id, position he is playing, side and status.

{
	"id": "1014100",
	"position": "RunningBack",
	"side": "Middle",
	"status": "Started"
}

id

Indicates an Unique id of the player

position

Indicates the position of the player. Available options: [Unknown, Kicker, Punter, Returner, RunningBack, Fullback, WideReceiver, TightEnd, Tackle, Guard, Quarterback, Center, End, Linebacker, Cornerback, Safety, Holder]

side

Indicates the side of the player. Available options: [Unknown, Right, Middle, Left]

status

Indicates the status of the player during the game.

Available options:
Started - Player was in the starting 11
Substituted - Player took part for at least one play during the match and was not in the Starting 11
ActiveNotPlayed - Player was dressed up for the game but did not play
NotActive - Player was not dressed up for the game
Unknown - Player status in not known

Use case: 1014100is part of the home team defensive lineup players. His position is running back and his side is middle. He was part of the starting 11.

Difference from v1: “name” was removed and “status” was introduced.

11. comments

The comments section contains comment objects that contain the text of comment and time when it was entered.

{
  "value": "Tv timeout",
  "utcTimestamp": "2021-06-02T20:31:36.956Z"
}

value

Comment itself

utcTimestamp

Timestamp indicates when comment was entered

Use case: There was a TV timeout.

12. currentPossession

The currentPossession section contains information about the team which is in possession and time when it was last updated.

{
  "value": "Home",
  "utcTimestamp": "2022-05-19T20:31:36.956Z"
}

value

Indicates which team has the possession currently in the match

utcTimestamp

Timestamp indicates when the possession in the match has changed

Use case: The possession of the match now belongs to home team.

13. yardsToEndzone

The yardsToEndzone section contains information about how many yards are from team’s endzone and when this information was last updated.

{
	"yards": 59,
	"team": "Away",
	"lastUpdatedUtc": "2022-05-19T22:04:26.2280028Z",
	"isConfirmed": false
}

yards

Indicates how many yards are left for the team to reach opponent’s endzone

team

Indicates the team who is in possession and needs to reach opponents endzone

lastUpdatedUtc

Timestamp indicates when this information has been updated

isConfirmed

Indicates whether the information is confirmed or not

Use case: Away team is in possession and has 59 yards left to opponents endzone.

14. risks

The risks section contains a list of risks that are important to consider (significant events) for betting purposes.

{
  "touchdown": "NonActive",
  "onsideKick": "NonActive",
  "fieldGoal": "Active",
  "fourthDown": "NonActive",
  "safety": "NonActive",
  "challenge": "NonActive",
  "penalty": "NonActive",
  "videoReview": "NonActive",
  "turnover": "NonActive",
  "other": "NonActive"
}

touchdown

Indicates whether risk of touchdown is active or not. Available options: [Unknown, Active, NonActive]

onsideKick

Indicates whether risk of onside kick is active or not. Available options: [Unknown, Active, NonActive]

fieldGoal

Indicates whether risk of fieldgoal is active or not. Available options: [Unknown, Active, NonActive]

fourthDown

Indicates whether risk of 4th down is active or not. Available options: [Unknown, Active, NonActive]

safety

Indicates whether risk of safety is active or not. Available options: [Unknown, Active, NonActive]

challenge

Indicates whether risk of challenge is active or not. Available options: [Unknown, Active, NonActive]

penalty

Indicates whether risk of penalty is active or not. Available options: [Unknown, Active, NonActive]

videoReview

Indicates whether risk of video review is active or not. Available options: [Unknown, Active, NonActive]

turnover

Indicates whether risk of turnover is active or not. Available options: [Unknown, Active, NonActive]

other

Indicates whether any other risk is active or not. Available options: [Unknown, Active, NonActive]

Use case: In this moment of the match there’s an active risk that the Field Goal will be scored.

15. isPlayUnderReview

isPlayUnderReview property describes if the current play is under review.

"isPlayUnderReview": true

isPlayUnderReview

Indicates whether the current play is under review or not

Use case: Current play is under review.

16. nextPlay

Describes precise enough details of what would be the characteristics of the next play, before it is actually created

{
	"type": "Snap",
	"scrimmageLocation": {
		"scrimmageYard": 41,
		"sideOfPitch": "Away"
	},
	"downNumber": 1,
	"yardsToGo": 10,
	"isConfirmed": true
}

type

Indicates the next play type. Available options: [Kickoff, Snap, Pat]

scrimmageLocation

Indicates where the football will be located (line of scrimmage)

downNumber

Indicates the down number for upcoming play

yardsToGo

Indicates the yards to go in the next play

isConfirmed

Indicates if information about next play is confirmed or not

Use case: Next play potentially will be a Snap play from 41 yard line on away team’s side. It will be the 1st attempt to get through first down line (10 yards).

17. source

The source property describes the source that is providing the feed for Match State. For NFL the following options are available - GeniusPremium, GeniusPremiumReplay,

"source": "GeniusPremium"

source

Indicates the source of this match state.

Use case: Current play is under review.

18. fixtureId

The fixtureId property indicates the id of the mapped source fixture to Genius Sports fixture.

"fixtureId": "1234567"

fixtureId

Indicates the mapped Genius Sports fixture id

Use case: Id of this fixture (match).

19. sequence

The sequence property indicates

"sequence": 12345

sequence

Indicates the sequence number of the feed match events

Use case: Sequence of the latest feed match event.

20. messageTimestampUtc

The messageTimestampUtc property indicates the exact time of this match state message.

"messageTimestampUtc": "2021-06-02T20:31:36.956Z"

messageTimestampUtc

Timestamp of the latest update to match state

Use case: Time when match state was last updated.

21. isReliable

The isReliable property is used to note whether the given match state is reliable or not. This property is a result of the reliabilityReasons statuses.

Reliability is used to indicate that some of the information within the message may be inaccurate and it should not be relied on for purposes where message accuracy is critical.

"isReliable": true

isReliable

Indicates whether the current match state is reliable or not

Use case: Current match state is reliable.

22. isCoverageCancelled

The isCoverageCancelled property is used to note whether the coverage of this match has been cancelled or not.

"isCoverageCancelled": false

isCoverageCancelled

Indicates whether the coverage for this particular match has been cancelled or not

Use case: Coverage for this match has not been cancelled.

23. reliabilityReasons

The reliabilityReasons section contains a list of items considered in order to make an automatic decision whether the match state is reliable or not.

{
  "Heartbeat": "Heartbeat Lost",
  "FeedReliability": "Feed is reliable",
  "Coverage": "Coverage Unknown"
}

Heartbeat

Short description of heartbeat status

FeedReliability

Short description of feed reliability status

Coverage

Short description of the coverage for this match

Use case: The heartbeat for the current match state has been lost, feed is considered reliable and the coverage is unknown.

Schema definitions

  • No labels