Skip to content

Latest commit

 

History

History
710 lines (545 loc) · 55 KB

Org.OData.Capabilities.V1.md

File metadata and controls

710 lines (545 loc) · 55 KB

Capabilities Vocabulary

Namespace: Org.OData.Capabilities.V1

Terms describing capabilities of a service

There are some capabilities which are strongly recommended for services to support even though they are optional. Support for $top and $skip is a good example as supporting these query options helps with performance of a service and are essential. Such capabilities are assumed to be default capabilities of an OData service even in the case that a capabilities annotation doesn’t exist. Capabilities annotations are mainly expected to be used to explicitly specify that a service doesn’t support such capabilities. Capabilities annotations can as well be used to declaratively specify the support of such capabilities.

On the other hand, there are some capabilities that a service may choose to support or not support and in varying degrees. $filter and $orderby are such good examples. This vocabulary aims to define terms to specify support or no support for such capabilities.

A service is assumed to support by default the following capabilities even though an annotation doesn’t exist:

  • Countability ($count)
  • Client pageability ($top, $skip)
  • Expandability ($expand)
  • Indexability by key
  • Batch support ($batch)
  • Navigability of navigation properties

A service is expected to support the following capabilities. If not supported, the service is expected to call out the restrictions using annotations:

  • Filterability ($filter)
  • Sortability ($orderby)
  • Queryability of top level entity sets
  • Query functions

A client cannot assume that a service supports certain capabilities. A client can try, but it needs to be prepared to handle an error in case the following capabilities are not supported:

  • Insertability
  • Updatability
  • Deletability

Terms

Term Type Description
ConformanceLevel ConformanceLevelType The conformance level achieved by this service
SupportedFormats [MediaType] Media types of supported formats, including format parameters
SupportedMetadataFormats [MediaType] Media types of supported formats for $metadata, including format parameters
AcceptableEncodings [String] List of acceptable compression methods for ($batch) requests, e.g. gzip
AsynchronousRequestsSupported Tag Service supports the asynchronous request preference
BatchContinueOnErrorSupported Tag Service supports the continue on error preference. Supports $batch requests. Services that apply the BatchContinueOnErrorSupported term should also specify the ContinueOnErrorSupported property from the BatchSupport term.
IsolationSupported IsolationLevel Supported odata.isolation levels
CrossJoinSupported Tag Supports cross joins for the entity sets in this container
CallbackSupported CallbackType Supports callbacks for the specified protocols
ChangeTracking ChangeTrackingType Change tracking capabilities of this service or entity set
CountRestrictions CountRestrictionsType Restrictions on /$count path suffix and $count=true system query option
NavigationRestrictions NavigationRestrictionsType Restrictions on navigating properties according to OData URL conventions
Restrictions specified on an entity set are valid whether the request is directly to the entity set or through a navigation property bound to that entity set. Services can specify a different set of restrictions specific to a path, in which case the more specific restrictions take precedence.
IndexableByKey Tag Supports key values according to OData URL conventions
TopSupported Tag Supports $top
SkipSupported Tag Supports $skip
ComputeSupported Tag Supports $compute
SelectSupport SelectSupportType Support for $select and nested query options within $select
BatchSupported Tag Supports $batch requests. Services that apply the BatchSupported term should also apply the more comprehensive BatchSupport term.
BatchSupport BatchSupportType Batch Support for the service
FilterFunctions [String] List of functions and operators supported in filter expressions
If not specified, null, or empty, all functions and operators may be attempted.
FilterRestrictions FilterRestrictionsType Restrictions on filter expressions
SortRestrictions SortRestrictionsType Restrictions on orderby expressions
ExpandRestrictions ExpandRestrictionsType Restrictions on expand expressions
SearchRestrictions SearchRestrictionsType Restrictions on search expressions
KeyAsSegmentSupported Tag Supports key-as-segment convention for addressing entities within a collection
QuerySegmentSupported Tag Supports passing query options in the request body
InsertRestrictions InsertRestrictionsType Restrictions on insert operations
DeepInsertSupport DeepInsertSupportType? Deep Insert Support of the annotated resource (the whole service, an entity set, or a collection-valued resource)
UpdateRestrictions UpdateRestrictionsType Restrictions on update operations
DeepUpdateSupport DeepUpdateSupportType Deep Update Support of the annotated resource (the whole service, an entity set, or a collection-valued resource)
DeleteRestrictions DeleteRestrictionsType Restrictions on delete operations
CollectionPropertyRestrictions [CollectionPropertyRestrictionsType] Describes restrictions on operations applied to collection-valued structural properties
OperationRestrictions OperationRestrictionsType Restrictions for function or action operation
AnnotationValuesInQuerySupported Tag Supports annotation values within system query options
ModificationQueryOptions ModificationQueryOptionsType Support for query options with modification requests (insert, update, action invocation)
ReadRestrictions ReadRestrictionsType Restrictions for retrieving a collection of entities, retrieving a singleton instance.
CustomHeaders [CustomParameter] Custom headers that are supported/required for the annotated resource (Example)
CustomQueryOptions [CustomParameter] Custom query options that are supported/required for the annotated resource (Example)
If the entity container is annotated, the query option is supported/required by all resources in that container.
MediaLocationUpdateSupported Tag Stream property or media stream supports update of its media edit URL and/or media read URL
DefaultCapabilities DefaultCapabilitiesType Default capability settings for all collection-valued resources in the container

Annotating a specific capability term, which is included as property in DefaultCapabilitiesType, for a specific collection-valued resource overrides the default capability with the specified properties using PATCH semantics:

  • Primitive or collection-valued properties specified in the specific capability term replace the corresponding properties specified in DefaultCapabilities
  • Complex-valued properties specified in the specific capability term override the corresponding properties specified in DefaultCapabilities using PATCH semantics recursively
  • Properties specified neither in the specific term nor in DefaultCapabilities have their default value

Member Value Description
Minimal 0 Minimal conformance level
Intermediate 1 Intermediate conformance level
Advanced 2 Advanced conformance level

Flag Member Value Description
Snapshot 1 All data returned for a request, including multiple requests within a batch or results retrieved across multiple pages, will be consistent as of a single point in time

A non-empty collection lists the full set of supported protocols. A empty collection means 'only HTTP is supported'

Property Type Description
CallbackProtocols [CallbackProtocol] List of supported callback protocols, e.g. http or wss

Property Type Description
Id String? Protocol Identifier
UrlTemplate String? URL Template including parameters. Parameters are enclosed in curly braces {} as defined in RFC6570
DocumentationUrl URL? Human readable description of the meaning of the URL Template parameters

Derived Types:

Property Type Description
Supported Boolean odata.track-changes preference is supported

Property Type Description
Supported Boolean odata.track-changes preference is supported
FilterableProperties [PropertyPath] Change tracking supports filters on these properties
If no properties are specified or FilterableProperties is omitted, clients cannot assume support for filtering on any properties in combination with change tracking.
ExpandableProperties [NavigationPropertyPath] Change tracking supports these properties expanded
If no properties are specified or ExpandableProperties is omitted, clients cannot assume support for expanding any properties in combination with change tracking.

Derived Types:

Property Type Description
Countable Boolean Instances can be counted in requests targeting a collection

Property Type Description
Countable Boolean Instances can be counted in requests targeting a collection
NonCountableProperties [PropertyPath] Members of these collection properties cannot be counted
NonCountableNavigationProperties [NavigationPropertyPath] Members of these navigation properties cannot be counted

Property Type Description
Navigability NavigationType? Default navigability for all navigation properties of the annotation target. Individual navigation properties can override this value via RestrictedProperties/Navigability.
RestrictedProperties [NavigationPropertyRestriction] List of navigation properties with restrictions

Using a property of NavigationPropertyRestriction in a NavigationRestrictions annotation is discouraged in favor of using an annotation with the corresponding term from this vocabulary and a target path starting with a container and ending in the NavigationProperty, unless the favored alternative is impossible because a dynamic expression requires an instance path whose evaluation starts at the target of the NavigationRestrictions annotation. See this example.

Property Type Description
NavigationProperty NavigationPropertyPath Navigation properties can be navigated
The target path of a NavigationRestrictions annotation followed by this navigation property path addresses the resource to which the other properties of NavigationPropertyRestriction apply. Instance paths that occur in dynamic expressions are evaluated starting at the boundary between both paths, which must therefore be chosen accordingly.
Navigability NavigationType? Supported navigability of this navigation property
FilterFunctions [String] List of functions and operators supported in filter expressions
If not specified, null, or empty, all functions and operators may be attempted.
FilterRestrictions FilterRestrictionsType? Restrictions on filter expressions
SearchRestrictions SearchRestrictionsType? Restrictions on search expressions
SortRestrictions SortRestrictionsType? Restrictions on orderby expressions
TopSupported Boolean Supports $top
SkipSupported Boolean Supports $skip
SelectSupport SelectSupportType? Support for $select
IndexableByKey Boolean Supports key values according to OData URL conventions
InsertRestrictions InsertRestrictionsType? Restrictions on insert operations
DeepInsertSupport DeepInsertSupportType? Deep Insert Support of the annotated resource (the whole service, an entity set, or a collection-valued resource)
UpdateRestrictions UpdateRestrictionsType? Restrictions on update operations
DeepUpdateSupport DeepUpdateSupportType? Deep Update Support of the annotated resource (the whole service, an entity set, or a collection-valued resource)
DeleteRestrictions DeleteRestrictionsType? Restrictions on delete operations
OptimisticConcurrencyControl Boolean Data modification (including insert) along this navigation property requires the use of ETags
ReadRestrictions ReadRestrictionsType? Restrictions for retrieving entities

Member Value Description
Recursive 0 Navigation properties can be recursively navigated
Single 1 Navigation properties can be navigated to a single level
None 2 Navigation properties are not navigable

Property Type Description
Supported Boolean Supports $select
InstanceAnnotationsSupported Boolean Supports instance annotations in $select list
Expandable Boolean $expand within $select is supported
Filterable Boolean $filter within $select is supported
Searchable Boolean $search within $select is supported
TopSupported Boolean $top within $select is supported
SkipSupported Boolean $skip within $select is supported
ComputeSupported Boolean $compute within $select is supported
Countable Boolean $count within $select is supported
Sortable Boolean $orderby within $select is supported

Property Type Description
Supported Boolean Service supports requests to $batch
ContinueOnErrorSupported Boolean Service supports the continue on error preference
ReferencesInRequestBodiesSupported Boolean Service supports Content-ID referencing in request bodies
ReferencesAcrossChangeSetsSupported Boolean Service supports Content-ID referencing across change sets
EtagReferencesSupported Boolean Service supports referencing Etags from previous requests
RequestDependencyConditionsSupported Boolean Service supports the if member in JSON batch requests
SupportedFormats [MediaType] Media types of supported formats for $batch
Allowed Values:
multipart/mixed
Multipart Batch Format
application/json
JSON Batch Format

Applicable Annotation Terms:

Derived Types:

Property Type Description
Filterable Boolean $filter is supported
RequiresFilter Boolean $filter is required
MaxLevels Int32 The maximum number of levels (including recursion) that can be traversed in a filter expression. A value of -1 indicates there is no restriction.

Applicable Annotation Terms:

Property Type Description
Filterable Boolean $filter is supported
RequiresFilter Boolean $filter is required
MaxLevels Int32 The maximum number of levels (including recursion) that can be traversed in a filter expression. A value of -1 indicates there is no restriction.
RequiredProperties [PropertyPath] These properties must be specified in the $filter clause (properties of derived types are not allowed here)
NonFilterableProperties [PropertyPath] These structural properties cannot be used in filter expressions
FilterExpressionRestrictions [FilterExpressionRestrictionType] These properties only allow a subset of filter expressions. A valid filter expression for a single property can be enclosed in parentheses and combined by and with valid expressions for other properties.

Applicable Annotation Terms:

Property Type Description
Property PropertyPath? Path to the restricted property
AllowedExpressions FilterExpressionType? Allowed subset of expressions

Type: String

Allowed Value Description
SingleValue Property can be used in a single eq clause
MultiValue Property can be used in multiple eq and in clauses, combined by or (which is logically equivalent to a single in clause)
SingleRange Property can be compared to a single closed, half-open, or open interval
The filter expression for this property consists of a single interval expression, which is either a single comparison of the property and a literal value with eq, le, lt, ge, or gt, or a pair of boundaries combined by and. The lower boundary is either ge or gt, the upper boundary either le or lt.
MultiRange Property can be compared to a union of one or more closed, half-open, or open intervals
The filter expression for this property consists of one or more interval expressions, combined by or. See SingleRange for the definition of an interval expression.
Alternatively the filter expression can consist of one or more ne expressions combined by and, which is roughly equivalent to the union of the complementing open intervals. Roughly equivalent because null is allowed as a right-side operand of an ne expression.
SearchExpression String property can be used as first operand in startswith, endswith, and contains clauses
MultiRangeOrSearchExpression Property can be compared to a union of zero or more closed, half-open, or open intervals plus zero or more simple string patterns
The filter expression for this property consists of one or more interval expressions or string comparison functions combined by or. See SingleRange for the definition of an interval expression. See SearchExpression for the allowed string comparison functions.

Derived Types:

Property Type Description
Sortable Boolean $orderby is supported

Applicable Annotation Terms:

Property Type Description
Sortable Boolean $orderby is supported
AscendingOnlyProperties [PropertyPath] These properties can only be used for sorting in Ascending order
DescendingOnlyProperties [PropertyPath] These properties can only be used for sorting in Descending order
NonSortableProperties [PropertyPath] These structural properties cannot be used in orderby expressions

Applicable Annotation Terms:

Derived Types:

Property Type Description
Expandable Boolean $expand is supported
StreamsExpandable Boolean $expand is supported for stream properties and media streams
MaxLevels Int32 The maximum number of levels that can be expanded in a expand expression. A value of -1 indicates there is no restriction.

Applicable Annotation Terms:

Property Type Description
Expandable Boolean $expand is supported
StreamsExpandable Boolean $expand is supported for stream properties and media streams
MaxLevels Int32 The maximum number of levels that can be expanded in a expand expression. A value of -1 indicates there is no restriction.
NonExpandableProperties [NavigationPropertyPath] These properties cannot be used in expand expressions
NonExpandableStreamProperties [PropertyPath] These stream properties cannot be used in expand expressions

Applicable Annotation Terms:

Property Type Description
Searchable Boolean $search is supported
UnsupportedExpressions SearchExpressions Expressions not supported in $search

Applicable Annotation Terms:

Flag Member Value Description
none 0 Single search term
AND 1 Multiple search terms, optionally separated by AND
OR 2 Multiple search terms separated by OR
NOT 4 Search terms preceded by NOT
phrase 8 Search phrases enclosed in double quotes
group 16 Precedence grouping of search expressions with parentheses

Derived Types:

Property Type Description
Insertable Boolean Entities can be inserted
MaxLevels Int32 The maximum number of navigation properties that can be traversed when addressing the collection to insert into. A value of -1 indicates there is no restriction.
TypecastSegmentSupported Boolean Entities of a specific derived type can be created by specifying a type-cast segment
QueryOptions ModificationQueryOptionsType? Support for query options with insert requests
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.

Property Type Description
Insertable Boolean Entities can be inserted
MaxLevels Int32 The maximum number of navigation properties that can be traversed when addressing the collection to insert into. A value of -1 indicates there is no restriction.
TypecastSegmentSupported Boolean Entities of a specific derived type can be created by specifying a type-cast segment
QueryOptions ModificationQueryOptionsType? Support for query options with insert requests
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.
NonInsertableProperties [PropertyPath] These structural properties cannot be specified on insert
NonInsertableNavigationProperties [NavigationPropertyPath] These navigation properties do not allow deep inserts
RequiredProperties [PropertyPath] These structural properties must be specified on insert
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to perform the insert.

Property Type Description
SchemeName SchemeName Authorization flow scheme name
Scopes [ScopeType] List of scopes that can provide access to the resource

Property Type Description
Scope String Name of the scope.
RestrictedProperties String? Comma-separated string value of all properties that will be included or excluded when using the scope.
Possible string value identifiers when specifying properties are *, PropertyName, -PropertyName.
* denotes all properties are accessible.
-PropertyName excludes that specific property.
PropertyName explicitly provides access to the specific property.
The absence of RestrictedProperties denotes all properties are accessible using that scope.

Property Type Description
Supported Boolean Annotation target supports deep inserts
ContentIDSupported Boolean Annotation target supports accepting and returning nested entities annotated with the Core.ContentID instance annotation.

Derived Types:

Property Type Description
Updatable Boolean Entities can be updated
Upsertable Boolean Entities can be upserted
DeltaUpdateSupported Boolean Entities can be inserted, updated, and deleted via a PATCH request with a delta payload
UpdateMethod HttpMethod? Supported HTTP Methods (PUT or PATCH) for updating an entity. If null, PATCH SHOULD be supported and PUT MAY be supported.
FilterSegmentSupported Boolean Members of collections can be updated via a PATCH request with a /$filter(...)/$each segment
TypecastSegmentSupported Boolean Members of collections can be updated via a PATCH request with a type-cast segment and a /$each segment
MaxLevels Int32 The maximum number of navigation properties that can be traversed when addressing the collection or entity to update. A value of -1 indicates there is no restriction.
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to perform the update.
QueryOptions ModificationQueryOptionsType? Support for query options with update requests
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.

Property Type Description
Updatable Boolean Entities can be updated
Upsertable Boolean Entities can be upserted
DeltaUpdateSupported Boolean Entities can be inserted, updated, and deleted via a PATCH request with a delta payload
UpdateMethod HttpMethod? Supported HTTP Methods (PUT or PATCH) for updating an entity. If null, PATCH SHOULD be supported and PUT MAY be supported.
FilterSegmentSupported Boolean Members of collections can be updated via a PATCH request with a /$filter(...)/$each segment
TypecastSegmentSupported Boolean Members of collections can be updated via a PATCH request with a type-cast segment and a /$each segment
MaxLevels Int32 The maximum number of navigation properties that can be traversed when addressing the collection or entity to update. A value of -1 indicates there is no restriction.
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to perform the update.
QueryOptions ModificationQueryOptionsType? Support for query options with update requests
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.
NonUpdatableProperties [PropertyPath] These structural properties cannot be specified on update
NonUpdatableNavigationProperties [NavigationPropertyPath] These navigation properties do not allow rebinding
RequiredProperties [PropertyPath] These structural properties must be specified on update

Flag Member Value Description
GET 1 The HTTP GET Method
PATCH 2 The HTTP PATCH Method
PUT 4 The HTTP PUT Method
POST 8 The HTTP POST Method
DELETE 16 The HTTP DELETE Method
OPTIONS 32 The HTTP OPTIONS Method
HEAD 64 The HTTP HEAD Method

Property Type Description
Supported Boolean Annotation target supports deep updates
ContentIDSupported Boolean Annotation target supports accepting and returning nested entities annotated with the Core.ContentID instance annotation.

Derived Types:

Property Type Description
Deletable Boolean Entities can be deleted
MaxLevels Int32 The maximum number of navigation properties that can be traversed when addressing the collection to delete from or the entity to delete. A value of -1 indicates there is no restriction.
FilterSegmentSupported Boolean Members of collections can be deleted via a DELETE request with a /$filter(...)/$each segment
TypecastSegmentSupported Boolean Members of collections can be deleted via a DELETE request with a type-cast segment and a /$each segment
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to perform the delete.
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.

Property Type Description
Deletable Boolean Entities can be deleted
MaxLevels Int32 The maximum number of navigation properties that can be traversed when addressing the collection to delete from or the entity to delete. A value of -1 indicates there is no restriction.
FilterSegmentSupported Boolean Members of collections can be deleted via a DELETE request with a /$filter(...)/$each segment
TypecastSegmentSupported Boolean Members of collections can be deleted via a DELETE request with a type-cast segment and a /$each segment
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to perform the delete.
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.
NonDeletableNavigationProperties [NavigationPropertyPath] These navigation properties do not allow DeleteLink requests

Property Type Description
CollectionProperty PropertyPath? Restricted Collection-valued property
FilterFunctions [String] List of functions and operators supported in filter expressions
If not specified, null, or empty, all functions and operators may be attempted.
FilterRestrictions FilterRestrictionsType? Restrictions on filter expressions
SearchRestrictions SearchRestrictionsType? Restrictions on search expressions
SortRestrictions SortRestrictionsType? Restrictions on orderby expressions
TopSupported Boolean Supports $top
SkipSupported Boolean Supports $skip
SelectSupport SelectSupportType? Support for $select
Insertable Boolean Members can be inserted into this collection
If additionally annotated with Core.PositionalInsert, members can be inserted at a specific position
Updatable Boolean Members of this ordered collection can be updated by ordinal
Deletable Boolean Members of this ordered collection can be deleted by ordinal

Property Type Description
FilterSegmentSupported Boolean Bound action or function can be invoked on a collection-valued binding parameter path with a /$filter(...) segment
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to invoke an action or function
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
ErrorResponses [HttpResponse] Possible error responses returned by the request.

Property Type Description
ExpandSupported Boolean Supports $expand with modification requests
SelectSupported Boolean Supports $select with modification requests
ComputeSupported Boolean Supports $compute with modification requests
FilterSupported Boolean Supports $filter with modification requests
SearchSupported Boolean Supports $search with modification requests
SortSupported Boolean Supports $orderby with modification requests

Derived Types:

Property Type Description
Readable Boolean Entities can be retrieved
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to read.
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.

Restrictions for retrieving an entity by key

Property Type Description
Readable Boolean Entities can be retrieved
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to read.
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.

Property Type Description
Readable Boolean Entities can be retrieved
Permissions [PermissionType?] Required permissions. One of the specified sets of scopes is required to read.
CustomHeaders [CustomParameter] Supported or required custom headers
CustomQueryOptions [CustomParameter] Supported or required custom query options
Description String? A brief description of the request
LongDescription String? A long description of the request
ErrorResponses [HttpResponse] Possible error responses returned by the request.
TypecastSegmentSupported Boolean Entities of a specific derived type can be read by specifying a type-cast segment
ReadByKeyRestrictions ReadByKeyRestrictionsType? Restrictions for retrieving an entity by key
Only valid when applied to a collection. If a property of ReadByKeyRestrictions is not specified, the corresponding property value of ReadRestrictions applies.

A custom parameter is either a header or a query option

The type of a custom parameter is always a string. Restrictions on the parameter values can be expressed by annotating the record expression describing the parameter with terms from the Validation vocabulary, e.g. Validation.Pattern or Validation.AllowedValues.

Property Type Description
Name String Name of the custom parameter
Description String? Description of the custom parameter
DocumentationURL URL? URL of related documentation
Required Boolean true: parameter is required, false or not specified: parameter is optional
ExampleValues [PrimitiveExampleValue] Example values for the custom parameter

Property Type Description
ChangeTracking ChangeTrackingBase? Change tracking capabilities
CountRestrictions CountRestrictionsBase? Restrictions on /$count path suffix and $count=true system query option
IndexableByKey Tag? Supports key values according to OData URL conventions
TopSupported Tag? Supports $top
SkipSupported Tag? Supports $skip
ComputeSupported Tag? Supports $compute
SelectSupport SelectSupportType? Support for $select and nested query options within $select
FilterRestrictions FilterRestrictionsBase? Restrictions on filter expressions
SortRestrictions SortRestrictionsBase? Restrictions on orderby expressions
ExpandRestrictions ExpandRestrictionsBase? Restrictions on expand expressions
SearchRestrictions SearchRestrictionsType? Restrictions on search expressions
InsertRestrictions InsertRestrictionsBase? Restrictions on insert operations
UpdateRestrictions UpdateRestrictionsBase? Restrictions on update operations
DeleteRestrictions DeleteRestrictionsBase? Restrictions on delete operations
OperationRestrictions OperationRestrictionsType? Restrictions for function or action operations
ReadRestrictions ReadRestrictionsType? Restrictions for retrieving a collection of entities, retrieving a singleton instance

Property Type Description
StatusCode String HTTP response status code, for example 400, 403, 501
Description String Human-readable description of the response