Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents

View file
nameV2.json

Ably American Football Match State V2

Introduction

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

Example Ably LiveAccess URL: https://platform.matchstate.api.geniussports.com/api/v1/sources/GeniusPremium/sports/17/fixtures/10173048/liveaccess?sportApiVersion=v2

 IMPORTANT: All enums should be considered as extensible, meaning any additional values beyond the ones explicitly defined should be accepted.

American Football Match State

View file
nameMatchState V2.json

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.

Code Block
languagejson
{
  "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:

View file
namefirstHalf.json

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.

Code Block
languagejson
{
  "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. The flag will always remain false at the drive level based on current behavior. This section will be updated when true becomes a possible value. Please reach out to your Genius representative with any questions.

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:

View file
namedrive.json

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.

Code Block
languagejson
{
  "sequence": 2,
  "downNumber": 1,
  "yardsToGo": 10, 
  "scrimmageLocation": {},
  "snap": {},
  "id": 6,
  "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

id

Play unique identifier

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:

View file
nameplay.json

Relevant information: When a team challenges a play and loses the challenge, they are charged a timeout, in which case the “Description” element will describe the timeout.

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.

Code Block
{
  "teamInPossession": "Home", 
  "type": "OnePoint", 
  "id": "257",
  "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]

id

Play unique identifier

isVoidIndicates

whether this conversion play has been cancelledObsolete identifier

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:

View file
nameconversionPlay.json

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.

Code Block
languagejson
{
	"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, Single (only available for CFL)]

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.

Code Block
{
  "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.

Code Block
{
	"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.

Code Block
{
  "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.

Code Block{

Each action now has a unique id to better identify the actions within a play

Additionally, the yardlines have been added to the match state for many actions so there is more granularity of where that action happened.

Code Block
languagejson
{
                                "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": "TackleRun",
 	"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.

Info Anchorv2_diff_action_typesv2_diff_action_typesDifference 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.

Code Block
{
	"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.

Info Anchorv2_diff_penaltiesv2_diff_penaltiesDifference from v1: New penalty type introduced: “IllegalCut”

1.1.9 players

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

Code Block
{
  "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".

Info Anchorv2_diff_player_typev2_diff_player_typeDifference 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.

Code Block
{
  "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.

Code Block
languagejson
{
	"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.

Code Block
languagejson
			{
				"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.

Code Block
languagejson
{
	"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.

Code Block
languagejson
{
  "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.

Code Block
{
  "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.

Code Block
{
  "clock": "00:04:11",
  "lastUpdatedUtc                            "id": 123
                                "subType": null,
                                "players": [
                                    {
                                        "playerType": "Runner",
                                        "id": "1111275"
                                    }
                                ],
                                "yards": -5,
                                "yardLine": null,
                                "isNullified": false,
                                "activeUnits": {
                                    "home": "Unknown",
                                    "away": "Unknown"
                                }
                            },
                            {
                                "sequence": 2,
                                "team": "Away",
                                "type": "Tackle",
                                "subType": null,
                                "players": [
                                    {
                                        "playerType": "TackleAssister",
                                        "id": "1111265"
                                    },
                                    {
                                        "playerType": "TackleAssister",
                                        "id": "1111314"
                                    }
                                ],
                                "yards": null,
                                "yardLine": {
                                    "yards": 45,
                                    "sideOfPitch": "Away"
                                },
                                "isNullified": false,
                                "activeUnits": {
                                    "home": "Unknown",
                                    "away": "Unknown"
                                }
                            }

sequence

Indicates the sequence of actions within the play

team

Indicates which team made that action

id

Unique action identifier

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, RunAfterCatch, Kneel, PuntBlocked, Lateral, BallBatted, Single (only available for CFL)]

subType

Indicates second level of action description. Available for specific actions and Match State sources
[Fumble - FumbledSnap, FumbledHandOff],
[Return - Advanced, NotAdvanced],
[KickOff - Onside],
[Sack - Tackled, PushedOutOfBounds, RanOutOfBounds]

yards

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

yardline

Indicates where specific action on the field has happened. Available for [Recovery, Fumble, Return, Tackle, OutOfBounds, Muff, Lateral,FairCatch]

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.

Info

Anchor
v2_diff_action_types
v2_diff_action_types
Difference from v1: New action “type” introduced: Muff, Recovery, FieldGoalBlocked, ConversionBlocked, DeadBall, RunAfterCatch, Kneel, PuntBlocked

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, enforcement spot, ball placement spot and penalty yards. Penalties are per play.

Code Block
"penalties": [
                            {
                                "id": "41",
                                "team": "Home",
                                "playerId": "1349458",
                                "type": "HoldingReturn",
                                "outcome": "Accepted",
                                "yards": 2,
                                "yardLines": [
                                    {
                                        "type": "Enforcement",
                                        "yards": 5,
                                        "sideOfPitch": "Home"
                                    },
                                    {
                                        "type": "Placement",
                                        "yards": 3,
                                        "sideOfPitch": "Home"
                                    }
                                ],
                                "enforcementSpot": "OtherSpot",
                                "nextDown": "Unknown",
                                "activeUnits": {
                                    "home": "Unknown",
                                    "away": "Unknown"
                                },
                                "utcTimestamp": "2024-03-07T15:01:58.4716382Z"
                            }

team

Indicates which team was charged with the penalty

playerId

Indicates which player was charged with penalty

type

All possible penalty types: [Unknown, BlockBelowWaist, BlockingOutOfBounds, ChopBlock, Clipping, ContactingTheKicker, CutBlocking, Defensive12OnField, DefensiveDelayOfGame, DefensiveHolding, DefensiveOffside, DefensivePassInterference, DefensiveTooManyMenOnField, DelayOfGame, DelayOfKickoff, DisconcertingSignals, Disqualification, Encroachment, EquipmentViolation, FaceMask, FairCatchInterference, FalseStart, Fighting, Holding, HoldingReturn, HorseCollarTackle, Hurdling, IllegalBat, IllegalBlindsideBlock, IllegalBlock, IllegalBlockAboveTheWaist, IllegalBlockAboveWaist, IllegalBlockAfterFcSignal, IllegalBlockInBack, IllegalBlockOnReturn, IllegalContact, IllegalContactWithSnapper, IllegalCrackback, IllegalCut, IllegalDoubleTeamBlock, IllegalDownfieldOnKick, IllegalFormation, IllegalForwardPass, IllegalInterferenceCover, IllegalInterferenceOnLooseBall, IllegalKickoff, IllegallyKickingBall, IllegalMotion, IllegalParticipation, IllegalPeelback, IllegalPunt, IllegalShift, IllegalSnap, IllegalSubstitution, IllegalTouchKick, IllegalTouchOfKick, IllegalTouchPass, IllegalUseOfHands, IllegalWedge, IneligibleDownfieldKick, IneligibleDownfieldOnPass, IneligibleDownfieldPass, IneligibleReceiver, IntentionalGrounding, InterferenceWithOpportunityToCatch, InvalidFairCatchSignal, KickCatchInterference, KickoffOutOfBounds, Leaping, Leverage, LowBlock, LoweringHeadToInitiateContact, NeutralZoneInfraction, NoYards15, NoYards5, ObjectionableConduct, Offensive12OnField, OffensiveHolding, OffensiveOffside, OffensivePassInterference, OffensiveTooManyMenOnField, Offside, OffsideOnFreeKick, PassInterference, PersonalFoul, PhysicalAbuseOnOfficial, PilingOn, PlayerOutOfBoundsOnKick, PlayerOutOfBoundsOnPunt, ProcedureGeneral, ProcedureIllegalFormation, ProcedureNoEnd, PushBlocking, Pyramiding, ReturnFromOutOfBounds, RoughingHolder, RoughingTheKicker, RoughingThePasser, RoughPlay, RunningIntoHolder, RunningIntoTheKicker, ShortFreeKick, SidelineInterference, Spearing, Targeting, Taunting, TimeCountAfter3MinuteWarningIntentional, TimeCountAfter3MinuteWarningLoss10Yards, TimeCountAfter3MinuteWarningLossDown, TimeCountAfter3MinuteWarningUnintentional, TimeCountBefore3MinuteWarning, TooManyPlayers, Tripping, UnnecessaryRoughness, UnnecessaryRoughnessMajorGrade2, UnsportsmanlikeConduct, OffensiveDisqualification, OffensiveIllegalBat, OffensiveIllegallyKickingBall]

outcome

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

yards

Indicates penalty yards

yardlines

Indicates enforcement and placement yardlines of the penalty if both available.

enforcementSpot

Indicates where the penalty is enforced from. Available options: [Unknown, DeadBall, OtherSpot, PreviousSpot, SuccedingSpot]

nextDown

Indicates if penalty results in firstDown, LossOfDown or down Repeats. Available options: [Unknown, First, Repeats, LossOfDown]

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.

Info

Anchor
v2_diff_penalties
v2_diff_penalties
Difference from v1: New penalty type introduced: “IllegalCut” and more granularity around yardlines and enforcement spot

1.1.9 players

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

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

playerType

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

id

Indicates an id of the to which this player is mapped

Player type

Valid action types

Explanation

Unknown

-

Not used

Tackled

Tackle Sack Fumble

The player that was tackled

Tackler

Tackle Sack Fumble

The player who tackled, in case of Tackle - primary tackler

TackleAssister

Tackle

The player who assisted tackling in the tackle (secondary tackler). Tackle can have two tackle assisters and no tackler

Scorer

Touchdown

The player who scored the points

Receiver

PassAttempt CompletedPass IncompletePass Interception FairCatch ConversionAttempt ConversionMade ConversionMissed Lateral

The player who is the intended receiver for a pass or fair catch. In case of conversions, only for two point conversion when it is passed

Passer

PassAttempt CompletedPass IncompletePass Interception ConversionAttempt ConversionMade ConversionMissed

The player who passed the ball. In case of conversions, only for two point conversion when it is passed

Fumbled

Fumble

The player who fumbled the ball

Recoverer

Recovery Fumble

The player who recovered the ball

Kicker

KickOff Punt FieldGoalAttempt FieldGoalMade FieldGoalBlocked FieldGoalMissed ConversionAttempt ConversionMade ConversionMissed ConversionBlocked

The play who kicked the ball. In case of conversions, only for one point conversion

Runner

Run RunAfterCatch Kneel ConversionAttempt ConversionMade ConversionMissed Fumble

The player who runs with the ball. In case of conversions, only for two point conversion when it is rushed

Returner

Return

The player who attempts to make a return with the ball

Interceptor

Interception

The player who intercepts the pass

Blocker

FieldGoalAttempt FieldGoalBlocked ConversionAttempt ConversionBlocked Punt

PuntBlocked

The player who blocks the kick

QbHitter

PassAttempt CompletedPass IncompletePass Sack

The player/s who hit the quarterback to the ground

PassDefender

PassAttempt IncompletePass

The player/s who earn pass defended on incomplete pass

Muffed

Muff

The player who muffs the catch

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

Info

Anchor
v2_diff_player_type
v2_diff_player_type
Difference from v1: New player types introduced: Interceptor, Blocker, QbHitter, PassDefender, Muffed, TackleAssister (renamed from Assist)

1.1.10 activeUnits

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

Code Block
{
  "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.

Code Block
languagejson
{
	"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.

Code Block
languagejson
			{
				"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.

Code Block
languagejson
{
	"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.

Code Block
languagejson
{
  "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.

Code Block
"challenges": [
        {
            "id": "37",
            "type": "Unknown", "TeamChallenge", "OfficialReview",
            "team": "home", "away", "null",
            "gameTime": int,
            "period": {
                "number": 1,
                "type": "Regular", "Overtime"
            },
            "playId": int,
            "rulingOnField": "string",
            "utcTimestamp": "2024-06-13T13:23:14.8203301Z",
            "result": "Unknown",
            "outcome": "Stands", "Confirmed", "Overturned"
        }

id

Unique id for the challenge/review

type

Indicates if it is a team challenge or official review

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

playId

The play ID for the original play being challenged/reviewed

rulingOnField

A string taken from collection tool on the official ruling made by official

utcTimestamp

Timestamp of the challenge

result

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

outcome

Indicates decision if play stands, confirmed or is overturned. Only overturned means original play will change

Use case: Head coach of away team initiated a challenge when remaining time was 11 minutes and 4 seconds. Outcome of challenge is play stands and play continues. NB: When using GeniusPremium source, result will be unknown, so use outcome to determine if it is won or lost.

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.

Code Block
{
  "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.
Important: Match State messages are not published with every second elapsed on the clock. New Match State message is only published if IsRunning flag in gameTime is updated from true to false or vice versa. Match State is also published if there is an adjustment of the clock value even if isRunning is not updated. Multiple MatchState messages published in a row are expected to have the same values of clock, lastUpdatedUtc and isRunning in gameTime in case the clock keeps ticking down. In order to calculate current clock value shown on the scoreboard when clock is running, you need to subtract lastUpdatedUtc from messageTimestampUtc and then to use the result to subtract from clock value.

6. matchStatus

The matchStatus property reflects the current match status.

Code Block
"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.

Code Block
{
  "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.

Code Block
 "periodWithStatus": {
        "status": "Finished",
        "isConfirmed": true,
        "number": 4,
        "type": "Regular"
    },

status

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

isConfirmed

Indicates if it is confirmed or not

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.

Code Block
{
  "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.

Code Block
{
  "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:

View file
nameLineups - sample.json

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.

Code Block
languagejson
{
	"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, LongSnapper, DefensiveBack, OffensiveLineman, DefensiveLineman]

For CFL there is also available options: [Kickreturner, Nosetackle, Slotback, Puntreturner]

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.

Info

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

11. injuries

The injuries section contains injury objects that contain updates on player injuries during a play, or updates to the player’s injury status given throughout the game.

Code Block
"injuries": [
  {
    "team": (home, away),
    "id": id of the injury,
    "playId": int (nullable),
    "playerId": string,
    "status": "Unknown, Out, Doubtful, Questionable, Probable, Returned"
    "isConfirmed": true,
    "utcTimestamp": "2024-05-21T11:31:19.460Z"
  }

team

Which team the player plays for (home,away)

id

ID for the injury collection

playId

Play ID of the play they were injured during. Can be null if this is just an update to the player’s status not tied to a specific play

playerId

Unique Genius Sports ID for that player

status

Player’s injury status

isConfirmed

Confirmation of injury update

utcTimestamp

UTC time of injury update

Use case: A player was injured on the first play of the game, this message will come through to identify the exact player and their status. Later in the game, that same player has returned to the game and an injury update is sent saying they are “returned” to the game.

12. comments

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

Code Block
{
  "value": "Tv timeout",
  "utcTimestamp": "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.

Code Block
"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.

Code Block
{
  "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.

Code Block
"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.

Code Block
{
  "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.

Code Block
{
  "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:

View file
nameLineups - sample.json

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.

Code Block
languagejson
{
	"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.

Info Anchorv2_diff_lineupsv2_diff_lineupsDifference 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.

Code Block
{
  "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.

Code Block
{
  "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.

Code Block
{
	"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.

Code Block
languagejson
{ "touchdown": "NonActive", "onsideKick": "NonActive", "fieldGoal": "Active", "fourthDown": "NonActive", "safety": "NonActive", "challenge": "NonActive", "penalty

value

Comment itself

utcTimestamp

Timestamp indicates when comment was entered

Use case: There was a TV timeout.

13. currentPossession

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

Code Block
{
  "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.

14. yardsToEndzone

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

Code Block
{
	"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.

15. risks

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

Code Block
languagejson
 "risks": {
        "touchdown": "NonActive",
        "onsideKick": "NonActive",
        "fieldGoal": "NonActive",
        "fourthDown": "NonActive",
        "safety": "NonActive",
        "challenge": "NonActive",
        "penalty": "NonActive",
        "videoReview": "NonActive",
        "turnover": "NonActive",
        "other": "Active",
        "playAboutToStart": "NonActive",
        "injury": "Active",
        "bigPlay": "Active",
        "statDelay": "Active"
    },

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]

playAboutToStart

Indicates that the play is about to start (teams are lining up to begin the play). Available options: [Unknown, Active, NonActive]

other

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

injury

Marked active when there is a potential injured player on a play, either on the offense or defense. Available options: [Unknown, Active, NonActive]

bigPlay

Indicates when a significant change in field position is expected (and potential score). Could be a deep pass downfield, run in the open field, kick return past the coverage team, etc Available options: [Unknown, Active, NonActive]

statDelay

Marked active in the rare event the NFL in-venue statistician has fallen behind when entering live plays. 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.

Code Block
languagejson
 "risks": {
        "touchdown": "NonActive",
        "onsideKick": "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
fieldGoal": "Active",
        "fourthDown": "NonActive",
        "safety": "NonActive",
        "challenge": "NonActive",
        "penalty": "NonActive",
        "videoReview": "NonActive",
        "turnover": "NonActive",
        "other": "NonActive",
        "playAboutToStart": "NonActive"

16. isPlayUnderReview

isPlayUnderReview property describes if the current play is under review.

Code Block
"isPlayUnderReview": true

isPlayUnderReview

Indicates whether the current play is under review or not

Use case: Current play is under review.

16

17. nextPlay

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

Code Block
languagejson
{
	"type": "Snap",
	"scrimmageLocation": {
		"scrimmageYard": 41,
		"sideOfPitch": "Away"
	},
	"downNumber": 1,
	"yardsToGo": 10,
	"isConfirmed": true
    "team": "Home"
}

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

team

Team data: [None, Home, Away]

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

Info

Anchor
v2_diff_nextplay
v2_diff_nextplay
Difference from v1: “team” is introduced to signal which team is going to be in possession in the next play

18. source

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

Code Block
"source": "GeniusPremium"

source

Indicates the source of this match state.

Use case: Current play is under review.

18

19. fixtureId

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

Code Block
"fixtureId": "1234567"

fixtureId

Indicates the mapped Genius Sports fixture id

Use case: Id of this fixture (match).

19

20. sequence

The sequence property indicates

Code Block
"sequence": 12345

sequence

Indicates the sequence number of the feed match events

Use case: Sequence of the latest feed match event.

20

21. messageTimestampUtc

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

Code Block
"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

22. 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.

Code Block
"isReliable": true

isReliable

Indicates whether the current match state is reliable or not

Use case: Current match state is reliable.

22

23. isCoverageCancelled

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

Code Block
"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

24. 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.

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

Heartbeat

Short description of heartbeat status

FeedReliability

Short description of feed reliability status. Some examples:

  • Feed reliable - no issues with feed

  • Clock unreliable - clock has gone down in venue

  • Score unreliable - there is a discrepancy between scoreboard score and score in play by play

  • Close Game - a serious discrepancy is noted by our Live Feed Analysts and marked the feed unreliable to protect customers until issue resolved

  • Backup Clock* - in this case, the feed is still marked as reliable, but the match state has failed over to a backup clock outside of venue to ensure data is still viable

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

Swagger integration
operationsSorteralpha
tagsSorteralpha
{
	"openapi": "3.0.1",
	"info": {
		"title": "Match State API for American Football",
		"version": "2.0"
	},
	"components": {
		"schemas": {
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ActionCancel": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Clock": {
				"required": [
					"clockTime",
					"isRunning"
				],
				"type": "object",
				"properties": {
					"isRunning": {
						"type": "boolean"
					},
					"clockTime": {
						"type": "string",
						"format": "date-span"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"period": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period"
					},
					"winnerTeamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"wasDeferred": {
						"type": "boolean",
						"nullable": true
					},
					"homeTeamChoice": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossChoice"
					},
					"awayTeamChoice": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossChoice"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossActionUpdate": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"winnerTeamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"wasDeferred": {
						"type": "boolean",
						"nullable": true
					},
					"homeTeamChoice": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossChoice"
					},
					"awayTeamChoice": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossChoice"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CoinToss.CoinTossChoice": {
				"enum": [
					"Kick",
					"Receive",
					"EndZone",
					"NorthEndZone",
					"EastEndZone",
					"SouthEndZone",
					"WestEndZone"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CommentAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"text": {
						"type": "string",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.CurrentPossessionAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.DeadBall.DeadBallAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"recoveredBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ExtraPoint.ExtraPointAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playActionId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ExtraPoint.ExtraPointUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.FairCatch.FairCatchAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"receiver": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.FieldGoal.FieldGoalAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playActionId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.FieldGoal.FieldGoalUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Fumble.FumbleAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardLine": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"tackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"secondTackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.GameTimeAction": {
				"required": [
					"gameClock",
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"gameClock": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Clock"
					},
					"playClock": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Clock"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.KickOff.KickoffAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.LineupsAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"homePlayers": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.Player"
						},
						"nullable": true
					},
					"awayPlayers": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.Player"
						},
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.Player": {
				"type": "object",
				"properties": {
					"id": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"position": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.PlayerPosition"
					},
					"status": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.PlayerStatus"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.PlayerPosition": {
				"enum": [
					"Unknown",
					"Quarterback",
					"Runningback",
					"Halfback",
					"Tailback",
					"Fullback",
					"LeftHalfback",
					"RightHalfback",
					"Blockingback",
					"Back",
					"Wingback",
					"WideReceiver",
					"Flanker",
					"SplitEnd",
					"End",
					"TightEnd",
					"LeftEnd",
					"LeftTackle",
					"LeftOffensiveTackle",
					"Tackle",
					"LeftGuard",
					"Guard",
					"Center",
					"RightGuard",
					"RightTackle",
					"RightOffensiveTackle",
					"RightEnd",
					"DefensiveLineman",
					"LeftDefensiveEnd",
					"DefensiveEnd",
					"LeftDefensiveTackle",
					"DefensiveTackle",
					"NoseTackle",
					"MiddleGuard",
					"DefensiveGuard",
					"RightDefensiveTackle",
					"RightDefensiveEnd",
					"LeftOutsideLinebacker",
					"RushLinebacker",
					"OutsideLinebacker",
					"LeftLinebacker",
					"LeftInsideLinebacker",
					"WeakSideLinebacker",
					"InsideLinebacker",
					"StrongSideLinebacker",
					"MiddleLinebacker",
					"RightInsideLinebacker",
					"RightLinebacker",
					"RightOutsideLinebacker",
					"Linebacker",
					"LeftCornerback",
					"Cornerback",
					"RightCornerback",
					"StrongSafety",
					"FreeSafety",
					"LeftDefensiveHalfback",
					"RightDefensiveHalfback",
					"LongSnapper",
					"Safety",
					"RightSafety",
					"Defensiveback",
					"Kicker",
					"Punter",
					"PuntReturner",
					"KickReturner",
					"Returner",
					"OffensiveLineman",
					"OffensiveTackle"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Lineups.PlayerStatus": {
				"enum": [
					"Unknown",
					"Started",
					"Substituted",
					"ActiveNotPlayed",
					"NotActive"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.MatchStatus": {
				"enum": [
					"Unknown",
					"NotStarted",
					"Warmup",
					"InProgress",
					"Postponed",
					"Finished",
					"Interrupted",
					"CoverageStopped",
					"Abandoned",
					"Cancelled",
					"Delayed"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.MatchStatusAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"matchStatus": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.MatchStatus"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Muff.MuffAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"muffedBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardLine": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.NextPlay.NextPlayAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"type": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.NextPlay.PlayType"
					},
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"downNumber": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardsToGo": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.NextPlay.PlayType": {
				"enum": [
					"Snap",
					"Kickoff",
					"Pat"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.OutOfBounds.OutOfBoundsAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"tackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"secondTackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Pass.Direction": {
				"enum": [
					"Left",
					"Middle",
					"Right"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Pass.PassAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"passedBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"direction": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Pass.Direction"
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Pass.PassResult"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"receivedBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"interceptedBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"quarterbackHitBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"passDefendedBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Pass.PassResult": {
				"enum": [
					"Complete",
					"Incomplete",
					"Intercepted",
					"Spike"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Penalty.PenaltyAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Penalty.PenaltyType"
					},
					"outcome": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Penalty.PenaltyOutcome"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Penalty.PenaltyOutcome": {
				"enum": [
					"Unknown",
					"Accepted",
					"Declined",
					"Offsetting",
					"Superseded"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Penalty.PenaltyType": {
				"enum": [
					"Unknown",
					"ChopBlock",
					"Clipping",
					"DefensiveHolding",
					"DefensiveOffside",
					"DefensivePassInterference",
					"Defensive12OnField",
					"DelayOfGame",
					"DelayOfKickoff",
					"Encroachment",
					"FaceMask",
					"FalseStart",
					"IllegalBlockAboveTheWaist",
					"IllegalContact",
					"IllegalCrackback",
					"IllegalFormation",
					"IllegalForwardPass",
					"IllegalMotion",
					"IllegalShift",
					"IllegalSubstitution",
					"IllegalTouchPass",
					"IllegalTouchKick",
					"IllegalUseOfHands",
					"IneligibleDownfieldKick",
					"IneligibleDownfieldPass",
					"IntentionalGrounding",
					"Leaping",
					"Leverage",
					"LowBlock",
					"NeutralZoneInfraction",
					"OffensiveHolding",
					"OffensiveOffside",
					"OffensivePassInterference",
					"Offensive12OnField",
					"RoughingTheKicker",
					"RoughingThePasser",
					"RunningIntoTheKicker",
					"DefensiveDelayOfGame",
					"PlayerOutOfBoundsOnPunt",
					"HorseCollarTackle",
					"UnnecessaryRoughness",
					"UnsportsmanlikeConduct",
					"Taunting",
					"OffsideOnFreekick",
					"Disqualification",
					"InterferenceWithOpportunityToCatch",
					"FairCatchInterference",
					"IllegalBlindsideBlock",
					"Tripping",
					"InvalidFairCatchSignal",
					"IllegalBat",
					"IllegallyKickingBall",
					"KickoffOutOfBounds",
					"IllegalCut"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period": {
				"required": [
					"number",
					"type"
				],
				"type": "object",
				"properties": {
					"number": {
						"type": "integer",
						"format": "int32"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.PeriodType"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.PeriodAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"number": {
						"type": "integer",
						"format": "int32"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.PeriodType"
					},
					"status": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.PeriodStatus"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.PeriodStatus": {
				"enum": [
					"NotStarted",
					"InProgress",
					"Finished"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.PeriodType": {
				"enum": [
					"Regular",
					"Overtime"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Play.KickoffPlayAction": {
				"required": [
					"isConfirmed",
					"period",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"period": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period"
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"isFinished": {
						"type": "boolean"
					},
					"startTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"startGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Play.KickoffPlayUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"isFinished": {
						"type": "boolean"
					},
					"startTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"startGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Play.PatPlayAction": {
				"required": [
					"isConfirmed",
					"period",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"period": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period"
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"isFinished": {
						"type": "boolean"
					},
					"startTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"startGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Play.PatPlayUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"isFinished": {
						"type": "boolean"
					},
					"startTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"startGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Play.SnapPlayAction": {
				"required": [
					"isConfirmed",
					"period",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"period": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period"
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"downNumber": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardsToGo": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isFinished": {
						"type": "boolean"
					},
					"startTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"startGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Play.SnapPlayUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"lineOfScrimmage": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"downNumber": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardsToGo": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isFinished": {
						"type": "boolean"
					},
					"startTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"startGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endTimeUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endGameClock": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.PlayReview.PlayReviewAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"isPlayUnderReview": {
						"type": "boolean",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Punt.PuntAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"kicker": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"blockedBy": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Recovery.RecoveryAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardLine": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"linkedToActionId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Return.ReturnAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardLine": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RisksAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"touchdown": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"onsideKick": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"fieldGoal": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"fourthDown": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"safety": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"challenge": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"penalty": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"videoReview": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"turnover": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"disconnect": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"other": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Risk.RiskStatus": {
				"enum": [
					"Unknown",
					"Active",
					"NonActive"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Rush.RushAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Sack.SackAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"tackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"secondTackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardLine": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"quarterback": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.SackFumble.SackFumbleAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"tackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"secondTackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardLine": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"quarterBack": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Safety.SafetyAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playActionId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Safety.SafetyUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult": {
				"enum": [
					"Missed",
					"Made",
					"Blocked",
					"Failed"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Snap.SnapAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"huddle": {
						"type": "boolean"
					},
					"formation": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Snap.SnapFormation"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Snap.SnapFormation": {
				"enum": [
					"Shotgun",
					"UnderCenter",
					"FieldGoal",
					"Punt",
					"ExtraPoint",
					"TwoPointConversion"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Tackle.TackleAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"tackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"secondTackler": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.TimeoutAction": {
				"required": [
					"isConfirmed",
					"period",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period"
					},
					"gameClock": {
						"type": "string",
						"format": "date-span"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.TimeoutsRemainingAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"homeTimeoutsRemaining": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"awayTimeoutsRemaining": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Period.Period"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Touchback.TouchbackAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Touchdown.TouchdownAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playActionId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.Touchdown.TouchdownUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.TwoPointConversion.TwoPointConversionAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"playActionId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult"
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.TwoPointConversion.TwoPointConversionUpdateAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32"
					},
					"playerId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.ScoringResult"
					},
					"isNullifiedByPenalty": {
						"type": "boolean"
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardLine": {
				"type": "object",
				"properties": {
					"yards": {
						"type": "integer",
						"format": "int32"
					},
					"fieldSideOfTeamId": {
						"type": "integer",
						"format": "int32"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchState.Platform.DataContracts.AmericanFootball.YardsToEndZoneAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"teamId": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchStateFramework.MatchState.Platform.Action.Data.MatchEventDto": {
				"type": "object",
				"properties": {
					"id": {
						"type": "integer",
						"format": "int32"
					},
					"fixtureId": {
						"type": "string",
						"nullable": true
					},
					"sourceId": {
						"type": "string",
						"nullable": true
					},
					"dateRaised": {
						"type": "string",
						"format": "date-time"
					},
					"sequenceId": {
						"type": "integer",
						"format": "int32"
					},
					"actionId": {
						"type": "integer",
						"format": "int32"
					},
					"type": {
						"type": "string",
						"nullable": true
					},
					"data": {
						"type": "string",
						"nullable": true
					},
					"batchId": {
						"type": "string",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchStateFramework.MatchState.Platform.DataContracts.Common.ReliabilityAction": {
				"type": "object",
				"properties": {
					"isReliable": {
						"type": "boolean"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"reason": {
						"maxLength": 200,
						"minLength": 0,
						"type": "string",
						"nullable": true
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.MatchStateFramework.MatchState.Platform.DataContracts.Common.ResetAction": {
				"required": [
					"isConfirmed",
					"utcTimestamp"
				],
				"type": "object",
				"properties": {
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ActionType": {
				"enum": [
					"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"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ActiveUnits": {
				"type": "object",
				"properties": {
					"home": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Unit"
					},
					"away": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Unit"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.AmericanFootballMatchState": {
				"type": "object",
				"properties": {
					"firstHalf": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Half"
					},
					"secondHalf": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Half"
					},
					"overtimePeriods": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Overtime"
						},
						"nullable": true
					},
					"challenges": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Challenge"
						},
						"nullable": true
					},
					"gameTime": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.GameTime"
					},
					"playClock": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.GameTime"
					},
					"matchStatus": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.MatchStatus"
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period"
					},
					"periodWithStatus": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodWithStatus"
					},
					"score": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Score"
					},
					"homeTeam": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Team"
					},
					"awayTeam": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Team"
					},
					"comments": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Comment"
						},
						"nullable": true
					},
					"currentPossession": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CurrentPossession"
					},
					"yardsToEndzone": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.YardsToEndzone"
					},
					"risks": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Risks"
					},
					"isPlayUnderReview": {
						"type": "boolean",
						"nullable": true
					},
					"nextPlay": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.NextPlay"
					},
					"source": {
						"type": "string",
						"nullable": true
					},
					"fixtureId": {
						"type": "string",
						"nullable": true
					},
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"messageTimestampUtc": {
						"type": "string",
						"format": "date-time"
					},
					"isReliable": {
						"type": "boolean"
					},
					"isCoverageCancelled": {
						"type": "boolean"
					},
					"reliabilityReasons": {
						"type": "object",
						"properties": {
							"Heartbeat": {
								"type": "string"
							},
							"FeedReliability": {
								"type": "string"
							},
							"Coverage": {
								"type": "string"
							}
						},
						"additionalProperties": false,
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Challenge": {
				"type": "object",
				"properties": {
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"gameTime": {
						"type": "string",
						"format": "date-span"
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					},
					"result": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ChallengeResult"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ChallengeResult": {
				"enum": [
					"Unknown",
					"Won",
					"Lost"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CoinToss": {
				"type": "object",
				"properties": {
					"winnerTeam": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"wasDeferred": {
						"type": "boolean",
						"nullable": true
					},
					"awayChoice": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CoinTossChoice"
					},
					"homeChoice": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CoinTossChoice"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CoinTossChoice": {
				"enum": [
					"Kick",
					"Receive",
					"EndZone",
					"NorthEndZone",
					"EastEndZone",
					"SouthEndZone",
					"WestEndZone"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Comment": {
				"type": "object",
				"properties": {
					"value": {
						"type": "string",
						"nullable": true
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ConversionPlay": {
				"type": "object",
				"properties": {
					"teamInPossession": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ConversionType"
					},
					"isVoid": {
						"type": "boolean"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"isFinished": {
						"type": "boolean"
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period"
					},
					"actions": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayAction"
						},
						"nullable": true
					},
					"penalties": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Penalty"
						},
						"nullable": true
					},
					"startedAtGameTime": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endedAtGameTime": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"startedAtUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endedAtUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ConversionType": {
				"enum": [
					"Unknown",
					"OnePoint",
					"TwoPoints"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CurrentPossession": {
				"type": "object",
				"properties": {
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"lastUpdatedUtc": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Drive": {
				"type": "object",
				"properties": {
					"teamInPossession": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"isKickOff": {
						"type": "boolean",
						"nullable": true
					},
					"plays": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Play"
						},
						"nullable": true
					},
					"conversionPlays": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ConversionPlay"
						},
						"nullable": true
					},
					"score": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScoreInfo"
						},
						"nullable": true
					},
					"isFinished": {
						"type": "boolean"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.GameTime": {
				"type": "object",
				"properties": {
					"clock": {
						"type": "string",
						"format": "date-span"
					},
					"lastUpdatedUtc": {
						"type": "string",
						"format": "date-time"
					},
					"isRunning": {
						"type": "boolean"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Half": {
				"type": "object",
				"properties": {
					"drives": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Drive"
						},
						"nullable": true
					},
					"timeouts": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TimeOut"
						},
						"nullable": true
					},
					"timeoutsRemaining": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TimeoutsRemaining"
					},
					"coinToss": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CoinToss"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.LineupPlayer": {
				"type": "object",
				"properties": {
					"id": {
						"type": "string",
						"nullable": true
					},
					"position": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayerPosition"
					},
					"side": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PositionSide"
					},
					"status": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayerStatus"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.MatchStatus": {
				"enum": [
					"Unknown",
					"NotStarted",
					"Warmup",
					"InProgress",
					"Postponed",
					"Finished",
					"Interrupted",
					"CoverageStopped",
					"Abandoned",
					"Cancelled",
					"Delayed"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.NextPlay": {
				"type": "object",
				"properties": {
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayType"
					},
					"scrimmageLocation": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScrimmageLocation"
					},
					"downNumber": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardsToGo": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isConfirmed": {
						"type": "boolean"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Overtime": {
				"type": "object",
				"properties": {
					"period": {
						"type": "integer",
						"format": "int32"
					},
					"drives": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Drive"
						},
						"nullable": true
					},
					"timeouts": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TimeOut"
						},
						"nullable": true
					},
					"timeoutsRemaining": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TimeoutsRemaining"
					},
					"coinToss": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.CoinToss"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Penalty": {
				"type": "object",
				"properties": {
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"playerId": {
						"type": "string",
						"nullable": true
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PenaltyType"
					},
					"outcome": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PenaltyOutcome"
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"activeUnits": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ActiveUnits"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PenaltyOutcome": {
				"enum": [
					"Unknown",
					"Accepted",
					"Declined",
					"Offsetting",
					"Superseded"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PenaltyType": {
				"enum": [
					"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"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period": {
				"type": "object",
				"properties": {
					"number": {
						"type": "integer",
						"format": "int32"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodType"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodStatus": {
				"enum": [
					"NotStarted",
					"InProgress",
					"Finished"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodType": {
				"enum": [
					"Regular",
					"Overtime"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodWithStatus": {
				"type": "object",
				"properties": {
					"status": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodStatus"
					},
					"number": {
						"type": "integer",
						"format": "int32"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PeriodType"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Play": {
				"type": "object",
				"properties": {
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"downNumber": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"yardsToGo": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"scrimmageLocation": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScrimmageLocation"
					},
					"snap": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Snap"
					},
					"isVoid": {
						"type": "boolean"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"isFinished": {
						"type": "boolean"
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period"
					},
					"actions": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayAction"
						},
						"nullable": true
					},
					"penalties": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Penalty"
						},
						"nullable": true
					},
					"startedAtGameTime": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"endedAtGameTime": {
						"type": "string",
						"format": "date-span",
						"nullable": true
					},
					"startedAtUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"endedAtUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"description": {
						"type": "string",
						"nullable": true
					},
					"sourcePlayId": {
						"type": "string",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayAction": {
				"type": "object",
				"properties": {
					"sequence": {
						"type": "integer",
						"format": "int32"
					},
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ActionType"
					},
					"players": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Player"
						},
						"nullable": true
					},
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"isNullified": {
						"type": "boolean",
						"nullable": true
					},
					"activeUnits": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ActiveUnits"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Player": {
				"type": "object",
				"properties": {
					"playerType": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayerType"
					},
					"id": {
						"type": "string",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayerPosition": {
				"enum": [
					"Unknown",
					"Kicker",
					"Punter",
					"Returner",
					"RunningBack",
					"Fullback",
					"WideReceiver",
					"TightEnd",
					"Tackle",
					"Guard",
					"Quarterback",
					"Center",
					"End",
					"Linebacker",
					"Cornerback",
					"Safety",
					"Holder"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayerStatus": {
				"enum": [
					"Unknown",
					"Started",
					"Substituted",
					"ActiveNotPlayed",
					"NotActive"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayerType": {
				"enum": [
					"Unknown",
					"Tackled",
					"Tackler",
					"Scorer",
					"Assist",
					"Receiver",
					"Passer",
					"OutOfBounds",
					"Fumbled",
					"Fumbler",
					"Recoverer",
					"Kicker",
					"Runner",
					"Returner",
					"Interceptor",
					"Blocker",
					"QbHitter",
					"PassDefender",
					"Muffed"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PlayType": {
				"enum": [
					"Kickoff",
					"Snap",
					"Pat"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.PositionSide": {
				"enum": [
					"Unknown",
					"Right",
					"Middle",
					"Left"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Risks": {
				"type": "object",
				"properties": {
					"touchdown": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"onsideKick": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"fieldGoal": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"fourthDown": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"safety": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"challenge": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"penalty": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"videoReview": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"turnover": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					},
					"other": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.RiskStatus": {
				"enum": [
					"Unknown",
					"Active",
					"NonActive"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Score": {
				"type": "object",
				"properties": {
					"home": {
						"type": "integer",
						"format": "int32"
					},
					"away": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScoreInfo": {
				"type": "object",
				"properties": {
					"period": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period"
					},
					"type": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScoreType"
					},
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"points": {
						"type": "integer",
						"format": "int32"
					},
					"isConfirmed": {
						"type": "boolean"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScoreType": {
				"enum": [
					"Touchdown",
					"OnePointConversion",
					"TwoPointConversion",
					"FieldGoal",
					"Safety",
					"OnePointSafety"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.ScrimmageLocation": {
				"type": "object",
				"properties": {
					"scrimmageYard": {
						"type": "integer",
						"format": "int32"
					},
					"sideOfPitch": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Snap": {
				"type": "object",
				"properties": {
					"isConfirmed": {
						"type": "boolean"
					},
					"timestampUtc": {
						"type": "string",
						"format": "date-time"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Team": {
				"type": "object",
				"properties": {
					"offensive": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.LineupPlayer"
						},
						"nullable": true
					},
					"defensive": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.LineupPlayer"
						},
						"nullable": true
					},
					"special": {
						"type": "array",
						"items": {
							"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.LineupPlayer"
						},
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide": {
				"enum": [
					"None",
					"Home",
					"Away"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TimeOut": {
				"type": "object",
				"properties": {
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"gameTime": {
						"type": "string",
						"format": "date-span"
					},
					"period": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Period"
					},
					"utcTimestamp": {
						"type": "string",
						"format": "date-time"
					},
					"isConfirmed": {
						"type": "boolean"
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TimeoutsRemaining": {
				"type": "object",
				"properties": {
					"away": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"home": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.Unit": {
				"enum": [
					"Unknown",
					"Defensive",
					"Offensive",
					"Special"
				],
				"type": "string",
				"format": "x-extensible-enum"
			},
			"GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.YardsToEndzone": {
				"type": "object",
				"properties": {
					"yards": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"team": {
						"$ref": "#/components/schemas/GeniusSports.Sports.AmericanFootball.Contracts.V2.MatchState.TeamSide"
					},
					"lastUpdatedUtc": {
						"type": "string",
						"format": "date-time",
						"nullable": true
					},
					"isConfirmed": {
						"type": "boolean",
						"nullable": true
					}
				},
				"additionalProperties": false
			},
			"Microsoft.AspNetCore.Mvc.ProblemDetails": {
				"type": "object",
				"properties": {
					"type": {
						"type": "string",
						"nullable": true
					},
					"title": {
						"type": "string",
						"nullable": true
					},
					"status": {
						"type": "integer",
						"format": "int32",
						"nullable": true
					},
					"detail": {
						"type": "string",
						"nullable": true
					},
					"instance": {
						"type": "string",
						"nullable": true
					}
				},
				"additionalProperties": {}
			}
		},
	}
}