gecko-dev/dom/html/HTMLAreaElement.h
Kris Maglione 4275cd1039 Bug 1406278: Part 1 - Pass subject principal to SetAttribute and friends. r=bz
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
2017-10-09 14:33:38 -07:00

215 lines
5.8 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_HTMLAreaElement_h
#define mozilla_dom_HTMLAreaElement_h
#include "mozilla/Attributes.h"
#include "mozilla/dom/Link.h"
#include "nsGenericHTMLElement.h"
#include "nsGkAtoms.h"
#include "nsIURL.h"
class nsIDocument;
namespace mozilla {
class EventChainPostVisitor;
class EventChainPreVisitor;
namespace dom {
class HTMLAreaElement final : public nsGenericHTMLElement,
public Link
{
public:
explicit HTMLAreaElement(already_AddRefed<mozilla::dom::NodeInfo>& aNodeInfo);
// nsISupports
NS_DECL_ISUPPORTS_INHERITED
// CC
NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED(HTMLAreaElement,
nsGenericHTMLElement)
NS_DECL_ADDSIZEOFEXCLUDINGTHIS
NS_IMPL_FROMCONTENT_HTML_WITH_TAG(HTMLAreaElement, area)
virtual int32_t TabIndexDefault() override;
virtual nsresult GetEventTargetParent(
EventChainPreVisitor& aVisitor) override;
virtual nsresult PostHandleEvent(EventChainPostVisitor& aVisitor) override;
virtual bool IsLink(nsIURI** aURI) const override;
virtual void GetLinkTarget(nsAString& aTarget) override;
virtual already_AddRefed<nsIURI> GetHrefURI() const override;
virtual nsresult BindToTree(nsIDocument* aDocument, nsIContent* aParent,
nsIContent* aBindingParent,
bool aCompileEventHandlers) override;
virtual void UnbindFromTree(bool aDeep = true,
bool aNullParent = true) override;
virtual nsresult Clone(mozilla::dom::NodeInfo* aNodeInfo, nsINode** aResult,
bool aPreallocateChildren) const override;
virtual EventStates IntrinsicState() const override;
// WebIDL
void GetAlt(DOMString& aValue)
{
GetHTMLAttr(nsGkAtoms::alt, aValue);
}
void SetAlt(const nsAString& aAlt, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::alt, aAlt, aError);
}
void GetCoords(DOMString& aValue)
{
GetHTMLAttr(nsGkAtoms::coords, aValue);
}
void SetCoords(const nsAString& aCoords, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::coords, aCoords, aError);
}
// argument type nsAString for HTMLImageMapAccessible
void GetShape(nsAString& aValue)
{
GetHTMLAttr(nsGkAtoms::shape, aValue);
}
void SetShape(const nsAString& aShape, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::shape, aShape, aError);
}
// argument type nsAString for nsContextMenuInfo
void GetHref(nsAString& aValue)
{
GetURIAttr(nsGkAtoms::href, nullptr, aValue);
}
void SetHref(const nsAString& aHref, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::href, aHref, aError);
}
void GetTarget(DOMString& aValue);
void SetTarget(const nsAString& aTarget, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::target, aTarget, aError);
}
void GetDownload(DOMString& aValue)
{
GetHTMLAttr(nsGkAtoms::download, aValue);
}
void SetDownload(const nsAString& aDownload, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::download, aDownload, aError);
}
void GetPing(DOMString& aValue)
{
GetHTMLAttr(nsGkAtoms::ping, aValue);
}
void SetPing(const nsAString& aPing, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::ping, aPing, aError);
}
void GetRel(DOMString& aValue)
{
GetHTMLAttr(nsGkAtoms::rel, aValue);
}
void SetRel(const nsAString& aRel, ErrorResult& aError)
{
SetHTMLAttr(nsGkAtoms::rel, aRel, aError);
}
nsDOMTokenList* RelList();
void SetReferrerPolicy(const nsAString& aValue, mozilla::ErrorResult& rv)
{
SetHTMLAttr(nsGkAtoms::referrerpolicy, aValue, rv);
}
void GetReferrerPolicy(nsAString& aReferrer)
{
GetEnumAttr(nsGkAtoms::referrerpolicy, EmptyCString().get(), aReferrer);
}
// The Link::GetOrigin is OK for us
// Link::Link::GetProtocol is OK for us
// Link::Link::SetProtocol is OK for us
// The Link::GetUsername is OK for us
// The Link::SetUsername is OK for us
// The Link::GetPassword is OK for us
// The Link::SetPassword is OK for us
// Link::Link::GetHost is OK for us
// Link::Link::SetHost is OK for us
// Link::Link::GetHostname is OK for us
// Link::Link::SetHostname is OK for us
// Link::Link::GetPort is OK for us
// Link::Link::SetPort is OK for us
// Link::Link::GetPathname is OK for us
// Link::Link::SetPathname is OK for us
// Link::Link::GetSearch is OK for us
// Link::Link::SetSearch is OK for us
// Link::Link::GetHash is OK for us
// Link::Link::SetHash is OK for us
// The Link::GetSearchParams is OK for us
bool NoHref() const
{
return GetBoolAttr(nsGkAtoms::nohref);
}
void SetNoHref(bool aValue, ErrorResult& aError)
{
SetHTMLBoolAttr(nsGkAtoms::nohref, aValue, aError);
}
void ToString(nsAString& aSource);
void Stringify(nsAString& aResult)
{
GetHref(aResult);
}
virtual void NodeInfoChanged(nsIDocument* aOldDoc) final override
{
ClearHasPendingLinkUpdate();
nsGenericHTMLElement::NodeInfoChanged(aOldDoc);
}
protected:
virtual ~HTMLAreaElement();
virtual JSObject* WrapNode(JSContext* aCx, JS::Handle<JSObject*> aGivenProto) override;
virtual nsresult AfterSetAttr(int32_t aNamespaceID, nsAtom* aName,
const nsAttrValue* aValue,
const nsAttrValue* aOldValue,
nsIPrincipal* aSubjectPrincipal,
bool aNotify) override;
RefPtr<nsDOMTokenList > mRelList;
};
} // namespace dom
} // namespace mozilla
#endif /* mozilla_dom_HTMLAreaElement_h */