electron_permission_manager.h 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. // Copyright (c) 2016 GitHub, Inc.
  2. // Use of this source code is governed by the MIT license that can be
  3. // found in the LICENSE file.
  4. #ifndef ELECTRON_SHELL_BROWSER_ELECTRON_PERMISSION_MANAGER_H_
  5. #define ELECTRON_SHELL_BROWSER_ELECTRON_PERMISSION_MANAGER_H_
  6. #include <memory>
  7. #include <vector>
  8. #include "base/containers/id_map.h"
  9. #include "base/functional/callback_forward.h"
  10. #include "base/values.h"
  11. #include "content/public/browser/permission_controller_delegate.h"
  12. namespace content {
  13. class WebContents;
  14. }
  15. namespace gin_helper {
  16. class Dictionary;
  17. } // namespace gin_helper
  18. namespace v8 {
  19. class Object;
  20. template <typename T>
  21. class Local;
  22. } // namespace v8
  23. namespace electron {
  24. class ElectronBrowserContext;
  25. class ElectronPermissionManager : public content::PermissionControllerDelegate {
  26. public:
  27. ElectronPermissionManager();
  28. ~ElectronPermissionManager() override;
  29. // disable copy
  30. ElectronPermissionManager(const ElectronPermissionManager&) = delete;
  31. ElectronPermissionManager& operator=(const ElectronPermissionManager&) =
  32. delete;
  33. using USBProtectedClasses = std::vector<uint8_t>;
  34. using StatusCallback =
  35. base::OnceCallback<void(blink::mojom::PermissionStatus)>;
  36. using StatusesCallback = base::OnceCallback<void(
  37. const std::vector<blink::mojom::PermissionStatus>&)>;
  38. using PairCallback = base::OnceCallback<void(base::Value::Dict)>;
  39. using RequestHandler = base::RepeatingCallback<void(content::WebContents*,
  40. blink::PermissionType,
  41. StatusCallback,
  42. const base::Value&)>;
  43. using CheckHandler =
  44. base::RepeatingCallback<bool(content::WebContents*,
  45. blink::PermissionType,
  46. const GURL& requesting_origin,
  47. const base::Value&)>;
  48. using DeviceCheckHandler =
  49. base::RepeatingCallback<bool(const v8::Local<v8::Object>&)>;
  50. using ProtectedUSBHandler = base::RepeatingCallback<USBProtectedClasses(
  51. const v8::Local<v8::Object>&)>;
  52. using BluetoothPairingHandler =
  53. base::RepeatingCallback<void(gin_helper::Dictionary, PairCallback)>;
  54. void RequestPermissionWithDetails(blink::PermissionType permission,
  55. content::RenderFrameHost* render_frame_host,
  56. const GURL& requesting_origin,
  57. bool user_gesture,
  58. base::Value::Dict details,
  59. StatusCallback response_callback);
  60. // Handler to dispatch permission requests in JS.
  61. void SetPermissionRequestHandler(const RequestHandler& handler);
  62. void SetPermissionCheckHandler(const CheckHandler& handler);
  63. void SetDevicePermissionHandler(const DeviceCheckHandler& handler);
  64. void SetProtectedUSBHandler(const ProtectedUSBHandler& handler);
  65. void SetBluetoothPairingHandler(const BluetoothPairingHandler& handler);
  66. void CheckBluetoothDevicePair(gin_helper::Dictionary details,
  67. PairCallback pair_callback) const;
  68. bool CheckPermissionWithDetails(blink::PermissionType permission,
  69. content::RenderFrameHost* render_frame_host,
  70. const GURL& requesting_origin,
  71. base::Value::Dict details) const;
  72. bool CheckDevicePermission(blink::PermissionType permission,
  73. const url::Origin& origin,
  74. const base::Value& object,
  75. ElectronBrowserContext* browser_context) const;
  76. void GrantDevicePermission(blink::PermissionType permission,
  77. const url::Origin& origin,
  78. const base::Value& object,
  79. ElectronBrowserContext* browser_context) const;
  80. void RevokeDevicePermission(blink::PermissionType permission,
  81. const url::Origin& origin,
  82. const base::Value& object,
  83. ElectronBrowserContext* browser_context) const;
  84. USBProtectedClasses CheckProtectedUSBClasses(
  85. const USBProtectedClasses& classes) const;
  86. protected:
  87. void OnPermissionResponse(int request_id,
  88. int permission_id,
  89. blink::mojom::PermissionStatus status);
  90. // content::PermissionControllerDelegate:
  91. void RequestPermissions(
  92. content::RenderFrameHost* render_frame_host,
  93. const content::PermissionRequestDescription& request_description,
  94. StatusesCallback callback) override;
  95. void ResetPermission(blink::PermissionType permission,
  96. const GURL& requesting_origin,
  97. const GURL& embedding_origin) override;
  98. blink::mojom::PermissionStatus GetPermissionStatus(
  99. blink::PermissionType permission,
  100. const GURL& requesting_origin,
  101. const GURL& embedding_origin) override;
  102. void RequestPermissionsFromCurrentDocument(
  103. content::RenderFrameHost* render_frame_host,
  104. const content::PermissionRequestDescription& request_description,
  105. base::OnceCallback<
  106. void(const std::vector<blink::mojom::PermissionStatus>&)> callback)
  107. override;
  108. content::PermissionResult GetPermissionResultForOriginWithoutContext(
  109. blink::PermissionType permission,
  110. const url::Origin& requesting_origin,
  111. const url::Origin& embedding_origin) override;
  112. blink::mojom::PermissionStatus GetPermissionStatusForCurrentDocument(
  113. blink::PermissionType permission,
  114. content::RenderFrameHost* render_frame_host,
  115. bool should_include_device_status) override;
  116. blink::mojom::PermissionStatus GetPermissionStatusForWorker(
  117. blink::PermissionType permission,
  118. content::RenderProcessHost* render_process_host,
  119. const GURL& worker_origin) override;
  120. blink::mojom::PermissionStatus GetPermissionStatusForEmbeddedRequester(
  121. blink::PermissionType permission,
  122. content::RenderFrameHost* render_frame_host,
  123. const url::Origin& requesting_origin) override;
  124. private:
  125. class PendingRequest;
  126. using PendingRequestsMap = base::IDMap<std::unique_ptr<PendingRequest>>;
  127. void RequestPermissionsWithDetails(
  128. content::RenderFrameHost* render_frame_host,
  129. const content::PermissionRequestDescription& request_description,
  130. base::Value::Dict details,
  131. StatusesCallback callback);
  132. RequestHandler request_handler_;
  133. CheckHandler check_handler_;
  134. DeviceCheckHandler device_permission_handler_;
  135. ProtectedUSBHandler protected_usb_handler_;
  136. BluetoothPairingHandler bluetooth_pairing_handler_;
  137. PendingRequestsMap pending_requests_;
  138. };
  139. } // namespace electron
  140. #endif // ELECTRON_SHELL_BROWSER_ELECTRON_PERMISSION_MANAGER_H_