| Summary: | [GStreamer] Let playbin handle redirects for us when appropriate | ||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Product: | WebKit | Reporter: | Philippe Normand <pnormand> | ||||||||||
| Component: | Media | Assignee: | Thibault Saunier <tsaunier> | ||||||||||
| Status: | RESOLVED FIXED | ||||||||||||
| Severity: | Normal | CC: | calvaris, cgarcia, commit-queue, eric.carlson, ews-watchlist, glenn, gustavo, jer.noble, mcatanzaro, menard, philipj, sergio, tsaunier, vjaquez, webkit-bug-importer | ||||||||||
| Priority: | P2 | Keywords: | InRadar | ||||||||||
| Version: | WebKit Nightly Build | ||||||||||||
| Hardware: | Unspecified | ||||||||||||
| OS: | Unspecified | ||||||||||||
| Attachments: |
|
||||||||||||
|
Description
Philippe Normand
2019-03-05 05:22:32 PST
Original url example: https://movietrailers.apple.com/movies/wb/shazam/shazam-trailer-2_480p.mov Redirected url example: http://movietrailers.apple.com/movies/wb/shazam/shazam-trailer-2_h480p.mov I suppose the origin check fails because the new url doesn't use https? Yup, the different protocol means it's a totally different security origin with no permission to access the other. Security origin is <protocol, host, port> (except in Internet Explorer, where port is not considered). To me the issue is in the REDIRECT is incorrect, it should point to the `https` variant. chrome or firefox are not able to play that stream either, for some reason Safari is. I would just close the bug tbh. Hi Eric, Can you shed some light here, maybe? Is this a server-side issue? Why is Safari not affected? Trailers play fine in Chromium here. I proposed patches in GStreamer to allow a better handling of redirection in case of quicktime streams with no tracks so playbin can support it for us, see: - https://gitlab.freedesktop.org/gstreamer/gst-plugins-base/merge_requests/419/diffs - https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/merge_requests/340 This makes thing simpler and cleaner for us, let's see how it goes there :-) Created attachment 379836 [details]
Patch
Comment on attachment 379836 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=379836&action=review > Source/WebCore/platform/graphics/gstreamer/MediaPlayerPrivateGStreamer.cpp:2170 > + g_object_get(m_pipeline.get(), "current-uri", &playbinUrlStr.outPtr(), NULL); nullptr Created attachment 380017 [details]
Patch for landing
Comment on attachment 380017 [details] Patch for landing Rejecting attachment 380017 [details] from commit-queue. Failed to run "['/Volumes/Data/EWS/WebKit/Tools/Scripts/webkit-patch', '--status-host=webkit-queues.webkit.org', '--bot-id=webkit-cq-01', 'validate-changelog', '--check-oops', '--non-interactive', 380017, '--port=mac']" exit_code: 1 cwd: /Volumes/Data/EWS/WebKit ChangeLog entry in Source/WebCore/ChangeLog contains OOPS!. Full output: https://webkit-queues.webkit.org/results/13087437 Created attachment 380018 [details]
Patch for landing
Comment on attachment 380018 [details]
Patch for landing
JHBuild bits missing?
(In reply to Philippe Normand from comment #12) > Comment on attachment 380018 [details] > Patch for landing > > JHBuild bits missing? Oops, indeed, fixing that Created attachment 380047 [details]
Patch for landing
Comment on attachment 380047 [details] Patch for landing View in context: https://bugs.webkit.org/attachment.cgi?id=380047&action=review > Tools/gstreamer/jhbuild.modules:85 > + <patch file="good-0001-qtdemux-Specify-REDIRECT-information-in-error-messag.patch" strip="1"/> <!-- Merged upstream, should be shipped in 1.16.1 --> 1.16.2 :) Comment on attachment 380047 [details] Patch for landing Clearing flags on attachment: 380047 Committed r250624: <https://trac.webkit.org/changeset/250624> All reviewed patches have been landed. Closing bug. |