electron_permission_manager.h 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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.h"
  10. #include "content/public/browser/permission_controller_delegate.h"
  11. #include "gin/dictionary.h"
  12. #include "shell/browser/electron_browser_context.h"
  13. #include "shell/common/gin_helper/dictionary.h"
  14. namespace base {
  15. class Value;
  16. } // namespace base
  17. namespace content {
  18. class WebContents;
  19. }
  20. namespace electron {
  21. class ElectronPermissionManager : public content::PermissionControllerDelegate {
  22. public:
  23. ElectronPermissionManager();
  24. ~ElectronPermissionManager() override;
  25. // disable copy
  26. ElectronPermissionManager(const ElectronPermissionManager&) = delete;
  27. ElectronPermissionManager& operator=(const ElectronPermissionManager&) =
  28. delete;
  29. using USBProtectedClasses = std::vector<uint8_t>;
  30. using StatusCallback =
  31. base::OnceCallback<void(blink::mojom::PermissionStatus)>;
  32. using StatusesCallback = base::OnceCallback<void(
  33. const std::vector<blink::mojom::PermissionStatus>&)>;
  34. using PairCallback = base::OnceCallback<void(base::Value::Dict)>;
  35. using RequestHandler = base::RepeatingCallback<void(content::WebContents*,
  36. blink::PermissionType,
  37. StatusCallback,
  38. const base::Value&)>;
  39. using CheckHandler =
  40. base::RepeatingCallback<bool(content::WebContents*,
  41. blink::PermissionType,
  42. const GURL& requesting_origin,
  43. const base::Value&)>;
  44. using DeviceCheckHandler =
  45. base::RepeatingCallback<bool(const v8::Local<v8::Object>&)>;
  46. using ProtectedUSBHandler = base::RepeatingCallback<USBProtectedClasses(
  47. const v8::Local<v8::Object>&)>;
  48. using BluetoothPairingHandler =
  49. base::RepeatingCallback<void(gin_helper::Dictionary, PairCallback)>;
  50. // Handler to dispatch permission requests in JS.
  51. void SetPermissionRequestHandler(const RequestHandler& handler);
  52. void SetPermissionCheckHandler(const CheckHandler& handler);
  53. void SetDevicePermissionHandler(const DeviceCheckHandler& handler);
  54. void SetProtectedUSBHandler(const ProtectedUSBHandler& handler);
  55. void SetBluetoothPairingHandler(const BluetoothPairingHandler& handler);
  56. // content::PermissionControllerDelegate:
  57. void RequestPermission(blink::PermissionType permission,
  58. content::RenderFrameHost* render_frame_host,
  59. const GURL& requesting_origin,
  60. bool user_gesture,
  61. StatusCallback callback) override;
  62. void RequestPermissionWithDetails(blink::PermissionType permission,
  63. content::RenderFrameHost* render_frame_host,
  64. const GURL& requesting_origin,
  65. bool user_gesture,
  66. base::Value::Dict details,
  67. StatusCallback callback);
  68. void RequestPermissions(const std::vector<blink::PermissionType>& permissions,
  69. content::RenderFrameHost* render_frame_host,
  70. const GURL& requesting_origin,
  71. bool user_gesture,
  72. StatusesCallback callback) override;
  73. void RequestPermissionsWithDetails(
  74. const std::vector<blink::PermissionType>& permissions,
  75. content::RenderFrameHost* render_frame_host,
  76. bool user_gesture,
  77. base::Value::Dict details,
  78. StatusesCallback callback);
  79. void CheckBluetoothDevicePair(gin_helper::Dictionary details,
  80. PairCallback pair_callback) const;
  81. bool CheckPermissionWithDetails(blink::PermissionType permission,
  82. content::RenderFrameHost* render_frame_host,
  83. const GURL& requesting_origin,
  84. base::Value::Dict details) const;
  85. bool CheckDevicePermission(blink::PermissionType permission,
  86. const url::Origin& origin,
  87. const base::Value& object,
  88. ElectronBrowserContext* browser_context) const;
  89. void GrantDevicePermission(blink::PermissionType permission,
  90. const url::Origin& origin,
  91. const base::Value& object,
  92. ElectronBrowserContext* browser_context) const;
  93. void RevokeDevicePermission(blink::PermissionType permission,
  94. const url::Origin& origin,
  95. const base::Value& object,
  96. ElectronBrowserContext* browser_context) const;
  97. USBProtectedClasses CheckProtectedUSBClasses(
  98. const USBProtectedClasses& classes) const;
  99. protected:
  100. void OnPermissionResponse(int request_id,
  101. int permission_id,
  102. blink::mojom::PermissionStatus status);
  103. // content::PermissionControllerDelegate:
  104. void ResetPermission(blink::PermissionType permission,
  105. const GURL& requesting_origin,
  106. const GURL& embedding_origin) override;
  107. blink::mojom::PermissionStatus GetPermissionStatus(
  108. blink::PermissionType permission,
  109. const GURL& requesting_origin,
  110. const GURL& embedding_origin) override;
  111. void RequestPermissionsFromCurrentDocument(
  112. const std::vector<blink::PermissionType>& permissions,
  113. content::RenderFrameHost* render_frame_host,
  114. bool user_gesture,
  115. base::OnceCallback<
  116. void(const std::vector<blink::mojom::PermissionStatus>&)> callback)
  117. override;
  118. content::PermissionResult GetPermissionResultForOriginWithoutContext(
  119. blink::PermissionType permission,
  120. const url::Origin& requesting_origin,
  121. const url::Origin& embedding_origin) override;
  122. blink::mojom::PermissionStatus GetPermissionStatusForCurrentDocument(
  123. blink::PermissionType permission,
  124. content::RenderFrameHost* render_frame_host) override;
  125. blink::mojom::PermissionStatus GetPermissionStatusForWorker(
  126. blink::PermissionType permission,
  127. content::RenderProcessHost* render_process_host,
  128. const GURL& worker_origin) override;
  129. blink::mojom::PermissionStatus GetPermissionStatusForEmbeddedRequester(
  130. blink::PermissionType permission,
  131. content::RenderFrameHost* render_frame_host,
  132. const url::Origin& requesting_origin) override;
  133. SubscriptionId SubscribePermissionStatusChange(
  134. blink::PermissionType permission,
  135. content::RenderProcessHost* render_process_host,
  136. content::RenderFrameHost* render_frame_host,
  137. const GURL& requesting_origin,
  138. base::RepeatingCallback<void(blink::mojom::PermissionStatus)> callback)
  139. override;
  140. void UnsubscribePermissionStatusChange(SubscriptionId id) override;
  141. private:
  142. class PendingRequest;
  143. using PendingRequestsMap = base::IDMap<std::unique_ptr<PendingRequest>>;
  144. RequestHandler request_handler_;
  145. CheckHandler check_handler_;
  146. DeviceCheckHandler device_permission_handler_;
  147. ProtectedUSBHandler protected_usb_handler_;
  148. BluetoothPairingHandler bluetooth_pairing_handler_;
  149. PendingRequestsMap pending_requests_;
  150. };
  151. } // namespace electron
  152. #endif // ELECTRON_SHELL_BROWSER_ELECTRON_PERMISSION_MANAGER_H_