-
-
Notifications
You must be signed in to change notification settings - Fork 828
Setting to strip EXIF metadata from JPEG uploads #1307
Conversation
…rip-exif # Conflicts: # src/ContentMessages.js # src/i18n/strings/en_EN.json
/me is unsure what is going on :/ |
@ara4n any update on this? |
not from me; it didn't work for @t3chguy and we haven't yet debugged it. |
Thanks for making this contribution a while back. Since the code base has changed since this was opened, it no longer applies cleanly, and I don't think there's a need to keep it open in this state, as we can always find the code here again if needed. It looks like we should probably file an issue (if there isn't one already) to track the problem being solved here. |
element-hq/element-web#4426 is the bug. |
So the reason why the thumbnails weren't working is that synapse silently chokes on thumbnailing the exif-stripped image, and so the server-side generated thumbnails 404. looks like it's refusing to thumbnail an application/octet-stream upload, given we've lost the mime-type while stripping. |
empirically this seems to work now. tested in e2ee & non-e2ee rooms, with small & massive images. It's worth noting that you have to try quite hard to make Riot/Web use server-generated thumbnails these days since #2439; images have to be bigger than 1MB and larger than 1600x1200 (on a retina display) before riot-web will actually ask synapse for a thumbnail. |
…x-org/matrix-react-sdk into matthew/strip-exif
Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also the two FIXMEs look like we should establish whether they do indeed break things in the way that they say they might.
Thanks for making this contribution a while back. Since the code base has changed since this was opened, it no longer applies cleanly, and I don't think there's a need to keep it open in this state, as we can always find the code here again if needed. If you are still interested in pursuing this feature, please discuss with us in #element-dev:matrix.org to find a good approach forward. |
… matthew/strip-exif � Conflicts: � src/ContentMessages.tsx � src/components/views/settings/tabs/user/PreferencesUserSettingsTab.tsx � src/i18n/strings/en_EN.json � src/settings/Settings.js
So I don't see a sane way to retain the Orientation IFD0 - as for the |
So whilst this won't work ideally in all cases, I think its good enough for 90% of cases. |
ugh. i failed to think through that this would break orientation and colorimetry. can we exclude those from being stripped? last thing we need is to make orientation even more flakey. |
Not easily, would be saner to load re-export out of a canvas IMO |
@t3chguy this PR is here for a while now, does it still apply? If yes, wouldn't it make sense to make a new issue for it so we can properly prioritise it take care of it later? |
@Palid what's wrong with the existing issue element-hq/element-web#4426 ? |
Like a lot of old issues it has spread thin in the details over the years and it's hard to see if it's still relevant. I think this issue is still relevant, but it made more sense to ping you. I think that details of the issue should be probably updated with some newer informations that we already have after initial implementations. |
I might be late on this, but... While I couldn't definitively be against option to strip metadata form cerrtain files if user chooses to, I'm totally against matrix (umbrella) touching anything in uploaded media by default. That is so big can of worms that will never stop even if you could figure out to do prefect stripping for every file format you accept to touch... And not to say you even can't do it really selectively for images.. (rotation, colorspace, etc data)... element-hq/element-web#4426 (comment) is still spot on comment on the thing.. Specificly: "private and secure is not the same as anonymous", those who don't want to exif data to "leak", they shoudn't send images with exif data in first place... It can't be matrix task to decide for user, at the least not by default... |
Existing social media platforms (Twitter, discord, telegram) already do this, they already strip potentially user-compromising data out of media, element would only be following the trend. I do agree that there'd be an option to disable it, but I think that element would be making a right choice for (at least) removing GPS data from images wherever possible. |
This strips EXIF metadata from uploaded JPEGs by default, thus avoiding privacy sensitive metadata such as GPS and timestamps being leaked over Matrix.
Fixes element-hq/element-web#4426