Retrieves a list of recently used iTwins for the calling user. A user can only have 25 recently used iTwins. They are returned in order with the most recently used iTwin first in the list.
When a user accesses your application you can use the Add iTwin to my recents API to mark the iTwin as recently used. If there are already 25 recents, then the oldest one will be removed to make room for the new one.
Inactive iTwins
iTwins with status=Inactive are not returned by default. This improves query performance and reduces clutter in user interfaces by filtering out unused iTwins. You should still provide a way for users to see their Inactive iTwins if they request them. In the API, you can do this by setting the status parameter or by using the includeInactive parameter.
If status=Inactive, the API will return only Inactive iTwins.
If includeInactive=true, the API will return all iTwins (Active, Trial and Inactive).
The includeInactive parameter is optional and defaults to false. A 422 error will be returned if you try to use a status parameter at the same time as the includeInactive parameter.
Authentication
Requires Authorization header with valid Bearer token for scope itwin-platform.
For more documentation on authorization and how to get access token visit OAUTH2 Authorization page.
Authorization
Any user can call this endpoint. It will only return iTwins that the user is a member of. Use the Access Control API to manage an iTwin's members.
Request parameters
Specify a particular subClass that you wish to query on. The subClass is optional but queries will be faster if specified and we recommend specifying it whenever possible. You can specify more than one by using a comma delimited string. Example: subClass=Asset,Project will find all Assets or Projects matching your query criteria.
Specify a particular status that you wish to query on.
Specify a particular type that you wish to query on.
The $top system query option requests the number of items in the queried collection to be included in the result. The default is 100. The max is 1000.
The $skip query option requests the number of items in the queried collection that are to be skipped and not included in the result.
By default, the query will not return Inactive iTwins unless you set includeInactive=true. Cannot be used at the same time as the status parameter.
Request headers
OAuth access token with itwin-platform scope
Setting to application/vnd.bentley.itwin-platform.v1+json is recommended.
Indicates a level of details in the response. This operation supports 'return=representation' and 'return=minimal' preferences.
Response 200 OK
OK
{ "iTwins": [{ "id": "dc914a84-e0c9-40e2-9d14-faf5ed84147f", "class": "Endeavor", "subClass": "Project", "type": "Construction Project", "number": "00001-ds-3902795", "displayName": "White River" }, { "id": "dd50fa65-ff23-4778-831b-c2caa5471a97", "class": "Endeavor", "subClass": "Project", "type": "Construction Project", "number": "f7sa7fas89d", "displayName": "Battle Creek 3" } ], "_links": { "self": { "href": "https://api.bentley.com/iTwins/recents?$skip=0&$top=100" }, "prev": { "href": "https://api.bentley.com/iTwins/recents?$skip=0&$top=100" }, "next": { "href": "https://api.bentley.com/iTwins/recents?$skip=100&$top=100" } } }
Response 401 Unauthorized
This response indicates that request lacks valid authentication credentials. Access token might not been provided, issued by the wrong issuer, does not have required scopes or request headers were malformed.
{ "error": { "code": "HeaderNotFound", "message": "Header Authorization was not found in the request. Access denied." } }
Response 422 Unprocessable Entity
Invalid request to get iTwins
{ "error": { "code": "InvalidiTwinsRequest", "message": "Cannot query iTwins.", "details": [{ "code": "InvalidValue", "message": "The $top query option must be a positive integer that does not exceed 1000.", "target": "$top" }, { "code": "InvalidValue", "message": "The $skip query option must be a non-negative integer.", "target": "$skip" }, { "code": "InvalidValue", "message": "A valid iTwin SubClass was not specified in the query.", "target": "subClass" }, { "code": "InvalidValue", "message": "Status value is incorrect. Valid values are Active, Inactive and Trial.", "target": "status" }, { "code": "InvalidParameter", "message": "The includeInactive parameter should not be used at the same time as the status parameter.", "target": "includeInactive" } ] } }
Response 429 Too many requests
This response indicates that the client sent more requests than allowed by this API for the current tier of the client.
{ "error": { "code": "RateLimitExceeded", "message": "The client sent more requests than allowed by this API for the current tier of the client." } }
Response headers
Number of seconds to wait until client is allowed to make more requests.
iTwin (summary)
Minimal representation of a iTwin that contains only id, class, subClass, type, number and displayName.
The iTwin Id.
An open ended property to better define your iTwin's Type.
A unique number or code for the iTwin. This is the value that uniquely identifies the iTwin within your organization.
A display name for the iTwin.
Must be one of Active, Inactive or Trial. The default value is Active. By default, Inactive iTwins are not returned from the Get my iTwins API unless requested using the includeInactive parameter.
{ "type": "object", "title": "iTwin (summary)", "description": "Minimal representation of a iTwin that contains only id, class, subClass, type, number and displayName.", "properties": { "id": { "type": "string", "description": "The iTwin Id." }, "class": { "$ref": "#/components/schemas/iTwinClass", "description": "The [Class](https://developer.bentley.com/apis/itwins/overview/#itwinclassesandsubclasses) of your iTwin." }, "subClass": { "$ref": "#/components/schemas/iTwinSubClass", "description": "The [subClass](https://developer.bentley.com/apis/itwins/overview/#itwinclassesandsubclasses) your iTwin." }, "type": { "type": "string", "nullable": true, "description": "An open ended property to better define your iTwin's Type.", "maxLength": 100 }, "number": { "type": "string", "description": "A unique number or code for the iTwin. This is the value that uniquely identifies the iTwin within your organization.", "maxLength": 255 }, "displayName": { "type": "string", "description": "A display name for the iTwin.", "maxLength": 255 }, "status": { "$ref": "#/components/schemas/iTwinStatus", "description": "Must be one of Active, Inactive or Trial. The default value is Active. By default, Inactive iTwins are not returned from the [Get my iTwins API](https://developer.bentley.com/apis/itwins/operations/get-my-itwins/) unless requested using the includeInactive parameter." } }, "additionalProperties": false }
iTwin
Full representation of a iTwin.
The iTwin Id.
An open ended property to better define your iTwin's Type.
A unique number or code for the iTwin. This is the value that uniquely identifies the iTwin within your organization.
A display name for the iTwin.
An optional field specifying the location of the iTwin. This is typically an address or city.
An optional field specifying the latitude of the iTwin.
An optional field specifying the longitude of the iTwin.
An optional field specifying the time zone of the iTwin. This must be a valid [IANA] (https://www.iana.org/time-zones) time zone id.
The data center where the data for this iTwin will be persisted. Default is East US. Valid Values: East US, North Europe, West Europe, Southeast Asia, Australia East, UK South, Canada Central, Central India, Japan East.
Must be one of Active, Inactive or Trial. The default value is Active. By default, Inactive iTwins are not returned from the Get my iTwins API unless requested using the includeInactive parameter.
The Id of the parent of this iTwin. For example, a Project iTwin could be a child of an Asset iTwin.
The Id of the Account that owns this iTwin. The Account is also the root of any iTwin hierarchy.
The name of the image. The name is unique and will only change if the image changes.
The URL of the image. This is a small, thumbnail image that was created using the Upload iTwin Image API. The URL will be valid for a minimum of 1 hour.
The date that the iTwin was created.
The Id of the user that created the iTwin.
The date that the iTwin was last updated.
The Id of the user that last updated the iTwin.
{ "type": "object", "description": "Full representation of a iTwin.", "properties": { "id": { "type": "string", "description": "The iTwin Id." }, "class": { "$ref": "#/components/schemas/iTwinClass", "description": "The [Class](https://developer.bentley.com/apis/itwins/overview/#itwinclassesandsubclasses) of your iTwin." }, "subClass": { "$ref": "#/components/schemas/iTwinSubClass", "description": "The [subClass](https://developer.bentley.com/apis/itwins/overview/#itwinclassesandsubclasses) your iTwin." }, "type": { "type": "string", "nullable": true, "description": "An open ended property to better define your iTwin's Type.", "maxLength": 100 }, "number": { "type": "string", "description": "A unique number or code for the iTwin. This is the value that uniquely identifies the iTwin within your organization.", "maxLength": 255 }, "displayName": { "type": "string", "description": "A display name for the iTwin.", "maxLength": 255 }, "geographicLocation": { "type": "string", "nullable": true, "description": "An optional field specifying the location of the iTwin. This is typically an address or city.", "maxLength": 255 }, "latitude": { "type": "number", "format": "double", "nullable": true, "description": "An optional field specifying the latitude of the iTwin." }, "longitude": { "type": "number", "format": "double", "nullable": true, "description": "An optional field specifying the longitude of the iTwin." }, "ianaTimeZone": { "type": "string", "nullable": true, "description": "An optional field specifying the time zone of the iTwin. This must be a valid [IANA] (https://www.iana.org/time-zones) time zone id." }, "dataCenterLocation": { "type": "string", "description": "The data center where the data for this iTwin will be persisted. Default is East US. Valid Values: East US, North Europe, West Europe, Southeast Asia, Australia East, UK South, Canada Central, Central India, Japan East." }, "status": { "$ref": "#/components/schemas/iTwinStatus", "description": "Must be one of Active, Inactive or Trial. The default value is Active. By default, Inactive iTwins are not returned from the [Get my iTwins API](https://developer.bentley.com/apis/itwins/operations/get-my-itwins/) unless requested using the includeInactive parameter." }, "parentId": { "type": "string", "nullable": true, "description": "The Id of the parent of this iTwin. For example, a Project iTwin could be a child of an Asset iTwin." }, "iTwinAccountId": { "type": "string", "nullable": true, "description": "The Id of the Account that owns this iTwin. The Account is also the root of any iTwin hierarchy." }, "imageName": { "type": "string", "nullable": true, "description": "The name of the image. The name is unique and will only change if the image changes." }, "image": { "type": "string", "nullable": true, "description": "The URL of the image. This is a small, thumbnail image that was created using the [Upload iTwin Image API](https://developer.bentley.com/apis/operations/upload-itwin-image/). The URL will be valid for a minimum of 1 hour." }, "createdDateTime": { "type": "string", "format": "date-time", "description": "The date that the iTwin was created." }, "createdBy": { "type": "string", "nullable": true, "description": "The Id of the user that created the iTwin." }, "lastModifiedDateTime": { "type": "string", "format": "date-time", "description": "The date that the iTwin was last updated." }, "lastModifiedBy": { "type": "string", "nullable": true, "description": "The Id of the user that last updated the iTwin." } }, "additionalProperties": false }
iTwins (prefer return=minimal)
A list of iTwins in the minimal representation format.
{ "type": "object", "title": "iTwins (prefer return=minimal)", "description": "A list of iTwins in the minimal representation format.", "properties": { "iTwins": { "type": "array", "description": "A list of iTwins in the minimal representation format.", "items": { "$ref": "#/components/schemas/iTwin-summary" } }, "_links": { "description": "Contains the hyperlinks to the previous and next pages of results.", "$ref": "#/components/schemas/links-paging" } }, "additionalProperties": false }
iTwins (prefer return=representation)
A list of iTwins in the full representation format.
{ "type": "object", "title": "iTwins (prefer return=representation)", "description": "A list of iTwins in the full representation format.", "properties": { "iTwins": { "type": "array", "description": "A list of iTwins in the full representation format.", "items": { "$ref": "#/components/schemas/iTwin" } }, "_links": { "description": "Contains the hyperlinks to the previous and next pages of results.", "$ref": "#/components/schemas/links-paging" } }, "additionalProperties": false }
links (paging)
URLs for the current request, getting to the previous or next page of results.
{ "title": "links (paging)", "description": "URLs for the current request, getting to the previous or next page of results.", "type": "object", "properties": { "self": { "description": "URL for the current request.", "$ref": "#/components/schemas/link" }, "next": { "description": "URL for getting the next page of results. This will only exist if there is a next page.", "$ref": "#/components/schemas/link" }, "prev": { "description": "URL for getting the previous page of results. This will only exist if there is a prev page.", "$ref": "#/components/schemas/link" } }, "additionalProperties": false }
link
Hyperlink container.
Hyperlink container.
{ "type": "object", "description": "Hyperlink container.", "properties": { "href": { "type": "string", "description": "Hyperlink container." } }, "additionalProperties": false }
iTwin Status
One of 'Active', 'Inactive', 'Trial'
{ "type": "string", "title": "iTwin Status", "description": "One of 'Active', 'Inactive', 'Trial'", "enum": [ "Active", "Inactive", "Trial" ] }
iTwin Class
The Class of your iTwin.
{ "type": "string", "title": "iTwin Class", "description": "The [Class](https://developer.bentley.com/apis/itwins/overview/#itwinclassesandsubclasses) of your iTwin.", "enum": [ "Account", "Thing", "Endeavor" ] }
iTwin SubClass
The subClass your iTwin.
{ "type": "string", "title": "iTwin SubClass", "description": "The [subClass](https://developer.bentley.com/apis/itwins/overview/#itwinclassesandsubclasses) your iTwin.", "enum": [ "Account", "Portfolio", "Asset", "Program", "Project", "WorkPackage" ] }
Error
Contains error information.
One of a server-defined set of error codes.
A human-readable representation of the error.
The target of the error.
{ "type": "object", "description": "Contains error information.", "properties": { "code": { "type": "string", "description": "One of a server-defined set of error codes." }, "message": { "type": "string", "description": "A human-readable representation of the error." }, "target": { "type": "string", "description": "The target of the error.", "nullable": true } }, "required": [ "code", "message" ], "additionalProperties": true }
Error Response
Gives details for an error that occurred while handling the request. Note that clients MUST NOT assume that every failed request will produce an object of this schema, or that all of the properties in the response will be non-null, as the error may have prevented this response from being constructed.
{ "type": "object", "title": "Error Response", "description": "Gives details for an error that occurred while handling the request. Note that clients MUST NOT assume that every failed request will produce an object of this schema, or that all of the properties in the response will be non-null, as the error may have prevented this response from being constructed.", "properties": { "error": { "description": "Error information.", "$ref": "#/components/schemas/Error" } }, "required": [ "error" ], "additionalProperties": false }
Was this page helpful?