Refactor WebsiteSettings to operate on a SecurityInfo
[chromium-blink-merge.git] / chrome / browser / media / midi_permission_context.cc
blobd2162e7ad05df93aec1308692688a30295cedc7d
1 // Copyright 2013 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.
5 #include "chrome/browser/media/midi_permission_context.h"
7 #include "chrome/browser/content_settings/tab_specific_content_settings.h"
8 #include "chrome/browser/permissions/permission_request_id.h"
9 #include "content/public/browser/child_process_security_policy.h"
10 #include "url/gurl.h"
12 MidiPermissionContext::MidiPermissionContext(Profile* profile)
13 : PermissionContextBase(profile, CONTENT_SETTINGS_TYPE_MIDI_SYSEX) {
16 MidiPermissionContext::~MidiPermissionContext() {
19 void MidiPermissionContext::UpdateTabContext(const PermissionRequestID& id,
20 const GURL& requesting_frame,
21 bool allowed) {
22 TabSpecificContentSettings* content_settings =
23 TabSpecificContentSettings::GetForFrame(id.render_process_id(),
24 id.render_frame_id());
25 if (!content_settings)
26 return;
28 if (allowed) {
29 content_settings->OnMidiSysExAccessed(requesting_frame);
31 content::ChildProcessSecurityPolicy::GetInstance()->
32 GrantSendMidiSysExMessage(id.render_process_id());
33 } else {
34 content_settings->OnMidiSysExAccessBlocked(requesting_frame);
38 bool MidiPermissionContext::IsRestrictedToSecureOrigins() const {
39 return true;