About Instances
You can add, modify, search, and delete instances, and add and remove instances in the Business Functional Hierarchy.
- Enterprise
- Site
- Segment
- Asset
- Tag
In Predix Essentials, adding or modifying assets using the Predix Essentials user interface, APIs, or Asset Ingestion Service, or bypassing the Unified Asset Ingestion Data Loader, causes the asset databases to become out-of-sync.
- You must add or modify assets using the Unified Asset Ingestion Data Loader.
- You cannot delete assets.
- You must use the Asset Ingestion Service to add tags to assets.
- You can add, modify, or delete assets in the user interface, using APIs, or using the Asset Ingestion Service.
- You can add tags to assets in the user interface, using APIs, or using the Asset Ingestion Service.
When you create an instance, you can add reserved attributes to the instance that are inherited by instances directly lower in the hierarchy. Reserved attributes are added to a parent node in the JSON.
- Create an instance.
- List instances by criteria and URI.
- List child nodes link to an instance.
- List tags associated with an instance.
- Add tags to an instance.Note: When using the API, you must set the nextRelatedTag section tagUri field to null in order to remove the correlation.
- Remove tags from an instance.
- Update an instance.
- Delete an instance.
A JSON is required when using an API or ingesting an asset group. The JSON structure for ingestion or APIs is different.
This request | Does this |
---|---|
POST | Create an instance and link tags to the instance. |
GET | List the instances using the Asset APIs. You can list by criteria or URI. You can also list directly linked child nodes using UUID, and list tag associations. Browse instances, all instances, or accessible resources. Parent instances are included in the accessible resources response. |
PATCH | Update the instance using the Asset APIs. |
DELETE | Delete a specific instance by UIID, and remove tags from an instance. |
/browse
endpoint. This is our API to populate the context browser only. Instead we recommend the following approach:- For the direct objects underneath the enterprise use
/enterprises/{{uuid}}/children
. - For all the sites underneath an enterprise use
/enterprises/{{uuid}}/children?deepSearch=true&childPrefix=/sites
. An alternate approach is/sites/query?q=parent->uri=/enterprise/{{uuid}}
.Note: If you are looking for just a single type of object, it is more efficient to use the specific/sites
or/assets
endpoint with the query parameters. - For all the sites, segments, and assets underneath an enterprise, use
/enterprises/{{uuid}}/children?deepSearch=true
. - For all the assets underneath a specific enterprise, use:
/assets/query?q=parent->name={{name of the enterprise}}
/assets/query?q=parent->uri={{uri of the enterprise}}
- For all the assets underneath a specific site, replace id of enterprise with the id of site.
To use the API to configure an instance, refer to the Asset APIs documentation.
Maximum number of results
The maximum number of results in the set for the /browse
API is 250, and not changeable. If you use our other endpoints, you can configure it from 1-1000.
/v1/assets?pageSize=250
Instance Rules
- You must have edit permissions.
- You cannot add a parent instance to itself or a descendant.
- If a business functional object or an asset instance is removed from the business functional hierarchy, it is orphaned and only an administrator can view it.
Create an Instance
- You will need to add the following values to
instances
in the JSON for ingestion.- name
- id
- description
- classification (names classification type)
- ccomClass (names Business Functional Hierarchy; ENTERPRISE, SITE, SEGMENT, ASSET).
- associatedEntityCcomClass
- properties (includes sub-values)
- id
- value
- type
- Repeat the previous step for any instance you want to add.
- Save the JSON, then ingest it using the REST client.
You are ready to add the instance to the business functional hierarchy.
Add an Instance to the Business Functional Hierarchy
You can add an enterprise, site, segment, or asset instance to the business functional hierarchy. Tag instances are added to an existing instance.
You can move an existing site, segment, or asset instance to another site, segment, or asset instance in the business functional hierarchy. Use your Asset Model to determine placement of the instance. You can add or move an instance to a node that is higher in the business functional hierarchy.
- You will need to add the following values to
connections
in the JSON for ingestion:- from (includes sub-values)
- id
- ccomClass (names originating connection; SITE, SEGMENT, ASSET)
- to (includes sub-values)
- type (predefined as
parent
) - id
- ccomClass (names parent object; ENTERPRISE, SITE, SEGMENT, ASSET)
- type (predefined as
- from (includes sub-values)
- Repeat the previous step for each instance you want to connect to the business function hierarchy.
- Save the JSON, then ingest it using the REST client.
Move an Instance within the Business Functional Hierarchy
You can move an instance from one area in the business functional hierarchy to another.
You can move entails using PATCH or ingestion to update and replace the classification for an instance.
Based on the following scenarios, an instance is moved within the business functional hierarchy as follows:
- If the custom attribute of the new classification has same name but different datatype than that of an instance attribute, an error message appears. In this case, you must either delete the instance attribute or delete the classification attribute to resolve the conflict.
- If the custom attribute of the new classification has same name and same datatype of an instance attribute, the attribute that matches the new classification will be inherited to the instance from the new classification. However, the instance attribute values will not be updated even if the classification has the same attribute as that of the instance.
- If the new classification contains attributes that are not available in the instance, the classification attributes are inherited to the instance along with their default values.
- Find the business functional object node from which you want to move the instance.
- Change the following parameters using PATCH or ingestion:
[{ "op" : "replace", "path" : "/type" "value" : "new type URI" }]
- Save the JSON, and then update it using the APIs.
Remove an Instance from the Business Functional Hierarchy
You can remove instances from a business functional object.
- Find the business functional object node from which you are removing the instance.
- Remove the association between the asset instance URI and the business functional object URI.
- Save the JSON, then update it using the APIs.
Add Tags to an Instance
tagAssociations
in the JSON.- You will need to add values under
tagAssociations
for ingestion:- monitoredEntity (includes sub-values)
- id (names the instance in the business functional hierarachy for which the tag is associated)
- ccomClass (names the classification type; e.g.,
ENTERPRISE
)
- tags (includes sub-values)
- name (tag name)
- id
- description
- classification (names associated tag type classification)
- aliases (names one or more tag aliases)
- nextRelatedTag (includes sub-value)
- idNote: You must set the ID field to null in order to remove the correlation.
- id
- monitoredEntity (includes sub-values)
- Repeat the previous step for any tag associations you want to add.
- Save the JSON, then ingest it using the REST client.
Remove Tags from an Instance
- Find the instance node from which you are removing the tag instances.
- Remove the association between the tag instance URI and the instance URI.
- Save the JSON, then update it using APIs.
Search for Instances
You can retrieve a list of instances by criteria or URI using the APIs.
You can use the API to retrieve the instances associated to a business functional object.
- uri
- name
- sourcekey
- description
- attributes
- reservedattributes
- type
- parent
- uri
- name
- sourcekey
- description
- attributes
- reservedattributes
- type
- monitoredentityuri
- monitoredentityname
- monitoredentitysourcekey
Delete an Instance
Cascade Delete of Instances
You must use precautionary measures when using the API to delete an asset or tag instance. The delete functionality permanently removes all child-assets, group associations, and the actual instance.
Upon successful deletion, the Audit Logs page updates the following information: Timestamp, UserName, Name, Resource, Resource Type, Action, Reason, and Detail. For example, Deleted Asset Instance-1234 (ID212434)
.
- Delete all objects in the entire hierarchy including tag instances associated to the objects.
- Cannot delete if an object has more than one parent in the deletion path.
- Cannot delete if the tag instance is associated to any object not in the deletion path.
- Deletes all the site, segment, and asset instances under the segment
- Deletes all the association with groups for the enterprise
- Deletes the object (enterprise)
- Deletes all the segment and asset instances under the segment
- Deletes all the association with groups for the site
- Deletes the object (site)
- Deletes all the asset instances under the segment
- Deletes all the association with groups for the segment
- Deletes all the segment instances under the segment
- Deletes the object (segment)
- Deletes all the tag instances of the asset
- Deletes all the association with groups for the asset
- Deletes the object (asset)
The API deletes the tag instance association and the tag instance.
Upon deletion the following HTTP status codes provide information that help with troubleshooting:
Status Code | Description |
---|---|
202 | Confirms that the request is accepted for processing. The deletion activity is asynchronous and runs in the background. |
404 | The cascade delete entity is not found. |