Please ensure Javascript is enabled for purposes of website accessibility
Powered by Zoomin Software. For more details please contactZoomin

PI Vision API Reference

Displays

  • Last UpdatedOct 08, 2025
  • 7 minute read

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


In This Topic
TitleResults for “How to create a CRG?”Also Available in