Skip to content
This repository has been archived by the owner on Nov 16, 2023. It is now read-only.

Latest commit

 

History

History
44 lines (26 loc) · 3.12 KB

swagger-style-cheatsheet.md

File metadata and controls

44 lines (26 loc) · 3.12 KB

Swagger spec style guide

Less style guide and more "cheat sheet," the following sections describe which fields or content are currently supported by docs.microsoft.com, the toolchain, and the Swagger/OpenAPI specification.

This document will be updated as features and support are added to the toolchain and docs.microsoft.com. As more features and support are added, this will become more of a style guide.

Documentation field support by object type

Not all Swagger documentation fields (summary, description, title) are supported by all Swagger object types. This is an OpenAPI specification restriction, not a docs.ms.com or toolchain restriction. The following table specifies which fields can be used for which object types in a Swagger *.json.

Object type summary description title
operation X X
parameter X
schema object X X
  • summary and title fields are appropriate for short-form documentation of 120 characters or less.
  • description is for long-form content, and can contain examples of use ("examples" in this context should not to be confused with the examples field).

GitHub-flavored Markdown (GFM)

GitHub-flavored Markdown (GFM) is not yet fully* supported in the description field.

* The Swagger specification itself supports GFM in the description field of several object types, as does OPS. However, AutoRest currently passes through GFM formatting tags directly, so **my bolded text** (including the asterisks) will end up in your generated clients' docs. Don't use GFM in Swagger spec descriptions yet.

HTML

Do not put HTML tags in any of the documentation fields.

examples field

You should populate the examples field for operation responses.

Format it as valid JSON (i.e. don't stuff it all into a string with \ns) and it'll be rendered as the raw JSON response object on docs. For an example, see the Monitor REST API reference

Overwrites

Not all fields support overwrites. For example, only the summary and description fields of a Swagger spec can be overwritten in REST API documentation. See the DocFx documentation for lists of which fields can be overwritten: