From 63a5d3e91ca0e37298e766b3ed5167d27af20bcd Mon Sep 17 00:00:00 2001 From: tang-mm Date: Thu, 19 May 2022 19:36:18 +0800 Subject: [PATCH 1/7] add API reference templates and guide --- .../v2/api-reference-endpoint-template.md | 85 ++++++++ api-reference/v2/api-reference-guide.md | 203 ++++++++++++++++++ .../v2/api-reference-overview-template.md | 64 ++++++ .../v2/api-reference-resource-template.md | 27 +++ 4 files changed, 379 insertions(+) create mode 100644 api-reference/v2/api-reference-endpoint-template.md create mode 100644 api-reference/v2/api-reference-guide.md create mode 100644 api-reference/v2/api-reference-overview-template.md create mode 100644 api-reference/v2/api-reference-resource-template.md diff --git a/api-reference/v2/api-reference-endpoint-template.md b/api-reference/v2/api-reference-endpoint-template.md new file mode 100644 index 00000000..7ad6445f --- /dev/null +++ b/api-reference/v2/api-reference-endpoint-template.md @@ -0,0 +1,85 @@ +# {Endpoint name} + +{Provide a one-line description of what the API does. Starts with a verb.} + +## Endpoint + +```bash +{METHOD} /{request_url}/{{path_parameter}} +``` + +## Description + +This endpoint ... + +{This paragraph is optional.} This endpoint has been deprecated. Use {the recommended endpoint} instead. For more information about how to migrate to {the recommended endpoint}, see [{the migration guide}](link). + +{This paragraph is optional.} The maximum number of calls to this API endpoint is {xx} per minute. For more information about API rate limiting/throttling, see [{the topic}](example). + + +## Authorization + +The {authorization method} is required for each API request. + +(Optional) Calling this endpoint also requires the {xx} permission. + + +## Request schema + +### Path parameters + +{This section is optional.} + +| Path parameter | Type | Required/Optional | Description | Notes | +|----------------|--------|-------------------|--------------------------|-----| +| {Id} | string | Required | Unique identifier of {}. | | +| {name} | string | Optional | Name of {}. | | +| | | | | | + +### Query parameters + +{This section is optional.} + +| Query parameter | Type | Required/Optional | Description | Notes | +|-----------------|------|-------------------|-------------|-------| +| | | | | | + + +### Header parameters + +{This section is optional.} + +| Header parameter | Type | Required/Optional | Description | Notes | +|------------------|------|-------------------|-------------|-------| +| | | | | | + +### Request body + +{This section is optional.} + +| Field | Type | Required/Optional | Description | Notes | +|-------|------|-------------------|-------------|-------| +| | | | | | + + +## Request example + +``` + + +``` + +## Response schema + +If the request succeeds, this endpoint returns {one of the following options: +* a {data} in the response body in the {content type} format. +* a 200 status code with no response body. +} + +Otherwise, this endpoint returns {[xx errors](link_to_error_list)}. + +## Response example + +``` + +``` diff --git a/api-reference/v2/api-reference-guide.md b/api-reference/v2/api-reference-guide.md new file mode 100644 index 00000000..0459d056 --- /dev/null +++ b/api-reference/v2/api-reference-guide.md @@ -0,0 +1,203 @@ +# API References Guide + +Read this document before you start working on the API references template. + +- _Document version_: 0.0.1 +- _Last updated_: May 19, 2022 + +## Overview + +Assuming that your API documentation set includes references of many API endpoints that are organized into groups, this template includes three parts: + +- The [API reference overview section](#about-the-api-reference-overview-section) provides reference information for the whole API documentation set. It describes product-wise API specifications, such as protocol, authorization method, versioning, status code, etc. +- The [API resource reference section](#about-the-api-resource-reference-section) provides reference information for a subset of API endpoints that are grouped around a resource type. It describes resource-wise API specifications, such as the data model of the resource. +- The [API endpoint reference section](#about-the-api-endpoint-reference-section) + provides reference information for a specific API endpoint. It describes the specifications of an API endpoint, such as the method, URL, request, and response schema. + +## Before writing the API references + +- Familiarize yourself with the API protocol. If possible, try making some API calls in a testing environment. +- Interact with your API developers to learn about the APIs that you are documenting. Understand the data models and the logical connections between the API endpoints. +- Discuss the logic of grouping the API endpoints. Although grouping the endpoints by resource type is a common practice, as used in this template, it is also possible to group them by use case or other characteristics that better suit the user's needs. +- Conduct some user research about how the audience of your documentation would use the APIs. Identify the programming languages that your audience would most likely adopt to interact with your APIs. +- Explore the possibility of auto-generating the API references. + +## About the API reference overview section + +### About the "Introduction" section + +Use this section to provide a high-level overview of your API set, including the main features, communication protocol, content types, organization, etc. + +### About the "Base URL" section + +Base URL is a common segment to which the API endpoint paths are appended. Defining the base URL in this section reduces the effort to duplicate the segment in each endpoint reference. + +The base URL may differ for different groups of users or in different environments. If multiple base URLs are available, list them in this section and clearly describe the conditions of using each of them. + + +### About the "Authorization" section + +Use this section to specify the authentication and authorization requirements of using the APIs, including the authorization type, request schema, possible error codes, and examples. + +Tips: + +- This section should only describe the technical specifications of the API authorization, such as parameters and token expiration. Details of how to authenticate should be documented in a separate how-to guide and be referred to as a link here. +- Provide an example of the authorization request or command. You can use random strings to replace the actual secrets. +- If there is more than one authorization type applicable to your APIs, describe and specify the use case of each. If one of the options is preferred, highlight it. +- If different permission levels apply to different API endpoints, document the requirements in the reference for that endpoint. + + +### About the "Versioning" section + +This section is optional. If applicable, use this section to describe the versioning, compatibility, and lifecycle policies of your API set. If migration guides are available, provide the links here. + + +### About the "Pagination" section + +This section is optional. If applicable, use this section to describe the options and default values for dividing long API responses into pages. + + +### About the "Rate limiting and throttling" section + +This section is optional. If applicable, use this section to describe the global rate limiting settings and quota of your APIs. If different quota applies to different endpoints, also add this section in the reference for endpoints. + + +### About the "Status code" section + +Tips: + +- For REST APIs, HTTP status codes are used. If you are writing references for other protocols, adjust the table columns. +- In the `Description` column, describe the causes of that error, and provide related information or links about how to deal with the error. + +### Additional sections + +If other specifications are applicable to the whole API set, such as data conventions, request retry logic, logging, monitoring, and so on, define your own sections at the end of this document. + + +## About the API resource reference section + +The template assumes that the API endpoints are grouped by the resource type that they are interacting with. + +**Title** + +Substitute the document title `{Resource Name}` with the actual name. + +**Short description** + +Provide a one-line definition of the resource in the opening section and explain how and when your users should use it. + +### About the "Data model" section + +Use this section to describe each attribute of the resource entity in the table. Use the `Notes` column to provide additional information such as whether the attribute has default values, validation restrictions, and whether it is a non-editable field that cannot be updated with POST requests. If a cell is empty, fill in “N/A” or “/”. + +### About the "Example" section + +Provide a concrete example of the data entity with valid values. Fill in as many optional attributes as possible. + +Use fenced code blocks (a pair of three backticks ` ``` `) to make your code distinctive from other text blocks. + +Many Markdown processors also support syntax highlighting, which adds color to keywords. Indicate the language mode of your example after the opening backticks to take advantage of this feature. For example: ` ```json `. The displayed color schema depends on your processor and the rendering configurations. + +### About the "Endpoints" section + +List the endpoints that can interact with this resource type in the table: + +- Capitalize the method names. +- Adopt a consistent naming convention for the APIs. In most cases, the naming convention used in the documentation is consistent with the one in the source code. +- Add a link to each of the endpoint names that directs users to the corresponding endpoint reference. +- For endpoints that are deprecated but still in use, add a note in the “Description” column. Consider using the strikethrough format (a pair of two tildes ~~) to indicate the deprecation status. + + +## About the API endpoint reference section + +**Title** + +Substitute the document title `{Endpoint Name}` with the actual name. + +Tips: + +- Typically the name of an API endpoint consists of the operation type and the resource type. For example, an API endpoint that creates a User resource can be named as `Create user`. +- As in the API resource reference, the naming convention should be consistent throughout your API documentation. +- Use the singular form of the resource name unless the endpoint is designed exclusively for a bulk operation, such as `List users`. + +**Short description** + +Provide a one-line description of what the API does. Starts with a verb. For example: + +- For "get" operations: `Returns a {resource}.` +- For "list" operations: `Returns a list of {resources}.` +- For "create" operations: `Creates a {resource}.` or `Inserts a {resource}.` +- For "update" operations: `Updates a {resource}.` +- For "delete" operations: `Removes a {resource}.` + +Ensure that the description here is consistent with that listed in the resource reference. + +### About the "Endpoint" section + +Use this section to define the API endpoint. + +Tips: + +- Use fenced code blocks (a pair of three backticks ` ``` `) to make your code distinctive from other text blocks. +- Replace {METHOD} with the actual request method and capitalize all letters. For example, `POST`. +- In the {request_url} segment, start with a slash character `/` and only provide the URL path (the segment after the hostname). The base URL can be omitted if you already document it in the API overview. For example, `/v2/users`. +- If the {request_url} contains path variables, use a placeholder to indicate the variable name. The format of placeholders should be consistent throughout the documentation set and conform to your organization’s guidelines. As an option, you can use snake case characters in curly brace `{}`, delimited by underscores. For example, `{user_id}`. +- Optionally use a different color to make the path parameters easily identifiable. +- Do not add slash characters `/` at the end. + +### About the "Description" section + +Use this section to provide more information on what the endpoint does, the purpose, and use cases of this API endpoint. + +Optionally add notes about the API versioning information, API limit, deprecation status, and whether a replacement is available. If they are not applicable, remove the paragraphs. + +### About the "Authorization" section + +Provide a link to the common `Authorization` section in the API reference overview. + +If calling the endpoint requires additional user roles or permissions, document them in this section. + +### About the "Request schema" section + +Use this section to define the specifications of the endpoint. + +Each of the sub-sections is optional and should be adopted according to the actual endpoint definition: + +- **Path parameters**: parameters defined within the path of the endpoint, denoted by placeholders. +- **Query parameters**: appended to the end of the request URL, after a question mark `?`. Parameters and their assigned values are connected by an equal sign `=`. Multiple query parameters are delimited by an and sign `&`. +- **Header parameters**: often the same across endpoints in an API set. Include this section only when specific header parameters are required for this endpoint. +- **Request body**: only applicable for requests using methods that permit a payload, such as POST, PUT, and PATCH. Include a link to the description of the resource type if applicable. + +If no parameters or request body can be sent in the request, specify "None" in this section. + +Tips: + +- In each of the tables, keep the parameter name the same as what is presented in the endpoint section above. +- In the `Required/Optional` column, specify "Required" or "Optional" to avoid ambiguity. +- In the `Type` column, if the data type has detailed definitions in another place, provide the link. +- In the `Description` column, start the description with a noun and omit the articles (the/a/an). No need to write "defines/specifies". +- Use the `Notes` column to provide additional information such as default values, minimum/maximum values, usage restrictions, and valid enum values. +- Do not leave cells empty in the table. If there is no content, fill in with “N/A” or “/”. + + +### About the "Request example" section + +Use this section to provide an example that is complete and correct. The request should include the base URL, endpoint, headers, parameters, and request body. It should show as many parameter configurations as possible. Preferable, the example could be copy-pasted directly into your user's environment and return the expected result. + +Tips: + +- If you have several parameters for different use cases, especially when then parameters can not be used together, consider providing multiple request examples. +- The recommended format for your example is `cURL` request. Depending on the business needs, you can add request samples in multiple programming languages, which can be generated by external tools. Do user research in advance to determine what languages should be adopted. Meanwhile, you should also consider the additional maintenance effort when you add more examples. +- Match the sample request and parameters to the exact response the user would receive with those same parameters. +- Use fenced code blocks (a pair of three backticks ` ``` `) to make your code distinctive from other text blocks. + +### About the "Response schema" section + +Use this section to describe the content type and data model that are returned in the response, in both successful and failed cases: + +- For successful requests, provide the content format. +- For failed requests, provide the possible error code and the link to the error description. + +### About the "Response example" section + +Use this section to provide an example of the response body if any, or clearly state that “the response body is empty”. diff --git a/api-reference/v2/api-reference-overview-template.md b/api-reference/v2/api-reference-overview-template.md new file mode 100644 index 00000000..551d5956 --- /dev/null +++ b/api-reference/v2/api-reference-overview-template.md @@ -0,0 +1,64 @@ +# API reference overview + +{Before using this template, read [the accompanying guide](api-reference-guide.md) to this template}. + +## Introduction + +The {product name} APIs are REST APIs that provides {xx features}. + +## Base URL + +The APIs referenced in this documentation use the following base URL: + +``` +https://api.example.com +``` + + +## Authorization + +All requests to the API must be authenticated and authorized before they can access or manage resources on the {environment or platform}. + +The {product name} API uses the **{auth_type}** authorization type. + +You can authenticate your requests by {using authentication type and method}. + +For example: + +``` + +``` + + +API requests without valid authentication will fail with a status of {error code}. + + +## Versioning + +{This section is optional.} + +The {product name} APIs provide {x} versions of API endpoints... + +## Pagination + +{This section is optional.} + +You can use {xx} to paginate the results returned by the {product name} APIs. If not specified, the default values are ... + +## Rate limiting and throttling + +{This section is optional.} + +The {product name} APIs use a {xx} rate limiting strategy. The maximum number of requests allowed to access a {resource/endpoint/..} is {xx} requests per {time period}. + +If the number of requests exceeds that limit, an HTTP `429 Too Many Request` error is returned. + +## Status code + +The {product name} APIs use standard HTTP response codes. + +| Status code | Message | Description | +|-------------|-------------------|---------------| +| 200 `OK` | Request succeeds. | {description} | +| | | | +| | | | \ No newline at end of file diff --git a/api-reference/v2/api-reference-resource-template.md b/api-reference/v2/api-reference-resource-template.md new file mode 100644 index 00000000..139e3879 --- /dev/null +++ b/api-reference/v2/api-reference-resource-template.md @@ -0,0 +1,27 @@ +# {Resource name} + +The {resource name} is used to {xxx}. + +## Data model + +| Attribute | Type | Required/Optional | Description | Notes | +|-----------|------|-------------------|-------------|-------| +| | | | | | +| | | | | | +| | | | | | + +## Example + +``` + +``` + +## Endpoints + +Use the following endpoints to interact with the {resource name} entities. + +| Method | Endpoint name | Description | +|--------|-----------------------------------------|-----------------------| +| POST | {[Endpoint name A](link_to_endpoint_a)} | Creates a {resource}. | +| GET | {[Endpoint name B](link_to_endpoint_b)} | Returns a {resource}. | +| | | | From ddbcd4be974af81e2a3d86c26e681ed484a9918e Mon Sep 17 00:00:00 2001 From: tang-mm Date: Thu, 19 May 2022 19:54:53 +0800 Subject: [PATCH 2/7] move template sections into one file --- .../v2/api-reference-endpoint-template.md | 85 --------- .../v2/api-reference-overview-template.md | 64 ------- .../v2/api-reference-resource-template.md | 27 --- api-reference/v2/api-reference-template.md | 179 ++++++++++++++++++ 4 files changed, 179 insertions(+), 176 deletions(-) delete mode 100644 api-reference/v2/api-reference-endpoint-template.md delete mode 100644 api-reference/v2/api-reference-overview-template.md delete mode 100644 api-reference/v2/api-reference-resource-template.md create mode 100644 api-reference/v2/api-reference-template.md diff --git a/api-reference/v2/api-reference-endpoint-template.md b/api-reference/v2/api-reference-endpoint-template.md deleted file mode 100644 index 7ad6445f..00000000 --- a/api-reference/v2/api-reference-endpoint-template.md +++ /dev/null @@ -1,85 +0,0 @@ -# {Endpoint name} - -{Provide a one-line description of what the API does. Starts with a verb.} - -## Endpoint - -```bash -{METHOD} /{request_url}/{{path_parameter}} -``` - -## Description - -This endpoint ... - -{This paragraph is optional.} This endpoint has been deprecated. Use {the recommended endpoint} instead. For more information about how to migrate to {the recommended endpoint}, see [{the migration guide}](link). - -{This paragraph is optional.} The maximum number of calls to this API endpoint is {xx} per minute. For more information about API rate limiting/throttling, see [{the topic}](example). - - -## Authorization - -The {authorization method} is required for each API request. - -(Optional) Calling this endpoint also requires the {xx} permission. - - -## Request schema - -### Path parameters - -{This section is optional.} - -| Path parameter | Type | Required/Optional | Description | Notes | -|----------------|--------|-------------------|--------------------------|-----| -| {Id} | string | Required | Unique identifier of {}. | | -| {name} | string | Optional | Name of {}. | | -| | | | | | - -### Query parameters - -{This section is optional.} - -| Query parameter | Type | Required/Optional | Description | Notes | -|-----------------|------|-------------------|-------------|-------| -| | | | | | - - -### Header parameters - -{This section is optional.} - -| Header parameter | Type | Required/Optional | Description | Notes | -|------------------|------|-------------------|-------------|-------| -| | | | | | - -### Request body - -{This section is optional.} - -| Field | Type | Required/Optional | Description | Notes | -|-------|------|-------------------|-------------|-------| -| | | | | | - - -## Request example - -``` - - -``` - -## Response schema - -If the request succeeds, this endpoint returns {one of the following options: -* a {data} in the response body in the {content type} format. -* a 200 status code with no response body. -} - -Otherwise, this endpoint returns {[xx errors](link_to_error_list)}. - -## Response example - -``` - -``` diff --git a/api-reference/v2/api-reference-overview-template.md b/api-reference/v2/api-reference-overview-template.md deleted file mode 100644 index 551d5956..00000000 --- a/api-reference/v2/api-reference-overview-template.md +++ /dev/null @@ -1,64 +0,0 @@ -# API reference overview - -{Before using this template, read [the accompanying guide](api-reference-guide.md) to this template}. - -## Introduction - -The {product name} APIs are REST APIs that provides {xx features}. - -## Base URL - -The APIs referenced in this documentation use the following base URL: - -``` -https://api.example.com -``` - - -## Authorization - -All requests to the API must be authenticated and authorized before they can access or manage resources on the {environment or platform}. - -The {product name} API uses the **{auth_type}** authorization type. - -You can authenticate your requests by {using authentication type and method}. - -For example: - -``` - -``` - - -API requests without valid authentication will fail with a status of {error code}. - - -## Versioning - -{This section is optional.} - -The {product name} APIs provide {x} versions of API endpoints... - -## Pagination - -{This section is optional.} - -You can use {xx} to paginate the results returned by the {product name} APIs. If not specified, the default values are ... - -## Rate limiting and throttling - -{This section is optional.} - -The {product name} APIs use a {xx} rate limiting strategy. The maximum number of requests allowed to access a {resource/endpoint/..} is {xx} requests per {time period}. - -If the number of requests exceeds that limit, an HTTP `429 Too Many Request` error is returned. - -## Status code - -The {product name} APIs use standard HTTP response codes. - -| Status code | Message | Description | -|-------------|-------------------|---------------| -| 200 `OK` | Request succeeds. | {description} | -| | | | -| | | | \ No newline at end of file diff --git a/api-reference/v2/api-reference-resource-template.md b/api-reference/v2/api-reference-resource-template.md deleted file mode 100644 index 139e3879..00000000 --- a/api-reference/v2/api-reference-resource-template.md +++ /dev/null @@ -1,27 +0,0 @@ -# {Resource name} - -The {resource name} is used to {xxx}. - -## Data model - -| Attribute | Type | Required/Optional | Description | Notes | -|-----------|------|-------------------|-------------|-------| -| | | | | | -| | | | | | -| | | | | | - -## Example - -``` - -``` - -## Endpoints - -Use the following endpoints to interact with the {resource name} entities. - -| Method | Endpoint name | Description | -|--------|-----------------------------------------|-----------------------| -| POST | {[Endpoint name A](link_to_endpoint_a)} | Creates a {resource}. | -| GET | {[Endpoint name B](link_to_endpoint_b)} | Returns a {resource}. | -| | | | diff --git a/api-reference/v2/api-reference-template.md b/api-reference/v2/api-reference-template.md new file mode 100644 index 00000000..1109ed95 --- /dev/null +++ b/api-reference/v2/api-reference-template.md @@ -0,0 +1,179 @@ +# API reference overview + +{Before using this template, read [the accompanying guide](api-reference-guide.md) to this template}. + +## Introduction + +The {product name} APIs are REST APIs that provides {xx features}. + +## Base URL + +The APIs referenced in this documentation use the following base URL: + +``` +https://api.example.com +``` + + +## Authorization + +All requests to the API must be authenticated and authorized before they can access or manage resources on the {environment or platform}. + +The {product name} API uses the **{auth_type}** authorization type. + +You can authenticate your requests by {using authentication type and method}. + +For example: + +``` + +``` + + +API requests without valid authentication will fail with a status of {error code}. + + +## Versioning + +{This section is optional.} + +The {product name} APIs provide {x} versions of API endpoints... + +## Pagination + +{This section is optional.} + +You can use {xx} to paginate the results returned by the {product name} APIs. If not specified, the default values are ... + +## Rate limiting and throttling + +{This section is optional.} + +The {product name} APIs use a {xx} rate limiting strategy. The maximum number of requests allowed to access a {resource/endpoint/..} is {xx} requests per {time period}. + +If the number of requests exceeds that limit, an HTTP `429 Too Many Request` error is returned. + +## Status code + +The {product name} APIs use standard HTTP response codes. + +| Status code | Message | Description | +|-------------|-------------------|---------------| +| 200 `OK` | Request succeeds. | {description} | +| | | | +| | | | + +# {Resource name} + +The {resource name} is used to {xxx}. + +## Data model + +| Attribute | Type | Required/Optional | Description | Notes | +|-----------|------|-------------------|-------------|-------| +| | | | | | +| | | | | | +| | | | | | + +## Example + +``` + +``` + +## Endpoints + +Use the following endpoints to interact with the {resource name} entities. + +| Method | Endpoint name | Description | +|--------|-----------------------------------------|-----------------------| +| POST | {[Endpoint name A](link_to_endpoint_a)} | Creates a {resource}. | +| GET | {[Endpoint name B](link_to_endpoint_b)} | Returns a {resource}. | +| | | | + + +# {Endpoint name} + +{Provide a one-line description of what the API does. Starts with a verb.} + +## Endpoint + +```bash +{METHOD} /{request_url}/{{path_parameter}} +``` + +## Description + +This endpoint ... + +{This paragraph is optional.} This endpoint has been deprecated. Use {the recommended endpoint} instead. For more information about how to migrate to {the recommended endpoint}, see [{the migration guide}](link). + +{This paragraph is optional.} The maximum number of calls to this API endpoint is {xx} per minute. For more information about API rate limiting/throttling, see [{the topic}](example). + + +## Authorization + +The {authorization method} is required for each API request. + +(Optional) Calling this endpoint also requires the {xx} permission. + + +## Request schema + +### Path parameters + +{This section is optional.} + +| Path parameter | Type | Required/Optional | Description | Notes | +|----------------|--------|-------------------|--------------------------|-----| +| {Id} | string | Required | Unique identifier of {}. | | +| {name} | string | Optional | Name of {}. | | +| | | | | | + +### Query parameters + +{This section is optional.} + +| Query parameter | Type | Required/Optional | Description | Notes | +|-----------------|------|-------------------|-------------|-------| +| | | | | | + + +### Header parameters + +{This section is optional.} + +| Header parameter | Type | Required/Optional | Description | Notes | +|------------------|------|-------------------|-------------|-------| +| | | | | | + +### Request body + +{This section is optional.} + +| Field | Type | Required/Optional | Description | Notes | +|-------|------|-------------------|-------------|-------| +| | | | | | + + +## Request example + +``` + + +``` + +## Response schema + +If the request succeeds, this endpoint returns {one of the following options: +* a {data} in the response body in the {content type} format. +* a 200 status code with no response body. +} + +Otherwise, this endpoint returns {[xx errors](link_to_error_list)}. + +## Response example + +``` + +``` From a0a42fccb6b940b41dccd53dab50a9f388f9abb8 Mon Sep 17 00:00:00 2001 From: tang-mm Date: Thu, 19 May 2022 19:56:11 +0800 Subject: [PATCH 3/7] fix format issues --- api-reference/v2/api-reference-guide.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/api-reference/v2/api-reference-guide.md b/api-reference/v2/api-reference-guide.md index 0459d056..0a076d6e 100644 --- a/api-reference/v2/api-reference-guide.md +++ b/api-reference/v2/api-reference-guide.md @@ -94,9 +94,9 @@ Use this section to describe each attribute of the resource entity in the table. Provide a concrete example of the data entity with valid values. Fill in as many optional attributes as possible. -Use fenced code blocks (a pair of three backticks ` ``` `) to make your code distinctive from other text blocks. +Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. -Many Markdown processors also support syntax highlighting, which adds color to keywords. Indicate the language mode of your example after the opening backticks to take advantage of this feature. For example: ` ```json `. The displayed color schema depends on your processor and the rendering configurations. +Many Markdown processors also support syntax highlighting, which adds color to keywords. Indicate the language mode of your example after the opening backticks to take advantage of this feature. For example: `` ```json ``. The displayed color schema depends on your processor and the rendering configurations. ### About the "Endpoints" section @@ -105,7 +105,7 @@ List the endpoints that can interact with this resource type in the table: - Capitalize the method names. - Adopt a consistent naming convention for the APIs. In most cases, the naming convention used in the documentation is consistent with the one in the source code. - Add a link to each of the endpoint names that directs users to the corresponding endpoint reference. -- For endpoints that are deprecated but still in use, add a note in the “Description” column. Consider using the strikethrough format (a pair of two tildes ~~) to indicate the deprecation status. +- For endpoints that are deprecated but still in use, add a note in the “Description” column. Consider using the strikethrough format (a pair of two tildes `~~`) to indicate the deprecation status. ## About the API endpoint reference section @@ -138,7 +138,7 @@ Use this section to define the API endpoint. Tips: -- Use fenced code blocks (a pair of three backticks ` ``` `) to make your code distinctive from other text blocks. +- Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. - Replace {METHOD} with the actual request method and capitalize all letters. For example, `POST`. - In the {request_url} segment, start with a slash character `/` and only provide the URL path (the segment after the hostname). The base URL can be omitted if you already document it in the API overview. For example, `/v2/users`. - If the {request_url} contains path variables, use a placeholder to indicate the variable name. The format of placeholders should be consistent throughout the documentation set and conform to your organization’s guidelines. As an option, you can use snake case characters in curly brace `{}`, delimited by underscores. For example, `{user_id}`. @@ -189,7 +189,7 @@ Tips: - If you have several parameters for different use cases, especially when then parameters can not be used together, consider providing multiple request examples. - The recommended format for your example is `cURL` request. Depending on the business needs, you can add request samples in multiple programming languages, which can be generated by external tools. Do user research in advance to determine what languages should be adopted. Meanwhile, you should also consider the additional maintenance effort when you add more examples. - Match the sample request and parameters to the exact response the user would receive with those same parameters. -- Use fenced code blocks (a pair of three backticks ` ``` `) to make your code distinctive from other text blocks. +- Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. ### About the "Response schema" section From 1395980c1808176091f7d1b6d9fc36e273cb8060 Mon Sep 17 00:00:00 2001 From: tang-mm Date: Mon, 27 Jun 2022 10:06:47 +0800 Subject: [PATCH 4/7] update files per workshop comments --- api-reference/v2/api-reference-guide.md | 96 ++++++++++++---------- api-reference/v2/api-reference-template.md | 69 +++++++++------- 2 files changed, 92 insertions(+), 73 deletions(-) diff --git a/api-reference/v2/api-reference-guide.md b/api-reference/v2/api-reference-guide.md index 0a076d6e..8747cf83 100644 --- a/api-reference/v2/api-reference-guide.md +++ b/api-reference/v2/api-reference-guide.md @@ -1,70 +1,75 @@ -# API References Guide +# API reference guide -Read this document before you start working on the API references template. +This `api-reference-guide` document provides extra writing tips describing **HOW** to fill in each of the sections within the [`api-reference-template`](api-reference-template.md) file. - _Document version_: 0.0.1 -- _Last updated_: May 19, 2022 +- _Last updated_: June 27, 2022 ## Overview -Assuming that your API documentation set includes references of many API endpoints that are organized into groups, this template includes three parts: +API references are technical manuals that provide the specifications and integration instructions of APIs. An accurate, concise, well-structured API documentation facilitates the adoption of APIs and increases the overall user experience. -- The [API reference overview section](#about-the-api-reference-overview-section) provides reference information for the whole API documentation set. It describes product-wise API specifications, such as protocol, authorization method, versioning, status code, etc. -- The [API resource reference section](#about-the-api-resource-reference-section) provides reference information for a subset of API endpoints that are grouped around a resource type. It describes resource-wise API specifications, such as the data model of the resource. -- The [API endpoint reference section](#about-the-api-endpoint-reference-section) - provides reference information for a specific API endpoint. It describes the specifications of an API endpoint, such as the method, URL, request, and response schema. +The [`api-reference-template`](api-reference-template.md) is designed to help you build the API documentation efficiently and keep it consistent in both format and appearance. ## Before writing the API references -- Familiarize yourself with the API protocol. If possible, try making some API calls in a testing environment. +- Familiarize yourself with the API protocol. If possible, try making some API calls in a testing environment. This API reference template works best with the REST API protocol. If you are working with other protocols, you may need to adjust the organization of some sections. - Interact with your API developers to learn about the APIs that you are documenting. Understand the data models and the logical connections between the API endpoints. - Discuss the logic of grouping the API endpoints. Although grouping the endpoints by resource type is a common practice, as used in this template, it is also possible to group them by use case or other characteristics that better suit the user's needs. - Conduct some user research about how the audience of your documentation would use the APIs. Identify the programming languages that your audience would most likely adopt to interact with your APIs. - Explore the possibility of auto-generating the API references. +- Optimize the visual presentation of the API references by applying customized stylesheet, such as using syntax highlighting, table of contents, multi-column layout, etc. + +## Document structure + +Assuming that your API documentation set includes references of many API endpoints that are organized into groups, this template includes three parts: + +- The [API reference overview section](#about-the-api-reference-overview-section) provides reference information for the whole API documentation set. It describes product-wise API specifications, such as protocol, authorization method, versioning, status code, etc. +- The [API resource reference section](#about-the-api-resource-reference-section) provides reference information for a subset of API endpoints that are grouped around a resource type. It describes resource-wise API specifications, such as the data model of the resource. +- The [API endpoint reference section](#about-the-api-endpoint-reference-section) + provides reference information for a specific API endpoint. It describes the specifications of an API endpoint, such as the method, URL, request, and response schema. ## About the API reference overview section -### About the "Introduction" section +### "Introduction" section Use this section to provide a high-level overview of your API set, including the main features, communication protocol, content types, organization, etc. -### About the "Base URL" section +### "Base URL" section Base URL is a common segment to which the API endpoint paths are appended. Defining the base URL in this section reduces the effort to duplicate the segment in each endpoint reference. The base URL may differ for different groups of users or in different environments. If multiple base URLs are available, list them in this section and clearly describe the conditions of using each of them. - -### About the "Authorization" section +### "Authorization" section Use this section to specify the authentication and authorization requirements of using the APIs, including the authorization type, request schema, possible error codes, and examples. -Tips: +**Tips**: - This section should only describe the technical specifications of the API authorization, such as parameters and token expiration. Details of how to authenticate should be documented in a separate how-to guide and be referred to as a link here. - Provide an example of the authorization request or command. You can use random strings to replace the actual secrets. - If there is more than one authorization type applicable to your APIs, describe and specify the use case of each. If one of the options is preferred, highlight it. - If different permission levels apply to different API endpoints, document the requirements in the reference for that endpoint. - -### About the "Versioning" section +### "Versioning" section This section is optional. If applicable, use this section to describe the versioning, compatibility, and lifecycle policies of your API set. If migration guides are available, provide the links here. -### About the "Pagination" section +### "Pagination" section This section is optional. If applicable, use this section to describe the options and default values for dividing long API responses into pages. -### About the "Rate limiting and throttling" section +### "Rate limiting and throttling" section This section is optional. If applicable, use this section to describe the global rate limiting settings and quota of your APIs. If different quota applies to different endpoints, also add this section in the reference for endpoints. -### About the "Status code" section +### "Status code" section -Tips: +**Tips**: - For REST APIs, HTTP status codes are used. If you are writing references for other protocols, adjust the table columns. - In the `Description` column, describe the causes of that error, and provide related information or links about how to deal with the error. @@ -86,11 +91,18 @@ Substitute the document title `{Resource Name}` with the actual name. Provide a one-line definition of the resource in the opening section and explain how and when your users should use it. -### About the "Data model" section +### "Data model" section -Use this section to describe each attribute of the resource entity in the table. Use the `Notes` column to provide additional information such as whether the attribute has default values, validation restrictions, and whether it is a non-editable field that cannot be updated with POST requests. If a cell is empty, fill in “N/A” or “/”. +Use this section to provide specifications of the resource entity in the table: -### About the "Example" section +- **Attribute**: the field name or property name defined by the resource +- **Type**: data type of the value +- **Required/Optional**: whether the attribute is a required field or not. Use a distinctive font to highlight the required attributes. In this template, capitalized letters are used. +- **Description**: additional information such as whether the attribute has default values, validation restrictions, and whether it is a non-editable field that cannot be updated with POST requests. + +If a cell is empty, fill in “N/A”. + +### "Example" section Provide a concrete example of the data entity with valid values. Fill in as many optional attributes as possible. @@ -98,7 +110,7 @@ Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code d Many Markdown processors also support syntax highlighting, which adds color to keywords. Indicate the language mode of your example after the opening backticks to take advantage of this feature. For example: `` ```json ``. The displayed color schema depends on your processor and the rendering configurations. -### About the "Endpoints" section +### "Endpoints" section List the endpoints that can interact with this resource type in the table: @@ -114,7 +126,7 @@ List the endpoints that can interact with this resource type in the table: Substitute the document title `{Endpoint Name}` with the actual name. -Tips: +**Tips**: - Typically the name of an API endpoint consists of the operation type and the resource type. For example, an API endpoint that creates a User resource can be named as `Create user`. - As in the API resource reference, the naming convention should be consistent throughout your API documentation. @@ -132,11 +144,11 @@ Provide a one-line description of what the API does. Starts with a verb. For exa Ensure that the description here is consistent with that listed in the resource reference. -### About the "Endpoint" section +### "Endpoint" section Use this section to define the API endpoint. -Tips: +**Tips**: - Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. - Replace {METHOD} with the actual request method and capitalize all letters. For example, `POST`. @@ -145,19 +157,19 @@ Tips: - Optionally use a different color to make the path parameters easily identifiable. - Do not add slash characters `/` at the end. -### About the "Description" section +### "Description" section Use this section to provide more information on what the endpoint does, the purpose, and use cases of this API endpoint. Optionally add notes about the API versioning information, API limit, deprecation status, and whether a replacement is available. If they are not applicable, remove the paragraphs. -### About the "Authorization" section +### "Authorization" section Provide a link to the common `Authorization` section in the API reference overview. If calling the endpoint requires additional user roles or permissions, document them in this section. -### About the "Request schema" section +### "Request schema" section Use this section to define the specifications of the endpoint. @@ -170,34 +182,32 @@ Each of the sub-sections is optional and should be adopted according to the actu If no parameters or request body can be sent in the request, specify "None" in this section. -Tips: +**Tips**: - In each of the tables, keep the parameter name the same as what is presented in the endpoint section above. -- In the `Required/Optional` column, specify "Required" or "Optional" to avoid ambiguity. +- In the `Required/Optional` column, specify "REQUIRED" or "Optional" to avoid ambiguity. - In the `Type` column, if the data type has detailed definitions in another place, provide the link. -- In the `Description` column, start the description with a noun and omit the articles (the/a/an). No need to write "defines/specifies". -- Use the `Notes` column to provide additional information such as default values, minimum/maximum values, usage restrictions, and valid enum values. -- Do not leave cells empty in the table. If there is no content, fill in with “N/A” or “/”. +- In the `Description` column, start the description with a noun and omit the articles (the/a/an). No need to write "defines/specifies". If applicable, provide additional information such as default values, minimum/maximum values, usage restrictions, and valid enum values. +- Do not leave cells empty in the table. If there is no content, fill in with “N/A”. - -### About the "Request example" section +### "Request example" section Use this section to provide an example that is complete and correct. The request should include the base URL, endpoint, headers, parameters, and request body. It should show as many parameter configurations as possible. Preferable, the example could be copy-pasted directly into your user's environment and return the expected result. -Tips: +**Tips**: - If you have several parameters for different use cases, especially when then parameters can not be used together, consider providing multiple request examples. - The recommended format for your example is `cURL` request. Depending on the business needs, you can add request samples in multiple programming languages, which can be generated by external tools. Do user research in advance to determine what languages should be adopted. Meanwhile, you should also consider the additional maintenance effort when you add more examples. - Match the sample request and parameters to the exact response the user would receive with those same parameters. -- Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. +- Use fenced code blocks (a pair of three backticks ```` ``` ````) to make your code distinctive from other text blocks. -### About the "Response schema" section +### "Response schema" section Use this section to describe the content type and data model that are returned in the response, in both successful and failed cases: -- For successful requests, provide the content format. -- For failed requests, provide the possible error code and the link to the error description. +- For successful requests, provide the content format. If the returned data type is documented somewhere else in the documentation, provide a link to the definition of the data type. +- For failed requests, provide the possible error codes and the link to the error description. The list of possible errors is usually a subset of the common errors provided in the [Status Code](#status-code-section) section. If a custom error type is returned, provide the error definition as a nested object. -### About the "Response example" section +### "Response example" section Use this section to provide an example of the response body if any, or clearly state that “the response body is empty”. diff --git a/api-reference/v2/api-reference-template.md b/api-reference/v2/api-reference-template.md index 1109ed95..c8d634cc 100644 --- a/api-reference/v2/api-reference-template.md +++ b/api-reference/v2/api-reference-template.md @@ -69,11 +69,12 @@ The {resource name} is used to {xxx}. ## Data model -| Attribute | Type | Required/Optional | Description | Notes | -|-----------|------|-------------------|-------------|-------| -| | | | | | -| | | | | | -| | | | | | +| Attribute | Type | Required/Optional | Description | +|-----------|--------|-------------------|----------------------------| +| {id} | string | REQUIRED | {Unique identifier of xx.} | +| {name} | string | Optional | {Name of xx}. | +| | | | | + ## Example @@ -113,7 +114,7 @@ This endpoint ... ## Authorization -The {authorization method} is required for each API request. +The [{authorization method}](#authorization) is required for each API request. (Optional) Calling this endpoint also requires the {xx} permission. @@ -124,37 +125,37 @@ The {authorization method} is required for each API request. {This section is optional.} -| Path parameter | Type | Required/Optional | Description | Notes | -|----------------|--------|-------------------|--------------------------|-----| -| {Id} | string | Required | Unique identifier of {}. | | -| {name} | string | Optional | Name of {}. | | -| | | | | | +| Path parameter | Type | Required/Optional | Description | +|----------------|--------|-------------------|----------------------------| +| {id} | string | REQUIRED | {Unique identifier of xx.} | +| | | | | ### Query parameters -{This section is optional.} - -| Query parameter | Type | Required/Optional | Description | Notes | -|-----------------|------|-------------------|-------------|-------| -| | | | | | +{This section is optional.} +| Query parameter | Type | Required/Optional | Description | +|-----------------|------|-------------------|---------------------------------| +| {pageSize} | int | Optional | {The number of items to be returned in a single request. The default value is 20.} | +| | | | | ### Header parameters -{This section is optional.} +{This section is optional.} -| Header parameter | Type | Required/Optional | Description | Notes | -|------------------|------|-------------------|-------------|-------| -| | | | | | +| Header parameter | Type | Required/Optional | Description | +|------------------|--------|-------------------|------------------------------| +| {Content-Type} | string | REQUIRED | {Media type of the resource. Must be xx}. | +| | | | | ### Request body -{This section is optional.} - -| Field | Type | Required/Optional | Description | Notes | -|-------|------|-------------------|-------------|-------| -| | | | | | +{This section is optional.} +| Field | Type | Required/Optional | Description | +|--------|--------|-------------------|----------------------------| +| {Id} | string | REQUIRED | {Unique identifier of xx.} | +| {name} | string | Optional | {Name of xx}. | ## Request example @@ -165,15 +166,23 @@ The {authorization method} is required for each API request. ## Response schema -If the request succeeds, this endpoint returns {one of the following options: -* a {data} in the response body in the {content type} format. -* a 200 status code with no response body. -} +| Status code | Schema | Description | +|-------------|-----------------------------------------------------|----------| +| 2xx | [{ExampleDataType}](link_to_data_type_definition) | {Describe the result where the request succeeds.} | +| 4xx | [{ExampleErrorType}](link_to_error_type_definition) | {Describe the result where the request fails with the specified error code.} | + +### ExampleErrorType -Otherwise, this endpoint returns {[xx errors](link_to_error_list)}. +{This section is optional.} + +| Field | Type | Description | +|----------------|----------|--------------------------------------------------| +| {errorType} | {enum} | {Predefined error codes. Possible enum values are xx, yy, ..., and zz.} | +| {errorMessage} | {string} | {Additional information about why the error occurs.} | ## Response example ``` + ``` From 5ab3d366861e8cabad4f4c004e0abd47247ecddb Mon Sep 17 00:00:00 2001 From: tang-mm Date: Mon, 27 Jun 2022 13:53:26 +0800 Subject: [PATCH 5/7] move files into versioned subdir --- api-reference/{ => v1}/about-api-reference.md | 0 api-reference/{ => v1}/api-reference.md | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename api-reference/{ => v1}/about-api-reference.md (100%) rename api-reference/{ => v1}/api-reference.md (100%) diff --git a/api-reference/about-api-reference.md b/api-reference/v1/about-api-reference.md similarity index 100% rename from api-reference/about-api-reference.md rename to api-reference/v1/about-api-reference.md diff --git a/api-reference/api-reference.md b/api-reference/v1/api-reference.md similarity index 100% rename from api-reference/api-reference.md rename to api-reference/v1/api-reference.md From f98998547f04b32ef58c4a9fc279afbc32d3545a Mon Sep 17 00:00:00 2001 From: tang-mm Date: Fri, 15 Jul 2022 23:43:03 +0800 Subject: [PATCH 6/7] address guide comments & remove version folders --- api-reference/{v2 => }/api-reference-guide.md | 26 ++++++----- .../{v2 => }/api-reference-template.md | 0 api-reference/v1/about-api-reference.md | 45 ------------------- api-reference/v1/api-reference.md | 41 ----------------- 4 files changed, 16 insertions(+), 96 deletions(-) rename api-reference/{v2 => }/api-reference-guide.md (94%) rename api-reference/{v2 => }/api-reference-template.md (100%) delete mode 100644 api-reference/v1/about-api-reference.md delete mode 100644 api-reference/v1/api-reference.md diff --git a/api-reference/v2/api-reference-guide.md b/api-reference/api-reference-guide.md similarity index 94% rename from api-reference/v2/api-reference-guide.md rename to api-reference/api-reference-guide.md index 8747cf83..7e5bb6ef 100644 --- a/api-reference/v2/api-reference-guide.md +++ b/api-reference/api-reference-guide.md @@ -2,23 +2,17 @@ This `api-reference-guide` document provides extra writing tips describing **HOW** to fill in each of the sections within the [`api-reference-template`](api-reference-template.md) file. -- _Document version_: 0.0.1 +- _Document version_: 0.1 - _Last updated_: June 27, 2022 ## Overview -API references are technical manuals that provide the specifications and integration instructions of APIs. An accurate, concise, well-structured API documentation facilitates the adoption of APIs and increases the overall user experience. +Application Programme Interface (API) references are technical manuals that provide API specifications and integration instructions to help your audience understand the product. The audience can vary based on your product user groups, and they can be technical or non-technical. + +Accurate, concise, well-structured API documentation facilitates efficient adoption of APIs and increases the overall user experience. The [`api-reference-template`](api-reference-template.md) is designed to help you build the API documentation efficiently and keep it consistent in both format and appearance. -## Before writing the API references - -- Familiarize yourself with the API protocol. If possible, try making some API calls in a testing environment. This API reference template works best with the REST API protocol. If you are working with other protocols, you may need to adjust the organization of some sections. -- Interact with your API developers to learn about the APIs that you are documenting. Understand the data models and the logical connections between the API endpoints. -- Discuss the logic of grouping the API endpoints. Although grouping the endpoints by resource type is a common practice, as used in this template, it is also possible to group them by use case or other characteristics that better suit the user's needs. -- Conduct some user research about how the audience of your documentation would use the APIs. Identify the programming languages that your audience would most likely adopt to interact with your APIs. -- Explore the possibility of auto-generating the API references. -- Optimize the visual presentation of the API references by applying customized stylesheet, such as using syntax highlighting, table of contents, multi-column layout, etc. ## Document structure @@ -29,6 +23,18 @@ Assuming that your API documentation set includes references of many API endpoin - The [API endpoint reference section](#about-the-api-endpoint-reference-section) provides reference information for a specific API endpoint. It describes the specifications of an API endpoint, such as the method, URL, request, and response schema. +## Before writing the API references + +You may follow these guidelines to help you write better API reference documentation: + +- Familiarize yourself with the API protocol. If possible, try making some API calls in a testing environment. +- Adjust the organization of some sections to align with your API protocol. This API reference template works best with the [Representational State Transfer (REST)](https://en.wikipedia.org/wiki/Representational_state_transfer) API protocol. +- Interact with your API developers to learn about the APIs that you are documenting. Understand the data models and the logical connections between the API endpoints. +- Discuss the logic of grouping the API endpoints. Although grouping the endpoints by resource type is a common practice, as used in this template, it is also possible to group them by use case or other characteristics that better suit the user's needs. +- Conduct some user research about how the audience of your documentation would use the APIs. Identify the programming languages that your audience would most likely adopt to interact with your APIs. +- Explore the possibility of auto-generating the API references. +- Optimize the visual presentation of the API references by applying customized stylesheet, such as using syntax highlighting, table of contents, multi-column layout, etc. + ## About the API reference overview section ### "Introduction" section diff --git a/api-reference/v2/api-reference-template.md b/api-reference/api-reference-template.md similarity index 100% rename from api-reference/v2/api-reference-template.md rename to api-reference/api-reference-template.md diff --git a/api-reference/v1/about-api-reference.md b/api-reference/v1/about-api-reference.md deleted file mode 100644 index 52f7ca4c..00000000 --- a/api-reference/v1/about-api-reference.md +++ /dev/null @@ -1,45 +0,0 @@ -# API Reference entry - -The reference section is a collection of short entries, arranged in alphabetical order. This template is for the individual reference entry that you create for a single endpoint. - -The reference section is important for API documentation. New users will start with other documents to help them get going, but experienced users will refer more frequently to the reference section for the detailed information they need to make use of the API. - -The reference section should contain a full listing of endpoints, methods, and parameters. - -## Content of the reference entry - -### Reference entries - -Each reference listing should contain: - -* A general description of the endpoint, including what it's for, and what it can do -* The HTTP method, if applicable -* An example of the syntax -* All the parameters for the endpoint - -For each parameter, include: - -* An example request -* An example response -* The response schema - -## Best practices for reference docs - -Each detailed reference entry should contain all the information readers need to know when using the feature. - -For parameters, include: - -* Name of the parameter -* Description of what the parameter does and when to use it -* Data type -* All the acceptable values, if there is a limited set of options -* Whether the parameter is required or optional - -Differentiate the endpoint from other similar endpoints. If more than one endpoint or parameter can achieve the same result, explain which one to use in what situation, as each probably exists for a specific reason. - -Include both syntax and a working example for each reference entry. Follow example code with extensive comments that explain how it works. - -## Examples - -examples: -[API reference of resource types](https://developers.google.com/gmail/api/v1/reference) diff --git a/api-reference/v1/api-reference.md b/api-reference/v1/api-reference.md deleted file mode 100644 index 17080431..00000000 --- a/api-reference/v1/api-reference.md +++ /dev/null @@ -1,41 +0,0 @@ -# Endpoint name - -Method | syntax ------ | ---------- -GET | base_url/endpoint/etc. - - - -## Description - - - -Parameters - -Name | type | Req. | Description ----- | ----- | ----- | -------------------- -Parameter_one | string | Y | Stores the customer name -Parameter_two | int | N | Stores a postal code, like the U.S. ZIP code. - - - - -## Examples - -### Request - -```HTTP - - -``` - - - -### Response - -```HTTP - - -``` - - \ No newline at end of file From 3be2df78c0f0cd81555b74e40801bec0ba1e87fc Mon Sep 17 00:00:00 2001 From: tang-mm Date: Tue, 26 Jul 2022 19:22:47 +0800 Subject: [PATCH 7/7] address comments & update doc structure --- api-reference/api-reference-guide.md | 132 +++++++++++------- api-reference/api-reference-template.md | 178 +++++++++++++----------- 2 files changed, 175 insertions(+), 135 deletions(-) diff --git a/api-reference/api-reference-guide.md b/api-reference/api-reference-guide.md index 7e5bb6ef..e504cc59 100644 --- a/api-reference/api-reference-guide.md +++ b/api-reference/api-reference-guide.md @@ -3,7 +3,7 @@ This `api-reference-guide` document provides extra writing tips describing **HOW** to fill in each of the sections within the [`api-reference-template`](api-reference-template.md) file. - _Document version_: 0.1 -- _Last updated_: June 27, 2022 +- _Last updated_: July 26, 2022 ## Overview @@ -16,12 +16,13 @@ The [`api-reference-template`](api-reference-template.md) is designed to help yo ## Document structure -Assuming that your API documentation set includes references of many API endpoints that are organized into groups, this template includes three parts: +The template assumes that your API documentation set includes references for many API endpoints, that are organized into groups. The template includes three parts: -- The [API reference overview section](#about-the-api-reference-overview-section) provides reference information for the whole API documentation set. It describes product-wise API specifications, such as protocol, authorization method, versioning, status code, etc. -- The [API resource reference section](#about-the-api-resource-reference-section) provides reference information for a subset of API endpoints that are grouped around a resource type. It describes resource-wise API specifications, such as the data model of the resource. -- The [API endpoint reference section](#about-the-api-endpoint-reference-section) - provides reference information for a specific API endpoint. It describes the specifications of an API endpoint, such as the method, URL, request, and response schema. +- [API overview section](#about-the-api-reference-overview-section) +- [API resource reference section](#about-the-api-resource-reference-section) +- [API endpoint reference section](#about-the-api-endpoint-reference-section) + +> add explanation about how to organize the sections. Change the H1 to H2. ## Before writing the API references @@ -35,106 +36,118 @@ You may follow these guidelines to help you write better API reference documenta - Explore the possibility of auto-generating the API references. - Optimize the visual presentation of the API references by applying customized stylesheet, such as using syntax highlighting, table of contents, multi-column layout, etc. -## About the API reference overview section +## About the "API reference overview" section + +The API overview section in the API reference describes the API components which apply to all endpoints in the API. This section includes information on topics such as protocol, authorization method, versioning, status code. -### "Introduction" section +### About the "Introduction" section Use this section to provide a high-level overview of your API set, including the main features, communication protocol, content types, organization, etc. -### "Base URL" section +### About the "Base URL" section Base URL is a common segment to which the API endpoint paths are appended. Defining the base URL in this section reduces the effort to duplicate the segment in each endpoint reference. The base URL may differ for different groups of users or in different environments. If multiple base URLs are available, list them in this section and clearly describe the conditions of using each of them. -### "Authorization" section +### About the "Authorization" section Use this section to specify the authentication and authorization requirements of using the APIs, including the authorization type, request schema, possible error codes, and examples. -**Tips**: +:information_source: **Tips**: - This section should only describe the technical specifications of the API authorization, such as parameters and token expiration. Details of how to authenticate should be documented in a separate how-to guide and be referred to as a link here. - Provide an example of the authorization request or command. You can use random strings to replace the actual secrets. - If there is more than one authorization type applicable to your APIs, describe and specify the use case of each. If one of the options is preferred, highlight it. - If different permission levels apply to different API endpoints, document the requirements in the reference for that endpoint. -### "Versioning" section +### About the "Versioning" section This section is optional. If applicable, use this section to describe the versioning, compatibility, and lifecycle policies of your API set. If migration guides are available, provide the links here. -### "Pagination" section +### About the "Pagination" section This section is optional. If applicable, use this section to describe the options and default values for dividing long API responses into pages. +:information_source: **Tip**: Your readers might not understand what "pagination" is, so it is wise to embed an explanation in the descriptive text. + +### About the "Rate limiting and throttling" section -### "Rate limiting and throttling" section +This section is optional. If applicable, use this section to describe the global rate limiting settings and quota of your APIs. If different quotas apply to different endpoints, also add this section in the reference for endpoints. -This section is optional. If applicable, use this section to describe the global rate limiting settings and quota of your APIs. If different quota applies to different endpoints, also add this section in the reference for endpoints. +### About the "HTTP status code" section -### "Status code" section +Use this section to provide the list of HTTP status code that are applicable to your APIs. It is possible that the APIs only return certain types of the standard HTTP status codes. -**Tips**: +:information_source: **Tips**: - For REST APIs, HTTP status codes are used. If you are writing references for other protocols, adjust the table columns. - In the `Description` column, describe the causes of that error, and provide related information or links about how to deal with the error. +### About the "Errors" section + +This section is optional. If applicable, use this section to list the custom error types defined for the APIs. For easier navigation, you may provide each of the error definitions as a subsection. + ### Additional sections -If other specifications are applicable to the whole API set, such as data conventions, request retry logic, logging, monitoring, and so on, define your own sections at the end of this document. +If other specifications are applicable to the whole API set, such as data conventions, request retry logic, logging, monitoring, define your own sections here. -## About the API resource reference section +## About the "API resource reference" section + +The API resource reference section provides reference information for a subset of API endpoints that are grouped around a resource type. This section describes the data model of the resource type. The template assumes that the API endpoints are grouped by the resource type that they are interacting with. **Title** -Substitute the document title `{Resource Name}` with the actual name. +Substitute the document title `{Resource Name}` with the actual name. The resource name usually uses the same naming convention as in the source code. **Short description** Provide a one-line definition of the resource in the opening section and explain how and when your users should use it. -### "Data model" section +### About the "Data model" section Use this section to provide specifications of the resource entity in the table: - **Attribute**: the field name or property name defined by the resource - **Type**: data type of the value -- **Required/Optional**: whether the attribute is a required field or not. Use a distinctive font to highlight the required attributes. In this template, capitalized letters are used. +- **Required?**: whether the attribute is a required field or not. Use a distinctive font to highlight the required attributes. In this template, capitalized letters are used. - **Description**: additional information such as whether the attribute has default values, validation restrictions, and whether it is a non-editable field that cannot be updated with POST requests. If a cell is empty, fill in “N/A”. -### "Example" section +### About the "Example" section Provide a concrete example of the data entity with valid values. Fill in as many optional attributes as possible. -Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. +Use fenced code blocks to make your code distinctive from other text blocks. -Many Markdown processors also support syntax highlighting, which adds color to keywords. Indicate the language mode of your example after the opening backticks to take advantage of this feature. For example: `` ```json ``. The displayed color schema depends on your processor and the rendering configurations. +If you are documenting in Markdown, many Markdown processors also support syntax highlighting, which adds color to keywords. Indicate the language mode of your example to take advantage of this feature. The displayed color schema depends on your processor and the rendering configurations. -### "Endpoints" section +### About the "Endpoints" section -List the endpoints that can interact with this resource type in the table: +List the endpoints that can interact with this resource type in a tabular format with the following guidelines: -- Capitalize the method names. -- Adopt a consistent naming convention for the APIs. In most cases, the naming convention used in the documentation is consistent with the one in the source code. +- Capitalize the method names, for example "GET". +- Adopt a consistent naming convention for the APIs. In most cases, the naming convention used in the documentation should be consistent with the one in the source code. - Add a link to each of the endpoint names that directs users to the corresponding endpoint reference. -- For endpoints that are deprecated but still in use, add a note in the “Description” column. Consider using the strikethrough format (a pair of two tildes `~~`) to indicate the deprecation status. +- For endpoints that are deprecated but still in use, add a note in the “Description” column. Consider using the strikethrough format to indicate the deprecation status. +## About the "API endpoint reference" section -## About the API endpoint reference section +The API endpoint reference section provides reference information for a specific API endpoint. It describes the specifications of an API endpoint, such as the method, URL, request, and response schema. **Title** Substitute the document title `{Endpoint Name}` with the actual name. -**Tips**: +:information_source:**Tips**: -- Typically the name of an API endpoint consists of the operation type and the resource type. For example, an API endpoint that creates a User resource can be named as `Create user`. +- Typically the name of an API endpoint consists of the operation type and the resource type. For example, an API endpoint that creates a User resource can be named `Create user`. - As in the API resource reference, the naming convention should be consistent throughout your API documentation. - Use the singular form of the resource name unless the endpoint is designed exclusively for a bulk operation, such as `List users`. @@ -142,78 +155,89 @@ Substitute the document title `{Endpoint Name}` with the actual name. Provide a one-line description of what the API does. Starts with a verb. For example: -- For "get" operations: `Returns a {resource}.` -- For "list" operations: `Returns a list of {resources}.` +- For "get" operations: `Retrieves a {resource}.` +- For "list" operations: `Lists {resources}.` - For "create" operations: `Creates a {resource}.` or `Inserts a {resource}.` - For "update" operations: `Updates a {resource}.` - For "delete" operations: `Removes a {resource}.` Ensure that the description here is consistent with that listed in the resource reference. -### "Endpoint" section +### About the "Endpoint" section + Use this section to define the API endpoint. -**Tips**: +:information_source: **Tips**: -- Use fenced code blocks (a pair of three backticks `` ``` ``) to make your code distinctive from other text blocks. +- Use fenced code blocks to make your code distinctive from other text blocks. - Replace {METHOD} with the actual request method and capitalize all letters. For example, `POST`. - In the {request_url} segment, start with a slash character `/` and only provide the URL path (the segment after the hostname). The base URL can be omitted if you already document it in the API overview. For example, `/v2/users`. - If the {request_url} contains path variables, use a placeholder to indicate the variable name. The format of placeholders should be consistent throughout the documentation set and conform to your organization’s guidelines. As an option, you can use snake case characters in curly brace `{}`, delimited by underscores. For example, `{user_id}`. - Optionally use a different color to make the path parameters easily identifiable. - Do not add slash characters `/` at the end. -### "Description" section +### About the "Description" section Use this section to provide more information on what the endpoint does, the purpose, and use cases of this API endpoint. Optionally add notes about the API versioning information, API limit, deprecation status, and whether a replacement is available. If they are not applicable, remove the paragraphs. -### "Authorization" section +### About the "Authorization" section Provide a link to the common `Authorization` section in the API reference overview. If calling the endpoint requires additional user roles or permissions, document them in this section. -### "Request schema" section +### About the "Request schema" section Use this section to define the specifications of the endpoint. Each of the sub-sections is optional and should be adopted according to the actual endpoint definition: -- **Path parameters**: parameters defined within the path of the endpoint, denoted by placeholders. +- **Path parameters**: parameters defined within the path of the endpoint, denoted by placeholders. Path parameters are always required. - **Query parameters**: appended to the end of the request URL, after a question mark `?`. Parameters and their assigned values are connected by an equal sign `=`. Multiple query parameters are delimited by an and sign `&`. - **Header parameters**: often the same across endpoints in an API set. Include this section only when specific header parameters are required for this endpoint. - **Request body**: only applicable for requests using methods that permit a payload, such as POST, PUT, and PATCH. Include a link to the description of the resource type if applicable. -If no parameters or request body can be sent in the request, specify "None" in this section. +If no request parameters or request body are supported, specify "None" in this section. -**Tips**: +:information_source: **Tips**: - In each of the tables, keep the parameter name the same as what is presented in the endpoint section above. -- In the `Required/Optional` column, specify "REQUIRED" or "Optional" to avoid ambiguity. +- In the `Required?` column, specify "Required" or "Optional" to avoid ambiguity. You may use uppercase or the bold style to emphasize the term "Required". - In the `Type` column, if the data type has detailed definitions in another place, provide the link. -- In the `Description` column, start the description with a noun and omit the articles (the/a/an). No need to write "defines/specifies". If applicable, provide additional information such as default values, minimum/maximum values, usage restrictions, and valid enum values. -- Do not leave cells empty in the table. If there is no content, fill in with “N/A”. +- In the `Description` column, start the description with a noun and omit the articles (the/a/an). No need to write "defines/specifies". For example, "Unique identifier of the user" or "Name of the user". If applicable, provide additional information, such as: + - default values. For example: "The default value is 0." + - minimum/maximum values. For example: "The value must be within the range 100 - 999 (both inclusive)." + - allowed values. For example: "The allowed values are `left` and `right`." + - usage restrictions. For example: "Use this parameter only when {a condition} is true." + - any limit applicable to this field. For example, "The ID must be 16 characters long." +- Do not leave cells empty in the table. If there is no content, fill with “N/A” (short for "not applicable"). -### "Request example" section +### About the "Request example" section Use this section to provide an example that is complete and correct. The request should include the base URL, endpoint, headers, parameters, and request body. It should show as many parameter configurations as possible. Preferable, the example could be copy-pasted directly into your user's environment and return the expected result. -**Tips**: +:information_source: **Tips**: - If you have several parameters for different use cases, especially when then parameters can not be used together, consider providing multiple request examples. - The recommended format for your example is `cURL` request. Depending on the business needs, you can add request samples in multiple programming languages, which can be generated by external tools. Do user research in advance to determine what languages should be adopted. Meanwhile, you should also consider the additional maintenance effort when you add more examples. - Match the sample request and parameters to the exact response the user would receive with those same parameters. -- Use fenced code blocks (a pair of three backticks ```` ``` ````) to make your code distinctive from other text blocks. +- Use fenced code blocks to make your code distinctive from other text blocks. -### "Response schema" section +### About the "Response schema" section -Use this section to describe the content type and data model that are returned in the response, in both successful and failed cases: +Use this section to describe the content type and data model that is returned in the response, in both successful and failed cases: - For successful requests, provide the content format. If the returned data type is documented somewhere else in the documentation, provide a link to the definition of the data type. -- For failed requests, provide the possible error codes and the link to the error description. The list of possible errors is usually a subset of the common errors provided in the [Status Code](#status-code-section) section. If a custom error type is returned, provide the error definition as a nested object. +- For failed requests, provide the possible error codes and the link to the error description. The list of possible errors is usually a subset of the common errors provided in the [Errors](#about-the-errors-section) section in API Overview. -### "Response example" section +### About the "Response example" section Use this section to provide an example of the response body if any, or clearly state that “the response body is empty”. + +## Additional resources + +- [REST Resource Naming Guide](https://restfulapi.net/resource-naming/) +- [HTTP Response Status Code](https://developer.mozilla.org/en-US/docs/Web/HTTP/Status) \ No newline at end of file diff --git a/api-reference/api-reference-template.md b/api-reference/api-reference-template.md index c8d634cc..33f38f73 100644 --- a/api-reference/api-reference-template.md +++ b/api-reference/api-reference-template.md @@ -1,12 +1,13 @@ -# API reference overview +# API Reference {Before using this template, read [the accompanying guide](api-reference-guide.md) to this template}. -## Introduction -The {product name} APIs are REST APIs that provides {xx features}. +## Overview -## Base URL +This reference describes the Application Program Interfaces (APIs) that help you {access | customize | program} {product}'s {features | functionality}. + +### Base URL The APIs referenced in this documentation use the following base URL: @@ -15,174 +16,189 @@ https://api.example.com ``` -## Authorization +### Authorization -All requests to the API must be authenticated and authorized before they can access or manage resources on the {environment or platform}. +All requests to the API must be authenticated and authorized before they can access or manage resources on the {environment | platform}. -The {product name} API uses the **{auth_type}** authorization type. +The {product} API uses the `{auth_type}` authorization type. -You can authenticate your requests by {using authentication type and method}. +You can authenticate your requests by using {authentication type and method}. For example: ``` - +{EXAMPLE} ``` -API requests without valid authentication will fail with a status of {error code}. +API requests without valid authentication will fail with a status of `{error_code}`. -## Versioning +### Versioning {This section is optional.} -The {product name} APIs provide {x} versions of API endpoints... +The {product} APIs provide multiple versions of API endpoints. + +{Commentary about the versions supported.} -## Pagination +### Pagination {This section is optional.} -You can use {xx} to paginate the results returned by the {product name} APIs. If not specified, the default values are ... +Due to the potential very large result sets from API calls, responses {are | can be} returned as shorter pages. + +Pagination can be customized using {pagination settings}. If not specified, the default values are {values}. -## Rate limiting and throttling +### Rate limiting and throttling {This section is optional.} -The {product name} APIs use a {xx} rate limiting strategy. The maximum number of requests allowed to access a {resource/endpoint/..} is {xx} requests per {time period}. +The {product} APIs use a {strategy_name} rate limiting strategy. The maximum number of requests allowed to access a {resource | endpoint |..} is {number} requests per {time period}. If the number of requests exceeds that limit, an HTTP `429 Too Many Request` error is returned. -## Status code +### HTTP status code -The {product name} APIs use standard HTTP response codes. +The {product} APIs use the following standard HTTP response codes: | Status code | Message | Description | |-------------|-------------------|---------------| -| 200 `OK` | Request succeeds. | {description} | +| `200 OK` | Request succeeds. | {description} | | | | | | | | | -# {Resource name} +### Errors + +{This section is optional.} + +The {product} APIs use the following error types: -The {resource name} is used to {xxx}. +| Error | Description | +|-----------------------------------------|------------------| +| [{ExampleErrorType}](#exampleerrortype) | {Failure in ...} | +| | | +| | | + +#### ExampleErrorType + +| Field | Type | Description | +|----------------|----------|--------------------------------------------------| +| {errorType} | {enum} | {Predefined error codes. Possible enum values are x, y, ..., and z.} | +| {errorMessage} | {string} | {Additional information about why the error occurs.} | -## Data model -| Attribute | Type | Required/Optional | Description | -|-----------|--------|-------------------|----------------------------| -| {id} | string | REQUIRED | {Unique identifier of xx.} | -| {name} | string | Optional | {Name of xx}. | -| | | | | +## {Resource name} +The {resource name} is used to {functionality}. -## Example +### Data model + +| Attribute | Type | Required? | Description | +|-----------|--------|-----------|------------------------------| +| {id} | string | Required | {Unique identifier of user.} | +| {name} | string | Optional | {Name of user}. | +| | | | | + + +### Example ``` - +{EXAMPLE} ``` -## Endpoints +### Endpoints Use the following endpoints to interact with the {resource name} entities. -| Method | Endpoint name | Description | -|--------|-----------------------------------------|-----------------------| -| POST | {[Endpoint name A](link_to_endpoint_a)} | Creates a {resource}. | -| GET | {[Endpoint name B](link_to_endpoint_b)} | Returns a {resource}. | -| | | | +| Method | Endpoint name | Description | +|--------|------------------------------------------|-------------------------| +| POST | {[Endpoint name A](#link_to_endpoint_a)} | Creates a {resource}. | +| GET | {[Endpoint name B](#link_to_endpoint_b)} | Retrieves a {resource}. | +| | | | -# {Endpoint name} +## {Endpoint name} -{Provide a one-line description of what the API does. Starts with a verb.} +{Provide a one-line description of what the API does. Starts with a verb. For example, "retrieves a user".} -## Endpoint +### Endpoint ```bash -{METHOD} /{request_url}/{{path_parameter}} +{METHOD} /{request-url}/{{path-parameter}} ``` -## Description +### Description This endpoint ... -{This paragraph is optional.} This endpoint has been deprecated. Use {the recommended endpoint} instead. For more information about how to migrate to {the recommended endpoint}, see [{the migration guide}](link). +{This paragraph is optional.} This endpoint has been deprecated. Use {the recommended endpoint} instead. For more information about how to migrate to {the recommended endpoint}, see [{the migration guide}](#link). -{This paragraph is optional.} The maximum number of calls to this API endpoint is {xx} per minute. For more information about API rate limiting/throttling, see [{the topic}](example). +{This paragraph is optional.} The maximum number of calls to this API endpoint is {number} per minute. For more information about API rate limiting/throttling, see [{the topic}](#example). -## Authorization +### Authorization The [{authorization method}](#authorization) is required for each API request. -(Optional) Calling this endpoint also requires the {xx} permission. +{This paragraph is optional.} Calling this endpoint also requires the {permission_name} permission. -## Request schema +### Request schema -### Path parameters +#### Path parameters {This section is optional.} -| Path parameter | Type | Required/Optional | Description | -|----------------|--------|-------------------|----------------------------| -| {id} | string | REQUIRED | {Unique identifier of xx.} | -| | | | | +| Path parameter | Type | Required? | Description | +|----------------|--------|-----------|------------------------------| +| {id} | string | Required | {Unique identifier of user.} | +| | | | | -### Query parameters +#### Query parameters {This section is optional.} -| Query parameter | Type | Required/Optional | Description | -|-----------------|------|-------------------|---------------------------------| -| {pageSize} | int | Optional | {The number of items to be returned in a single request. The default value is 20.} | -| | | | | +| Query parameter | Type | Required? | Description | +|-----------------|------|-----------|-----------------------------------------| +| {pageSize} | int | Optional | {The number of items to be returned in a single request. The default value is 20.} | +| | | | | -### Header parameters +#### Header parameters {This section is optional.} -| Header parameter | Type | Required/Optional | Description | -|------------------|--------|-------------------|------------------------------| -| {Content-Type} | string | REQUIRED | {Media type of the resource. Must be xx}. | -| | | | | +| Header parameter | Type | Required? | Description | +|------------------|--------|-----------|--------------------------------------| +| {Content-Type} | string | Required | {Media type of the resource. Must be object}. | +| | | | | -### Request body +#### Request body {This section is optional.} -| Field | Type | Required/Optional | Description | -|--------|--------|-------------------|----------------------------| -| {Id} | string | REQUIRED | {Unique identifier of xx.} | -| {name} | string | Optional | {Name of xx}. | +| Field | Type | Required? | Description | +|--------|--------|-----------|----------------------------------| +| {id} | string | Required | {Unique identifier of the user.} | +| {name} | string | Optional | {Name of the user.} | -## Request example +### Request example ``` - +{EXAMPLE} ``` -## Response schema +### Response schema | Status code | Schema | Description | |-------------|-----------------------------------------------------|----------| -| 2xx | [{ExampleDataType}](link_to_data_type_definition) | {Describe the result where the request succeeds.} | -| 4xx | [{ExampleErrorType}](link_to_error_type_definition) | {Describe the result where the request fails with the specified error code.} | - -### ExampleErrorType - -{This section is optional.} - -| Field | Type | Description | -|----------------|----------|--------------------------------------------------| -| {errorType} | {enum} | {Predefined error codes. Possible enum values are xx, yy, ..., and zz.} | -| {errorMessage} | {string} | {Additional information about why the error occurs.} | +| `2xx` | [{ExampleDataType}](#data-model) | {Describe the result where the request succeeds.} | +| `4xx` | [{ExampleErrorType}](#exampleerrortype) | {Describe the result where the request fails with the specified error code.} | -## Response example +### Response example ``` - +{EXAMPLE} ```