Bug 172328

Summary: Prevent javascript interface from activating picture-in-picture for video elements that are showing capture camera on ios.
Product: WebKit Reporter: Jeremy Jones <jeremyj-wk>
Component: MediaAssignee: Jeremy Jones <jeremyj-wk>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, eric.carlson, jer.noble, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: iPhone / iPad   
OS: Unspecified   
Attachments:
Description Flags
Patch
eric.carlson: review+
Patch for landing. none

Jeremy Jones
Reported 2017-05-18 18:10:33 PDT
Prevent javascript interface from activating picture-in-picture for video elements that are showing capture camera on ios.
Attachments
Patch (9.88 KB, patch)
2017-05-18 18:20 PDT, Jeremy Jones
eric.carlson: review+
Patch for landing. (8.52 KB, patch)
2017-05-19 15:11 PDT, Jeremy Jones
no flags
Jeremy Jones
Comment 1 2017-05-18 18:15:57 PDT
Jeremy Jones
Comment 2 2017-05-18 18:20:56 PDT
Eric Carlson
Comment 3 2017-05-19 08:25:08 PDT
Comment on attachment 310585 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=310585&action=review > Source/WebCore/html/HTMLVideoElement.cpp:160 > + if (player() && !player()->supportsPictureInPicture()) > + return false; Nit: I see that there is another "if (player() && player()->xxx)" in this method, followed by an unguarded use of "player()", so apparently this method can't succeed if player() is NULL. Can you remove this check and add an "ASSERT(player())" at the beginning of the method to verify this in debug builds, plus an early return to avoid a release build crash? > Source/WebCore/platform/graphics/mac/MediaPlayerPrivateQTKit.h:83 > + bool supportsPictureInPicture() const override { return true; }; > + bool supportsFullscreen() const override { return true; }; Nit: I doubt PiP works in QTKit, I would skip this.
Jeremy Jones
Comment 4 2017-05-19 15:08:30 PDT
Comment on attachment 310585 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=310585&action=review >> Source/WebCore/html/HTMLVideoElement.cpp:160 >> + return false; > > Nit: I see that there is another "if (player() && player()->xxx)" in this method, followed by an unguarded use of "player()", so apparently this method can't succeed if player() is NULL. Can you remove this check and add an "ASSERT(player())" at the beginning of the method to verify this in debug builds, plus an early return to avoid a release build crash? it is actually a if (!player() || !player()->supportsFullscreen()) return false. That is the line that allows the later code to just use dereference player() without checking. I can just add a if (!player()) return false; to the top of the function and remove that check throughout. >> Source/WebCore/platform/graphics/mac/MediaPlayerPrivateQTKit.h:83 >> + bool supportsFullscreen() const override { return true; }; > > Nit: I doubt PiP works in QTKit, I would skip this. Skipped QTKit changes. > Source/WebCore/platform/graphics/mac/MediaPlayerPrivateQTKit.mm:-761 > - Skipped this change too.
Jeremy Jones
Comment 5 2017-05-19 15:11:26 PDT
Created attachment 310705 [details] Patch for landing.
WebKit Commit Bot
Comment 6 2017-05-19 17:25:04 PDT
Comment on attachment 310705 [details] Patch for landing. Clearing flags on attachment: 310705 Committed r217175: <http://trac.webkit.org/changeset/217175>
Note You need to log in before you can comment on or make changes to this bug.