This repository has been archived by the owner on Apr 26, 2024. It is now read-only.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Support rendering previews with data: URLs in them #11767
Support rendering previews with data: URLs in them #11767
Changes from 14 commits
ff7c377
5b09001
fb448dd
9b98fea
f07df94
6cd9b5b
88917c0
b9a1c66
116015f
3b38444
e042244
deeec27
5124a94
d38a07c
043b4c1
2042da1
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
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.
Do you know how this differs from
urljoin
in the standard lib?Not necessarily opposed to rolling our own, but it'd be nice to know if we had specific motivation for doing so.
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.
I didn't know of it, but I'll look into it!
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.
I think this will work OK, but I'd rather punt this to a separate PR since it is pretty unrelated to this work. Would that be OK?
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.
yeah OK
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.
Should we cross reference this with the mime-type in the data url?
(Do we want to have some kind of whitelist of trusted mime types which are okay to preview?)
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.
This is the mime-type from the data URL, it gets parsed out for us and shoved into a
headers
property for some reason.The docs for
urlopen
have some info on howdata
URLs are handled:The
addinfourl
object has aheaders
property:The
EmailMessage
object has aget_content_type()
property:This all doesn't really make sense for
data
URLs, but from trial and error it seems to do the correct thing.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.
I added a clarifying comment in 116015f -- hopefully that helps?
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.
We might want to assert HTTP(S) schemes here as additional error checking.
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.
Yeah I feel like I'd be happier having a few select allowed protocols rather than singling out
data:
; not sure it really makes sense to ask us to preview anftp:
URI either for example.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.
Yep, note that those will fail right now (we won't try them), but it would be better to be explicit, I think!
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.
I think this might actually be tougher to get correct than I initially though since we seem to support previewing scheme-less URLs. I'm not sure it makes sense to refactor that as part of this.
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.
Yeah, fair enough.