2003-07-24 05:15:20 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2012-05-21 11:12:37 +00:00
|
|
|
/* 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/. */
|
2003-07-24 05:15:20 +00:00
|
|
|
|
|
|
|
#ifndef nsPrincipal_h__
|
|
|
|
#define nsPrincipal_h__
|
|
|
|
|
|
|
|
#include "nsAutoPtr.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsJSPrincipals.h"
|
2007-09-17 22:18:28 +00:00
|
|
|
#include "nsTArray.h"
|
|
|
|
#include "nsAutoPtr.h"
|
2012-08-20 18:34:33 +00:00
|
|
|
#include "nsIProtocolHandler.h"
|
|
|
|
#include "nsNetUtil.h"
|
|
|
|
#include "nsScriptSecurityManager.h"
|
2003-07-24 05:15:20 +00:00
|
|
|
|
|
|
|
class nsIObjectInputStream;
|
|
|
|
class nsIObjectOutputStream;
|
|
|
|
|
2012-06-10 23:44:50 +00:00
|
|
|
class nsBasePrincipal : public nsJSPrincipals
|
2003-07-24 05:15:20 +00:00
|
|
|
{
|
|
|
|
public:
|
2012-06-10 23:44:50 +00:00
|
|
|
nsBasePrincipal();
|
2003-07-24 05:15:20 +00:00
|
|
|
|
|
|
|
protected:
|
2012-06-10 23:44:50 +00:00
|
|
|
virtual ~nsBasePrincipal();
|
2003-07-24 05:15:20 +00:00
|
|
|
|
|
|
|
public:
|
2014-03-27 20:38:33 +00:00
|
|
|
NS_IMETHOD_(MozExternalRefCountType) AddRef(void);
|
|
|
|
NS_IMETHOD_(MozExternalRefCountType) Release(void);
|
2012-06-10 23:44:50 +00:00
|
|
|
NS_IMETHOD GetCsp(nsIContentSecurityPolicy** aCsp);
|
|
|
|
NS_IMETHOD SetCsp(nsIContentSecurityPolicy* aCsp);
|
2003-07-24 05:15:20 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
static const char sInvalid[];
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
2012-06-10 23:44:50 +00:00
|
|
|
#ifdef DEBUG
|
|
|
|
virtual void dumpImpl() = 0;
|
|
|
|
#endif
|
|
|
|
|
2010-01-22 21:38:21 +00:00
|
|
|
nsCOMPtr<nsIContentSecurityPolicy> mCSP;
|
2012-06-10 23:44:50 +00:00
|
|
|
};
|
|
|
|
|
2014-08-05 17:33:55 +00:00
|
|
|
class nsPrincipal MOZ_FINAL : public nsBasePrincipal
|
2012-06-10 23:44:50 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
NS_DECL_ISUPPORTS_INHERITED
|
|
|
|
NS_DECL_NSISERIALIZABLE
|
2015-01-08 15:18:00 +00:00
|
|
|
NS_IMETHOD Equals(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD EqualsConsideringDomain(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetHashValue(uint32_t* aHashValue) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetURI(nsIURI** aURI) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetDomain(nsIURI** aDomain) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD SetDomain(nsIURI* aDomain) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetOrigin(char** aOrigin) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD Subsumes(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD SubsumesConsideringDomain(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD CheckMayLoad(nsIURI* uri, bool report, bool allowIfInheritsPrincipal) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetJarPrefix(nsACString& aJarPrefix) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetAppStatus(uint16_t* aAppStatus) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetAppId(uint32_t* aAppStatus) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetIsInBrowserElement(bool* aIsInBrowserElement) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetUnknownAppId(bool* aUnknownAppId) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetIsNullPrincipal(bool* aIsNullPrincipal) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetBaseDomain(nsACString& aBaseDomain) MOZ_OVERRIDE;
|
2015-03-13 20:15:09 +00:00
|
|
|
virtual bool IsOnCSSUnprefixingWhitelist() MOZ_OVERRIDE;
|
2012-06-10 23:44:50 +00:00
|
|
|
#ifdef DEBUG
|
2015-01-08 15:18:00 +00:00
|
|
|
virtual void dumpImpl() MOZ_OVERRIDE;
|
2012-06-10 23:44:50 +00:00
|
|
|
#endif
|
2012-07-20 05:44:03 +00:00
|
|
|
|
|
|
|
nsPrincipal();
|
|
|
|
|
2012-10-22 06:29:55 +00:00
|
|
|
// Init() must be called before the principal is in a usable state.
|
2012-10-22 06:29:56 +00:00
|
|
|
nsresult Init(nsIURI* aCodebase,
|
2012-08-22 15:56:38 +00:00
|
|
|
uint32_t aAppId,
|
2012-07-20 05:44:03 +00:00
|
|
|
bool aInMozBrowser);
|
2012-06-10 23:44:50 +00:00
|
|
|
|
|
|
|
virtual void GetScriptLocation(nsACString& aStr) MOZ_OVERRIDE;
|
|
|
|
void SetURI(nsIURI* aURI);
|
|
|
|
|
2012-08-20 18:34:33 +00:00
|
|
|
static bool IsPrincipalInherited(nsIURI* aURI) {
|
|
|
|
// return true if the loadee URI has
|
|
|
|
// the URI_INHERITS_SECURITY_CONTEXT flag set.
|
|
|
|
bool doesInheritSecurityContext;
|
|
|
|
nsresult rv =
|
|
|
|
NS_URIChainHasFlags(aURI,
|
|
|
|
nsIProtocolHandler::URI_INHERITS_SECURITY_CONTEXT,
|
|
|
|
&doesInheritSecurityContext);
|
|
|
|
|
|
|
|
if (NS_SUCCEEDED(rv) && doesInheritSecurityContext) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-07-19 04:23:44 +00:00
|
|
|
/**
|
|
|
|
* Computes the puny-encoded origin of aURI.
|
|
|
|
*/
|
|
|
|
static nsresult GetOriginForURI(nsIURI* aURI, char **aOrigin);
|
|
|
|
|
2015-03-13 20:15:09 +00:00
|
|
|
/**
|
|
|
|
* Called at startup to setup static data, e.g. about:config pref-observers.
|
|
|
|
*/
|
|
|
|
static void InitializeStatics();
|
|
|
|
|
2012-06-10 23:44:50 +00:00
|
|
|
nsCOMPtr<nsIURI> mDomain;
|
|
|
|
nsCOMPtr<nsIURI> mCodebase;
|
2012-08-22 15:56:38 +00:00
|
|
|
uint32_t mAppId;
|
2012-07-20 05:44:03 +00:00
|
|
|
bool mInMozBrowser;
|
2007-06-18 15:07:02 +00:00
|
|
|
// If mCodebaseImmutable is true, mCodebase is non-null and immutable
|
2011-09-29 06:19:26 +00:00
|
|
|
bool mCodebaseImmutable;
|
|
|
|
bool mDomainImmutable;
|
2012-06-10 23:44:50 +00:00
|
|
|
bool mInitialized;
|
2015-03-13 20:15:09 +00:00
|
|
|
mozilla::Maybe<bool> mIsOnCSSUnprefixingWhitelist; // Lazily-computed
|
2012-07-20 05:44:03 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual ~nsPrincipal();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the app status of the principal based on mAppId and mInMozBrowser.
|
|
|
|
*/
|
2012-08-22 15:56:38 +00:00
|
|
|
uint16_t GetAppStatus();
|
2003-07-24 05:15:20 +00:00
|
|
|
};
|
|
|
|
|
2012-06-10 23:44:50 +00:00
|
|
|
class nsExpandedPrincipal : public nsIExpandedPrincipal, public nsBasePrincipal
|
|
|
|
{
|
|
|
|
public:
|
2014-09-02 22:20:14 +00:00
|
|
|
explicit nsExpandedPrincipal(nsTArray< nsCOMPtr<nsIPrincipal> > &aWhiteList);
|
2012-06-10 23:44:50 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual ~nsExpandedPrincipal();
|
|
|
|
|
|
|
|
public:
|
|
|
|
NS_DECL_ISUPPORTS_INHERITED
|
|
|
|
NS_DECL_NSIEXPANDEDPRINCIPAL
|
|
|
|
NS_DECL_NSISERIALIZABLE
|
2015-01-08 15:18:00 +00:00
|
|
|
NS_IMETHOD Equals(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD EqualsConsideringDomain(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetHashValue(uint32_t* aHashValue) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetURI(nsIURI** aURI) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetDomain(nsIURI** aDomain) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD SetDomain(nsIURI* aDomain) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetOrigin(char** aOrigin) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD Subsumes(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD SubsumesConsideringDomain(nsIPrincipal* other, bool* _retval) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD CheckMayLoad(nsIURI* uri, bool report, bool allowIfInheritsPrincipal) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetJarPrefix(nsACString& aJarPrefix) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetAppStatus(uint16_t* aAppStatus) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetAppId(uint32_t* aAppStatus) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetIsInBrowserElement(bool* aIsInBrowserElement) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetUnknownAppId(bool* aUnknownAppId) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetIsNullPrincipal(bool* aIsNullPrincipal) MOZ_OVERRIDE;
|
|
|
|
NS_IMETHOD GetBaseDomain(nsACString& aBaseDomain) MOZ_OVERRIDE;
|
2015-03-13 20:15:09 +00:00
|
|
|
virtual bool IsOnCSSUnprefixingWhitelist() MOZ_OVERRIDE;
|
2012-06-10 23:44:50 +00:00
|
|
|
#ifdef DEBUG
|
2015-01-08 15:18:00 +00:00
|
|
|
virtual void dumpImpl() MOZ_OVERRIDE;
|
2012-06-10 23:44:50 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
virtual void GetScriptLocation(nsACString &aStr) MOZ_OVERRIDE;
|
|
|
|
|
|
|
|
private:
|
|
|
|
nsTArray< nsCOMPtr<nsIPrincipal> > mPrincipals;
|
|
|
|
};
|
2003-07-24 05:15:20 +00:00
|
|
|
|
|
|
|
#define NS_PRINCIPAL_CONTRACTID "@mozilla.org/principal;1"
|
|
|
|
#define NS_PRINCIPAL_CID \
|
2012-12-06 22:51:37 +00:00
|
|
|
{ 0x09b7e598, 0x490d, 0x423f, \
|
|
|
|
{ 0xa8, 0xa6, 0x2e, 0x6c, 0x4e, 0xc8, 0x77, 0x50 }}
|
2003-07-24 05:15:20 +00:00
|
|
|
|
2012-06-10 23:44:50 +00:00
|
|
|
#define NS_EXPANDEDPRINCIPAL_CONTRACTID "@mozilla.org/expandedprincipal;1"
|
|
|
|
#define NS_EXPANDEDPRINCIPAL_CID \
|
|
|
|
{ 0xb33a3807, 0xb76c, 0x44e5, \
|
|
|
|
{ 0xb9, 0x9d, 0x95, 0x7e, 0xe9, 0xba, 0x6e, 0x39 }}
|
2003-07-24 05:15:20 +00:00
|
|
|
|
|
|
|
#endif // nsPrincipal_h__
|