Data types
TypeSpec.Httpβ
AcceptedResponse
β
The request has been accepted for processing, but processing has not yet completed.
model TypeSpec.Http.AcceptedResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 202 | The status code. |
ApiKeyAuth
β
An API key is a token that a client provides when making API calls. The key can be sent in the query string:
GET /something?api_key=abcdef12345
or as a request header
GET /something HTTP/1.1
X-API-Key: abcdef12345
or as a cookie
GET /something HTTP/1.1
Cookie: X-API-KEY=abcdef12345
model TypeSpec.Http.ApiKeyAuth<Location, Name>
Template Parametersβ
Name | Description |
---|---|
Location | The location of the API key |
Name | The name of the API key |
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.AuthType.apiKey | |
in | Location | |
name | Name |
AuthorizationCodeFlow
β
Authorization Code flow
model TypeSpec.Http.AuthorizationCodeFlow
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.OAuth2FlowType.authorizationCode | authorization code flow |
authorizationUrl | string | the authorization URL |
tokenUrl | string | the token URL |
refreshUrl? | string | the refresh URL |
scopes? | string[] | list of scopes for the credential |
BadRequestResponse
β
The server could not understand the request due to invalid syntax.
model TypeSpec.Http.BadRequestResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 400 | The status code. |
BasicAuth
β
Basic authentication is a simple authentication scheme built into the HTTP protocol.
The client sends HTTP requests with the Authorization header that contains the word Basic word followed by a space and a base64-encoded string username:password.
For example, to authorize as demo / p@55w0rd
the client would send
Authorization: Basic ZGVtbzpwQDU1dzByZA==
model TypeSpec.Http.BasicAuth
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.AuthType.http | Http authentication |
scheme | "basic" | basic auth scheme |
BearerAuth
β
Bearer authentication (also called token authentication) is an HTTP authentication scheme that involves security tokens called bearer tokens. The name βBearer authenticationβ can be understood as βgive access to the bearer of this token.β The bearer token is a cryptic string, usually generated by the server in response to a login request. The client must send this token in the Authorization header when making requests to protected resources:
Authorization: Bearer <token>
model TypeSpec.Http.BearerAuth
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.AuthType.http | Http authentication |
scheme | "bearer" | bearer auth scheme |
Body
β
Defines a model with a single property of the given type, marked with @body
.
This can be useful in situations where you cannot use a bare type as the body and it is awkward to add a property.
model TypeSpec.Http.Body<Type>
Template Parametersβ
Name | Description |
---|---|
Type | The type of the model's body property. |
Propertiesβ
Name | Type | Description |
---|---|---|
body | Type |
ClientCredentialsFlow
β
Client credentials flow
model TypeSpec.Http.ClientCredentialsFlow
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.OAuth2FlowType.clientCredentials | client credential flow |
tokenUrl | string | the token URL |
refreshUrl? | string | the refresh URL |
scopes? | string[] | list of scopes for the credential |
ConflictResponse
β
The request conflicts with the current state of the server.
model TypeSpec.Http.ConflictResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 409 | The status code. |
CreatedResponse
β
The request has succeeded and a new resource has been created as a result.
model TypeSpec.Http.CreatedResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 201 | The status code. |
ForbiddenResponse
β
Access is forbidden.
model TypeSpec.Http.ForbiddenResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 403 | The status code. |
HeaderOptions
β
Header options.
model TypeSpec.Http.HeaderOptions
Propertiesβ
Name | Type | Description |
---|---|---|
name? | string | Name of the header when sent over HTTP. |
format? | "csv" | "multi" | "tsv" | "ssv" | "pipes" | "simple" | "form" | Determines the format of the array if type array is used. |
ImplicitFlow
β
Implicit flow
model TypeSpec.Http.ImplicitFlow
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.OAuth2FlowType.implicit | implicit flow |
authorizationUrl | string | the authorization URL |
refreshUrl? | string | the refresh URL |
scopes? | string[] | list of scopes for the credential |
LocationHeader
β
The Location header contains the URL where the status of the long running operation can be checked.
model TypeSpec.Http.LocationHeader
Propertiesβ
Name | Type | Description |
---|---|---|
location | string | The Location header contains the URL where the status of the long running operation can be checked. |
MovedResponse
β
The URL of the requested resource has been changed permanently. The new URL is given in the response.
model TypeSpec.Http.MovedResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 301 | The status code. |
location | string | The Location header contains the URL where the status of the long running operation can be checked. |
NoAuth
β
This authentication option signifies that API is not secured at all. It might be useful when overriding authentication on interface of operation level.
model TypeSpec.Http.NoAuth
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.AuthType.noAuth |
NoContentResponse
β
There is no content to send for this request, but the headers may be useful.
model TypeSpec.Http.NoContentResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 204 | The status code. |
NotFoundResponse
β
The server cannot find the requested resource.
model TypeSpec.Http.NotFoundResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 404 | The status code. |
NotModifiedResponse
β
The client has made a conditional request and the resource has not been modified.
model TypeSpec.Http.NotModifiedResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 304 | The status code. |
OAuth2Auth
β
OAuth 2.0 is an authorization protocol that gives an API client limited access to user data on a web server.
OAuth relies on authentication scenarios called flows, which allow the resource owner (user) to share the protected content from the resource server without sharing their credentials. For that purpose, an OAuth 2.0 server issues access tokens that the client applications can use to access protected resources on behalf of the resource owner. For more information about OAuth 2.0, see oauth.net and RFC 6749.
model TypeSpec.Http.OAuth2Auth<Flows, Scopes>
Template Parametersβ
Name | Description |
---|---|
Flows | The list of supported OAuth2 flows |
Scopes | The list of OAuth2 scopes, which are common for every flow from Flows . This list is combined with the scopes defined in specific OAuth2 flows. |
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.AuthType.oauth2 | |
flows | Flows | |
defaultScopes | Scopes |
OkResponse
β
The request has succeeded.
model TypeSpec.Http.OkResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 200 | The status code. |
OpenIdConnectAuth
β
OpenID Connect (OIDC) is an identity layer built on top of the OAuth 2.0 protocol and supported by some OAuth 2.0 providers, such as Google and Azure Active Directory. It defines a sign-in flow that enables a client application to authenticate a user, and to obtain information (or "claims") about that user, such as the user name, email, and so on. User identity information is encoded in a secure JSON Web Token (JWT), called ID token. OpenID Connect defines a discovery mechanism, called OpenID Connect Discovery, where an OpenID server publishes its metadata at a well-known URL, typically
https://server.com/.well-known/openid-configuration
model TypeSpec.Http.OpenIdConnectAuth<ConnectUrl>
Template Parametersβ
Name | Description |
---|---|
ConnectUrl |
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.AuthType.openIdConnect | Auth type |
openIdConnectUrl | ConnectUrl | Connect url. It can be specified relative to the server URL |
PasswordFlow
β
Resource Owner Password flow
model TypeSpec.Http.PasswordFlow
Propertiesβ
Name | Type | Description |
---|---|---|
type | TypeSpec.Http.OAuth2FlowType.password | password flow |
tokenUrl | string | the token URL |
refreshUrl? | string | the refresh URL |
scopes? | string[] | list of scopes for the credential |
PlainData
β
Produces a new model with the same properties as T, but with @query
,
@header
, @body
, and @path
decorators removed from all properties.
model TypeSpec.Http.PlainData<Data>
Template Parametersβ
Name | Description |
---|---|
Data | The model to spread as the plain data. |
Propertiesβ
None
QueryOptions
β
Query parameter options.
model TypeSpec.Http.QueryOptions
Propertiesβ
Name | Type | Description |
---|---|---|
name? | string | Name of the query when included in the url. |
format? | "multi" | "csv" | "ssv" | "tsv" | "simple" | "form" | "pipes" | Determines the format of the array if type array is used. |
Response
β
Describes an HTTP response.
model TypeSpec.Http.Response<Status>
Template Parametersβ
Name | Description |
---|---|
Status | The status code of the response. |
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | Status |
UnauthorizedResponse
β
Access is unauthorized.
model TypeSpec.Http.UnauthorizedResponse
Propertiesβ
Name | Type | Description |
---|---|---|
statusCode | 401 | The status code. |
ApiKeyLocation
β
Describes the location of the API key
enum TypeSpec.Http.ApiKeyLocation
AuthType
β
Authentication type
enum TypeSpec.Http.AuthType
OAuth2FlowType
β
Describes the OAuth2 flow type
enum TypeSpec.Http.OAuth2FlowType