-
Notifications
You must be signed in to change notification settings - Fork 89
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
existing entities are overwritten when creating a device #728
Comments
Did you check this part of the documentation?: Specially the config parameter |
Thank you for your comment! Yes i have tried playing with those options, including the From what i understood those 3 options are primarily responsible for controlling how the Iot Agent behaves, when it receives a message, right? What i am investigating is at a point in time, where there has no message yet been send or received. The 3 options have no influence on the initial creation of the entity via an upsert request, which overwrites the existing entity. |
In theory, using Append Mode should not overwrite the entities in the broker. As far as I can see, you are using scorpio broker. Probably @jason-fox could give you more info about the NGSI-LD behaviour regarding how the IoT Agent interacts with the broker itself and the expected behaviour |
But just in general, no matter the combination of the the 3 options, what the IOTAgent does, is an upsert request, creating the "initial entity", which has at that point not received any message. But with that upsert request, the context broker overwrites an existing entity, if there may be an existing entity with the provided id. Again from the log:
So i dont think this is "false behaviour" from the context broker, is it? I personally think the request from the iot agent could be of the form:
To make sure, that when creating the initial entity, existing entities are not overwritten. This is of course only then an issue, if this would be the expected or intended behaviour of the iot agent. Maybe i shortly explain what i use that for and why this is an issue for me and maybe this is also more of a niche usecase and i just have to work around that if this is not what the iot agent is supposed to be used for :D I have an onthology describing a system i am modelling. I now have all the entities and relationships of the system (according to the given onthology) in the context broker, so many entities with different propertys and relationships. Only a subset of those property attributes i now want to "connect" to the iot agent. So the best workflow would be to create all the entities in the context broker with all the information and then connect the subset of the entities each with their subset of attributes to the iot agent. A workaround at the moment is to just change the order, first create the devices for the iot agent and then create the entitys, then everything works as expected. But i was just wondering if this is in general expected behaviour of the iotagent, of if not maybe having |
Hi,
i dont know if this is intented behavior, but if a device is created, referencing an existing entity from the context broker, this entity is overwritten and all the attributes are lost.
The following steps can be done to replicate the issue:
1.) Create an entity with an id and post it to the context broker, for example the following entity
2.) Create and post a device, referencing this entity
3.) Get the entity from the context broker:
Following are the logs of the IOT Agent:
It can be seen that an upsert request is performed, coupled with the message that the "initial entity in the Context Broker" is created. This overwrites the previous entity. However, this makes the IOT Agent less useful in a scenario where entities already exist that you want to reference via the IOT Agent.
I suggest the following approach, which I unfortunately can't implement myself because I can't code JavaScript :)
2.a) If the entity exists, it is updated with the attributes defined in the device. Matching attributes remain unchanged, new attributes are updated and the value is set to None.
2.b) If the Entity does not exist, it will be created. However, the defined attributes are also passed directly, and the values are set None.
This would have the advantage of being able to connect already created entities to the IOT Agent without losing any information. On the other hand an update with the attributes, which stand in the device configuration, would have the advantage that even if still no message was received, a query of the entity shows, which attributes of this are actually intended, even if the values for it are in each case still None.
The text was updated successfully, but these errors were encountered: