short-circuit_permissions_checks_in_mediastreamdevicescontroller.patch 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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 efbea8c15b096344b0cc65cc337a9cdbd727cb55..ca31bba7fc6daf68e6862554a70032dfdc8285b5 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,19 +155,25 @@ 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. - permission_types, rfh, request.user_gesture,
  47. - base::BindOnce(
  48. - &MediaStreamDevicesController::PromptAnsweredGroupedRequest,
  49. - std::move(controller)));
  50. + if (previously_approved) {
  51. + controller->PromptAnsweredGroupedRequest({blink::mojom::PermissionStatus::GRANTED /*audio*/,
  52. + blink::mojom::PermissionStatus::GRANTED /*video*/});
  53. + } else {
  54. + rfh->GetBrowserContext()
  55. + ->GetPermissionController()
  56. + ->RequestPermissionsFromCurrentDocument(
  57. + permission_types, rfh, request.user_gesture,
  58. + base::BindOnce(
  59. + &MediaStreamDevicesController::PromptAnsweredGroupedRequest,
  60. + std::move(controller)));
  61. + }
  62. }
  63. MediaStreamDevicesController::~MediaStreamDevicesController() {
  64. @@ -435,6 +443,7 @@ bool MediaStreamDevicesController::PermissionIsBlockedForReason(
  65. return false;
  66. }
  67. +#if 0
  68. // TODO(raymes): This function wouldn't be needed if
  69. // PermissionManager::RequestPermissions returned a denial reason.
  70. content::PermissionResult result =
  71. @@ -445,6 +454,7 @@ bool MediaStreamDevicesController::PermissionIsBlockedForReason(
  72. DCHECK_EQ(blink::mojom::PermissionStatus::DENIED, result.status);
  73. return true;
  74. }
  75. +#endif
  76. return false;
  77. }
  78. diff --git a/components/webrtc/media_stream_devices_controller.h b/components/webrtc/media_stream_devices_controller.h
  79. index b4258f59081c5d99b9c3edf02ca538499a5a435e..3bb6ac4e27fb39283d71a46dd3af7b9f7258d1e2 100644
  80. --- a/components/webrtc/media_stream_devices_controller.h
  81. +++ b/components/webrtc/media_stream_devices_controller.h
  82. @@ -48,7 +48,8 @@ class MediaStreamDevicesController {
  83. // synchronously or asynchronously returned via |callback|.
  84. static void RequestPermissions(const content::MediaStreamRequest& request,
  85. MediaStreamDeviceEnumerator* enumerator,
  86. - ResultCallback callback);
  87. + ResultCallback callback,
  88. + bool previously_approved = false);
  89. ~MediaStreamDevicesController();