3.0 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Naming Conventions
General Naming Rules
- Use American English
- Use lowercase ("snake_case")
- Don't use acronyms
- Use underscore to delimit words
Every identifier MUST be in American English and written in lowercase. An identifier SHOULD NOT contain acronyms. Underscore (_) MUST be used to delimit combined words.
URI
Every URI MUST follow the General Rules. In addition, an URI MUST NOT end with a trailing slash (/).
Example
A well-formed URI:
/system_orders/1234/author
Query Parameters and Path Fragments
Every URI query parameter or fragment MUST follow the General Rules. In addition, they MUST NOT clash with the reserved query parameter names.
URI Template Variables
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.
Example
A well-formed URI Template Variable:
/system_orders/{order_id}/author
Representation Format Fields
Every representation format field MUST conform to the General Naming Rules.
Example
A well-formed resource representation:
{
  "_links": {
    "self": {
      "href": "/orders/1234"
    },
    "author": {
      "href": "/users/john"
    }
  },
  "order_number": 1234,
  "item_count": 42,
  "status": "pending"
}
Relation Type Identifier
Every custom relation identifier MUST be in lowercase with words separated by hyphen (-).
Example
A well-formed resource representation with custom relation fulfillment-provider:
{
  "_links": {
    "fulfillment-provider": {
      "href": "/users/natalie"
    }
  }
}
HTTP Headers
Every HTTP Header should use Hyphenated-Pascal-Case. A custom HTTP Header SHOULD NOT start with X- (RFC6648).
Example
ORDER-METADATA-HEADER: 42
API Description
Naming conventions within API Description document.
API Name
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.
Example
swagger: '2.0'
info:
  version: '1.0.0'
  title: '[Demo] Orders API'
Resource Name
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.
Example
/orders:
  x-summary: List of Orders
Action Name
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.
Example
get:
  summary: Retrieve List of Orders