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
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
|
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 |
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 |