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

Side by Side Diff: chrome/browser/extensions/api/tab_capture/tab_capture_event_router.cc

Issue 10928043: Media Related changes for TabCapture API (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Initial Created 8 years, 2 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2012 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 #include "chrome/browser/extensions/api/tab_capture/tab_capture_event_router.h"
6
7 #include "base/string_number_conversions.h"
8 #include "base/string_piece.h"
9 #include "chrome/browser/profiles/profile.h"
10 #include "chrome/browser/profiles/profile_dependency_manager.h"
11 #include "chrome/browser/media/media_internals.h"
12 #include "chrome/browser/extensions/event_names.h"
13 #include "chrome/browser/extensions/event_router.h"
14 #include "chrome/common/extensions/api/experimental_tab_capture.h"
15
16 namespace events = extensions::event_names;
17 namespace tab_capture = extensions::api::experimental_tab_capture;
18
19 namespace extensions {
20
21 TabCaptureEventRouter::TabCaptureEventRouter(Profile* profile)
22 : profile_(profile) {
23 MediaInternals::GetInstance()->AddObserver(this);
24 }
25
26 TabCaptureEventRouter::~TabCaptureEventRouter() {
27 MediaInternals::GetInstance()->RemoveObserver(this);
28 }
29
30 void TabCaptureEventRouter::OnRequestUpdate(
31 const content::MediaStreamDevice& device,
32 const content::MediaStreamRequest::RequestState new_state) {
33 EventRouter* router = profile_ ? profile_->GetExtensionEventRouter() : NULL;
34 if (!router)
35 return;
36
37 if (device.type != content::MEDIA_TAB_VIDEO_CAPTURE &&
38 device.type != content::MEDIA_TAB_AUDIO_CAPTURE)
39 return;
40
41 // Parse out the tab_id.
42 const size_t sep_pos = device.device_id.find(':');
43 if (sep_pos == std::string::npos)
44 return;
45
46 const base::StringPiece component1(device.device_id.data(), sep_pos);
47 int tabId = -1;
48 if (!base::StringToInt(component1, &tabId))
49 return;
50
51 tab_capture::TabCaptureState state =
52 tab_capture::EXPERIMENTAL_TAB_CAPTURE_TAB_CAPTURE_STATE_NONE;
53 switch (new_state) {
54 case content::MediaStreamRequest::STATE_REQUESTED:
55 state = tab_capture::EXPERIMENTAL_TAB_CAPTURE_TAB_CAPTURE_STATE_REQUESTED;
56 break;
57 case content::MediaStreamRequest::STATE_PENDING_APPROVAL:
58 state = tab_capture::EXPERIMENTAL_TAB_CAPTURE_TAB_CAPTURE_STATE_PENDING;
59 break;
60 case content::MediaStreamRequest::STATE_OPENING:
61 state = tab_capture::EXPERIMENTAL_TAB_CAPTURE_TAB_CAPTURE_STATE_ACTIVE;
62 break;
63 case content::MediaStreamRequest::STATE_DONE:
64 state = tab_capture::EXPERIMENTAL_TAB_CAPTURE_TAB_CAPTURE_STATE_STOPPED;
65 break;
66 case content::MediaStreamRequest::STATE_ERROR:
67 state = tab_capture::EXPERIMENTAL_TAB_CAPTURE_TAB_CAPTURE_STATE_ERROR;
68 break;
69 default:
70 // TODO(justinlin): Handle muted event.
71 break;
72 }
73
74 scoped_ptr<base::ListValue> args(new ListValue());
75 args->AppendInteger(tabId);
76 args->Append(tab_capture::CreateEnumValue(state).get());
77 router->DispatchEventToRenderers(events::kOnTabCaptured,
78 args.Pass(),
79 profile_,
80 GURL());
81 }
82
83 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698