Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(specs): improve API reference documentation #2831

Merged
merged 23 commits into from
Mar 12, 2024
Merged
Show file tree
Hide file tree
Changes from 15 commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
"scripts:test": "yarn workspace scripts test",
"specs:fix": "eslint --ext=yml specs/$0 --fix",
"specs:lint": "eslint --ext=yml specs/$0",
"website": "yarn cli build specs all -s && cd website && yarn start",
"website": "yarn cli build specs all -d -s && cd website && yarn start",
"website:build": "bash scripts/website/build.sh"
},
"devDependencies": {
Expand Down
45 changes: 26 additions & 19 deletions specs/common/parameters.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,16 @@
IndexName:
name: indexName
in: path
description: Index on which to perform the request.
description: Name of the index on which to perform the operation.
required: true
schema:
type: string
example: myIndexName
example: YourIndexName

ObjectID:
name: objectID
in: path
description: Unique record (object) identifier.
description: Unique record identifier.
required: true
schema:
type: string
Expand All @@ -21,7 +21,7 @@ ObjectID:
Index:
in: query
name: index
description: Index name to target.
description: Index name.
required: true
schema:
type: string
Expand All @@ -30,33 +30,34 @@ Index:
StartDate:
in: query
name: startDate
description: Start date (a string in the format `YYYY-MM-DD`) of the period to analyze.
description: Start date (`YYYY-MM-DD`) of the period to analyze.
schema:
type: string
format: date
example: 2022-09-19
pattern: ^\d{4}-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])$

EndDate:
in: query
name: endDate
description: End date (a string in the format `YYYY-MM-DD`) of the period to analyze.
description: End date (`YYYY-MM-DD`) of the period to analyze.
schema:
type: string
format: date
example: 2023-01-21
pattern: ^\d{4}-(0[1-9]|1[0-2])-(0[1-9]|[12][0-9]|3[01])$

ForwardToReplicas:
in: query
name: forwardToReplicas
description: Indicates whether changed index settings are forwarded to the replica indices.
description: Whether changes are applied to replica indices.
schema:
type: boolean

Page:
in: query
name: page
description: >
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we can replace all > with pipes to preserve formatting, wdyt?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, that's better.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done it for the Search API and common. Will do it for the rest in separate PRs when updating the docs for the other APIs.

Curiously, the | doesn't appear in the bundled specs. Something in the process of formatting and writing the spec changes this. I couldn't find any formatting artifacts on the website due to this, so I'm not sure what's going on here.

Returns the requested page number. The page size is determined by the `hitsPerPage` parameter. You can see the number of available pages in the `nbPages` response attribute. When `page` is null, the API response is not paginated.
Requested page of the API response.
If `null`, the API response is not paginated.
schema:
type: integer
minimum: 0
Expand All @@ -67,7 +68,8 @@ PageDefault0:
in: query
name: page
description: >
Returns the requested page number (the first page is 0). Page size is set by `hitsPerPage`. When null, there's no pagination.
Requested page of the API response.
If `null`, the API response is not paginated.
schema:
type: integer
nullable: true
Expand All @@ -77,32 +79,37 @@ PageDefault0:
HitsPerPage:
in: query
name: hitsPerPage
description: Maximum number of hits per page.
description: Number of hits per page.
schema:
type: integer
default: 100

Offset:
in: query
name: offset
description: Position of the starting record. Used for paging. 0 is the first record.
description: Position of the first item to return.
schema:
type: integer
default: 0
minimum: 0

Limit:
in: query
name: limit
description: Number of records to return (page size).
description: Number of items to return.
schema:
type: integer
default: 10

# misc
objectID:
type: string
description: Unique object identifier.
example: 'product-1'
description: Unique record identifier.

ruleID:
title: objectID
type: string
description: Unique identifier of a rule object.

id:
type: string
Expand All @@ -112,7 +119,7 @@ id:
indexName:
type: string
example: products
description: Algolia index name.
description: Index name.

hitsPerPage:
type: integer
Expand All @@ -123,13 +130,13 @@ hitsPerPage:

query:
type: string
description: Full-text query.
description: Search query.
default: ''

page:
type: integer
minimum: 0
description: Requested page (the first page is page 0).
description: Requested page of the API response.

trackedSearchCount:
type: integer
Expand Down
18 changes: 10 additions & 8 deletions specs/common/responses/common.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,24 @@ taskID:
type: integer
format: int64
example: 1514562690001
description: >
description: |
Unique identifier of a task.

A successful API response means that a task was added to a queue. It might not run immediately. You can check the task's progress with the `task` operation and this `taskID`.
A successful API response means that a task was added to a queue. It might not run immediately. You can check the task's progress with the [`task` operation](#tag/Indices/operation/getTask) and this `taskID`.

objectIDs:
type: array
items:
type: string
example: ['record-1','record-2']
description: Unique object (record) identifiers.
example:
- record-1
- record-2
description: Unique record identifiers.

createdAt:
type: string
example: '2023-07-04T12:49:15Z'
description: Timestamp of creation in [ISO-8601](https://wikipedia.org/wiki/ISO_8601) format.
example: 2023-07-04T12:49:15Z
description: Timestamp of creation in [ISO 8601](https://wikipedia.org/wiki/ISO_8601) format.

createdAtTimestamp:
type: integer
Expand All @@ -27,10 +29,10 @@ createdAtTimestamp:

updatedAt:
type: string
example: '2023-07-04T12:49:15Z'
example: 2023-07-04T12:49:15Z
description: Timestamp of the last update in [ISO 8601](https://wikipedia.org/wiki/ISO_8601) format.

deletedAt:
type: string
example: '2023-06-27T14:42:38.831Z'
example: 2023-06-27T14:42:38.831Z
description: Timestamp of deletion in [ISO 8601](https://wikipedia.org/wiki/ISO_8601) format.
16 changes: 9 additions & 7 deletions specs/common/schemas/HighlightResult.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
highlightResultOption:
type: object
description: Show highlighted section and words matched on a query.
description: Surround words that match the query with HTML tags for highlighting.
additionalProperties: false
properties:
value:
Expand All @@ -9,7 +9,7 @@ highlightResultOption:
$ref: '#/matchLevel'
matchedWords:
type: array
description: List of words from the query that matched the object.
description: List of matched words from the search query.
example: ['action']
items:
type: string
Expand All @@ -23,23 +23,24 @@ highlightResultOption:

highlightedValue:
type: string
description: Markup text with `facetQuery` matches highlighted.
description: Highlighted attribute value, including HTML tags.
example: '<em>George</em> <em>Clo</em>oney'

matchLevel:
type: string
description: Indicates how well the attribute matched the search query.
description: Whether the whole query string matches or only a part.
enum: [none, partial, full]

highlightResultOptionMap:
type: object
description: Show highlighted section and words matched on a query.
description: Surround words that match the query with HTML tags for highlighting.
additionalProperties:
x-additionalPropertiesName: attribute
$ref: '#/highlightResultOption'

highlightResultOptionArray:
type: array
description: Show highlighted section and words matched on a query.
description: Surround words that match the query with HTML tags for highlighting.
items:
$ref: '#/highlightResultOption'

Expand All @@ -51,6 +52,7 @@ highlightResult:

highlightResultMap:
type: object
description: Show highlighted section and words matched on a query.
description: Surround words that match the query with HTML tags for highlighting.
additionalProperties:
x-additionalPropertiesName: attribute
$ref: '#/highlightResult'
Loading
Loading