- URL:
- https://<root>/<serviceName>/MapServer/exts/SchematicServer/templates/<tempID>/updateDiagram
- Methods:
POST
- Version Introduced:
- 10.1
Description
The update
operation updates an existing schematic diagram. It is performed on a Schematic Diagram Template resource. The result of this operation is a Schematic Diagram Information Object.
You can provide arguments to the update
operation as query parameters defined in the parameters table below.
Request Parameters
Parameter | Details |
---|---|
| Description: The response format. The default response format is html. Values: html | json |
| Required Description: The diagram name. Syntax: Example: |
| Required Description: The login of the user who updates the diagram. _Syntax: _ Example: |
| Description: The builder property which specifies how the diagram has to be updated. This parameter is required only for diagrams based on the Standard builder. Syntax: //For a diagram based on the Standard builder, the operation expects the update action that will be used:
_Example: _ |
| Required Description: The context for the builder that updates the diagram. This parameter syntax depends on the diagram builder:
|
| Required Description: The persistence option to specify whether the removed/reduced schematic features are restored after update and the schematic feature links whose connections have been modified are reconnected to be in exact coherence with their associated real features after update. Value: |
Example Usage
Example 1: updateDiagram operation by synchronizing a Standard builder diagram content
Under the S1_Schematics Schematics service, the MainNetwork template is based on the Standard builder and works from input GIS features organized into a geometric network. Since this sample service was published without the Editing operation enabled, the updateDiagram operation is not supported. But, with the Editing operation enabled, you could synchronize the MPS_Goldmine schematic diagram based on this template (id=2) by executing the updateDiagram operation with the following parameters:
MPS_
for the name parameterGoldmine {"action" : "synchronize"}
for the builderProperties parameter{"initial
for the builderContext parameterObjects": []} user3882
for the builderContext parameterTrue
for the persistOption parameter
Then, the updateDiagram operation would be sent to the server as follows:
https://myserver.esri.com/arcgis/rest/services/S1_Schematics/MapServer/exts/SchematicsServer/templates/2/updateDiagram?name=MPS_Goldmine&builderProperties=%7B%22action%22+%3A+%22synchronize%22%7D&builderContext=%7B%22initialObjects%22%3A+%5B%5D%7D&user=user3882&persistOption=True&f=pjson
Example 2: updateDiagram operation by appending some new GIS features to a Standard builder diagram without synchronizing all the diagram content
Another kind of updateDiagram operation could be executed to append new GIS features to this schematic diagram without synchronizing all the diagram content. For example, in that case, you could use the following parameters:
MPS_
for the name parameterGoldmine {"action" : "append
for the builderProperties parameterWith Partial Synchronization"} {"initial
for the builderContext parameter to append the PrimaryLine with OBJECTID=1 to the diagramObjects": [{"object Class Name": "Primary Line", "object IDs": [1]}]} user5001
for the builderContext parameterTrue
for the persistOption parameter
Then, the updateDiagram operation would be sent to the server as follows:
https://myserver.esri.com/arcgis/rest/services/S1_Schematics/MapServer/exts/SchematicsServer/templates/2/updateDiagram?name=MPS_Goldmine&builderProperties=%7B%22action%22+%3A+%22appendWithPartialSynchronization%22%7D&builderContext=%7B%22initialObjects%22%3A+%5B%7B%22objectClassName%22%3A+%22PrimayLine%22%2C+%22objectIDs%22%3A+%5B1%5D%7D%5D%7D&user=user5001&persistOption=True&f=pjson
JSON Response Syntax
{
"name": "<diagramName>",
"id": "<diagramId>",
"templateIdentifier": "<templateIdentifier>",
"templateObjectID": <templateObjectID>,
"schematicLayerIdentifier": <schematicLayerIdentifier>,
"folderObjectID": <folderObjectID>,
"folderIdentifier": "<folderIdentifier>",
"objectID": <objectID>,
"createdBy": "<diagramCreator>",
"lastModificationBy": "<diagramLastEditor>",
"lastUpdateBy": "<diagramLastUpdator>",
"creationDate": "<diagramCreationDate>",
"lastModificationDate": "<diagramModificationDate>",
"lastUpdateDate": "<diagramLastUpdateDate>",
"lockedBy": "<diagramLastLocker>",
"version": "<version>",
"extent": <envelope>,
"rootNodes": [
"<rootNode1>",
...,
"<rootNodeN>"
],
"endNodes": [
"<endNode1>",
...,
"<endNodeK>"
]
}
JSON Response Example
{
"name": "DiagramFrom_pug_PUG_gas_plants_ID3",
"id": "0-5",
"templateIdentifier": "0",
"templateObjectID": 892,
"schematicLayerIdentifier": 0,
"folderObjectID": -2,
"folderIdentifier": "-2",
"objectID": 5,
"createdBy": "NCA3885",
"lastModificationBy": "NCA3885",
"lastUpdateBy": "NCA3885",
"creationDate": "05/13/11 14:13:57",
"lastModificationDate": "05/15/11 09:13:57",
"lastUpdateDate": "05/15/11 09:13:57",
"lockedBy": "",
"version": "sde.DEFAULT",
"extent": {
"xmin": -37.342619999999989,
"ymin": -11.398460000000886,
"xmax": -37.342179999999097,
"ymax": -11.398019999999997,
"spatialReference": {
"wkid": 4326,
"latestWkid": 4326
}
}
}