Transforms: Special Cases
Special cases arising when working on transforms in Faros
If you find yourself trying to write a transform and it isn't succeeding, your transform might fall into these special cases.
The "jsonb" case will occur when you're trying to write to a derived category - this is the case if you see within the schema there is a "jsonb" somewhere.
jsonb
First is the case when a field type is "jsonb", for example in the case of the ims_Incident fields "severity" and "priority":
Notice that when we query "severity" and "priority" we get an object that contains the fields "detail" and "category" inside it. If we wanted to write to the "severityCategory", "severityDetail", "priorityCategory", and "priorityDetail" fields, we'd need to write out to objects which contain the following somewhere within them (although you don't need to include both category and detail).
...
"severity": {
"category": "my new severity category",
"detail": "my new severity detail"
},
"priority": {
"category": "my new priority category",
"detail": "my new priority detail",
}
...
The following is a working example of JSONata and related data creating an ims_Incident object with severity "category" and "detail" properly generated:
(
$getCreator := function($name){
$name ? $name : "unknown"
};
data.tms_Task.{
"uid": "incident-" & uid,
"source": "incident-transform-" & source,
"resolvedAt": resolvedAt,
"title": name,
"url": "https://foo.com/" & uid,
"description": $getCreator(creator.name) & ": " & createdAt,
"severity": {
"category": priority.category,
"detail": creator.name
},
"priority": {
"category": "fixed category value"
}
}
)
And here is the associated GraphQL (same as in the main Transforms Doc page):
query MyQuery {
tms_Task {
additionalFields
createdAt
creator {
uid
name
}
name
uid
source
resolvedAt
priority
resolutionStatus
refreshedAt
type
}
}
The result structure will be able to write the fields "severity"/"priority" to the output objects properly.
Updated about 2 months ago