- Use American English
- Don't use acronyms
- Use
camelCase
unless stated otherwise - Reconcile terms with adidas CDM
Every identifier MUST be in American English and written in lowercase
. An identifier SHOULD NOT contain acronyms. CamelCase (camelCase
) MUST be used to delimit combined words.
Every URI MUST follow the General Rules except for the camelCase
rule. Instead, a hyphen (-
) SHOULD be used to delimit combined words (kebab-case). Besides, a URI MUST NOT end with a trailing slash (/
).
Plural nouns SHOULD be used in the URI where appropriate to identify collections of data resources (e.g. /orders
, /products
).
An individual resource in a collection of resources MAY exist directly beneath the collection URI. (e.g. /orders/{order_id}
).
A well-formed URI:
/system-orders/1234/author
Every URI query parameter or fragment MUST follow the General Rules. Also, they MUST NOT clash with the reserved query parameter names.
In addition to General Naming Rules, URI Template Variable names MUST follow the RFC6570. That is, the variable names can consist only from ALPHA / DIGIT / "_" / pct-encoded
.
NOTE: Per RFC6570 Hyphen (
-
) is NOT legal URI Template variable name character.
A well-formed URI Template Variable:
/system-orders/{orderId}/author
Every representation format field MUST conform to the General Naming Rules.
A well-formed resource representation:
{
"_links": {
"self": {
"href": "/orders/1234"
},
"author": {
"href": "/users/john"
}
},
"orderNumber": 1234,
"itemCount": 42,
"status": "pending"
}
Every custom relation identifier MUST be in lowercase
with words separated by the hyphen (-
).
A well-formed resource representation with custom relation fulfillment-provider
:
{
"_links": {
"fulfillment-provider": {
"href": "/users/natalie"
}
}
}
Every HTTP Header should use Hyphenated-Pascal-Case
. A custom HTTP Header SHOULD NOT start with X-
(RFC6648).
Order-Metadata-Header: 42
Naming conventions within API Description document.
Every API Description API name MUST start with API domain enclosed in square brackets (e.g. [API Domain] My API
). Words MUST be separated by space.
swagger: '2.0'
info:
version: '1.0.0'
title: '[Demo] Orders API'
Every resource MUST have a name (defined by x-summary
field). Resource name MUST be in Title Case
. Words MUST be separated by a space.
/orders:
x-summary: List of Orders
Every action (operation) MUST have a name (defined by summary
field). Action name MUST be in Title Case
. Words MUST be separated by a space.
get:
summary: Retrieve List of Orders