Displays
- Last UpdatedOct 08, 2025
- 7 minute read
- PI System
- PI Vision API Reference
- Developer
Displays endpoint, used to manipulate displays object on server.
Get Displays
Return list of displays. Additional parameters serve to support pagination and to narrow down the list to entities that are stored inside specific folder.
Request
GET /api/v1/displays
?FolderId={FolderId}&Skip={Skip}&Count={Count}
Request Headers
| Required | Header | Type | Description |
|---|---|---|---|
| yes | X-Requested-With | string | Any value. |
Parameters
[optional] integer FolderId
Parent Folder Id. Skip this parameter to get displays from the root folder.[optional] integer Skip
Amount of records to skip. Default: 0.[optional] integer Count
Amount of records to fetch. Default: 100.
Response
| Status Code | Body Type | Description |
|---|---|---|
| 200 | DisplaysResponse | Success. |
| 400 | None | Bad Request. |
| 401 | None | Unauthorized. |
| 403 | None | Forbidden. |
| 500 | None | Internal server error. |
Example response body
200 Response
The following example illustrate that folder has two displays. It may contain Folders as well, which can be requested by using Folders endpoint.
{
"Items": [
{
"Id": 78103,
"Name": "Display1",
"Owner": "Domain\\user"
},
{
"Id": 78127,
"Name": "Display2",
"Owner": "Domain\\user"
}
],
"HasMore": false
}
400 Response
{
"Message": "The request is invalid.",
"ModelState": {
"FolderId": [
"folderId parameter should be a positive integer."
]
}
}
Update Display
Writes display, attachments, labels, and identities into the database.
Request
PUT /api/v1/displays
Request Headers
| Required | Header | Type | Description |
|---|---|---|---|
| yes | X-Requested-With | string | Any value. |
Parameters
Request Body
DTO that contains information required to export/import display. Not all fields are changeable, and we recommend that you change only following fields:
Identities
Labels
ParentId
Display.Name
Display.Owner
{
"DatabaseID": "D2D817B21AD241ADBFEC6C3135E0F43C",
"Identities": [
{
"Identifier": "7eb0e507-fe9d-4c32-9ff0-8ff1ac7ad8ea",
"Name": "World",
"Permission": 0
}
],
"Labels": [],
"Display": {
"Symbols": [
{
"Name": "Symbol0",
"SymbolType": "group",
"Configuration": {
"Left": 40,
"Top": 15,
"Width": 1200,
"Height": 35,
"HideThumbnail": true,
"Fill": "rgba(0,0,0,0)",
"Children": [
"cboPeriod",
"CboSelectArea",
"cmdMoveBack",
"cmdMoveForward",
"cmdReset",
"chkSyncTrends",
"cmdHelp",
"cmdExport",
"cmdClose"
]
}
}
],
"AttachmentIds": [],
"RequestId": null,
"StartTime": "*-8h",
"EndTime": "*",
"LegacyDisplay": null,
"EventFramePath": null,
"Id": 78103,
"Name": "Sample Display",
"Path": null,
"Owner": "Domain\\user",
"ReadOnly": false,
"Revision": 0,
"DisplayProperties": {
"BackgroundColor": "#C0C0C0",
"Calculations": []
}
},
"Symbols": null,
"COG": null,
"StorageTypeId": 0,
"ParentId": null,
"Attachments": [],
"Created": "2019-10-02T00:36:07Z",
"Modified": "2019-11-10T19:04:51Z"
}
Response
| Status Code | Body Type | Description |
|---|---|---|
| 200 | DisplaySaveInfo | Success. |
| 400 | None | Bad Request. |
| 401 | None | Unauthorized. |
| 403 | None | Forbidden. |
| 500 | None | Internal server error. |
Example response body
200 Response
{
"Id": 100,
"PatchErrors": null,
"DuplicateDisplayWriteBehavior": "Overwrite"
}
400 Response
{
"Message": "The request is invalid.",
"ModelState": {
"FolderId": [
"folderId parameter should be a positive integer."
]
}
}
Get Display Export
Return export data for a single display. Will include metadata for display and information about associated entities.
Request
GET /api/v1/displays/{id}/export
Request Headers
| Required | Header | Type | Description |
|---|---|---|---|
| yes | X-Requested-With | string | Any value. |
Parameters
integer Id
Display Id.
Response
| Status Code | Body Type | Description |
|---|---|---|
| 200 | DisplayTransferInfo | Success. |
| 400 | None | Bad Request. |
| 401 | None | Unauthorized. |
| 403 | None | Forbidden. |
| 500 | None | Internal server error. |
Example response body
200 Response
{
"DatabaseID": "D2D817B21AD241ADBFEC6C3135E0F43C",
"Identities": [
{
"Identifier": "7eb0e507-fe9d-4c32-9ff0-8ff1ac7ad8ea",
"Name": "World",
"Permission": 0
}
],
"Labels": [],
"Display": {
"Symbols": [
{
"Name": "Symbol0",
"SymbolType": "statictext",
"Configuration": {
"Height": 34.5,
"SetTextFromLink": false,
"StaticText": "Thank you for being our client!",
"LinkURL": "",
"Fill": "rgba(255,255,255,0)",
"Stroke": "rgba(255,255,255,1)",
"Rotation": 0,
"FontSize": null,
"UseIntegerFontSize": false,
"Top": 112,
"Left": 53,
"Align": true
}
},
{
"Name": "Symbol2",
"SymbolType": "rectangle",
"Configuration": {
"Top": 23,
"Left": 54,
"Width": 406,
"Height": 84,
"Fill": "rgba(255,255,255,1)",
"Rotation": 0,
"Stroke": "rgba(255,255,255,1)",
"StrokeWidth": 3,
"StrokeStyle": ""
}
},
{
"Name": "Symbol1",
"SymbolType": "image",
"Configuration": {
"Top": 25,
"Left": 55,
"AttachmentId": 0,
"Width": 396,
"Height": 75,
"Rotation": 0
}
}],
"AttachmentIds": [],
"RequestId": null,
"StartTime": "*-8h",
"EndTime": "*",
"LegacyDisplay": null,
"EventFramePath": null,
"Id": 78103,
"Name": "Sample Display",
"Path": null,
"Owner": "Domain\\user",
"ReadOnly": true,
"Revision": 3,
"DisplayProperties": {
"BackgroundColor": "#C0C0C0",
"Calculations": []
},
"ProductVersion": "3.6"
},
"Symbols": null,
"COG": null,
"StorageTypeId": 0,
"ParentId": null,
"Attachments": [
{
"ID": 0,
"Name": "a0",
"Data": ""
}
],
"Created": "2019-10-02T00:36:07Z",
"Modified": "2019-11-10T19:04:51Z"
}
400 Response
{
"Message": "The request is invalid.",
"ModelState": {
"FolderId": [
"id parameter should be a positive integer."
]
}
}
List Display Identities
Return Access Rights for the specific display
Request
GET /api/v1/displays/{id}/AccessControl
Request Headers
| Required | Header | Type | Description |
|---|---|---|---|
| yes | X-Requested-With | string | Any value. |
Parameters
integer id
Display Id
Response
| Status Code | Body Type | Description |
|---|---|---|
| 200 | IdentityModel[] | Success. |
| 400 | None | Bad Request. |
| 401 | None | Unauthorized. |
| 403 | None | Forbidden. |
| 500 | None | Internal server error. |
Example response body
200 Response
[
{
"Identifier": "7eb0e507-fe9d-4c32-9ff0-8ff1ac7ad8ea",
"Name": "World",
"Permission": 0,
"Enabled": true
}
]
Put Display Identities
Set Access Rights for the specific display
Request
PUT /api/v1/displays/{id}/AccessControl
Request Headers
| Required | Header | Type | Description |
|---|---|---|---|
| yes | X-Requested-With | string | Any value. |
Parameters
integer id
Display Id
Request Body
Request information for updating display identities
{
"Identities": [
{
"Identifier": "a2c8b729-db89-49d8-8306-97072ec51111",
"Name": "DisplayGroup1",
"Permission": 0
},
{
"Identifier": "3f9dc5bc-ab4c-4fb3-a40b-1896a6581111",
"Name": "DisplayGroup2",
"Permission": 0
}
]
}
Response
| Status Code | Body Type | Description |
|---|---|---|
| 200 | string | Success. |
| 400 | None | Bad Request. |
| 401 | None | Unauthorized. |
| 403 | None | Forbidden. |
| 500 | None | Internal server error. |
Definitions
DisplaysResponse
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| Items | [DisplayInfo] | false | true | Requested items. |
| HasMore | boolean | false | false | Indicate if there are more items to request. |
{
"Items": [
{
"Id": 11,
"Name": "Main Display",
"Owner": "Domain\\user"
}
],
"HasMore": false
}
DisplayInfo
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| Id | int64 | false | false | None |
| Name | string | false | true | None |
| Owner | string | false | true | None |
{
"Id": 17,
"Name": "Display",
"Owner": "Domain\\user"
}
DisplayTransferInfo
Display information used to read or write a display
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| DatabaseID | string | true | true | Origin Database Id, used to maintain links during export/import. |
| TransferSessionId | guid | false | true | Obsolete. |
| Identities | [IdentityModel] | false | true | Gets or sets a list of identities that have access to this display. |
| Labels | string[] | false | true | None |
| Display | EditorDisplay | true | true | None |
| Symbols | object | false | true | Gets or sets a symbol list used for legacy displays. |
| COG | object | false | true | Gets or sets a COG used for legacy displays. |
| StorageTypeId | StorageType | false | false | Type of entity. Only StandardDisplay and EventCompareDisplay supported. |
| ParentId | int64 | false | true | Gets or sets the parent folder ID |
| Attachments | [Attachment] | false | true | None |
| ServerMappingInfo | ServerMappingInfo | false | true | Gets or sets AF and PI server mapping information. |
| DuplicateDisplayWriteBehavior | DuplicateDisplayWriteBehavior | false | false | Gets or sets an enum indicating if display with duplicate name found in folder should create a new display, overwrite the existing display, or skip creating the display. Default value is Append. |
| InheritPermissions | boolean | false | true | Gets or sets the boolean flag for inheriting permissions. |
| Created | string | false | true | The date/time the display was created on in ISO 8601 format. Read only. |
| Modified | string | false | true | The date/time the display was last modified on in ISO 8601 format. Read only. |
{
"DatabaseID": "string",
"TransferSessionId": "string",
"Identities": [
{
"Identifier": "7eb0e507-fe9d-4c32-9ff0-8ff1ac7ad8ea",
"Name": "World",
"Permission": 0
}
],
"Labels": [
"BasicDisplays"
],
"Display": {
"Id": 21,
"Name": "Display",
"Path": null,
"Owner": "Domain\\user",
"HasWriteAccess": true,
"ReadOnly": false,
"Revision": 0,
"DisplayProperties": {
"BackgroundColor": "#C0C0C0",
"Calculations": []
},
"Symbols": [ ],
"AttachmentIds": [ ],
"RequestId": null,
"StartTime": "*-8h*",
"EndTime": "**",
"LegacyDisplay": null,
"EventFramePath": null
},
"Symbols": { },
"COG": { },
"StorageTypeId": 0,
"ParentId": null,
"Attachments": [ ],
"ServerMappingInfo": { },
"DuplicateDisplayWriteBehavior": "Append",
"InheritPermissions": false,
"Created": "2021-10-21T01:23:45Z",
"Modified": "2021-10-21T01:23:45Z"
}
IdentityModel
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| Identifier | string | true | true | None |
| Name | string | false | true | None |
| Permission | PermissionType | false | true | None |
| PermissionFlag | PermissionFlags | false | true | None |
| Enabled | boolean | false | false | None |
{
"Identifier": "string",
"Name": "string",
"Permission": 0,
"PermissionFlag": 0,
"Enabled": true
}
PermissionType
Enumerated Values
| Property | Value |
|---|---|
| Read | 0 |
| Write | 1 |
PermissionFlags
This enumeration supports a bitwise combination of permission values.
Enumerated Values
| Property | Value | Value (Binary) |
|---|---|---|
| None | 0 | 0 |
| AllowRead | 1 | 0000 0001 |
| AllowWrite | 2 | 0000 0010 |
| AllowManage | 4 | 0000 0100 |
| DenyManage | 8 | 0000 1000 |
| DenyWrite | 16 | 0001 0000 |
| DenyRead | 32 | 0010 0000 |
| AllowAdmin | 64 | 0100 0000 |
EditorDisplay
Properties
| Property Name | Data Type | Nullable | Description | |
|---|---|---|---|---|
| Id | int64 | false | Display Id. | |
| Name | string[1024] | true | Display Name. | |
| Path | string | true | None | |
| Owner | string | true | Display Owner. | |
| HasWriteAccess | boolean | false | None | |
| ReadOnly | boolean | false | None | |
| Revision | int64 | false | Display Revision. | |
| DisplayProperties | any | true | None | |
| ProductVersion | string | true | Indicates what Server Version was used to create this Display. | |
| Symbols | [object] | true | None | |
| AttachmentIds | [LongAndStringPair] | false | true | None |
| RequestId | string | true | None | |
| StartTime | string | true | None | |
| EndTime | string | true | None | |
| LegacyDisplay | string | true | None | |
| EventFramePath | string | true | None |
{
"Id": 0,
"Name": "string",
"Path": "string",
"Owner": "string",
"HasWriteAccess": true,
"ReadOnly": true,
"Revision": 0,
"DisplayProperties": null,
"ProductVersion": "string",
"Symbols": [ ],
"AttachmentIds": [
{
"Item1": 0,
"Item2": "string"
}
],
"RequestId": "string",
"StartTime": "string",
"EndTime": "string",
"LegacyDisplay": "string",
"EventFramePath": "string"
}
LongAndStringPair
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| Item1 | int64 | false | false | None |
| Item2 | string | false | true | None |
{
"Item1": 0,
"Item2": "string"
}
StorageType
Enumerated Values
| Property | Value | Description |
|---|---|---|
| StandardDisplay | 0 | |
| ProcessBookDisplay | 1 | |
| Folder | 2 | |
| Group | 3 | |
| Image | 4 | |
| ImportFolder | 5 | |
| EventCompareDisplay | 6 |
Attachment
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| ID | int64 | true | false | Attachment Id. |
| Name | string | true | true | Attachement Name. |
| Data | string | true | true | BASE64 encoded content. |
{
"ID": 0,
"Name": "string",
"Data": "string"
}
ServerMappingInfo
Server mapping information sent from client.
Properties
| Property Name | Data Type | Description |
|---|---|---|
| SourceAFServer | string | Source Server AF. |
| DestinationAFServer | string | Destination Server AF. |
| SourceAFDatabase | string | Source Database. |
| DestinationAFDatabase | string | Destination Database. |
| SourcePIServer | string | Source Server PI. |
| DestinationPIServer | string | Destination Server PI. |
{
"SourceAFServer": "string",
"DestinationAFServer": "string",
"SourceAFDatabase": "string",
"DestinationAFDatabase": "string",
"SourcePIServer": "string",
"DestinationPIServer": "string"
}
DuplicateDisplayWriteBehavior
Enum for determining if new display should be created, existing display overwritten, or request skipped when a display with the same name is found in folder requested
Enumerated Values
| Property | Value | Description |
|---|---|---|
| Append | Append | Create a new display every time. If Display with exact name exists, new Display name will be adjusted (usually by adding (1) to its name). For example: DisplayName -> Display Name (1) |
| Skip | Skip | If Display with exact name exists in target folder, skip importing. |
| Overwrite | Overwrite | If Display with exact name exists in target folder, overwrite original Display. |
IdentitiesRequest
Request information for updating display identities
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| Identities | [IdentityModel] | false | true | Gets or sets the list of identities to add or remove from the displays. |
| Insert | boolean | false | false | Gets or sets a value indicating whether identities should be inserted or deleted Legacy flag for previous versions before PV2020. |
{
"Identities": [
{
"Identifier": "string",
"Name": "string",
"Permission": 0,
"Enabled": true
}
],
"Insert": true
}
DisplaySaveInfo
Result information for a display save call
Properties
| Property Name | Data Type | Required | Nullable | Description |
|---|---|---|---|---|
| Id | int64 | false | false | Display Id. |
| Name | string | false | true | Display name. Can be different from initial display name if auto-rename was performed. |
| PatchErrors | string[] | false | true | List of datasources that could not be patched. |
| DuplicateDisplayWriteBehavior | DuplicateDisplayWriteBehavior | false | false | Flag that indicate if display was Appended, Overwritten, or Skipped. |
{
"Id": 17,
"Name": "New Display",
"PatchErrors": [
],
"DuplicateDisplayWriteBehavior": "Append"
}