-
-
Notifications
You must be signed in to change notification settings - Fork 362
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
Forbid deleting element that's part of a relation #5851
Comments
The current behavior is, that all tags are removed from such node, but the node itself is kept, which is wrong. Either the node should be removed from the relations it is part of or the 'delete element' button should be disabled for such cases. For the situation of node (info board) being part of a way, it is not possible to decide, if the node should be removed (does not hold any geometric info for the way) or should be kept. In this case, the disabled button is probably the only choice. |
What do you mean with "the disabled button is probably the only choice."? |
Is it a theoretical bug or something encountered? I faintly remember deletion of relation members being disabled at least in some context. |
I mean the removal from relation is safe, removal from a way can not be decided without user intervention and study of the underlying data. If I place aditional node on a way with info board (on the wall of te building), the node should be removed. If I use some node of the building that is part of its geometry, is should not be removed. |
Hm? Removal of some node from a relation doesn't seem safe to me. Very much depends on the type of relation and the role of the node that is about to be deleted. |
Encountered for second time in few days. Example is https://www.openstreetmap.org/changeset/155834201, https://www.openstreetmap.org/node/3892283189 |
OK, we meet it in cases, where it is fine. There may be other situations, where it is a problem. Then the generic solution is to disable the 'delete' button/function if the node is part of either a way or a relation and link the user to some advanced editor to inspect the situation. Maybe some note or other such tag can be added to this node instead of deletion? |
This might be an issue. At the time the element is shown (in the quest / overlay), StreetComplete doesn't know whether an element is part of a way or relation. That's how the data is structured. |
You are able to use only OSM API calls or Overpass is available as well? |
Well looks OSM API should be fine as well: https://wiki.openstreetmap.org/wiki/API_v0.6#Ways_for_node:_GET_/api/0.6/node/#id/ways (next call in the docs for relations) So a check before the upload occurs should be possible, right? |
Yes, as I wrote, a check can be done during upload. The app should and does work completely offline, so no calls to the OSM API are made during usage, only during download and upload. |
Sorry, I misremembered. It is actually possible in SC to check if a node is part of a relation when opening the element / quest, also offline. However, and that is an issue, relations of the following types are discarded (i.e. not persisted in local database) on download by StreetComplete because of (very real) performance reasons:
What does that mean? That StreetComplete is simply not aware of the existence of these relations and thus also doesn't know if any element is part of any such relation EXCEPT during upload. It must be aware of these relations during upload because SC must be able to correctly modify such relations when e.g. uploading the splitting of ways. It specifically queries the OSM API during upload for this with the OSM API calls you mentioned. |
O, so would you be able to either perform the check before you discard the relations or before the upload with OSM API? With info boards where we have global quality control for Czech Republic, we wind these cases (at least most of), but it is a global problem, so would be nice to fix it and not leave orphans in the data. |
The check is performed before upload to the OSM API. Only because of the check, the element is not deleted but only the tags are cleared. But what should the check do if the element turns out to be part of a relation after all? If the change is then simply discarded, the quest will just pop up for the user (and the next user, ...) again. |
OK, I see. Then either we must find a way how to check before the quests are offered (to not offer this at all) or mark it in OSM data so it is not presented to the user again. With the second option - you set the check_date tag with current date, right? Could this be exploited - e.g. do not offer objects tested recently? |
Another (suboptimal) option could be to use lifecycle prefixes instead of object deletion in these cases - e.g. removed: etc. ? |
Perhaps on upload, if to-be-deleted node is determined to be part of relation(s), instead of clearing the tags, we can auto-create a note at that node location saying that "The mapper on the ground indicated this no longer exists, but as it is part of relation, it needs separate checking and handling" ? (just like the user has chosen to "leave a note" manually). That should both provide useful information to mappers with more capable editors, and skip quests for other StreetComplete users at the same time. |
Yeah, but setting the check date to now even though the user replies that it does not exist anymore seems like... adding wrong data to OSM. The check date is set to now if the user replied that indeed it still exists.
This could work, but also requires to find out first which tag to actually prepend with
This occured to me too. It would be somewhat of a precedence, as SC does not usually create automated notes. But I think this is going to be technically difficult, because the osm edit uploader knows nothing of notes. It would be very hacky, at best. At the very least, the auto-generated note would first appear as another edit in the undo history and probably not even uploaded in the same go. |
If auto-generating a note is an issue (and I see both the technical and the ideological problem there), perhaps instead that to-be-deleted element could be modified with |
I fear this is not a solution because elements can be deleted in a number of different quests. In many quests, you have the other answer option to state that it does not exist. |
To the example at hand. The deletion was wrong because after all, the element existed but at a slightly different position? Or what exactly was the new situation? |
all of them?
There are problems with some lifecycle prefix tagging (when used for old, historic objects not kept temporarily). But these are not troll tags in meaning of "and this tag inverts/negates meaning of another tag" |
Though I am not sure whether I guess it looks less weird, but effect is basically the same. Maybe it saves confused mapper time needed to check object history? |
It kept a node without any tags on original position being part of the relation. (In the mean time I corrected this as the contributor confirmed it to be a mistake in this case and the board is there. For others I simply removed the node from the relation and delete the empty node to fix the situation) |
I'd say it is.
Yes it is easier, but even more so it makes it easy to search for those (in OverPass, or JOSM find, etc) and handle them properly |
Has it been considered to set a boolean on the object, e.g. a bad 1deaCall the boolean `in_a_relationship` and, on April 1st, show the toast "To avoid heartbreak, StreetComplete does not allow breaking up relationships." |
So, regarding the latest suggestion, to mark elements during download if they are part of a relation and then based on this value, don't offer a "delete POI" option: Yes, it is possible, but this wouldn't solve the issue fully, as the node could have become part of a relation since it has been downloaded. With the current behavior already rarely being an issue, if that solution was implemented, it would just become even more rarely an issue, but not resolve it. So, I am not in favor of that. To prepend all tags with First of all, not sure. Because there are a lot of So, to me, the better solution is, and it was already suggested, also by @mnalis, additionally to clearing the tags (current behavior), add a |
I settled for |
City and community maintained tourist routes need special handling as they usually get repaired and if part is missing then the rest of the route is probably too.
How to Reproduce
In quest "Is it still here" on information board that is part of a tourist track choose 'delete element'
Expected Behavior
Hide/disable the 'delete element' button
Versions affected
The text was updated successfully, but these errors were encountered: