- fixed bug: EditSG can be modified by second client while reserved

pull/6/head
Michael Zillgith 10 years ago
parent 584493cf53
commit 9bba6ce44a

@ -548,9 +548,11 @@ getSettingGroupBySGCB(MmsMapping* self, SettingGroupControlBlock* sgcb)
} }
static void static void
unselectSettingGroup(SettingGroup* settingGroup) unselectEditSettingGroup(SettingGroup* settingGroup)
{ {
if (DEBUG_IED_SERVER)
printf("IED_SERVER: Unselect setting group\n"); printf("IED_SERVER: Unselect setting group\n");
settingGroup->sgcb->editSG = 0; settingGroup->sgcb->editSG = 0;
settingGroup->editingClient = NULL; settingGroup->editingClient = NULL;
MmsValue* editSg = MmsValue_getElement(settingGroup->sgcbMmsValues, 2); MmsValue* editSg = MmsValue_getElement(settingGroup->sgcbMmsValues, 2);
@ -568,7 +570,7 @@ unselectAllSettingGroups(MmsMapping* self, MmsServerConnection serverCon)
SettingGroup* settingGroup = (SettingGroup*) LinkedList_getData(settingGroupElement); SettingGroup* settingGroup = (SettingGroup*) LinkedList_getData(settingGroupElement);
if (settingGroup->editingClient == (ClientConnection) serverCon) if (settingGroup->editingClient == (ClientConnection) serverCon)
unselectSettingGroup(settingGroup); unselectEditSettingGroup(settingGroup);
settingGroupElement = LinkedList_getNext(settingGroupElement); settingGroupElement = LinkedList_getNext(settingGroupElement);
} }
@ -584,7 +586,7 @@ MmsMapping_checkForSettingGroupReservationTimeouts(MmsMapping* self, uint64_t cu
if (settingGroup->sgcb->editSG != 0) if (settingGroup->sgcb->editSG != 0)
if (currentTime >= settingGroup->reservationTimeout) if (currentTime >= settingGroup->reservationTimeout)
unselectSettingGroup(settingGroup); unselectEditSettingGroup(settingGroup);
settingGroupElement = LinkedList_getNext(settingGroupElement); settingGroupElement = LinkedList_getNext(settingGroupElement);
} }
@ -1712,8 +1714,10 @@ mmsWriteHandler(void* parameter, MmsDomain* domain,
if (sg != NULL) { if (sg != NULL) {
uint32_t val = MmsValue_toUint32(value); uint32_t val = MmsValue_toUint32(value);
if ((val == 0) && (sg->editingClient == (ClientConnection) connection)) { if (sg->editingClient == (ClientConnection) connection) {
unselectSettingGroup(sg);
if (val == 0) {
unselectEditSettingGroup(sg);
return DATA_ACCESS_ERROR_SUCCESS; return DATA_ACCESS_ERROR_SUCCESS;
} }
@ -1743,11 +1747,13 @@ mmsWriteHandler(void* parameter, MmsDomain* domain,
else else
return DATA_ACCESS_ERROR_OBJECT_ACCESS_DENIED; return DATA_ACCESS_ERROR_OBJECT_ACCESS_DENIED;
} }
else else
return DATA_ACCESS_ERROR_OBJECT_VALUE_INVALID; return DATA_ACCESS_ERROR_OBJECT_VALUE_INVALID;
} }
else /* Edit SG was set by other client */
return DATA_ACCESS_ERROR_TEMPORARILY_UNAVAILABLE;
}
} }
else if (strcmp(nameId, "CnfEdit") == 0) { else if (strcmp(nameId, "CnfEdit") == 0) {
SettingGroup* sg = getSettingGroupByMmsDomain(self, domain); SettingGroup* sg = getSettingGroupByMmsDomain(self, domain);
@ -1762,7 +1768,7 @@ mmsWriteHandler(void* parameter, MmsDomain* domain,
sg->editSgConfirmedHandler(sg->editSgConfirmedHandlerParameter, sg->sgcb, sg->editSgConfirmedHandler(sg->editSgConfirmedHandlerParameter, sg->sgcb,
sg->sgcb->editSG); sg->sgcb->editSG);
unselectSettingGroup(sg); unselectEditSettingGroup(sg);
return DATA_ACCESS_ERROR_SUCCESS; return DATA_ACCESS_ERROR_SUCCESS;
} }

Loading…
Cancel
Save