Index: chrome/browser/media/chrome_midi_permission_context.h |
diff --git a/chrome/browser/media/chrome_midi_permission_context.h b/chrome/browser/media/chrome_midi_permission_context.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..41d23bed5120be3dde8380b65f0e690e54599bdf |
--- /dev/null |
+++ b/chrome/browser/media/chrome_midi_permission_context.h |
@@ -0,0 +1,79 @@ |
+// Copyright 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_BROWSER_MEDIA_CHROME_MIDI_PERMISSION_CONTEXT_H_ |
+#define CHROME_BROWSER_MEDIA_CHROME_MIDI_PERMISSION_CONTEXT_H_ |
+ |
+#include "base/callback.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "chrome/browser/content_settings/permission_queue_controller.h" |
+#include "content/public/browser/browser_context.h" |
+ |
+class GURL; |
+class PermissionRequestID; |
+class Profile; |
+ |
+// This class manages MIDI permissions flow, and delegates UI handling. |
+class ChromeMIDIPermissionContext |
+ : public base::RefCountedThreadSafe<ChromeMIDIPermissionContext> { |
+ public: |
+ explicit ChromeMIDIPermissionContext(Profile* profile); |
+ |
+ // Request to ask users permission about MIDI. Called on the IO thread, |
+ // and works on the UI thread internally. |
+ void RequestMIDISysExPermission( |
+ int render_process_id, |
+ int render_view_id, |
+ const GURL& requesting_frame, |
+ const content::BrowserContext::MIDISysExPermissionCallback& callback); |
+ |
+ // Called on the UI thread when the profile is about to be destroyed. |
+ void ShutdownOnUIThread(); |
+ |
+ private: |
+ friend class base::RefCountedThreadSafe<ChromeMIDIPermissionContext>; |
+ |
+ virtual ~ChromeMIDIPermissionContext(); |
+ |
+ // Return an instance of the infobar queue controller, creating it |
+ // if necessary. |
+ PermissionQueueController* GetQueueController(); |
+ |
+ // Called on the UI thread when the permission decision is made. It may be by |
+ // the InfoBarDelegate to notify permission has been set. |
+ void NotifyPermissionSet( |
+ const PermissionRequestID& id, |
+ const GURL& requesting_frame, |
+ const content::BrowserContext::MIDISysExPermissionCallback& callback, |
+ bool allowed); |
+ |
+ // Decide whether the permission should be granted. |
+ // Calls PermissionDecided if permission can be decided non-interactively, |
+ // or NotifyPermissionSet if permission decided by presenting an infobar. |
+ // Called on the UI thread. |
+ void DecidePermission( |
+ const PermissionRequestID& id, |
+ const GURL& requesting_frame, |
+ const GURL& embedder, |
+ const content::BrowserContext::MIDISysExPermissionCallback& callback); |
+ |
+ // Called when permission is granted without interactively asking the user. |
+ // Called on the UI thread. |
+ void PermissionDecided( |
+ const PermissionRequestID& id, |
+ const GURL& requesting_frame, |
+ const GURL& embedder, |
+ const content::BrowserContext::MIDISysExPermissionCallback& callback, |
+ bool allowed); |
+ |
+ // Create an PermissionQueueController. Called on the UI thread. |
+ PermissionQueueController* CreateQueueController(); |
+ |
+ Profile* const profile_; |
+ bool shutting_down_; |
+ scoped_ptr<PermissionQueueController> permission_queue_controller_; |
+}; |
+ |
+#endif // CHROME_BROWSER_MEDIA_CHROME_MIDI_PERMISSION_CONTEXT_H_ |