blob: eb100681c09f24ed12da44111ca8af7f501b0e9b [file] [log] [blame]
/*
* Copyright (C) 2009 Google 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:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * 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.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 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 THE COPYRIGHT
* OWNER OR 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 WebDocument_h
#define WebDocument_h
#include "WebDraggableRegion.h"
#include "WebExceptionCode.h"
#include "WebFrame.h"
#include "WebNode.h"
#include "public/platform/WebColor.h"
#include "public/platform/WebReferrerPolicy.h"
#include "public/platform/WebSecurityOrigin.h"
#include "public/platform/WebVector.h"
namespace v8 {
class Value;
template <class T>
class Local;
}
namespace blink {
class Document;
class WebAXObject;
class WebElement;
class WebFormElement;
class WebElementCollection;
class WebString;
class WebURL;
struct WebDistillabilityFeatures;
using WebStyleSheetId = unsigned;
// Provides readonly access to some properties of a DOM document.
class WebDocument : public WebNode {
public:
WebDocument() {}
WebDocument(const WebDocument& e) : WebNode(e) {}
WebDocument& operator=(const WebDocument& e) {
WebNode::Assign(e);
return *this;
}
void Assign(const WebDocument& e) { WebNode::Assign(e); }
BLINK_EXPORT WebURL Url() const;
// Note: Security checks should use the getSecurityOrigin(), not url().
BLINK_EXPORT WebSecurityOrigin GetSecurityOrigin() const;
BLINK_EXPORT bool IsSecureContext() const;
BLINK_EXPORT WebString Encoding() const;
BLINK_EXPORT WebString ContentLanguage() const;
BLINK_EXPORT WebString GetReferrer() const;
BLINK_EXPORT WebColor ThemeColor() const;
// The url of the OpenSearch Desription Document (if any).
BLINK_EXPORT WebURL OpenSearchDescriptionURL() const;
// Returns the frame the document belongs to or 0 if the document is
// frameless.
BLINK_EXPORT WebLocalFrame* GetFrame() const;
BLINK_EXPORT bool IsHTMLDocument() const;
BLINK_EXPORT bool IsXHTMLDocument() const;
BLINK_EXPORT bool IsPluginDocument() const;
BLINK_EXPORT WebURL BaseURL() const;
// The firstPartyForCookies is used to compute whether this document
// appears in a "third-party" context for the purpose of third-party
// cookie blocking.
BLINK_EXPORT WebURL FirstPartyForCookies() const;
BLINK_EXPORT WebElement DocumentElement() const;
BLINK_EXPORT WebElement Body() const;
BLINK_EXPORT WebElement Head();
BLINK_EXPORT WebString Title() const;
BLINK_EXPORT WebString ContentAsTextForTesting() const;
BLINK_EXPORT WebElementCollection All();
BLINK_EXPORT void Forms(WebVector<WebFormElement>&) const;
BLINK_EXPORT WebURL CompleteURL(const WebString&) const;
BLINK_EXPORT WebElement GetElementById(const WebString&) const;
BLINK_EXPORT WebElement FocusedElement() const;
BLINK_EXPORT WebReferrerPolicy GetReferrerPolicy() const;
BLINK_EXPORT WebString OutgoingReferrer();
// Accessibility support. These methods should only be called on the
// top-level document, because one accessibility cache spans all of
// the documents on the page.
// Gets the accessibility object for this document.
BLINK_EXPORT WebAXObject AccessibilityObject() const;
// Gets the accessibility object for an object on this page by ID.
BLINK_EXPORT WebAXObject AccessibilityObjectFromID(int ax_id) const;
// Gets the accessibility object that has focus.
BLINK_EXPORT WebAXObject FocusedAccessibilityObject() const;
// Inserts the given CSS source code as a stylesheet in the document, and
// return its id.
BLINK_EXPORT WebStyleSheetId InsertStyleSheet(const WebString& source_code);
// Removes the CSS which was previously inserted by a call to
// InsertStyleSheet().
BLINK_EXPORT void RemoveInsertedStyleSheet(WebStyleSheetId);
// Arranges to call WebFrameClient::didMatchCSS(frame(), ...) when one of
// the selectors matches or stops matching an element in this document.
// Each call to this method overrides any previous calls.
BLINK_EXPORT void WatchCSSSelectors(const WebVector<WebString>& selectors);
BLINK_EXPORT WebVector<WebDraggableRegion> DraggableRegions() const;
BLINK_EXPORT v8::Local<v8::Value> RegisterEmbedderCustomElement(
const WebString& name,
v8::Local<v8::Value> options,
WebExceptionCode&);
BLINK_EXPORT WebURL ManifestURL() const;
BLINK_EXPORT bool ManifestUseCredentials() const;
BLINK_EXPORT WebDistillabilityFeatures DistillabilityFeatures();
#if BLINK_IMPLEMENTATION
BLINK_EXPORT WebDocument(Document*);
BLINK_EXPORT WebDocument& operator=(Document*);
BLINK_EXPORT operator Document*() const;
#endif
};
DECLARE_WEB_NODE_TYPE_CASTS(WebDocument);
} // namespace blink
#endif