short-circuit_permissions_checks_in_mediastreamdevicescontroller.patch 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
  2. From: Jeremy Rose <[email protected]>
  3. Date: Tue, 12 Jul 2022 16:51:43 -0700
  4. Subject: short-circuit permissions checks in MediaStreamDevicesController
  5. The //components/permissions architecture is complicated and not that
  6. widely used in Chromium, and mostly oriented around showing permissions
  7. UI and/or remembering per-site permissions, which we're not interested
  8. in.
  9. Since we do a permissions check prior to invoking the
  10. MediaStreamDevicesController, and don't (yet) provide the ability to set
  11. granular permissions (e.g. allow video but not audio), just
  12. short-circuit all the permissions checks in MSDC for now to allow us to
  13. unduplicate this code.
  14. diff --git a/components/webrtc/media_stream_devices_controller.cc b/components/webrtc/media_stream_devices_controller.cc
  15. index be66cc8226fa719645701d5cf708ae91c2bf823d..6cf82318db3cc74b2387cb76583284df5ddaed4a 100644
  16. --- a/components/webrtc/media_stream_devices_controller.cc
  17. +++ b/components/webrtc/media_stream_devices_controller.cc
  18. @@ -57,7 +57,8 @@ bool PermissionIsRequested(blink::PermissionType permission,
  19. void MediaStreamDevicesController::RequestPermissions(
  20. const content::MediaStreamRequest& request,
  21. MediaStreamDeviceEnumerator* enumerator,
  22. - ResultCallback callback) {
  23. + ResultCallback callback,
  24. + bool previously_approved) {
  25. content::RenderFrameHost* rfh = content::RenderFrameHost::FromID(
  26. request.render_process_id, request.render_frame_id);
  27. // The RFH may have been destroyed by the time the request is processed.
  28. @@ -93,6 +94,7 @@ void MediaStreamDevicesController::RequestPermissions(
  29. std::vector<blink::PermissionType> permission_types;
  30. +#if 0
  31. content::PermissionController* permission_controller =
  32. web_contents->GetBrowserContext()->GetPermissionController();
  33. @@ -153,21 +155,27 @@ void MediaStreamDevicesController::RequestPermissions(
  34. permission_types.push_back(blink::PermissionType::CAMERA_PAN_TILT_ZOOM);
  35. }
  36. }
  37. +#endif
  38. // It is OK to ignore `request.security_origin` because it will be calculated
  39. // from `render_frame_host` and we always ignore `requesting_origin` for
  40. // `AUDIO_CAPTURE` and `VIDEO_CAPTURE`.
  41. // `render_frame_host->GetMainFrame()->GetLastCommittedOrigin()` will be used
  42. // instead.
  43. - rfh->GetBrowserContext()
  44. - ->GetPermissionController()
  45. - ->RequestPermissionsFromCurrentDocument(
  46. - rfh,
  47. - content::PermissionRequestDescription(permission_types,
  48. - request.user_gesture),
  49. - base::BindOnce(
  50. - &MediaStreamDevicesController::PromptAnsweredGroupedRequest,
  51. - std::move(controller)));
  52. + if (previously_approved) {
  53. + controller->PromptAnsweredGroupedRequest({blink::mojom::PermissionStatus::GRANTED /*audio*/,
  54. + blink::mojom::PermissionStatus::GRANTED /*video*/});
  55. + } else {
  56. + rfh->GetBrowserContext()
  57. + ->GetPermissionController()
  58. + ->RequestPermissionsFromCurrentDocument(
  59. + rfh,
  60. + content::PermissionRequestDescription(permission_types,
  61. + request.user_gesture),
  62. + base::BindOnce(
  63. + &MediaStreamDevicesController::PromptAnsweredGroupedRequest,
  64. + std::move(controller)));
  65. + }
  66. }
  67. MediaStreamDevicesController::~MediaStreamDevicesController() {
  68. @@ -437,6 +445,7 @@ bool MediaStreamDevicesController::PermissionIsBlockedForReason(
  69. return false;
  70. }
  71. +#if 0
  72. // TODO(raymes): This function wouldn't be needed if
  73. // PermissionManager::RequestPermissions returned a denial reason.
  74. content::PermissionResult result =
  75. @@ -447,6 +456,7 @@ bool MediaStreamDevicesController::PermissionIsBlockedForReason(
  76. DCHECK_EQ(blink::mojom::PermissionStatus::DENIED, result.status);
  77. return true;
  78. }
  79. +#endif
  80. return false;
  81. }
  82. diff --git a/components/webrtc/media_stream_devices_controller.h b/components/webrtc/media_stream_devices_controller.h
  83. index b4258f59081c5d99b9c3edf02ca538499a5a435e..3bb6ac4e27fb39283d71a46dd3af7b9f7258d1e2 100644
  84. --- a/components/webrtc/media_stream_devices_controller.h
  85. +++ b/components/webrtc/media_stream_devices_controller.h
  86. @@ -48,7 +48,8 @@ class MediaStreamDevicesController {
  87. // synchronously or asynchronously returned via |callback|.
  88. static void RequestPermissions(const content::MediaStreamRequest& request,
  89. MediaStreamDeviceEnumerator* enumerator,
  90. - ResultCallback callback);
  91. + ResultCallback callback,
  92. + bool previously_approved = false);
  93. ~MediaStreamDevicesController();