diff options
Diffstat (limited to 'cloud/pkg/devicecontroller/controller/downstream.go')
| -rw-r--r-- | cloud/pkg/devicecontroller/controller/downstream.go | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/cloud/pkg/devicecontroller/controller/downstream.go b/cloud/pkg/devicecontroller/controller/downstream.go index 20bc84ad1..adc3c3ac1 100644 --- a/cloud/pkg/devicecontroller/controller/downstream.go +++ b/cloud/pkg/devicecontroller/controller/downstream.go @@ -208,6 +208,9 @@ func isExistModel(deviceMap *sync.Map, device *v1beta1.Device) bool { // If NodeName is updated, call add device for newNode, deleteDevice for old Node. // If Spec is updated, send update message to edge func (dc *DownstreamController) deviceUpdated(device *v1beta1.Device) { + if len(device.Status.Twins) > 0 { + removeTwinWithNameChanged(device) + } deviceID := util.GetResourceID(device.Namespace, device.Name) value, ok := dc.deviceManager.Device.Load(deviceID) dc.deviceManager.Device.Store(deviceID, device) @@ -417,3 +420,20 @@ func NewDownstreamController(crdInformerFactory crdinformers.SharedInformerFacto } return dc, nil } + +// Remove twin with changed attribute names. +func removeTwinWithNameChanged(device *v1beta1.Device) { + properties := device.Spec.Properties + twins := device.Status.Twins + newTwins := make([]v1beta1.Twin, 0, len(properties)) + for _, twin := range twins { + twinName := twin.PropertyName + for _, property := range properties { + if property.Name == twinName { + newTwins = append(newTwins, twin) + break + } + } + } + device.Status.Twins = newTwins +} |
