An imaginary, but delightful Museum API for interacting with museum services and information. Built by Redocly for educational purposes. Enjoy!
Note
This OpenAPI description uses the OpenAPI 3.1.0 specification.
Introducing the "Museum API", which offers a set of endpoints to interact with a museum's services--such as retrieving museum hours, managing special events, and purchasing tickets.
New functionality may be added to the Museum API in the future. Is there an example you'd like to see? Please open an issue.
Note
Reminder that this is a fictional example for learning purposes. The features below are only for learning.
The Museum API has the following core features (sorted by tags):
- Operations
- Get museum operational hours
- Special events
- Get special event data
- List special events
- Create and update a special event
- Delete a special event
- Tickets
- Purchase museum tickets for general entry or special events
- Get scannable QR code for museum ticket
- Clone this repo.
- Open the repo in your IDE.
- Run
npm install
to install the Redocly CLI.
We encourage you to explore the museum's OpenAPI description and make changes. Try experimenting with the following approaches:
Preview the museum's API docs and observe your changes visually.
- Run
npm run preview
to preview the documentation. - Navigate to the List special events operation in the preview.
- With the preview running...
- Go to the openapi.yaml file in your IDE.
- Search for
listSpecialEvents
to find the matchingoperationId
. - Replace the
description
field with the snippet below:
description: |-
Return a list of _upcoming_ special events at the museum.
See one you like? Use this API to [buy a ticket](/#tag/Tickets/operation/buyMuseumTickets).
See the updated description? This is a great way to preview how end-users of your docs will experience your changes.
Lint your changes to the OpenAPI description using Redocly CLI.
- Open the museum's openapi.yaml file in your IDE.
- Add the following snippet to
paths
above the /museum-hours operation:
/example:
get:
summary: Example Summary
description: Example description
responses:
'200':
description: Success
'400':
description: Bad Request
- Run
npm run lint
in your terminal. See the errors?
The linting behavior is controlled by the redocly.yaml configuration file. The linter is configured to use Redocly's recommended ruleset, which are built into the CLI. However, we also added a configurable rule for enforcing sentence casing on operation summaries.