7 Key Questions to Ask your Issue Sync Vendor : Part 2 – Autonomy

adminUncategorized

Autonomy is essential for any solution which different organizations use to exchange information in a structured way. This article shows some concepts of setting up synchronization.

 

flower

 

Configuration models

There are 2 configuration models to set up a synchronization: centralized or distributed.

Centralized configuration

The centralized configuration is a synchronization setup where all mapping, filtering, and transformation happen in a single location. The decision on how this synchronization should behave is implemented in a single, centralized point.

Distributed configuration

The distributed configuration is the setup where all mapping, filtering, and transformation are done at endpoints. The common data model ensures that every endpoint determines how shared information is transformed into the local context.

 

Requirements

When 2 independent organizations want to exchange information in a structured way, some constraints need to be taken into account.

 

Requirement
Description
 Access Security As an administrator, you have a lot of responsibilities. In many cases, thousands of users are using the tracker to manage their day-to-day tasks.
The last thing you want is that you have to provide access to your own system to some third-party administrator.
 Information Security An issue tracker carries a lot of information that is IP-sensitive. You don’t want to leak out the details of your next major feature, do you? So, only fine-grained information can be exchanged.
 Change management Configurations evolve as the organization evolves. One week, your workflow may include 4 steps to track the status of an issue, while the other week, you’re going to need to expand this with 2 additional statuses to track the delivery into production.

When your tracker is connected to 5 other trackers (each with their own configuration), you want to be sure that you have the freedom to change your own configuration without the need to negotiate it with your counterparts.

 Upgrades Software evolution happens all the time. In some cases, software gets exchanged with completely different systems. It is important that these major changes are possible without breaking any existing agreements with the other systems.

 

Comparison

Requirement
Centralized
Distributed
Access Security(minus) An admin needs access to the whole system(plus) Each admin configures the interaction locally, not having to access the remote system
Information Security(minus) All information is exchanged between the two systems. A central configuration defines what information is actually used in the synchronization(plus) Each admin defines what information is sent over the wire.
Change management(minus) A centrally defined synchronization relation requires cooperation with the counterparty to agree on how this configuration can be changed(plus) Each admin defines what information is exchanged and how it is being applied locally. If the configuration changes, the admin can make sure that the information sent to the other side still complies with the agreed interfaces.
Upgrades(minus) Every upgrade needs to be checked with all counterparts.(plus) Each site can upgrade its environment ‘at will’

 

Conclusion

Autonomy is extremely important.  You don’t want an issue sync solution where each local change requires interaction with other parties. As the number of connected issue trackers increases, autonomy will ensure that every individual site can evolve its configuration without having to negotiate it with counterparts.