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

Side by Side Diff: third_party/WebKit/Source/web/StorageClientImpl.cpp

Issue 2786673002: Separate ContentSettingsClient out from LocalFrameClient (Closed)
Patch Set: fix Created 3 years, 8 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
1 /* 1 /*
2 * Copyright (C) 2009 Google Inc. All Rights Reserved. 2 * Copyright (C) 2009 Google Inc. All Rights Reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * 12 *
13 * THIS SOFTWARE IS PROVIDED BY GOOGLE INC. ``AS IS'' AND ANY 13 * THIS SOFTWARE IS PROVIDED BY GOOGLE INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GOOGLE INC. OR 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GOOGLE INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */ 24 */
25 25
26 #include "web/StorageClientImpl.h" 26 #include "web/StorageClientImpl.h"
27 27
28 #include <memory>
29 #include "core/frame/ContentSettingsClient.h"
28 #include "modules/storage/StorageNamespace.h" 30 #include "modules/storage/StorageNamespace.h"
29 #include "public/platform/WebStorageNamespace.h" 31 #include "public/platform/WebStorageNamespace.h"
30 #include "public/web/WebContentSettingsClient.h"
31 #include "public/web/WebViewClient.h" 32 #include "public/web/WebViewClient.h"
32 #include "web/WebLocalFrameImpl.h"
33 #include "web/WebViewImpl.h" 33 #include "web/WebViewImpl.h"
34 #include "wtf/PtrUtil.h" 34 #include "wtf/PtrUtil.h"
35 #include <memory>
36 35
37 namespace blink { 36 namespace blink {
38 37
38 #define STATIC_ASSERT_MATCHING_ENUM(enum_name1, enum_name2) \
39 static_assert(static_cast<int>(enum_name1) == static_cast<int>(enum_name2), \
40 "mismatching enums: " #enum_name1)
41 STATIC_ASSERT_MATCHING_ENUM(LocalStorage,
42 ContentSettingsClient::StorageType::kLocal);
43 STATIC_ASSERT_MATCHING_ENUM(SessionStorage,
44 ContentSettingsClient::StorageType::kSession);
45
39 StorageClientImpl::StorageClientImpl(WebViewImpl* webView) 46 StorageClientImpl::StorageClientImpl(WebViewImpl* webView)
40 : m_webView(webView) {} 47 : m_webView(webView) {}
41 48
42 std::unique_ptr<StorageNamespace> 49 std::unique_ptr<StorageNamespace>
43 StorageClientImpl::createSessionStorageNamespace() { 50 StorageClientImpl::createSessionStorageNamespace() {
44 if (!m_webView->client()) 51 if (!m_webView->client())
45 return nullptr; 52 return nullptr;
46 return WTF::wrapUnique(new StorageNamespace( 53 return WTF::wrapUnique(new StorageNamespace(
47 WTF::wrapUnique(m_webView->client()->createSessionStorageNamespace()))); 54 WTF::wrapUnique(m_webView->client()->createSessionStorageNamespace())));
48 } 55 }
49 56
50 bool StorageClientImpl::canAccessStorage(LocalFrame* frame, 57 bool StorageClientImpl::canAccessStorage(LocalFrame* frame,
51 StorageType type) const { 58 StorageType type) const {
52 WebLocalFrameImpl* webFrame = WebLocalFrameImpl::fromFrame(frame); 59 return !frame->contentSettingsClient() ||
dcheng 2017/04/02 05:26:19 The caller seems to check that frame is attached,
kinuko 2017/04/03 15:15:06 Done.
53 return !webFrame->contentSettingsClient() || 60 frame->contentSettingsClient()->allowStorage(
54 webFrame->contentSettingsClient()->allowStorage(type == LocalStorage); 61 static_cast<ContentSettingsClient::StorageType>(type));
55 } 62 }
56 63
57 } // namespace blink 64 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698