Asset Ingestion
Asset Ingestion Process
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.
- Ingest the enterprise, site, segment, and asset data using the Asset Ingestion Loader ( ). For more information on using the Asset Ingestion Loader refer to Unified Loaders documentation in About Data Loaders section of the help.
- Ingest reserved attributes, custom attributes, groups, tags, geo location, and classifications for the ingested assets using the Ingestion Setup ( ).
Typically, a system integrator or customer administrator performs asset ingestion. The ingestion process includes the following actions:
- Creating an asset ingestion file.
Asset ingestion files are JSON files that specify customer assets and their hierarchical structure or asset model. You can specify a complete set of assets and its asset model in a single JSON file within a ZIP file, or as discrete JSON files for each type, such as classifications, instances, connections, tag classifications, and tag associations within a single ZIP file.
- Submitting the ingestion file.
Appropriate credentials are needed to submit an asset ingestion file. Ask the customer administrator to provide the asset ingestor user ID and password.
- Verifying the ingestion.
After submitting an ingestion file, log in to Predix Essentials to verify that the asset model and assets were ingested correctly. Correct any errors in the ingestion file and resubmit as needed.
About Asset Ingestion File
Determine how to extract asset hierarchy data and convert it to the JSON asset-ingestion file. Use the JSON asset-ingestion file to build an inventory of the assets and levels that make up the existing customer asset hierarchy. You can also use the file to develop an asset hierarchy for a new customer. Typically, the source of the hierarchy comes from a customer database. After building the asset model and data for ingestion, create a ZIP file containing JSON code for ingesting assets into Predix Essentials.
The following applies to the asset ingestion JSON file(s):
- It must conform to the specified JSON format with all the required elements.
A sample JSON is shown below:
{ "classifications": [ { "id": "AVDtest-Asset-Enterprise-Type", "name": "AVDtest Enterprise Type", "description": "Enterprise Type Descirption", "ccomClass": "ENTERPRISE_TYPE", "properties": [ { "id": "AVDtest Enterprise Asset Type Property", "value": [ "AVDtest Enterprise Asset Type property value" ], "type": "string" } ], "parent": null }, { "id": "AVDtest-Asset-Site-Type", "name": "AVDtest Asset Site Type", "description": "Site Type Description", "ccomClass": "SITE_TYPE", "properties": [ { "id": "AVDtest Site Asset Type property", "value": [ "AVDtest Site Asset Type property value" ], "type": "string" } ], "parent": null }, { "id": "AVDtest-Asset-Segment-Type", "name": "AVDtest-Asset-Segment-Type", "description": "Segment Type Description", "ccomClass": "SEGMENT_TYPE", "parent": null }, { "id": "AVDtest-Asset-Type", "name": "AVDtest Asset Type_updated", "description": "Asset Type Description", "ccomClass": "ASSET_TYPE", "parent": null } ], "instances": [ { "id": "AVDtest-Asset-Enterprise", "name": "AVDtest Enterprise", "description": "AVDtest Asset entierprise description", "properties": [ { "id": "Location", "value": [ "Bay Area" ], "type": "string" } ], "classification": "AVDtest-Asset-Enterprise-Type", "ccomClass": "ENTERPRISE" }, { "id": "AVDtest-CA-Site", "name": "AVDtest Site", "description": "AVDtest Site description", "properties": [ { "id": "AVDtest_CA_address", "value": [ "Bay Area" ], "type": "string" } ], "classification": "AVDtest-Asset-Site-Type", "ccomClass": "SITE" }, { "id": "AVDtest-CA-Segment-ID", "name": "Samp Segment", "description": "AVDtest Segment description", "properties": [ { "id": "AVDtest_model_number", "value": [ "AVDtest Segment description" ], "type": "string" }, { "id": "ts_attr", "type": "Timestamp", "value": [ "07-15-2016 04.45.30" ] } ], "classification": "AVDtest-Asset-Segment-Type", "ccomClass": "SEGMENT" }, { "id": "avdtest-CA-Asset-ID", "name": "AVDtest Asset", "description": "AVDtest Description", "classification": "AVDtest-Asset-Type", "ccomClass": "ASSET" } ], "connections": [ { "from": { "id": "AVDtest-CA-Site", "ccomClass": "SITE" }, "to": [ { "type": "parent", "id": "AVDtest-Asset-Enterprise", "ccomClass": "ENTERPRISE" } ] }, { "from": { "id": "AVDtest-CA-Segment-ID", "ccomClass": "SEGMENT" }, "to": [ { "type": "parent", "id": "AVDtest-CA-Site", "ccomClass": "SITE" } ] }, { "from": { "id": "avdtest-CA-Asset-ID", "ccomClass": "ASSET" }, "to": [ { "type": "parent", "id": "AVDtest-CA-Segment-ID", "ccomClass": "SEGMENT" } ] } ], "tagClassifications": [ { "id": "AVDtest_Tag_Type_Classification_ID", "name": "AVDtest_Tag_Pressure_Classification_name", "description": "This is tag Pressure Classification description", "unitGroup": "pressure", "properties": [ { "id": "compressor", "value": [ 190 ], "type": "int" } ] } ], "tagAssociations": [ { "monitoredEntity": { "id": "AVDtest-Asset-Enterprise", "ccomClass": "ENTERPRISE" }, "tags": [ { "name": "AVDtest Enterprise Tag updated", "id": "AVDtest-Asset-Enterprise.AVDtest_Tag_Pressure", "description": "Enterprise Tag Descrpition", "classification": "AVDtest_Tag_Type_Classification_ID", "aliases": [ "AVDtest Enterprise Tag Alias" ] } ] }, { "monitoredEntity": { "id": "AVDtest-CA-Site", "ccomClass": "SITE" }, "tags": [ { "name": "AVDtest Site Tag Pressure", "id": "AVDtest-CA-Site.AVDtest_Tag_Pressure", "description": "Site Tag Pressure Descrpition", "classification": "AVDtest_Tag_Type_Classification_ID", "aliases": [ "AVDtest Site Tag Pressure Alias_updated" ] } ] }, { "monitoredEntity": { "id": "AVDtest-CA-Segment-ID", "ccomClass": "SEGMENT" }, "tags": [ { "name": "AVDtest Segment Tag name", "id": "AVDtest-CA-Segment-ID.AVDtest_Tag_Segment_ID", "description": "Segment Tag Pressure Descrpition", "classification": "AVDtest_Tag_Type_Classification_ID", "aliases": [ "AVDtest Tag Segment Alias 1" ] } ] }, { "monitoredEntity": { "id": "avdtest-CA-Asset-ID", "ccomClass": "ASSET" }, "tags": [ { "name": "AVDtest Asset Tag Pressure name", "id": "AVDtest-CA-Asset-ID.AVDtest_Tag_Pressure_ID", "description": "Asset Tag Pressure Descrpition", "classification": "AVDtest_Tag_Type_Classification_ID", "properties": [ { "id": "ch_attr_min", "type": "Character", "value": [ "A" ] }, { "id": "ch_attr_array", "type": "Character", "value": [ "Z", "a", "v", "N", "q", "i" ] }, { "id": "sh_attr_min", "type": "Short", "value": [ -32768 ] }, { "id": "sh_attr_max", "type": "Short", "value": [ 32767 ] }, { "id": "sh_attr_array", "type": "Short", "value": [ 32767, 300, 600, 90, 158, -32768 ] }, { "id": "int_attr_min", "type": "Integer", "value": [ -2147483648 ] }, { "id": "int_attr_max", "type": "Integer", "value": [ 2147483647 ] }, { "id": "int_attr_array", "type": "Integer", "value": [ 2147483647, 200, -500, 600, 99999, -1452895 ] }, { "id": "fl_attr_min", "type": "Float", "value": [ -3.4e+38 ] }, { "id": "fl_attr_max", "type": "Float", "value": [ 3.4e+38 ] }, { "id": "fl_attr_array", "type": "Float", "value": [ 3.4e+38, 3.2e+38, 3.1e+38 ] }, { "id": "dbl_attr_min", "type": "Double", "value": [ -1.7e+308 ] }, { "id": "dbl_attr_max", "type": "Double", "value": [ 1.7e+308 ] }, { "id": "dbl_attr_array", "type": "Double", "value": [ 1.7e+308, 1.6e+302, 1.4e+302, 1.1e+38 ] }, { "id": "bool_attr_true", "type": "Boolean", "value": [ true ] }, { "id": "bool_attr_fal", "type": "Boolean", "value": [ false ] }, { "id": "ts_attr", "type": "Timestamp", "value": [ "07-15-2016 04.45.30" ] }, { "id": "ts_attr_array:07/15/2016 04:45:30", "type": "Timestamp", "value": [ "07-15-2016 04.45.30", "07-15-2016 04.45.30", "07-15-2016 04.45.30" ] }, { "id": "str_attr_min", "type": "String", "value": [ "Test String" ] }, { "id": "str_attr_array", "type": "String", "value": [ "First", "Second", "Third", "Fourt" ] } ], "reservedProperties": { "status": "01", "uom": "MetersPerSecond", "dataType": "Double", "resolution": "7" }, "aliases": [ "AVDtest Tag Pressure Alias" ] }, { "name": "AVDtest Asset Tag Pressure name2", "id": "AVDtest-CA-Asset-ID.AVDtest_Tag_Pressure_ID2", "description": "Asset Tag Pressure Descrpition2", "classification": "AVDtest_Tag_Type_Classification_ID", "properties": [ { "id": "ch_attr_min", "type": "Character", "value": [ "A" ] }, { "id": "ch_attr_array", "type": "Character", "value": [ "Z", "a", "v", "N", "q", "i" ] }, { "id": "sh_attr_min", "type": "Short", "value": [ -32768 ] }, { "id": "sh_attr_max", "type": "Short", "value": [ 32767 ] }, { "id": "sh_attr_array", "type": "Short", "value": [ 32767, 300, 600, 90, 158, -32768 ] }, { "id": "int_attr_min", "type": "Integer", "value": [ -2147483648 ] }, { "id": "int_attr_max", "type": "Integer", "value": [ 2147483647 ] }, { "id": "int_attr_array", "type": "Integer", "value": [ 2147483647, 200, -500, 600, 99999, -1452895 ] }, { "id": "fl_attr_min", "type": "Float", "value": [ -3.4e+38 ] }, { "id": "fl_attr_max", "type": "Float", "value": [ 3.4e+38 ] }, { "id": "fl_attr_array", "type": "Float", "value": [ 3.4e+38, 3.2e+38, 3.1e+38 ] }, { "id": "dbl_attr_min", "type": "Double", "value": [ -1.7e+308 ] }, { "id": "dbl_attr_max", "type": "Double", "value": [ 1.7e+308 ] }, { "id": "dbl_attr_array", "type": "Double", "value": [ 1.7e+308, 1.6e+302, 1.4e+302, 1.1e+38 ] }, { "id": "bool_attr_true", "type": "Boolean", "value": [ true ] }, { "id": "bool_attr_fal", "type": "Boolean", "value": [ false ] }, { "id": "ts_attr", "type": "Timestamp", "value": [ "07-15-2016 04.45.30" ] }, { "id": "ts_attr_array", "type": "Timestamp", "value": [ "07-15-2016 04.45.30", "07-15-2016 04.45.30", "07-15-2016 04.45.30" ] }, { "id": "str_attr_min", "type": "String", "value": [ "Test String" ] }, { "id": "str_attr_array", "type": "String", "value": [ "First", "Second", "Third", "Fourt" ] } ], "reservedProperties": { "status": "01", "uom": "MetersPerSecond", "dataType": "Double", "resolution": "7" }, "aliases": [ "AVDtest Tag Pressure Alias2" ] } ] } ], "groups": [ { "id": "AVDtest_Tag_Group", "name": "AVDtest Tag Group", "description": "AVDtest Tag Group Description", "ccomClass": "GROUP", "associatedEntityCcomClass": "TAG", "properties": [ { "id": "AVDtest_Tag_Group_attribute", "value": [ "AVDtest Tag Group Attribute Description"], "type": "string" } ], "associatedEntityIds": [ "AVDtest-CA-Segment-ID.AVDtest_Tag_Segment_ID", "AVDtest-CA-Site.AVDtest_Tag_Pressure" ], "mappedInstances": [ { "ccomClass": "ASSET", "id": "AVDtest-CA-Asset-ID" } ] } ] }
Note: You can create a copy of the sample JSON file. The ingestion JSON file must be encoded in UTF-8. Otherwise, some of the special characters will not be ingested. - The values in the JSON supports ingesting all UTF-8 characters.
- The above sample JSON does not apply to Unified APM. The enterprise, site, segment, and asset data must be uploaded using the Asset Ingestion Loader ( ). For more information on using the Asset Ingestion Loader, refer to the Unified Loaders in About Data Loaders section of the documentation.
- You should limit the number of objects during ingestion to 150,000 objects per file. The ingestion will continue, however when you inspect the job on the data ingestion page, the summary will either load very slowly or not load at all.
- If needed, split into individual JSON files, each for classifications, tagClassifications, and tagAssociations.
- It may be combined into a single ZIP file, or can be ingested as separate ZIP files.
- You should not have duplicate objects in the same ZIP file. Otherwise, the ingestion of the data will be indeterministic as there is no specific order in which the data will be processed, and the object that is ingested last will be the state of the object in the system.
- The objects in the ZIP file are processed in the following order:
- your_classifications
- your_tagClassifications
- your_instances
- your_tagAssociations
- your_connection
Note: If the object does not contain the required dependencies and elements, the object will be skipped, and the ingestion will complete with errors.
Ingestion Endpoints and Credentials
Endpoints and Credentials in the Setup Page
Predix Essentials Only: You can view some of these key-value pairs on the Tenant Preferences page in your tenant. Log in to your tenant as a user administrator, and then select .
Credential Name | Description |
---|---|
Grant Type | The type of authorization to grant access to ingestion services. Typically, the default value is Password . |
Client ID | A large alphanumeric string typically with the prefix ingestor , which represents the client id needed for the server to authenticate the validity of the client. For example, ingestor.5dadc6577e2d410c9baffcb34ceaf841 . |
Username | An alphanumeric string that represents your ingestor username. |
Password | Hidden text (asterisks) that represents the password for ingesting assets or alerts. This parameter is user-configurable. |
Tenant UUID | An alphanumeric string that represents the tenant id. For example, 6F527FC00A184CDE9693BBA2820ADF77 . |
Endpoint | Description |
---|---|
Token Request URL | The access URL to obtain the authorization token required for ingesting assets and alerts into Predix Essentials. For example, https://9864edf5-b2b9-4786-9935-6821bc1a364c.predix-uaa-staging.grc-apps.svc.ice.ge.com/oauth/token . |
Asset ingestion URL | The access URL to ingest assets using HTTPS through a REST client. For example, https://apm-s95-adapter-dev.grc-apps.svc.ice.ge.com/v1/asset/upload . |
Alerts ingestion URL | The access URL to ingest alerts using HTTPS through a REST client. For example, https://apm-gateway-dev.grc-apps.svc.ice.ge.com/v1/jobs . |
Timeseries ingestion URL | The access URL to ingest time series using HTTPS through a REST client. For example, https://apm-timeseries-services-dev.grc-apps.svc.ice.ge.com/v1/data/add?file_type=json . |
Other Endpoints
You need the following endpoints to check the status of ingestion.
Endpoint | Description |
---|---|
Asset ingestion status check URL | The URL to check the status of asset ingestion using HTTP GET through a REST client. Use the https://apm-s95-adapter-<environment>.<hostname> from the asset ingestion URL, and append /v1/tasks/<uuid> (replace <uuid> with the value from the POST response). For example, https://apm-s95-adapter-dev.grc-apps.svc.ice.ge.com/v1/tasks/fdgd36378 . |
Alerts ingestion status check URL | The URL to check the ingestion status for alerts using HTTPS GET through a REST client. Append /<uuid>/status to the alert ingestion URL. (Replace <uuid> with the value from the POST response). For example, https://apm-gateway-dev.grc-apps.svc.ice.ge.com/v1/jobs/8C3D72213EC44D7697A8C465F858F59E/status . |
For more information about bulk ingestion using the Asset APIs, refer to the About Classifications section, and for information about browsing using the Asset APIs, refer to the About Instances section of the documentation.
Obtain the Authorization Token for your Tenant
Before You Begin
- The token request URL.
- Get the following information from the Setup section:
- Token Request URL
- Client ID
- Username
- The ingestion password that you set up during first-time tenant access as an administrator.
- Access to a REST client such as Postman or Advanced REST client, or curl CLI.
About This Task
Use this procedure to obtain an authorization bearer token before registering services using Event Hub with your tenant. Also, before ingesting data (assets, alerts, or time series) into a specific tenant. Tokens are client-specific and usually expire within a set time period. You must obtain a new token every time your token expires.
Procedure
Results
On successful ingestion, you receive the authorization bearer token as a JSON response; copy this information into a temporary file. Also, make note of the expires_in
field in the JSON response, as it gives the expiration time in seconds.
Example
The following code sample shows a JSON response :
{
"access_token": "eyJhbGciOiJSUzI1NiJ9.eyJqdGkiOiI1ZTJjOTBlYS05ZWRkLTRkYTEtODBjOC00YTBkNjdmNzdlZjMiLCJzdWIiOiI2YWY0YjBlNi1mZmY4LTRmOWEtYTdhNC1mYzI5Nzg4ZTY5YzAiLCJzY29wZSI6WyJvcGVuaWQiXSwiY2xpZW50X2lkIjoiaW5nZXN0b3IuREU2QjcxODQyODI0NENGMkE0MDlGM0YwRUU1OTBBNzQiLCJjaWQiOiJpbmdlc3Rvci5ERTZCNzE4NDI4MjQ0Q0YyQTQwOUYzRjBFRTU5MEE3NCIsImF6cCI6ImluZ2VzdG9yLkRFNkI3MTg0MjgyNDRDRjJBNDA5RjNGMEVFNTkwQTc0IiwiZ3JhbnRfdHlwZSI6InBhc3N3b3JkIiwidXNlcl9pZCI6IjZhZjRiMGU2LWZmZjgtNGY5YS1hN2E0LWZjMjk3ODhlNjljMCIsIm9yaWdpbiI6InVhYSIsInVzZXJfbmFtZSI6IjlCMjY0QUU3MDk2NzQ3QzM4MEM2QjA5OUU2NkQ3NTdBX2luZ2VzdG9yIiwiZW1haWwiOiI5QjI2NEFFNzA5Njc0N0MzODBDNkIwOTlFNjZENzU3QV9pbmdlc3RvckBhcG0tYXBwbGljYXRpb24tYWNjZXB0YW5jZS5ncmMtYXBwcy5zdmMuaWNlLmdlLmNvbSIsImF1dGhfdGltZSI6MTQ0OTE2NTQyNywicmV2X3NpZyI6ImJiNjI3MzU0IiwiaWF0IjoxNDQ5MTY1NDI3LCJleHAiOjE0NDkyNTE4MjcsImlzcyI6Imh0dHBzOi8vMDRiOGM4OTEtZWRlYS00NGQ0LWI3YmEtYmIzMGQ3MDA2ZDU5LnByZWRpeC11YWEtc3lzaW50LmdyYy1hcHBzLnN2Yy5pY2UuZ2UuY29tL29hdXRoL3Rva2VuIiwiemlkIjoiMDRiOGM4OTEtZWRlYS00NGQ0LWI3YmEtYmIzMGQ3MDA2ZDU5IiwiYXVkIjpbImluZ2VzdG9yLkRFNkI3MTg0MjgyNDRDRjJBNDA5RjNGMEVFNTkwQTc0Iiwib3BlbmlkIl19.dtcD0uYyahB0ocp6I7xPoefwAxPBiXx0yqVxrmPHxagXEwuK9a1SswiG9-dIByf6ty2PMPDau4UeMwxzZg29DE6qxfEWXEOP4J7Uy_H2AiM9V9WqJg7Q2NbVoEYwlKfnH8RIScz20nDLP1IEqFHld1Kf7MhXwxhcLVed250Z0I7qmMlB1axqjcWqeBv2BdLUlgja1o5YOa9A9xq46rwZ81TyGyAu9_UavibYO6H9l4cYQYJkU5TwFJdY4D83hvxRtXpUownDC7wHVWDHUP1DXpu44F3uMkBB40K8FqbzQQmhujOmSbV5hdVaSF_QBu71a59KI78knEyclDa0BK5GHA",
"token_type": "bearer",
"refresh_token": "eyJhbGciOiJSUzI1NiJ9.eyJqdGkiOiIzZTU0NTgzZS0xZjIwLTQ0ZjUtODk2NC0zMTQxNDcyYzhiMzUtciIsInN1YiI6IjZhZjRiMGU2LWZmZjgtNGY5YS1hN2E0LWZjMjk3ODhlNjljMCIsInNjb3BlIjpbIm9wZW5pZCJdLCJpYXQiOjE0NDkxNjU0MjcsImV4cCI6MTQ0OTc3MDIyNywiY2lkIjoiaW5nZXN0b3IuREU2QjcxODQyODI0NENGMkE0MDlGM0YwRUU1OTBBNzQiLCJjbGllbnRfaWQiOiJpbmdlc3Rvci5ERTZCNzE4NDI4MjQ0Q0YyQTQwOUYzRjBFRTU5MEE3NCIsImlzcyI6Imh0dHBzOi8vMDRiOGM4OTEtZWRlYS00NGQ0LWI3YmEtYmIzMGQ3MDA2ZDU5LnByZWRpeC11YWEtc3lzaW50LmdyYy1hcHBzLnN2Yy5pY2UuZ2UuY29tL29hdXRoL3Rva2VuIiwiemlkIjoiMDRiOGM4OTEtZWRlYS00NGQ0LWI3YmEtYmIzMGQ3MDA2ZDU5IiwiZ3JhbnRfdHlwZSI6InBhc3N3b3JkIiwidXNlcl9uYW1lIjoiOUIyNjRBRTcwOTY3NDdDMzgwQzZCMDk5RTY2RDc1N0FfaW5nZXN0b3IiLCJvcmlnaW4iOiJ1YWEiLCJ1c2VyX2lkIjoiNmFmNGIwZTYtZmZmOC00ZjlhLWE3YTQtZmMyOTc4OGU2OWMwIiwicmV2X3NpZyI6ImJiNjI3MzU0IiwiYXVkIjpbImluZ2VzdG9yLkRFNkI3MTg0MjgyNDRDRjJBNDA5RjNGMEVFNTkwQTc0Iiwib3BlbmlkIl19.Kc4PioQAOeHNeGacFwfePhLSogh06RR8c4zQPPr46rD_S49UHegOq1Uv3cWnP6sttL25GaPeidTnYyFLADFF-GyORkdmKUjx4CiAdQucoKusidjoNJQmaQNhicL62B2goUNf9VYztjrBqHGZkKt2DvdtU0RtXAkgc-qFUo2ToMQj86hqc80OhiIb_2mnXOOWZswrrfxPizgk9zL22-i6a00LGsptJZ2ErCDSmpGBka6h6H-N8vVWTsOhx_nnp7jUHKGZOZQjcsqSIWwRosIE_G6kgGMpL2L_bLgDVpZiQ3Ri19K5J7co1y4TqjMF3kvXb0rOdIJsDO1PCfMztAazlw",
"expires_in": 86399,
"scope": "openid",
"jti": "5e2c90ea-9edd-4da1-80c8-4a0d67f77ef3"
}
What To Do Next
Use the obtained token for accessing, registering tenant resources and performing data ingestion for the tenant.
Ingest Assets through the REST Client
Before You Begin
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.
- Asset ZIP file containing a valid JSON file.
- Oauth token to ingest assets.Important: Make sure you have a valid, unexpired token. Tokens are client specific and usually expire within a set time. Look for the token expiration in the JSON response.
- On the Setup section, get the following information:
- Client ID
- Asset ingestion URL
- Username
- Ingestion Password that was created during initial tenant setup.
- Access to a REST client such as Postman or Advanced REST client.
About This Task
- Reserved attributes
- Custom attributes
- Geo location
- Groups
- Tags
- Classifications
- When ingesting classifications, tagClassifications, and tagAssociations as separate files, you must ingest the <your_classifications_filename>.zip first. You can then repeat this procedure to ingest each of the remaining files in the following order: <your_tagClassfications_filename>.zip, and <your_tagAssociations_filename.zip>.
Procedure
Results
On successful acceptance, you receive a 200 OK in the JSON response. Note that the ingestion happens asynchronously, which means that your request is queued for the server to process it. You must check the ingestion progress through HTTP GET to make sure if ingestion was successful. Save the uuid from the JSON response for tracking purposes.
Example
The following code sample appears a JSON response:
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 293
{
"tenantUuid": "A5BE798652EE43F0BDE0CA20A7239BBB",
"description": "Upload S95 assets from zip file: newE2EAsset.zip, size: 1927 bytes",
"status": "QUEUED",
"ingestionLogMsgList": [],
"uuid": "2408ba25-77d2-42b2-9a8f-88b01875a86b",
"isActive": true,
"createdOn": 1464298499106,
"updatedOn": 1464298499106
}
What To Do Next
For information about bulk ingestion using the Asset APIs, refer to the About Classifications documentation. For information about browsing using the Asset APIs, refer to the About Instances documentation.
Ingest Assets through the User Interface
Before You Begin
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.
About This Task
Ingest only the following asset data through the user interface:
- Reserved attributes
- Custom attributes
- Geo location
- Groups
- Tags
- Classifications
- When ingesting classifications, tagClassifications, and tagAssociations as separate files, you must ingest the <your_classifications_filename>.zip file first. You can then repeat this procedure to ingest each of the remaining files in the following order: <your_tagClassfications_filename>.zip, and <your_tagAssociations_filename.zip>.
- Same file cannot be reingested until completed. Unless, the file has been in progress for more than 30 minutes.
- Ingestion zip file size is limited to 10 MB.
Field | Description |
---|---|
File Name | Displays the name of the ingestion file. |
Status | Displays the status of the ingestion. The status can be any of the following:
|
Task Progress | Displays the percentage of the ingestion. |
Start Time | Displays the date and time the ingestion started. |
End Time | Displays the date and time the ingestion ended. |
File Size | Displays the size of the ingestion file. |
Procedure
Results
Legend | Description |
---|---|
Completed | The ingestion completed successfully. You should be able to see the ingested asset data in the Assets module. |
Completed with Errors | The ingestion completed with errors. Review the error(s) for details and possible resolution. Some of these errors can be related to data validation issues. |
In Progress | The file ingestion into the application asset store is currently in progress. Ingested assets will be available in the application after the ingestion completes. |
Skipped | The file ingestion was skipped due to the file being already in progress from a previous ingestion. Wait for the previous ingestion to complete or wait 30 minutes to re-ingest the file. |
Asset Ingestion HTTP Status Codes
Predix Essentials Time Series microservices adhere to standard HTTP and REST conventions in its use of HTTP status codes.
The following HTTP status codes provide information that may help with troubleshooting any ingestion-related issues. The information returned may vary depending on the type of HTTP method used (GET
or POST
).
Status Code | Meaning |
---|---|
200 OK |
If a valid ZIP file is attached, or the ZIP file is empty, the task status varies based on ingestion progress. The code for a valid ZIP file displays as If the JSON within the ZIP file is empty, the task status displays as |
202 Accepted | A new resource was created successfully. Check the Location header in the response to get information on the resource URI . |
204 No Content | An update to an existing resource was applied successfully. |
400 Bad Request | The request was not formatted appropriately. Review the response body for additional information on the type of error that occurred. For example, this error appears if you did not attach a ZIP file, or your request contains invalid query syntax or operators. |
401 Unauthorized | The request failed authentication; the provided credentials are either invalid, or were not provided. This can also happen when the token has expired. |
404 Not Found | The requested resource was not found. It might mean that the resource you requested was not created at the server side. |
500 Server Error | You receive a server error if down-stream systems are not available. Exception: You may receive a 500 instead of a 404 when you are updating a tag group with a non-existing URI. |