Skip to content

questionlp/api.wwdt.me_v2

Repository files navigation

Wait Wait Don't Tell Me! Stats API v2.0

Overview

The Stats API is written in Python and is built on FastAPI and provides endpoints that can be used to query guest, host, location, panelist, scorekeeper, and show data from a copy of the Wait Wait Don't Tell Me! Stats database.

If you're looking for the version 1.0 of the API, check out the api.wwdt.me repository.

Requirements

  • Python 3.8 or newer
  • MySQL or MariaDB Server hosting a version of the aforementioned Wait Wait Don't Tell Me! Stats database

Changes from v1.0

Stats API v2.0 not only brings a significant change on web frameworks, migrating from Flask to FastAPI, but also breaks compatibility with v1.0 and in terms of API documentation.

For additional details on the breaking changes that the new version brings, refer to the API-CHANGES.md document. The document details the new API response object format, changes in API endpoints, and migrating to OpenAPI-based documentation.

Known Issues

OpenAPI 3.0 Specification and Response Models

The application makes significant use of Optional, Union, and Tuple types in the properties for the various response models. This is a necessity due to the way objects are built and returned from wwdtm. Unfortunately, OpenAPI 3.0, the version of the specification that FastAPI supports, does not provide analogs for those types in its specification.

This issue doesn't come up when querying the API through Swagger UI or directly using Postman; but, if you've imported the generated OpenAPI JSON into Postman, then run queries and/or tests, it will result in warnings and/or errors being reported about type mismatches (i.e.: returns null instead of a string).

Installation

Refer to INSTALLING.md for information on how to set up an instance of this web application that can be served through Gunicorn and NGINX.

Code of Conduct

This projects follows version 2.1 of the Contributor Convenant's Code of Conduct. A copy of the Code of Conduct document is included in this repository.

License

This web application is licensed under the terms of the Apache License 2.0.