-
-
Notifications
You must be signed in to change notification settings - Fork 49
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
Store uploader token in xattr so uploader can delete #292
Comments
Hey! 👋🏼 The idea sounds very interesting, but I have never used xattr myself before. My questions are:
|
I think it's worth it, the performance impact really depends on the system you're running it on but this method should be many times faster than a database lookup in any case, on my machine it's 800ns slower to read xattrs in addition to reading the file. It's important to keep in mind that a write will only apply on a successful upload and a read only on a potential delete. Rust is new to me, so I would just be learning it as I go. I found this crate for xattrs which at a cursory look seems okay. No reason this couldn't be changed or improved later though. The only thing which needs to be decided beforehand is the xattr's name and the format for the token, we could decide to save a hash of the token instead if you think it that would be better (though I would want to make this optional, since for me, anyone who has read access to the directory itself also has a token anyway). |
Sounds reasonable. We can move forward with the implementation if you'd like, I can provide more opinions once I see how it works! |
I really like the idea. However, this means rustypaste can't be run on Windows anymore. Unless Windows supports extended attributes. |
@jdek are you looking into this? You can start a PR and I can help you if you get stuck, although I am rather new to Rust too. But orhun is an expert Rust coder in case I get stuck too. ;-) Just pick a name for the xattr that makes sense e.g. |
@tessus has it been two weeks already... I've been a bit busy, I'll get a PR up this week. |
I've had a quick look, and have a couple ideas:
In both of these the case for turning off deletes if there are no delete tokens would be removed, as long as there is one insert token the route should be active. I think for deletes the authentication has to be fully moved into the delete handler itself since we cannot know if it's valid until the file is checked. More generic token handling should probably be preferred since another feature I was interested in was the possibility a token being able to access the list endpoint when its globally disabled to list owned files. |
I have to think about this. We might not want that people are automatically allowed to delete the files they uploaded. I think we need an option that enables this feature: e.g. If that option is set, the deletion function checks wether the current token is the one stored in the xattr. Does that make sense? Or am I totally off? Maybe orhun also has some input. I am not the owner, so he might want to decide on the design. |
My thought wasn't about whether it should be allowed in general (besides, from my understanding, GDPR requires you to provide the user with the ability to delete their own content). I'm more wondering about the mechanism by which the token goes from the header into the main logic. In any case I think expanding the tokens to a more generic permission system would be beneficial since it would allow you to do things such as:
|
Let's wait for @orhun's input. |
I feel like the discussion here derails a bit from xattr into a better token mechanism. The mindset of this project is to keep everything as simple as possible so let's try not to overcomplicate things 🐻 I would much rather discuss this over a implementation/PoC so feel free to go ahead and hack something together :)
Yes, that sounds reasonable. |
@jdek are you still interested in working on this? |
@tessus I would love to but am very pressed on time, I can only finish it in the late summer. Apologies. If you want to take it over feel free. |
Ok, let's see who gets to it first. ;-) |
personally i just cbor encoded into a mapping and stored it. no reason to overengineer the storing of less than a kilobyte. it felt important to keep this extensible. for instance, encrypted files are trivial to implement if you keep your metadata as a cbor map with optional fields. i implemented both oneshot and url through this feature as well. while keeping it compatible that do not support xattr support maybe can look at some of this for inspiration although you do not have a bucket system, could likely use the same idea of overriding metadata based off the form field submitted. |
This may decrease performance by requiring an xattr lookup, but should be isolated to DELETEs. A configuration option for this feature would be added such that a user has to manually enable it, then on startup the service would check if the target directory has xattr support and error out if it was requested but there is no support.
On DELETE, first the global delete tokens would be checked, if they all fail then xattr would be checked. I think the impact for abuse here is less than just fetching the file itself.
Let me know what you think of this feature, I'd be happy to implement it.
The text was updated successfully, but these errors were encountered: