Business 360 REST API Reference > Business 360 REST API > Job instance API
  

Job instance API

Use the job instance APIs to manage ingress, egress, and match and merge jobs. You can create and run job instances, search for job instances, and retrieve a short summary or the complete details of a job instance. The APIs use the jobInstance resource.

Create Ingress Job Instance

Use the Create Ingress Job Instance API to create and run an ingress job instance that imports data from an external source system to Business 360 data store.
Before using this API, you must first define an ingress job in Business 360 Console. For more information about defining an ingress job, see Ingress data.
The API supports the POST method.

POST request

To create and run an ingress job instance, submit a POST request with the following URI:
POST <baseApiURL>/job/public/api/v1/jobInstance/Ingress
You can use the following parameters in the request body:
Parameter
Type
Description
jobDefinitionId
String
The internal ID of a job.
You can view the internal ID of a job when you open the job definition in Business 360 Console.

POST response

The response is in the JSON format. The response shows the HTTP 200 OK response code and returns the ID of job instance.

POST example

You might use the following sample request to create and run an ingress job instance:
POST <baseApiUrl>/job/public/api/v1/jobInstance/Ingress
Content-Type: application/json
IDS-SESSION-ID: XXXXXXXXXXXXXXXXXXXXXX

{

"jobDefinitionId": "ingress_org"

}
The following sample response contains the HTTP 200 OK response code and the job instance ID:
HTTP/1.1 200 OK
Content-Type: application/json

{
"id": "714189942313869312"
}
Note: Use the value of id to retrieve a summary or the complete details of a job instance. For more information about retrieving a summary of a job instance, see Read Job Instance Summary. For more information about retrieving the complete details of a job instance, see Read Job Instance Details.

Create Egress Job Instance

Use the Create Egress Job Instance API to create and run an egress job instance that exports data from Business 360 data store to an external data source.
Before using this API, you must first define an egress job in Business 360 Console. For more information about defining an egress job, see Egress data.
The API supports the POST method.

POST request

To create and run an egress job, submit a POST request with the following URI:
POST <baseApiURL>/job/public/api/v1/jobInstance/Egress
You can use the following parameters in the request body:
Parameter
Type
Description
jobDefinitionId
String
The internal ID of a job.
You can view the internal ID of a job when you open the job definition in Business 360 Console.

POST response

The response is in the JSON format. The response shows the HTTP 200 OK response code and returns the ID of job instance.

POST example

You might use the following sample request to create and run an egress job instance:
POST <baseApiUrl>/job/public/api/v1/jobInstance/Egress
Content-Type: application/json
IDS-SESSION-ID: XXXXXXXXXXXXXXXXXXXXXX

{

"jobDefinitionId": "egress_org"

}
The following sample response contains the HTTP 200 OK response code and the job instance ID:
HTTP/1.1 200 OK
Content-Type: application/json

{
"id": "714195872447352832"
}
Note: Use the value of id to retrieve a summary or the complete details of a job instance. For more information about retrieving a summary of a job instance, see Read Job Instance Summary. For more information about retrieving the complete details of a job instance, see Read Job Instance Details.

Create Match and Merge Job Instance

Use the Create Match and Merge Job Instance API to create and run a match and merge job that identifies and resolves duplicate records.
Before using this API, you must first define a match and merge job in Business 360 Console. For more information about defining a match and merge job, see Define and run a match and merge job.
The API supports the POST method.

POST request

To crate and run a match and merge job, submit a POST request with the following URI:
POST <baseApiURL>/job/public/api/v1/jobInstance/MatchMerge
You can use the following parameters in the request body::
Parameter
Type
Description
jobDefinitionId
String
The internal ID of a job.
You can view the internal ID of a job when you open the job definition in Business 360 Console.
matchModelId
String
The ID of the match model. You can view the ID of match model when you open it in Business 360 Console.
matchModelVersion
String
The version of the match model.
businessEntity
String
The internal ID of the business entity.

POST response

The response is in the JSON format. The response shows the HTTP 200 OK response code and returns the ID of job instance.

POST example

You might use the following sample request to create and run a match and merge job:
POST <baseApiUrl>/job/public/api/v1/jobInstance/MatchMerge
Content-Type: application/json
IDS-SESSION-ID: XXXXXXXXXXXXXXXXXXXXXX

{
"jobDefinitionId": "matchmerge1",
"matchModelId": "org.ruleset1",
"matchModelVersion": 1,
"businessEntity": "c360.organization"
}
The following sample response contains the HTTP 200 OK response code and the job instance ID:
HTTP/1.1 200 OK
Content-Type: application/json

{
"id": "714542403541159936"
}
Note: Use the value of id to retrieve a summary or the complete details of a job instance. For more information about retrieving a summary of a job instance, see Read Job Instance Summary. For more information about retrieving the complete details of a job instance, see Read Job Instance Details.

Search Job Instances

Use the Search Job Instances API to search for matching job instances based on the job name, the job type, the status of job instances, or the user who started the job instance.
The API supports the POST method.

POST request

To search for ingress, egress, and match and merge jobs, submit a POST request with the following URI:
POST <baseApiURL>/job/public/api/v1/search
You can use the following parameters in the request body:
Parameter
Type
Description
search
String
Search string to search for matching job name, job type, status of job instances, or user who started the job instance.
pageSize
Number
Number of search results to display on each page. Minimum value is 1.
pageOffset
Number
Optional. Number of pages to skip. For example, pageOffset=2 means that the search must skip the first two pages of the search results. Minimum value is 0.
filter
Array
Specifies a list of fields that you want to use to filter the search results.
filters > operator
String
The boolean operator that joins multiple filters. Use AND or OR as the boolean operator.
Use AND if fieldName has different values. Use OR if fieldName has the same values but fieldValue has different values.
fieldName
String
Type of value based on which you want to filter job instances.
Use one of the following value types:
  • - name. Filters job instances based on the specified job name.
  • - status. Filters job instances based on the specified job status.
  • - jobType. Filters job instances based on the specified job type.
fieldValue
String
Value based on which you want to filter the job instances.

POST response

The response is in the JSON format. The response returns the matching job instances.
The response includes the following parameters:
Parameter
Type
Description
totalRecords
Number
The number of job instances returned in the search.
totalPages
Number
The number of pages returned in the search.
currentPage
Number
The page number from which you view the search results.
jobInstances
Array
The list of job instances returned in the search.
metadataEntities
String
The metadata details of the job instance.
runTimeParameters
String
The runtime parameters that were used to run the job instance.
jobLevelMetrics
String
The key metrics of the job instance.
completedAt
String
Date when the job instance was completed.
state
String
Status of job instances.
createdAt
String
Date when the job was created.
createdBy
String
Name of the user who created the job.
updatedAt
String
Date when the job was updated.
updatedBy
String
Name of the user who last updated the job.
startedAt
String
Date when the job instance was started.
startedBy
String
Name of the user who started the job instance.
isCompleted
Boolean
Indicates whether the job instance was completed.

POST example

You might use the following request to search for a job:
POST <baseApiUrl>/job/public/api/v1/search
Content-Type: application/json
IDS-SESSION-ID: XXXXXXXXXXXXXXXXXXXXXX

{
"search": "*",
"pageSize": 25,
"pageOffset": 0,
"filters": {
"operator": "or",
"filter": [
{
"fieldName": "jobType",
"fieldValue": "c360.be.match.finishTraining"
},
{
"fieldName": "jobType",
"fieldValue": "c360.be.matchmerge"
},
{
"fieldName": "jobType",
"fieldValue": "c360.be.match.startTraining"
}
]
}
}
You get the following response:
HTTP/1.1 200 OK
Content-Type: application/json

{
"totalRecords": 49,
"totalPages": 2,
"currentPage": 0,
"jobInstances": [
{
"id": "714542403541159936",
"name": "seanci1",
"jobType": "c360.be.matchmerge",
"jobDefinition": {
"id": "seanci1",
"caiProcess": {
"name": "MatchMerge"
},
"metadataEntities": [
{
"name": "TARGET_ENTITY",
"entities": [
{
"name": "Baseline Match Model for person Deduplication",
"id": "c360.person"
}
]
}
],
"parameters": [
{
"name": "MATCH_MODEL_ID",
"value": "person.ruleset1",
"type": "String"
},
{
"name": "MATCH_MODEL_VERSION",
"value": "1",
"type": "String"
},
{
"name": "MATCH_MODEL_NAME",
"value": "Baseline Match Model for person Deduplication",
"type": "String"
},
{
"name": "SEARCH_INDEX_LOAD_TYPE",
"value": "ALL",
"type": "String"
},
{
"name": "PROCESS_TYPE",
"value": "Match and Merge",
"type": "String"
},
{
"name": "JOB_FLOW_NAME",
"value": "MATCH_MERGE",
"type": "String"
}
]
},
"runTimeParameters": [
{
"name": "MATCH_MODEL_ID",
"value": "person.ruleset1",
"type": "String"
},
{
"name": "MATCH_MODEL_VERSION",
"value": "1",
"type": "String"
},
{
"name": "MATCH_MODEL_NAME",
"value": "Baseline Match Model for person Deduplication",
"type": "String"
},
{
"name": "SEARCH_INDEX_LOAD_TYPE",
"value": "ALL",
"type": "String"
},
{
"name": "PROCESS_TYPE",
"value": "Match and Merge",
"type": "String"
},
{
"name": "JOB_FLOW_NAME",
"value": "MATCH_MERGE",
"type": "String"
},
{
"name": "isTerminationAllowed",
"value": true,
"type": "Boolean"
},
{
"name": "MODEL_VERSION",
"value": "1653588983323",
"type": "String"
}
],
"jobLevelMetrics": null,
"_meta": {
"completedAt": 1653589344087,
"state": "SUCCESS",
"createdAt": 1653588985202,
"createdBy": "impactci1",
"updatedAt": 1653589344087,
"updatedBy": "impactci1",
"startedAt": 1653588985202,
"startedBy": "impactci1",
"isCompleted": true
}
}
...

Read Job Instance Summary

Use the Read Job Instance Summary API to retrieve a brief summary about the job instance. The summary contains the details of runtime parameters and metrics of a job instance.
The API supports the GET method.

GET request

To retrieve the summary of a job instance, submit a GET request with the following URI:
GET <baseApiURL>/job/public/api/v1/jobInstance/<jobInstanceId>
The GET request contains the following path parameters:
Parameter
Type
Description
jobInstanceId
String
The ID of the job instance.

GET response

The response is in the JSON format. The response body contains the summary of a job instance.
The GET response includes the following parameters:
Parameter
Type
Description
metadataEntities
String
The metadata details of the job instance.
runTimeParameters
String
The runtime parameters that were used to run the underlying taskflow related to the job.
jobLevelMetrics
String
The key metrics of the job instance.
completedAt
String
Date when the job was completed.
state
String
Indicates the status of the job. The job instance can have one of the following statuses:
  • - RUNNING. Indicates that the job is being processed.
  • - SUCCESS. Indicates that the job was successful.
  • - FAILED. Indicates that the job failed.
  • - STOPPED. Indicates that the job was stopped.
  • - WARNING. Indicates that the job completed with warnings.
  • - SKIPPED. Indicates that the job was skipped and not processed by MDM SaaS.
  • - QUEUED. Indicates that the job was queued.
createdAt
String
Date when the job was created.
createdBy
String
Name of the user who created the job.
updatedAt
String
Date when the job was updated.
updatedBy
String
Name of the user who last updated the job.
startedAt
String
Date when the job was started.
startedBy
String
Name of the user who started the job.
isCompleted
Boolean
Indicates whether the job was completed.
Note: All dates are in the Unix epoch time format.

GET example

You might use the following request to retrieve the summary of a job instance based on the job instance ID 93d25c14-c874-438b-8ed0-442944a37a54:
GET <baseApiURL>/job/public/api/v1/jobInstance/93d25c14-c874-438b-8ed0-442944a37a54
Content-Type: application/json
IDS-SESSION-ID: XXXXXXXXXXXXXXXXXXXXXX
The sample response shows the HTTP 200 OK response code and retrieves the summary of a job instance.

{
"id": "93d25c14-c874-438b-8ed0-442944a37a54",
"name": "ingress_organization",
"jobDefinition": {
"id": "internal.c360.ingress.fileImportJob",
"caiProcess": {
"name": "MDMFlowFileImportDQ"
},
"metadataEntities": [
{
"name": "TARGET_ENTITY",
"entities": [
{
"name": "Organizationwefwef",
"id": "c360.organization"
}
]
},
{
"name": "Source_System",
"entities": [
{
"name": "Default",
"id": "b360.default.system"
}
]
}
],
"parameters": [
{
"name": "continueOnError",
"value": true,
"type": "Boolean"
}
]
},
"runTimeParameters": [
{
"name": "continueOnError",
"value": true,
"type": "Boolean"
},
{
"name": "USER_ID",
"value": "9EKrJA9TwrWbrqwEUn6gA4",
"type": "String"
},
{
"name": "MODEL_VERSION",
"value": "1649151390520",
"type": "String"
}
],
"jobLevelMetrics": [
{
"id": "NUM_OF_ASSETS",
"name": "Target Assets",
"type": "PROCESSED",
"value": 1
},
{
"id": "NUM_OF_INCOMING_RECORDS",
"name": "Input Rows",
"type": "INPUT",
"value": 10000
},
{
"id": "NUM_OF_REC_SUCCEEDED",
"name": "Success Rows",
"type": "SUCCESS",
"value": 10000
},
{
"id": "NUM_OF_REC_FAILED",
"name": "Error Rows",
"type": "FAILED",
"value": 0
},
{
"id": "NUM_OF_REC_LOAD_CREATED",
"name": "Success Records",
"type": "SUCCESS",
"value": 10000
},
{
"id": "NUM_OF_REC_LOAD_FAILED",
"name": "Failed Records",
"type": "FAILED",
"value": 0
}
],
"_meta": {
"completedAt": 1649151874361,
"state": "SUCCESS",
"createdAt": 1649151399754,
"createdBy": "impactci1",
"updatedAt": 1649151874361,
"updatedBy": "impactci1",
"startedAt": 1649151399754,
"startedBy": "impactci1",
"isCompleted": true
}
}

Read Job Instance Details

Use the Read Job Instance Details API to retrieve the complete details of a job instance. The details include a brief summary of the job instance and the information about steps related to the job instance.
The API supports the GET method.

GET request

To retrieve the details of a job instance, submit a GET request with the following URI:
GET <baseApiURL>/job/public/api/v1/jobInstance/<jobInstanceId>?details=true
The GET request contains the following path parameters:
Parameter
Type
Description
jobInstanceId
String
The ID of the job instance.

GET response

The response is in the JSON format. The response body contains the complete details of a job instance.
The GET response includes the following parameters:
Parameter
Type
Description
metadataEntities
String
The metadata details of the job instance.
runTimeParameters
String
The runtime parameters that were used to run the underlying taskflow related to the job.
jobLevelMetrics
String
The key metrics of the job instance.
steps
String
Lists the steps and their details.
completedAt
String
Date when the job was completed.
state
String
Indicates whether the job was successful.
createdAt
String
Date when the job was created.
createdBy
String
Name of the user who created the job.
updatedAt
String
Date when the job was updated.
updatedBy
String
Name of the user who last updated the job.
startedAt
String
Date when the job was started.
startedBy
String
Name of the user who started the job.
isCompleted
Boolean
Indicates whether the job was completed.
Note: All dates are in the Unix epoch time format.

GET example

You might use the following request to retrieve the details of a job instance based on the job instance ID 93d25c14-c874-438b-8ed0-442944a37a54:
GET <baseApiURL>/job/public/api/v1/jobInstance/93d25c14-c874-438b-8ed0-442944a37a54?details=true
Content-Type: application/json
IDS-SESSION-ID: XXXXXXXXXXXXXXXXXXXXXX
The following sample response shows the HTTP 200 OK response code and retrieves the details of a job instance:

{
"id": "93d25c14-c874-438b-8ed0-442944a37a54",
"name": "ingress_organization",
"jobDefinition": {
"id": "internal.c360.ingress.fileImportJob",
"caiProcess": {
"name": "MDMFlowFileImportDQ"
},
"metadataEntities": [
{
"name": "TARGET_ENTITY",
"entities": [
{
"name": "Organizationwefwef",
"id": "c360.organization"
}
]
},
{
"name": "Source_System",
"entities": [
{
"name": "Default",
"id": "b360.default.system"
}
]
}
],
"parameters": [
{
"name": "continueOnError",
"value": true,
"type": "Boolean"
}
]
},
"runTimeParameters": [
{
"name": "continueOnError",
"value": true,
"type": "Boolean"
},
{
"name": "USER_ID",
"value": "9EKrJA9TwrWbrqwEUn6gA4",
"type": "String"
},
{
"name": "MODEL_VERSION",
"value": "1649151390520",
"type": "String"
}
],
"jobLevelMetrics": [
{
"id": "NUM_OF_ASSETS",
"name": "Target Assets",
"type": "PROCESSED",
"value": 1
},
{
"id": "NUM_OF_INCOMING_RECORDS",
"name": "Input Rows",
"type": "INPUT",
"value": 10000
},
{
"id": "NUM_OF_REC_SUCCEEDED",
"name": "Success Rows",
"type": "SUCCESS",
"value": 10000
},
{
"id": "NUM_OF_REC_FAILED",
"name": "Error Rows",
"type": "FAILED",
"value": 0
},
{
"id": "NUM_OF_REC_LOAD_CREATED",
"name": "Success Records",
"type": "SUCCESS",
"value": 10000
},
{
"id": "NUM_OF_REC_LOAD_FAILED",
"name": "Failed Records",
"type": "FAILED",
"value": 0
}
],
"steps": [
{
"name": "Index for Search",
"runTimeParameters": [
{
"name": "SEARCH_INDEX_STATUS",
"value": {
"startedBy": "impactci1",
"startTime": 1649151812429,
"endTime": 1649151826197,
"entityInfo": [
{
"entityName": "c360.organization",
"jobCompleted": true,
"jobId": "es-index-25ca8b7ff91ba641-driver",
"jobContext": {
"jobCallbackData": {
"jobCallbackAttemptCount": 1
},
"jobStatus": "SUCCESS",
"metrics": {
"indexRecordProcessed": 10000,
"deleteRecordProcessed": 0,
"total_record_count": 10000,
"deleteTimeTaken": 0,
"deleteRecordSuccess": 0,
"deleteRecordFailure": 0,
"indexTimeTaken": 5205,
"updateTimeTaken": 5136,
"indexRecordFailure": 0,
"indexRecordSuccess": 10000,
"record_failure_count": 0
},
"runTimeParameters": {
"jobInstanceId": "93d25c14-c874-438b-8ed0-442944a37a54",
"tenantId": "6MZknGZ16fLbrn9mRY2C2r",
"stepId": "INDEX",
"entityGuid": "c360.organization",
"startTime": 1649151813374,
"endTime": 1649151826164
},
"outputParameters": {}
},
"retry": false
}
]
}
}
],
"type": "STEP",
"metrics": [
{
"id": "SEARCH_INDEX_TOTAL_RECORDS",
"name": "SEARCH_INDEX_TOTAL_RECORDS",
"type": "PROCESSED",
"value": 10000,
"subMetrics": [
{
"id": "c360.organization",
"name": "c360.organization",
"type": "PROCESSED",
"value": 10000
}
]
},
{
"id": "SEARCH_INDEX_FAILED_RECORDS",
"name": "SEARCH_INDEX_FAILED_RECORDS",
"type": "PROCESSED",
"value": 0,
"subMetrics": [
{
"id": "c360.organization",
"name": "c360.organization",
"type": "PROCESSED",
"value": 0
}
]
}
],
"id": "93d25c14-c874-438b-8ed0-442944a37a54_INDEX",
"_meta": {
"completedAt": 1649151826350,
"state": "SUCCESS",
"createdAt": 1649151812184,
"createdBy": "impactci1",
"updatedAt": 1649151826350,
"updatedBy": "impactci1",
"startedAt": 1649151812184,
"startedBy": "impactci1",
"isCompleted": true
}
...