summaryrefslogtreecommitdiff
path: root/Source/WebKit2/UIProcess/API/APIPageConfiguration.h
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebKit2/UIProcess/API/APIPageConfiguration.h')
-rw-r--r--Source/WebKit2/UIProcess/API/APIPageConfiguration.h134
1 files changed, 134 insertions, 0 deletions
diff --git a/Source/WebKit2/UIProcess/API/APIPageConfiguration.h b/Source/WebKit2/UIProcess/API/APIPageConfiguration.h
new file mode 100644
index 000000000..98ae2aa71
--- /dev/null
+++ b/Source/WebKit2/UIProcess/API/APIPageConfiguration.h
@@ -0,0 +1,134 @@
+/*
+ * Copyright (C) 2015, 2016 Apple Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef APIPageConfiguration_h
+#define APIPageConfiguration_h
+
+#include "APIObject.h"
+#include "WebPreferencesStore.h"
+#include <WebCore/SessionID.h>
+#include <wtf/Forward.h>
+#include <wtf/GetPtr.h>
+
+namespace WebKit {
+class VisitedLinkStore;
+class WebPageGroup;
+class WebPageProxy;
+class WebPreferences;
+class WebProcessPool;
+class WebUserContentControllerProxy;
+}
+
+namespace API {
+
+class WebsiteDataStore;
+
+class PageConfiguration : public ObjectImpl<Object::Type::PageConfiguration> {
+public:
+ static Ref<PageConfiguration> create();
+
+ explicit PageConfiguration();
+ virtual ~PageConfiguration();
+
+ Ref<PageConfiguration> copy() const;
+
+ // FIXME: The configuration properties should return their default values
+ // rather than nullptr.
+
+ WebKit::WebProcessPool* processPool();
+ void setProcessPool(WebKit::WebProcessPool*);
+
+ WebKit::WebUserContentControllerProxy* userContentController();
+ void setUserContentController(WebKit::WebUserContentControllerProxy*);
+
+ WebKit::WebPageGroup* pageGroup();
+ void setPageGroup(WebKit::WebPageGroup*);
+
+ WebKit::WebPreferences* preferences();
+ void setPreferences(WebKit::WebPreferences*);
+
+ WebKit::WebPreferencesStore::ValueMap& preferenceValues() { return m_preferenceValues; }
+
+ WebKit::WebPageProxy* relatedPage();
+ void setRelatedPage(WebKit::WebPageProxy*);
+
+ WebKit::VisitedLinkStore* visitedLinkStore();
+ void setVisitedLinkStore(WebKit::VisitedLinkStore*);
+
+ WebsiteDataStore* websiteDataStore();
+ void setWebsiteDataStore(WebsiteDataStore*);
+
+ WebCore::SessionID sessionID();
+ void setSessionID(WebCore::SessionID);
+
+ bool treatsSHA1SignedCertificatesAsInsecure() { return m_treatsSHA1SignedCertificatesAsInsecure; }
+ void setTreatsSHA1SignedCertificatesAsInsecure(bool treatsSHA1SignedCertificatesAsInsecure) { m_treatsSHA1SignedCertificatesAsInsecure = treatsSHA1SignedCertificatesAsInsecure; }
+
+#if PLATFORM(IOS)
+ bool alwaysRunsAtForegroundPriority() { return m_alwaysRunsAtForegroundPriority; }
+ void setAlwaysRunsAtForegroundPriority(bool alwaysRunsAtForegroundPriority) { m_alwaysRunsAtForegroundPriority = alwaysRunsAtForegroundPriority; }
+#endif
+ bool initialCapitalizationEnabled() { return m_initialCapitalizationEnabled; }
+ void setInitialCapitalizationEnabled(bool initialCapitalizationEnabled) { m_initialCapitalizationEnabled = initialCapitalizationEnabled; }
+
+ bool waitsForPaintAfterViewDidMoveToWindow() const { return m_waitsForPaintAfterViewDidMoveToWindow; }
+ void setWaitsForPaintAfterViewDidMoveToWindow(bool shouldSynchronize) { m_waitsForPaintAfterViewDidMoveToWindow = shouldSynchronize; }
+
+ bool isControlledByAutomation() const { return m_controlledByAutomation; }
+ void setControlledByAutomation(bool controlledByAutomation) { m_controlledByAutomation = controlledByAutomation; }
+
+ const WTF::String& overrideContentSecurityPolicy() const { return m_overrideContentSecurityPolicy; }
+ void setOverrideContentSecurityPolicy(const WTF::String& overrideContentSecurityPolicy) { m_overrideContentSecurityPolicy = overrideContentSecurityPolicy; }
+
+private:
+
+ RefPtr<WebKit::WebProcessPool> m_processPool;
+ RefPtr<WebKit::WebUserContentControllerProxy> m_userContentController;
+ RefPtr<WebKit::WebPageGroup> m_pageGroup;
+ RefPtr<WebKit::WebPreferences> m_preferences;
+ WebKit::WebPreferencesStore::ValueMap m_preferenceValues;
+ RefPtr<WebKit::WebPageProxy> m_relatedPage;
+ RefPtr<WebKit::VisitedLinkStore> m_visitedLinkStore;
+
+ RefPtr<WebsiteDataStore> m_websiteDataStore;
+ // FIXME: We currently have to pass the session ID separately here to support the legacy private browsing session.
+ // Once we get rid of it we should get rid of this configuration parameter as well.
+ WebCore::SessionID m_sessionID;
+
+ bool m_treatsSHA1SignedCertificatesAsInsecure = true;
+#if PLATFORM(IOS)
+ bool m_alwaysRunsAtForegroundPriority = false;
+#endif
+ bool m_initialCapitalizationEnabled = true;
+ bool m_waitsForPaintAfterViewDidMoveToWindow = true;
+ bool m_controlledByAutomation = false;
+
+ WTF::String m_overrideContentSecurityPolicy;
+};
+
+} // namespace API
+
+
+#endif // APIPageConfiguration_h