Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(28)

Side by Side Diff: chrome/browser/media/permission_bubble_media_access_handler.h

Issue 1095393004: Refactor: Make MediaCaptureDevicesDispatcher have pluggable handlers. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase and address review comments of ps#2 Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CHROME_BROWSER_MEDIA_PERMISSION_BUBBLE_MEDIA_ACCESS_HANDLER_H_
6 #define CHROME_BROWSER_MEDIA_PERMISSION_BUBBLE_MEDIA_ACCESS_HANDLER_H_
7
8 #include <deque>
9 #include <map>
10
11 #include "chrome/browser/media/media_access_handler.h"
12 #include "content/public/browser/notification_observer.h"
13 #include "content/public/browser/notification_registrar.h"
14
15 struct PendingAccessRequest {
Sergey Ulanov 2015/06/01 23:39:18 this can be nested in PermissionBubbleMediaAccessH
changbin 2015/06/02 14:20:09 Done.
16 PendingAccessRequest(const content::MediaStreamRequest& request,
17 const content::MediaResponseCallback& callback);
18 ~PendingAccessRequest();
19
20 // TODO(gbillock): make the MediaStreamDevicesController owned by
21 // this object when we're using bubbles.
22 content::MediaStreamRequest request;
23 content::MediaResponseCallback callback;
24 };
25
26 class PermissionBubbleMediaAccessHandler
27 : public MediaAccessHandler,
28 public content::NotificationObserver {
29 public:
30 PermissionBubbleMediaAccessHandler();
31 ~PermissionBubbleMediaAccessHandler() override;
32
33 // MediaAccessHandler implementation.
34 bool SupportsStreamType(const content::MediaStreamType type,
35 const extensions::Extension* extension) override;
36 bool CheckMediaAccessPermission(
37 content::WebContents* web_contents,
38 const GURL& security_origin,
39 content::MediaStreamType type,
40 const extensions::Extension* extension) override;
41 void HandleRequest(content::WebContents* web_contents,
42 const content::MediaStreamRequest& request,
43 const content::MediaResponseCallback& callback,
44 const extensions::Extension* extension) override;
45 void UpdateMediaRequest(int render_process_id,
46 int render_frame_id,
47 int page_request_id,
48 content::MediaStreamType stream_type,
49 content::MediaRequestState state) override;
50
51 private:
52 void ProcessQueuedAccessRequest(content::WebContents* web_contents);
53 void OnAccessRequestResponse(content::WebContents* web_contents,
54 const content::MediaStreamDevices& devices,
55 content::MediaStreamRequestResult result,
56 scoped_ptr<content::MediaStreamUI> ui);
57
58 // content::NotificationObserver implementation.
59 void Observe(int type,
60 const content::NotificationSource& source,
61 const content::NotificationDetails& details) override;
62
63 typedef std::deque<PendingAccessRequest> RequestsQueue;
Sergey Ulanov 2015/06/01 23:39:18 please move before other private methods: https://
64 typedef std::map<content::WebContents*, RequestsQueue> RequestsQueues;
65 RequestsQueues pending_requests_;
66 content::NotificationRegistrar notifications_registrar_;
67 };
68 #endif // CHROME_BROWSER_MEDIA_PERMISSION_BUBBLE_MEDIA_ACCESS_HANDLER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698