Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Gliffy
imageAttachmentIdatt88015679
macroIde78a49e5-51f6-422b-bcae-ea3d11370a7b
baseUrlhttps://lf-onap.atlassian.net/wiki
displayNameFlattening of JSON
nameFlattening of JSON
diagramAttachmentIdatt87982674
containerId79822969
version3

Grouping of create and remove operations in delta report is fairly straightforward because the two do not Grouping of create and remove operations in delta report is fairly straightforward because the two do not lead to complex scenarios. If a data node is added all its child nodes are also added, same applies in case of remove operation where if a parent node is removed all its child nodes are also removed. Similarly, operations on parent-child nodes like create+update, create+remove, remove+update and remove+createare not possible because if a parent is added or removed the child cannot be added, removed or updated. Hence, the grouping of data nodes which are either added or removed is simpler.

...

  • In order to find the values that have been updated between two data nodes, each leaf node present under the source data node is to be accessed and compared to the leaf node present under the target data node. In doing so all the information about the data nodes relation to other data nodes is lost, because the algorithm first flattens all the data nodes into a linear structure for easier comparision.

  • Then the algorithm accesses each the source and target data node based on their xpath, then accesses

  • When it finds source and target data nodes having the same xpath, we fetch the individual leaves nodes of the said data node, which these leaves are then compared and based on if any changes detected the leaves are added to the delta report.
    Since the data is accessed at a low level (leaf node) to generate the delta report, it becomes impossible to reconstruct the data node back and represent the updated data in the original JSON/XML structure. Therefore, the best approach is to provide the delta of updated nodes individually irrespective of the fact that they are in a parent-child relationship.

  • Reconstructing the data node to represent the original data structure would require some kind of data manipulation which is not suitable as it could lead to discrepancies in the delta that is generated.

  • The same is described below in form of the flowchart.

For the following scenarios we take the following source and target data as a common starting point

Expand

Source Data

Target Data

Code Block
[
  {
    "parent": {
      "leaf-1": "leaf-1 data",
      "leaf-2": "leaf-2 data",
      "child": {
        "child-1 data": "child-1 data",
        "child-2 data": "child-2 data"
      }
    }
  }
]
Code Block
languagejson
[
  {
    "parent": {
      "leaf-1": "leaf-1 data",
      "leaf-2": "leaf-2 updated data",
      "child": {
        "child-1 data": "child-1 updated data",
        "child-2 data": "child-2 data"
      }
    }
  }
]

Mechanism for comparison

Flattening of Data Nodes before comparing

Gliffy
9449afce-5ab1
imageAttachmentIdatt84869188
macroIdbaseUrlhttps://lf-onap.atlassian.net/wiki
nameFlattening of JSON
pageid79822969
timestamp1735206010231

Flowchart: Mechanism for comparison of Data Nodes to check for updates

Gliffy
imageAttachmentIdatt84869188
macroId9449afce-5ab1-4b5a-bf40-dc0ba2d2b5d5
baseUrlhttps://lf-onap.atlassian.net/wiki
displayNameFlowchart of replace operation in Delta Frature
nameUpdate Flowchart
diagramAttachmentIdatt84901971
containerId79822969
version13
timestamp1734600420506

...

If a parent and its child are updated, then both of them should be reported as 2 separate update operations. This is because when comparing data nodes that have been updated, it is not possible to maintain the parent-child relation of the 2 data nodes as explained above.

[ {
Expand
Code Block
titleExample Source and Target Data

Source Data

Target Data

Code Block
[
  {
    "
action
parent":
"update",
 {
      "
xpath
leaf-1": "
/parent
leaf-1 data",
      "
sourceData
leaf-2":
[
 "leaf-2 data",
      "child": {
        "
data
child-1 data": "
old
child-1 data",
      
}
  "child-2 data": "child-2 data"
 
],
     
"targetData":
}
[
    }
  
{
}
]
Code Block
[
  {
    "
data
parent": 
"updated
{
data"
      
} ] }
"leaf-1": "leaf-1 data",
  
{
    
"
action
leaf-2": "
update
leaf-2 updated data",
    
"xpath":
  "
/parent/
child
", "sourceData
":
[
 {
        "child-1 data": "
old
child-1 updated data",
      
}
  "child-2 data": 
],
"child-2 data"
      
"targetData":
}
[
    }
  
{
}
]
Expand
titleSample Delta Report
Code Block
[
  {
    "dataaction": "updated dataupdate",
      }"xpath": "/parent",
    "sourceData": [
      {
    ]   }
]

Scenario 2: Parent is updated, child is added or removed

In a scenario where parent node is updated and its child node either added or removed, then in such a scenario each node must be reported separately and grouped based on their respective operation. For example, if a parent is updated and 2 child nodes are either added. Then the delta report should have 2 entries, first an update entry containing details of the updated parent node and the second a create entry containing both the child nodes, grouped together.

Expand
titleExample
Code Block
[ "leaf-2": "leaf-2 data"
      }
    ],
    "targetData": [
      {
        "leaf-2": "leaf-2 updated data"
      }
    ]
  },
  {
    "action": "update",
    "xpath": "/parent/child",
    "sourceData": [
      {
        "child-1 data": "oldchild-1 data"
      }
    ],
    "targetData": [
      {
        "child-1 data": "child-1 updated data"
      }
    ]
  },
  {
    "action": "create",
    "xpath": "/parent/child",
    "targetData": [
      {
        "data": "child data",
        "grand-child": [
          
]

Scenario 2: Parent is updated, child is added or removed

In a scenario where parent node is updated and its child node either added or removed, then in such a scenario each node must be reported separately and grouped based on their respective operation. For example, if a parent is updated and 2 child nodes are either added. Then the delta report should have 2 entries, first an update entry containing details of the updated parent node and the second a create entry containing both the child nodes, grouped together.

Expand
titleExample Source and Target Data

Source Data

Target Data

Code Block
[
  {
    "parent": {
      "
data
leaf-1": "
grandchild
leaf-1 data",
      "leaf-2": "leaf-2 data"
    }
  }
]
Code Block
[
  {
  
]
  "parent": {
   
}
   "leaf-1": 
]
"leaf-1 data",
  
} ]

Scenario 3: Parent is updated, child 1 is added or removed, child 2 is updated (Siblings scenario) 

If the parent and one of its children are updated while another child is added or removed then in such a case, the parent and updated child will be reported individually as two update operations while the added/removed child would be reported as a separate create/remove operation.

[
Expand
titleExample
Code Block
    "leaf-2": "leaf-2 updated data",
      "child": {
        "child-1 data": "child-1 data",
        "grand-child": [
          {
    
"action": "update",
        "
xpath
data": "
/parent
grandchild data"
,

    
"sourceData":
 
[
     }
 
{
       ]
 
"data": "old data"
     }
    }
  }
], "targetData": [
]
Expand
titleSample Delta Report
Code Block
[
  {
   
    "dataaction": "updated dataupdate",
      }
    ]
  },
  {
    "action": "update",
    "xpath": "/parent/child-2",
    "sourceData": [
      {
        "dataleaf-2": "oldleaf-2 data"
      }
    ],
    "targetData": [
      {
        "dataleaf-2": "leaf-2 updated data"
      }
    ]
  },
  {
    "action": "updatecreate",
    "xpath": "/parent/child-3",
    "sourceDatatargetData": [
      {
        "child-1 data": "oldchild-1 data",
      }  "grand-child": [
 ],     "targetData": [   {
   {         "data": "updatedgrandchild data"
          }
    ]   }, ]
 {     "action": "create",}
    ]
"xpath": "/parent/child-1",
    "targetData": [
      {
        "data": "child-1 data",
        "grand-child": [
          {
            "data": "grandchild data"
          }
        ] }
]

Scenario 3: Parent is updated, child 1 is added or removed, child 2 is updated (Siblings scenario) 

If the parent and one of its children are updated while another child is added or removed then in such a case, the parent and updated child will be reported individually as two update operations while the added/removed child would be reported as a separate create/remove operation.

Example
Expand
titleExample Source and Target Data
Expand
title

Source Data

Target Data

Code Block
[
  {
    "parent": {
      
}
"leaf-1": "leaf-1 data",
  
]
   
} ]

Scenario 4: Parent is updated, child remains unchanged, grandchild is updated

This is another scenario which justifies the proposal that every update operation should be reported separately, because if a parent and its grandchild are updated while the child node is unchanged, then maintaining the parent-child-grandchild relation and the original JSON/XML structure in the delta report becomes impossible because the delta report will not contain any information about the child node as it was not updated. Hence making the grouping operation impossible in such a scenario.

 "leaf-2": "leaf-2 data",
      "child-2": {
        "child-2 data": "child-2 data"
      }
    }
  }
]
Code Block
[
  {
    "parent": {
      "leaf-1": "leaf-1 data",
      "leaf-2": "leaf-2 updated data",
      "child-1": {
        "child-1 data": "child-1 data"
      },
      "child-2": {
        "child-2 data": "child-2 data updated"
      }
    }
  }
]
Expand
titleSample Delta Report
Code Block
[
  {
    "action": "update",
    "xpath": "/parent",
    "sourceData": [
      {
        "leaf-2": "leaf-2 data"
      }
    ],
    "targetData": [
      {
        "leaf-2": "leaf-2 updated data"
      }
    ]
  },
  {
    "action": "update",
    "xpath": "/parent/child-2",
    "sourceData": [
      {
        "child-2 data": "child-2 data"
      }
    ],
    "targetData": [
      {
        "child-2 data": "child-2 data updated"
      }
    ]
  },
  {
    "action": "create",
    "xpath": "/parent/child-1",
    "targetData": [
      {
        "child-1": {
        "child-1 data": "child-1 data"
      }
      }
    ]
  }
]

Scenario 4: Parent is updated, child remains unchanged, grandchild is updated

This is another scenario which justifies the proposal that every update operation should be reported separately, because if a parent and its grandchild are updated while the child node is unchanged, then maintaining the parent-child-grandchild relation and the original JSON/XML structure in the delta report becomes impossible because the delta report will not contain any information about the child node as it was not updated. Hence making the grouping operation impossible in such a scenario.

Expand
titleExample Source and Target Data

Source Data

Target Data

Code Block
[
  {
    "parent": {
      "leaf-1": "leaf-1 data",
      "leaf-2": "leaf-2 data",
      "child": {
        "child-1 data": "child-1 data",
        "grand-child": [
          {
            "data": "grandchild data"
          }
        ]
      }
    }
  }
]
Code Block
[
  {
    "parent": {
      "leaf-1": "leaf-1 data",
      "leaf-2": "leaf-2 updated data",
      "child": {
        "child-1 data": "child-1 data",
        "grand-child": [
          {
            "data": "grandchild data updated"
          }
        ]
      }
    }
  }
]
Expand
titleSample Delta Report
Code Block
[
  {
    "action": "update",
    "xpath": "/parent",
    "sourceData": [
      {
        "dataleaf-2": "oldleaf-2 data"
      }
    ],
    "targetData": [
      {
        "dataleaf-2": "leaf-2 updated data"
      }
    ]
  },
  {
    "action": "update",
    "xpath": "/parent/grandchild",
    "sourceData": [
      {
        "data": "oldgrandchild data"
      }
    ],
    "targetData": [
      {
        "data": "updatedgrandchild data updated"
      }
    ]
  }
]