mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-10 15:33:23 +00:00
4275cd1039
In order to tailor certain security checks to the caller that is attempting to load a particular piece of content, we need to be able to attach an appropriate triggering principal to the corresponding requests. Since most HTML content is loaded based on attribute values, that means capturing the subject principal of the caller who sets those attributes, which means making it available to AfterSetAttr hooks. MozReview-Commit-ID: BMDL2Uepg0X --HG-- extra : rebase_source : 25e438c243700a9368c393e40e3a6002d968d6c8
148 lines
4.2 KiB
C++
148 lines
4.2 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef mozilla_dom_DocumentFragment_h__
|
|
#define mozilla_dom_DocumentFragment_h__
|
|
|
|
#include "mozilla/Attributes.h"
|
|
#include "mozilla/dom/BorrowedAttrInfo.h"
|
|
#include "mozilla/dom/FragmentOrElement.h"
|
|
#include "nsIDOMDocumentFragment.h"
|
|
#include "nsStringFwd.h"
|
|
|
|
class nsAtom;
|
|
class nsIDocument;
|
|
class nsIContent;
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
|
|
class Element;
|
|
|
|
class DocumentFragment : public FragmentOrElement,
|
|
public nsIDOMDocumentFragment
|
|
{
|
|
private:
|
|
void Init()
|
|
{
|
|
MOZ_ASSERT(mNodeInfo->NodeType() == nsIDOMNode::DOCUMENT_FRAGMENT_NODE &&
|
|
mNodeInfo->Equals(nsGkAtoms::documentFragmentNodeName,
|
|
kNameSpaceID_None),
|
|
"Bad NodeType in aNodeInfo");
|
|
}
|
|
|
|
public:
|
|
using FragmentOrElement::GetFirstChild;
|
|
using nsINode::QuerySelector;
|
|
using nsINode::QuerySelectorAll;
|
|
// Make sure bindings can see our superclass' protected GetElementById method.
|
|
using nsINode::GetElementById;
|
|
|
|
// nsISupports
|
|
NS_DECL_ISUPPORTS_INHERITED
|
|
NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED(DocumentFragment, FragmentOrElement)
|
|
|
|
// interface nsIDOMNode
|
|
NS_FORWARD_NSIDOMNODE_TO_NSINODE
|
|
|
|
// interface nsIDOMDocumentFragment
|
|
NS_DECL_NSIDOMDOCUMENTFRAGMENT
|
|
|
|
explicit DocumentFragment(already_AddRefed<mozilla::dom::NodeInfo>& aNodeInfo)
|
|
: FragmentOrElement(aNodeInfo), mHost(nullptr)
|
|
{
|
|
Init();
|
|
}
|
|
|
|
explicit DocumentFragment(nsNodeInfoManager* aNodeInfoManager)
|
|
: FragmentOrElement(aNodeInfoManager->GetNodeInfo(
|
|
nsGkAtoms::documentFragmentNodeName,
|
|
nullptr, kNameSpaceID_None,
|
|
nsIDOMNode::DOCUMENT_FRAGMENT_NODE)),
|
|
mHost(nullptr)
|
|
{
|
|
Init();
|
|
}
|
|
|
|
virtual JSObject* WrapNode(JSContext *aCx, JS::Handle<JSObject*> aGivenProto) override;
|
|
|
|
// nsIContent
|
|
using nsIContent::SetAttr;
|
|
virtual nsresult SetAttr(int32_t aNameSpaceID, nsAtom* aName,
|
|
nsAtom* aPrefix, const nsAString& aValue,
|
|
nsIPrincipal* aSubjectPrincipal,
|
|
bool aNotify) override
|
|
{
|
|
return NS_OK;
|
|
}
|
|
virtual nsresult UnsetAttr(int32_t aNameSpaceID, nsAtom* aAttribute,
|
|
bool aNotify) override
|
|
{
|
|
return NS_OK;
|
|
}
|
|
virtual const nsAttrName* GetAttrNameAt(uint32_t aIndex) const override
|
|
{
|
|
return nullptr;
|
|
}
|
|
virtual BorrowedAttrInfo GetAttrInfoAt(uint32_t aIndex) const override
|
|
{
|
|
return BorrowedAttrInfo(nullptr, nullptr);
|
|
}
|
|
virtual uint32_t GetAttrCount() const override
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
virtual bool IsNodeOfType(uint32_t aFlags) const override;
|
|
|
|
virtual nsIDOMNode* AsDOMNode() override { return this; }
|
|
|
|
virtual nsresult BindToTree(nsIDocument* aDocument, nsIContent* aParent,
|
|
nsIContent* aBindingParent,
|
|
bool aCompileEventHandlers) override
|
|
{
|
|
NS_ASSERTION(false, "Trying to bind a fragment to a tree");
|
|
return NS_ERROR_NOT_IMPLEMENTED;
|
|
}
|
|
|
|
virtual void UnbindFromTree(bool aDeep, bool aNullParent) override
|
|
{
|
|
NS_ASSERTION(false, "Trying to unbind a fragment from a tree");
|
|
}
|
|
|
|
virtual Element* GetNameSpaceElement() override
|
|
{
|
|
return nullptr;
|
|
}
|
|
|
|
Element* GetHost() const { return mHost; }
|
|
|
|
void SetHost(Element* aHost) { mHost = aHost; }
|
|
|
|
static already_AddRefed<DocumentFragment>
|
|
Constructor(const GlobalObject& aGlobal, ErrorResult& aRv);
|
|
|
|
#ifdef DEBUG
|
|
virtual void List(FILE* out, int32_t aIndent) const override;
|
|
virtual void DumpContent(FILE* out, int32_t aIndent, bool aDumpAll) const override;
|
|
#endif
|
|
|
|
protected:
|
|
virtual ~DocumentFragment()
|
|
{
|
|
}
|
|
|
|
nsresult Clone(mozilla::dom::NodeInfo *aNodeInfo, nsINode **aResult,
|
|
bool aPreallocateChildren) const override;
|
|
nsCOMPtr<Element> mHost;
|
|
};
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|
|
|
|
|
|
#endif // mozilla_dom_DocumentFragment_h__
|