Troubleshooting a Data Synchro
Here we will see some common issues when running a Data Synchro.
Recommendations
Choosing a primary_key
It is crucial to use a primary_key for which
each values is unique and stable.
- 
Be sure that there will never be 2 source objects sharing the sameprimary_keyvalue.
- 
Be sure that your source objects will never have theirprimary_keymodified in the Source.
The primary_key field must be provided in a
single column in the source data. If you want to
use a combination of Source fields, then have the Source
application concatenating them into a single column.
Reconciliation Attributes
How to choose the Reconciliation Attributes on a Source Data Synchro:
- 
If the Source Application is the master for that class (no object of that class can be created directly in iTop), then use theprimary_keyto reconcile or more exactly the columns having the same information.- 
Storing the Source applicationprimary_keywithin a field of iTop object simplifies a lot any future troubleshooting.
- 
In that case the Source data must duplicate theprimary_keycolumn in 2 different columns, the first one being used asprimary_keyfor the SynchroReplica object, the other being used to update an iTop object field.
 
- 
- 
Otherwise if you chose iTop attributes which can be modified in the Source:- 
those Reconciliation attributes must be updated and locked by the Data Synchro !
- 
Not required only if you are sure that they cannot be modified in the Source
 
- 
Internal processing
Data Source Import
When running synchro_import.php or updating with your own
process the synchro_data_xxx table, MySQL triggers
some background behaviors:
- 
updating the SynchroReplica objects associated with each updated row insynchro_data_xxx- 
status_last_seen = now
- 
status = 'modified'
 
- 
- 
creating a SynchroReplica object for each created row insynchro_data_xxx- 
status_last_seen = now
- 
status = 'new'
 
- 
Synchronizing Data
Handling not seen Replicas
For those replicas
SELECT SynchroReplica WHERE sync_source_id = :source_id AND STATUS IN ('new', 'synchronized', 'modified', 'orphan') AND status_last_seen < (now – :full_load_interval)
Update SynchroReplica
- 
status = ‘obsolete’
- 
If Deletion Policy = “Update” or “Update then delete”- 
Update iTop object using Update rules
- 
Update SynchroReplica withinfo_last_modified= Now
 
- 
Handling new Replicas
For each SynchroReplica in status ‘new’, we search in iTop for objects having the same value as the source row for each Data Synchro Attributes having Reconciliation = 'yes':
- 
If no object found (or multiple if Action on many= “create”): we create a new iTop object- 
If the creation is successful, we update SynchroReplica:- 
info_creation_date= now
- 
dest_id = id of just created object
- 
status_dest_creator = 'yes'
- 
status = 'synchronized'
 
- 
- 
If the creation fails, we update SynchroReplica:- 
status_last_error = Error message from the failing creation
 
- 
 
- 
- 
If one object found (or multiple if Action on many= “take first”):- 
Update SynchroReplica:- 
dest_id = id of the retrieved object
- 
status_dest_creator = 'no'
- 
status = 'synchronized'
 
- 
- 
Update iTop associated object
- 
If it works, update SynchroReplica with info_last_modified = now
- 
If it fails, update SynchroReplica with status_last_warning = Error message from the failing update
 
- 
- 
If more than one object found and Action on many= “error”- 
Update SynchroReplica with status_last_warning = “n destination objects match the reconciliation criterias: xxxxxxxx ”
 
- 
Handling updated Replicas
For each SynchroReplicas with status = “modified”
- 
Update iTop associated object- 
If it works, update SynchroReplica:- 
info_last_modified = now
- 
status = 'synchronized'
 
- 
- 
If it fails, update SynchroReplica:- 
status_last_warning = Error message from the failing update
 
- 
 
- 
Handling Obsolete Replicas
For every 'obsolete' replicas for which we should apply the Deletion Policy
SELECT SynchroReplica WHERE sync_source_id = :source_id AND STATUS IN ('obsolete') AND status_last_seen < (now _ :retention_delay)
- 
If Deletion Policy = “Update” or “Update then delete”- 
Delete the iTop object
- 
Delete corresponding SynchroReplica(s)
- 
Delete corresponding row(s) insynchro_data_xxxtable
 
- 
Common issues
Non unique primary_key
If more than one object in the source share the same primary_key, you are in serious trouble. Those various objects with the same primary_key, will all update the same iTop object. That iTop object will change each time one of the source objects changes and you won't understand why.
primary_key
values must be unique within the SourceNon stable primary_key
The chosen primary_key for the Source data must be
stable and never change for any given object.
primary_key of an object in the Source.primary_key as reconciliation keysWhy ''primary_key'' must not be changed in the Source?
Let's suppose you have a Data Synchro in place, for Person where you have provided a primary_key in the Source, the person's email, but you have set as reconciliation keys: name + firstname + org_id.
- 
You run a first synchro:- 
In the Source we have a row with primary_key: smith@biz.com.
- 
This row creates a new SynchroReplica,
- 
Which then create or update an iTop Person: Alex Smith with that email.
 
- 
- 
Later, in your Source application, the person's email get changed for whatever reason from smith@biz.com into alex.smith@biz.com, and a synchro is started:- 
As the email is the 'primary_key' of the source, that new email appears as a new row in thesynchro_data_xxxsource table, so create a new SynchroReplica: alex.smith@biz.com
- 
The new SynchroReplica get mapped to the existing iTop Person: Alex Smith and its email is modified
- 
The old SynchroReplica: smith@biz.com is no more in the Source and get flagged asobsolete. As it is still mapped to the same iTop Person: Alex Smith.
 
- 
- 
Some synchros later, onDelete Policyexpiration delay:- 
the old obsolete SynchroReplica: smith@biz.com updates the iTop Person Alex Smith for example to set its status toinactive
- 
In the meantime the new SynchroReplica: alex.smith@biz.com being unchanged, because nothing has changed in the Source, it does not update the iTop Person
 
- 
- 
Some more synchro later, onRetention Durationexpiration:- 
the old obsolete SynchroReplica: smith@biz.com delete the iTop Person Alex Smith
- 
As a retroaction, that deletion deletes both SynchroReplicas: smith@biz.com and alex.smith@biz.com
 
- 
- 
Following synchro:- 
A SynchroReplicas: alex.smith@biz.com is recreated and an iTop Person Alex Smith is recreated (assuming the Data Synchro can create iTop Object). But all the relationships of the previous Alex Smith Person are lost, the Tickets that he has created, his teams, and so on…
 
- 
What if?
What to do if you have chosen a bad primary_key and
want to change it?
You have put in place a Data Synchro using the Person email and
later you notice that this is a problem because email address in
your company is not stable in time and is generating issues as
explained above.
So you think about using the Source application Person Id, which is
a stable value in your world. It could be stable because that
Source Application is the master application for handling Persons
in your Company, every new Person is created in there, every
changes is made there. The Person id would remain the same
regardless of any email changes, family name change or organization
change, .
In that case create a new Data Synchro Source and delete the
previous one
- 
Object created by the old Data Synchro will not be flagged as created by the new Data Synchro,
- 
So this will prevent object deletion by the Data Synchro
Non retrieved ExternalKey
While trying to retrieve a remote iTop object using the Reconciliation Key field containing the provided source information, that search may fail, either because there isn't any object matching or because there is more than one object matching. If the ExternalKey is a required field of the synchronized object, this will generate an error, otherwise just a warning and the ExternalKey will be emptied.
Could not find [unique] object for 'manager_id': searched on friendlyname = ‘Bob Smith’
Non valid Enum value
If for a Enum Attribute of the synchronized object, the Source provides an invalid value, for eg an “empty string” which is never a valid Enum value, then you get either a warning or an error depending if the Enum attribute is mandatory or not.
Unable to update destination object: Unexpected value for attribute 'status': Null not allowed: 
issues = {0=>Unexpected value for attribute 'status': Null not allowed}, class = Person, id = 14
null value within an Enum
attribute, if you need something like this, then add a new allowed
value for this Enum, representing the null but being a
true value with a text like “unset” for eg.