- Created by Martin Kuks on Jul 05, 2022
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": {} }
| Contains the array of drives happened in this half of the match. |
| Contains the array of timeouts that either home or away team took during this half |
| Contains the number of how many timeouts remained for both home and away teams at this half |
| 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 }
| Indicates which team was in possession of this drive. Possible options: [None, Away, Home] |
| Indicates whether this drive was a kickoff or not |
| Contains the array of plays happened during this drive |
| Contains information about any conversion play happened during this drive |
| Contains the array of scoring events happened during this drive |
| 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" }
| Indicates the number of attempt team is conducting during the drive |
| Indicates the number of attempt (out of 4) the team to cross the first down line |
| Indicates the yards the team has remaining to go till the first down line |
| Indicates the location of football from where the play is started |
| Indicates whether the play has been started and the ball has been snapped |
| Indicates whether the play has been cancelled |
| Indicates if the play with all its actions has been confirmed |
| Indicates if the play has ended |
| Contains information which period is it in a match when this play was happening |
| Contains all the actions that belong to this specific play |
| Contains a list of penalties that happened during this specific play |
| Indicates at what time of the game this play has started |
| Indicates at what time of the game this play has ended |
| Timestamp indicates the exact time when this play has started |
| Timestamp indicates the exact time when this play has ended |
| Play description |
| 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" }
| Indicates which team is in possession of this conversion play |
| Indicates the type of the conversion play. Available options: [Unknown, OnePoint, TwoPoints] |
| Indicates whether this conversion play has been cancelled |
| Indicates if the conversion play with all its actions has been confirmed |
| Indicates if the conversion play has ended |
| Contains information which period is it in a match when this conversion play was happening |
| Contains all the actions that belong to this specific conversion play |
| Contains a list of penalties that happened during this specific conversion play |
| Indicates at what time of the game this conversion play has started |
| Indicates at what time of the game this conversion play has ended |
| Timestamp indicates the exact time when this conversion play has started |
| Timestamp indicates the exact time when this conversion play has ended |
| Conversion play description |
| 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" }
| Contains information about the period this scoring action happened |
| Indicates the type of the scoring play. Available options: [Touchdown, OnePointConversion, TwoPointConversion, FieldGoal, Safety, OnePointSafety] |
| Indicates the team who scored. Available options: [None, Home, Away] |
| Indicates how many points the team gained |
| Indicates if it is confirmed or not |
| 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" }
| Indicates the yard line where the football is placed at the start of the play |
| 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" }
| Indicates the number of the quarter |
| 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" } }
| Indicates the sequence of actions within the play |
| Indicates which team made that action |
| 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] |
| Indicates the amount of yards gained or lost (it’s shown or not depending on the action). |
| Indicates whether this action was nullified (for example by penalty) |
| 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" }
| Indicates which team was charged with the penalty |
| Indicates which player was charged with penalty |
| 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] |
| Indicates the outcome of the penalty. Available options: [Unknown, Accepted, Declined, Offsetting, Superseded] |
| Indicates penalty yards |
| Currently not provided |
| 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" }
| 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] |
| 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 }
| Indicates which team took the timeout |
| Indicates game time at what the timeout was taken |
| Indicates the period when the timeout was taken |
| Timestamp indicates exact time of the timeout |
| 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 }
| Indicates how many timeouts are left for the away team in the half |
| 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" }
| Indicates the team who won the coin toss |
| Indicates whether the winner team decided to defer or not |
| Indicates the away team choice. Available options: [Kick, Receive, EndZone, NorthEndZone, EastEndZone, SouthEndZone, WestEndZone] |
| 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": {} }
| Indicates which overtime period it is |
| Contains the array of drives happened in this overtime |
| Contains the array of timeouts that either home or away team took during this overtime period |
| Contains the number of how many timeouts remained for both home and away teams at this overtime period |
| 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" }
| Indicates the team whose coach initiated the challenge |
| Indicates the game time when the challenge was initiated |
| Indicates the period in which the challenge was initiated |
| Timestamp of the challenge |
| 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 }
| Reflects the game clock |
| Timestamp of the latest game clock value update |
| 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"
| 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" }
| Indicates the number of the quarter |
| 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" }
| Indicates the status of the period. Available options: [NotStarted, InProgress, Finished] |
| Indicates the number of the quarter |
| 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 }
| Indicates how many points has the home team scored in the whole match |
| Indicates how many points has the away team scored in the whole match |
| 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": [{}] }
| Contains the list of offensive players for either home or away team |
| Contains the list of defensive players for either home or away team |
| 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" }
| Indicates an Unique id of the player |
| 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] |
| Indicates the side of the player. Available options: [Unknown, Right, Middle, Left] |
| Indicates the status of the player during the game. Available options: |
Use case: 1014100
is 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" }
| Comment itself |
| 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" }
| Indicates which team has the possession currently in the match |
| 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 }
| Indicates how many yards are left for the team to reach opponent’s endzone |
| Indicates the team who is in possession and needs to reach opponents endzone |
| Timestamp indicates when this information has been updated |
| 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" }
| Indicates whether risk of touchdown is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of onside kick is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of fieldgoal is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of 4th down is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of safety is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of challenge is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of penalty is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of video review is active or not. Available options: [Unknown, Active, NonActive] |
| Indicates whether risk of turnover is active or not. Available options: [Unknown, Active, NonActive] |
| 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
| 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 }
| Indicates the next play type. Available options: [Kickoff, Snap, Pat] |
| Indicates where the football will be located (line of scrimmage) |
| Indicates the down number for upcoming play |
| Indicates the yards to go in the next play |
| 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"
| 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"
| Indicates the mapped Genius Sports fixture id |
Use case: Id of this fixture (match).
19. sequence
The sequence property indicates
"sequence": 12345
| 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"
| 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
| 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
| 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" }
| Short description of heartbeat status |
| Short description of feed reliability status |
| 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