Skip to main content

Documentation Index

Fetch the complete documentation index at: https://docs.oddspapi.io/llms.txt

Use this file to discover all available pages before exploring further.

What it streams

Metadata for a given fixtureId — including match status, start times, participants, and tournament/sport info. Also includes optional scores and mapped provider IDs. This is the anchor stream used to map odds/scores to a real-world fixture.

Routing

  • Entity key: payload.fixtureId
  • Filters: sportIds, tournamentIds, fixtureIds
  • Access: live/pregame determined by your apiKey

Payload fields

FieldTypeDescription
fixtureIdstringUnique ID of the fixture
statusobjectMatch status info
status.livebooleanTrue if currently live
status.statusIdnumber | nullOptional status code
status.statusNamestring | nullStatus name (e.g. “Live”, “Postponed”)
sportobjectSport metadata
sport.sportIdnumberUnique sport ID
sport.sportNamestringSport name
tournamentobjectTournament metadata
tournament.tournamentIdnumberUnique tournament ID
tournament.tournamentNamestringTournament name
tournament.categoryNamestringGeographic/organizational category
seasonobjectSeason metadata
season.seasonIdnumber | nullSeason ID (nullable)
season.seasonNamestring | nullSeason name
season.seasonRoundnumber | nullRound/matchday number within the season
venueobjectVenue metadata
venue.venueIdnumber | nullVenue ID
venue.venueNamestring | nullVenue name (translated)
venue.venueLocationstring | nullVenue location (translated)
startTimenumberScheduled start (epoch seconds UTC)
trueStartTimestring | nullActual start time (ISO 8601)
trueEndTimestring | nullActual end time (ISO 8601)
participantsobjectCompetitor metadata
participants.participant1IdnumberTeam/player 1 ID
participants.participant1NamestringTeam/player 1 name
participants.participant1ShortNamestring | nullShort name (e.g. “Hawks”)
participants.participant1Abbrstring | nullOptional abbreviation
participants.participant1RotNrnumber | nullOptional rotation number
participants.participant2IdnumberTeam/player 2 ID
participants.participant2NamestringTeam/player 2 name
participants.participant2ShortNamestring | nullShort name (e.g. “Heat”)
participants.participant2Abbrstring | nullOptional abbreviation
participants.participant2RotNrnumber | nullOptional rotation number
scoresobjectOptional score object (same format as scores stream)
clockobject | nullLive match clock data
clock.currentPeriodstring | nullCurrent period (e.g. “p2”)
clock.currentTimestring | nullCurrent match time
clock.remainingTimestring | nullRemaining time in match
clock.remainingTimeInPeriodstring | nullRemaining time in current period
clock.stoppedboolean | nullWhether the clock is stopped
expectedPeriodsnumber | nullNumber of scheduled periods (e.g. halves/sets/quarters)
periodLengthnumber | nullPeriod duration in minutes
externalProvidersobjectMapped provider IDs
externalProviders.betradarIdnumber | nullBetradar fixture ID
externalProviders.flashscoreIdstring | nullFlashscore ID
externalProviders.pinnacleIdnumber | nullPinnacle fixture ID
externalProviders.sofascoreIdnumber | nullSofascore ID
externalProviders.oddinIdnumber | nullOddin ID
externalProviders.mollybetIdstring | nullMollybet ID
externalProviders.opticoddsIdstring | nullOpticodds ID
externalProviders.lsportsIdnumber | nullLSports ID
externalProviders.txoddsIdnumber | nullTXOdds ID

Example message (JSON)

{
  "channel": "fixtures",
  "type": "UPDATE",
  "payload": {
    "fixtureId": "id1100013270505056",
    "status": {
      "live": true,
      "statusId": 1,
      "statusName": "Live"
    },
    "sport": {
      "sportId": 11,
      "sportName": "Basketball"
    },
    "tournament": {
      "tournamentId": 132,
      "tournamentName": "NBA",
      "categoryName": "USA"
    },
    "season": {
      "seasonId": 131631,
      "seasonName": "NBA 25/26",
      "seasonRound": null
    },
    "venue": {
      "venueId": 6054,
      "venueName": "Madison Square Garden",
      "venueLocation": "New York, NY, USA"
    },
    "startTime": 1776729600,
    "trueStartTime": "2026-04-21T00:09:08+00:00",
    "trueEndTime": null,
    "participants": {
      "participant1Id": 3421,
      "participant1RotNr": 303,
      "participant1Name": "New York Knicks",
      "participant1ShortName": "New York",
      "participant1Abbr": "NYK",
      "participant2Id": 3423,
      "participant2RotNr": 302,
      "participant2Name": "Atlanta Hawks",
      "participant2ShortName": "Atlanta",
      "participant2Abbr": "ATL"
    },
    "scores": {
      "p1": {
        "period": "p1",
        "participant1Score": 32,
        "participant2Score": 23,
        "updatedAt": "2026-04-21T00:59:42.287458+00:00"
      },
      "p2": {
        "period": "p2",
        "participant1Score": 29,
        "participant2Score": 31,
        "updatedAt": "2026-04-21T01:25:05.532295+00:00"
      },
      "result": {
        "period": "result",
        "participant1Score": 61,
        "participant2Score": 54,
        "updatedAt": "2026-04-21T01:24:37.154297+00:00"
      }
    },
    "clock": {
      "currentPeriod": null,
      "currentTime": null,
      "remainingTime": null,
      "remainingTimeInPeriod": null,
      "stopped": null
    },
    "expectedPeriods": 4,
    "periodLength": 12,
    "externalProviders": {
      "betgeniusId": 13808265,
      "betradarId": 70505056,
      "flashscoreId": "nTPkYS3K",
      "mollybetId": "2026-04-21,29093,29096",
      "oddinId": null,
      "opticoddsId": "20260421A1AB4678",
      "pinnacleId": 1628730839,
      "sofascoreId": 15935017,
      "lsportsId": null,
      "txoddsId": null
    },
    "bookmakers": {}
  },
  "ts": 1776729608000,
  "entryId": "1776729608000-4273"
}

Example: fixture update that includes a scores.result

Some fixture updates include a scores object (for example, a pre-game or result snapshot).
{
  "channel": "fixtures",
  "type": "UPDATE",
  "payload": {
    "fixtureId": "id1000070367118324",
    "status": {
      "live": true,
      "statusId": 1,
      "statusName": "Live"
    },
    "sport": {
      "sportId": 10,
      "sportName": "Soccer"
    },
    "tournament": {
      "tournamentId": 703,
      "tournamentName": "Primera Nacional",
      "categoryName": "Argentina"
    },
    "season": {
      "seasonId": 138218,
      "seasonName": "Primera Nacional 2026",
      "seasonRound": 10
    },
    "venue": {
      "venueId": 12720,
      "venueName": "Estadio Don Leon Kolbovsky",
      "venueLocation": "Buenos Aires, Argentina"
    },
    "startTime": 1776729600,
    "trueStartTime": "2026-04-21T00:06:06.546877+00:00",
    "trueEndTime": null,
    "participants": {
      "participant1Id": 53799,
      "participant1RotNr": 210458,
      "participant1Name": "CA Atlanta",
      "participant1ShortName": "Atlanta",
      "participant1Abbr": "ATL",
      "participant2Id": 3214,
      "participant2RotNr": 210457,
      "participant2Name": "Chacarita Juniors",
      "participant2ShortName": "Chacarita Juniors",
      "participant2Abbr": "CAC"
    },
    "scores": {
      "p1": {
        "period": "p1",
        "participant1Score": 0,
        "participant2Score": 0,
        "updatedAt": "2026-04-21T00:55:10.401457+00:00"
      },
      "result": {
        "period": "result",
        "participant1Score": 1,
        "participant2Score": 0,
        "updatedAt": "2026-04-21T01:13:15.757548+00:00"
      }
    },
    "clock": {
      "currentPeriod": null,
      "currentTime": null,
      "remainingTime": null,
      "remainingTimeInPeriod": null,
      "stopped": null
    },
    "expectedPeriods": 2,
    "periodLength": 45,
    "externalProviders": {
      "betgeniusId": 13767372,
      "betradarId": 67118324,
      "flashscoreId": null,
      "mollybetId": "2026-04-21,10097858,10097878",
      "oddinId": null,
      "opticoddsId": "202604183517C8A7",
      "pinnacleId": 1628328116,
      "sofascoreId": 15275552,
      "lsportsId": null,
      "txoddsId": null
    },
    "bookmakers": {}
  },
  "ts": 1776729666000,
  "entryId": "1776729666000-4278"
}