The maximum subframe count check should not be skipped for empty URLs.
[WebKit-https.git] / Source / WebCore / html / HTMLFrameOwnerElement.h
1 /*
2  * Copyright (C) 2006-2019 Apple Inc. All rights reserved.
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Library General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Library General Public License for more details.
13  *
14  * You should have received a copy of the GNU Library General Public License
15  * along with this library; see the file COPYING.LIB.  If not, write to
16  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17  * Boston, MA 02110-1301, USA.
18  *
19  */
20
21 #pragma once
22
23 #include "HTMLElement.h"
24 #include "ReferrerPolicy.h"
25 #include <wtf/HashCountedSet.h>
26 #include <wtf/NeverDestroyed.h>
27
28 namespace WebCore {
29
30 class Frame;
31 class RenderWidget;
32 class SVGDocument;
33
34 class HTMLFrameOwnerElement : public HTMLElement {
35     WTF_MAKE_ISO_ALLOCATED(HTMLFrameOwnerElement);
36 public:
37     virtual ~HTMLFrameOwnerElement();
38
39     Frame* contentFrame() const { return m_contentFrame; }
40     WEBCORE_EXPORT WindowProxy* contentWindow() const;
41     WEBCORE_EXPORT Document* contentDocument() const;
42
43     void setContentFrame(Frame*);
44     void clearContentFrame();
45
46     void disconnectContentFrame();
47
48     // Most subclasses use RenderWidget (either RenderEmbeddedObject or RenderIFrame)
49     // except for HTMLObjectElement and HTMLEmbedElement which may return any
50     // RenderElement when using fallback content.
51     RenderWidget* renderWidget() const;
52
53     ExceptionOr<Document&> getSVGDocument() const;
54
55     virtual ScrollbarMode scrollingMode() const { return ScrollbarAuto; }
56
57     SandboxFlags sandboxFlags() const { return m_sandboxFlags; }
58
59     void scheduleInvalidateStyleAndLayerComposition();
60
61     virtual bool canLoadScriptURL(const URL&) const = 0;
62
63     virtual ReferrerPolicy referrerPolicy() const { return ReferrerPolicy::EmptyString; }
64
65 protected:
66     HTMLFrameOwnerElement(const QualifiedName& tagName, Document&);
67     void setSandboxFlags(SandboxFlags);
68     bool isProhibitedSelfReference(const URL&) const;
69
70 private:
71     bool isKeyboardFocusable(KeyboardEvent*) const override;
72     bool isFrameOwnerElement() const final { return true; }
73
74     Frame* m_contentFrame { nullptr };
75     SandboxFlags m_sandboxFlags { SandboxNone };
76 };
77
78 class SubframeLoadingDisabler {
79 public:
80     explicit SubframeLoadingDisabler(ContainerNode* root)
81         : m_root(root)
82     {
83         if (m_root)
84             disabledSubtreeRoots().add(m_root);
85     }
86
87     ~SubframeLoadingDisabler()
88     {
89         if (m_root)
90             disabledSubtreeRoots().remove(m_root);
91     }
92
93     static bool canLoadFrame(HTMLFrameOwnerElement&);
94
95 private:
96     static HashCountedSet<ContainerNode*>& disabledSubtreeRoots()
97     {
98         static NeverDestroyed<HashCountedSet<ContainerNode*>> nodes;
99         return nodes;
100     }
101
102     ContainerNode* m_root;
103 };
104
105 } // namespace WebCore
106
107 SPECIALIZE_TYPE_TRAITS_BEGIN(WebCore::HTMLFrameOwnerElement)
108     static bool isType(const WebCore::Node& node) { return node.isFrameOwnerElement(); }
109 SPECIALIZE_TYPE_TRAITS_END()