-
Notifications
You must be signed in to change notification settings - Fork 44
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
Deleted account tombstone #72
Comments
Another option would be to delete everything in the user's account dir, and then add a tombstone root The way that the account creation API currently checks if an account already exists is - it looks for the presence of the root .acl file. So I figure, we might as well reuse that mechanism for the 410? |
I think we should transfer this issue to specification, anyone opposed? |
@kjetilk +1, let's do it. (re transfer this issue) |
It might be good to have an override for this functionality to allow the WebID can be reused. If a Pod got corrupted, sometimes the easiest approach to fixing it is to delete the Pod and immediately create a new one using the same WebID. Maybe have a "Pod reset" option? |
A resource server doesn't have knowledge of accounts eg. a WebID URL is an RDF source like all other RDF sources. Whether a deleted account is associated with a WebID can be reusable or not is something should be up to an identity provider. We don't have an interface to help indicate that a deleted account's resources should return a particular status message or a provenance record. If that becomes available, when requesting to access a deleted WebID URL, implementations can potentially mirror identity provider's intention, promise, or what's possible eg. 4xx, 3xx, or something else. I suggest to leave the specific status code or marking an account as "tombstone" to implementations to their discretion - same decision made for all resources: #103 ie. 410 is optional (falling back on RFC 7231). In that view, by default WebIDs can reused provided that URI persistence is taken into account. |
I think it's worth noting on this topic that existing social networking sites tend to have "sunset", "grace", and/or "purge" terms for terminated/"deleted" accounts. For a period of time (typically, a year or so), actions trying to interact with the terminated account receive an appropriate error message, and no-one is allowed to assume that account's identifier (typically, a simple username). Some sites also preserve the terminating user's data for this defined period. Some sites allow the original user to revive the account and, if preserved, restore that data, during the same period. At the end of such a grace period, any preserved data is generally purged. Typically at the same time, but sometimes after an additional waiting period, the username is "freed", and another user can adopt it. I don't see any long-term viable reason why Solid should follow a different path, even with the oft cited but impossible to deliver credo that "A given URI always refers to the same referent, and should/can not be reused to refer to a different referent, forever and ever." Just considering the temporality of domain registrations, at some future date "github.com", for instance, could be taken over by a new registrant, and all the users now identified by such gems as |
I think this on itself should be enough of the reason for not taking it for granted that any given WebID, currently by definition HTTP(S), stays under control of the same actor. We can encourage some best practices while staying realistic that this can happen. |
To complete solid/solid#14, we need to record what to do with incoming requests after deletion. At the very least, we should make sure that nobody gets the same URI so that they can impersonate the former account owner.
As noted there, we should respond with
410
if nothing else has been recorded, but even better is it to allow users to register their new home and do a301
. At the very least, their new WebID should be saved.I thought about using the old
.htaccess
format for this, that we just dump such a file in the former home dir of the user.The text was updated successfully, but these errors were encountered: