This is the OpenGameData dataset/file repository API.
Its primary use is for getting information about what data is available from the fileserver used by data.opengamedata.io, but could be used for any repository of datasets using the OpenGameData pipeline.
The latest release of the API supports the endpoints listed below.
Broadly speaking, the file API has a 3-level hierarchy for retrieving information about games and their datasets.
- Games: The top-level entity is a game. Each game has an ID and is associated with one or more datasets.
- Datasets: The term "dataset" refers to all data for a specific month of play from a specific game. For any given dataset, the actual data in that "set" may include game events, post-hoc "detector" events, session-level features, player-level features, or population-level features.
- Files: A "file" contains actual data of one type from a dataset.
-
/gamesRetrieve a list of all games for which at least one dataset exists.
Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games
{ "type": "GET", "val": { "game_ids": ["AQUALAB", "BACTERIA", "BALLOON", ...] }, "msg": "SUCCESS: Retrieved list of games with available datasets" } -
/games/<game_id>Retrieve a summary of the game and its datasets
Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/AQUALAB
response = { "type": "GET", "val": { "game_id": "AQUALAB", "dataset_count": 57, "session_average": 1234, "initial_dataset": "2021-04-11 00:00:00" }, "msg": "SUCCESS: Retrieved monthly game usage" }
-
/games/detailsRetrieve summaries of all games for which at least one dataset exists.
Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/details
response = { "type": "GET", "val": { "AQUALAB": { "game_id": "AQUALAB", "dataset_count": 57, "session_average": 1234, "initial_dataset": "2021-04-11 00:00:00" }, "AQUALAB": { "game_id": "BACTERIA", "dataset_count": 42, "session_average": 543, "initial_dataset": "2021-01-10 00:00:00" }, }, "msg": "SUCCESS: Retrieved list of games with available datasets" }
-
/games/<game_id>/datasetsRetrieve a list of datasets and associated session counts for a specific game.
Approximately equivalent to the
/MonthlyGameUsagelegacy endpoint. However, the legacy endpoint includes additional entries for non-existent datasets that lie within the range of all extant datasets, with the session counts set to 0.Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/AQUALAB/datasets
response = { "type": "GET", "val": { "game_id": "AQUALAB", "datasets": [ ... {"year": 2025, "month": 9, "total_sessions": 4908, "sessions_file": ..., "players_file": ..., "population_file": ...}, {"year": 2025, "month": 10, "total_sessions": 4763, ...}, {"year": 2025, "month": 11, "total_sessions": 5339, ...} ] }, "msg": "SUCCESS: Retrieved monthly game usage" }
-
/games/<game_id>/datasets/<year>Retrieve a list of datasets and associated session counts for a specific game within a specific month. Roughly equivalent to the
/games/<game_id>/datasets/endpoint, but scoped to a single year.Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/AQUALAB/datasets/2023
response = { "type": "GET", "val": { "game_id": "AQUALAB", "datasets": [ {"year": 2023, "month": 1, "total_sessions": 2013, "sessions_file": ..., "players_file": ..., "population_file": ...}, {"year": 2023, "month": 2, "total_sessions": 17, ...}, {"year": 2023, "month": 3, "total_sessions": 8605, ...} ... ] }, "msg": "SUCCESS: Retrieved monthly game usage" }
-
/games/<game_id>/datasets/<year>/<month>Get detailed info on the files and other resources that are available for a specific dataset. This is roughly equivalent to the
/getGameFileInfoByMonthlegacy endpoint.Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/AQUALAB/datasets/2023/01
-
/games/<game_id>/datasets/<year>/<month>/manifest(experimental)Get a full "dataset manifest" for the given dataset. This includes details about events and features included in the dataset.
Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/AQUALAB/datasets/2023/01/manifest
-
/games/<game_id>/datasets/<month>/<year>/<file_type>Retrieve the contents of a specific dataset file. Valid
file_types arepopulation,player, andsession.This is only recommended for applications that need direct access to dataset file contents. Local downloads should be obtained through the URLs provided in the other dataset endpoints.
Future releases may add support for requesting event file contents.
Example:
curl https://ogd-staging.fielddaylab.wisc.edu/apis/files/main/games/AQUALAB/datasets/2023/01/player
Steps to run:
- Ensure you have Python and pip installed in your development environment.
- (optional) From the project root folder, run
python -m venv .venvto create the.venvdirectory that will contain the virtual environment. - (optional) Activate the environment with
source .venv/bin/activateon Mac/Linux, or.venv/Scripts/activateon Windows. - From the app's root directory run
pip install -r requirements.txtto ensure you have Flask and other dependencies installed for the app.- If you are performing local development, you should instead run
pip install -e ./
- If you are performing local development, you should instead run
- Copy
config/config.py.templatetosrc/config.pyto create a config. Updateconfig.pyconfiguration values as needed. - Enter the source folder with
cd srcand then runpython -m flask run, or optionally include the--debugflag. - A web server should begin running at
http://localhost:5000