gecko-dev/caps/NullPrincipalURI.cpp

329 строки
8.5 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim: sw=2 ts=2 sts=2 expandtab
* 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/. */
#include "NullPrincipalURI.h"
#include "mozilla/DebugOnly.h"
#include "mozilla/MemoryReporting.h"
#include "mozilla/ipc/URIParams.h"
#include "nsEscape.h"
#include "nsCRT.h"
#include "nsIUUIDGenerator.h"
using namespace mozilla;
////////////////////////////////////////////////////////////////////////////////
//// NullPrincipalURI
NullPrincipalURI::NullPrincipalURI() {}
NullPrincipalURI::NullPrincipalURI(const NullPrincipalURI& aOther) {
mPath.Assign(aOther.mPath);
}
nsresult NullPrincipalURI::Init() {
// FIXME: bug 327161 -- make sure the uuid generator is reseeding-resistant.
nsCOMPtr<nsIUUIDGenerator> uuidgen = services::GetUUIDGenerator();
NS_ENSURE_TRUE(uuidgen, NS_ERROR_NOT_AVAILABLE);
nsID id;
nsresult rv = uuidgen->GenerateUUIDInPlace(&id);
NS_ENSURE_SUCCESS(rv, rv);
mPath.SetLength(NSID_LENGTH - 1); // -1 because NSID_LENGTH counts the '\0'
id.ToProvidedString(
*reinterpret_cast<char(*)[NSID_LENGTH]>(mPath.BeginWriting()));
MOZ_ASSERT(mPath.Length() == NSID_LENGTH - 1);
MOZ_ASSERT(strlen(mPath.get()) == NSID_LENGTH - 1);
return NS_OK;
}
/* static */
already_AddRefed<NullPrincipalURI> NullPrincipalURI::Create() {
RefPtr<NullPrincipalURI> uri = new NullPrincipalURI();
nsresult rv = uri->Init();
NS_ENSURE_SUCCESS(rv, nullptr);
return uri.forget();
}
static NS_DEFINE_CID(kNullPrincipalURIImplementationCID,
NS_NULLPRINCIPALURI_IMPLEMENTATION_CID);
NS_IMPL_ADDREF(NullPrincipalURI)
NS_IMPL_RELEASE(NullPrincipalURI)
NS_INTERFACE_MAP_BEGIN(NullPrincipalURI)
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIURI)
if (aIID.Equals(kNullPrincipalURIImplementationCID))
foundInterface = static_cast<nsIURI*>(this);
else
NS_INTERFACE_MAP_ENTRY(nsIURI)
NS_INTERFACE_MAP_ENTRY(nsISizeOf)
NS_INTERFACE_MAP_END
////////////////////////////////////////////////////////////////////////////////
//// nsIURI
NS_IMETHODIMP
NullPrincipalURI::GetAsciiHost(nsACString& _host) {
_host.Truncate();
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::GetAsciiHostPort(nsACString& _hostport) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetAsciiSpec(nsACString& _spec) {
nsAutoCString buffer;
// Ignore the return value -- NullPrincipalURI::GetSpec() is infallible.
Unused << GetSpec(buffer);
// This uses the infallible version of |NS_EscapeURL| as |GetSpec| is
// already infallible.
NS_EscapeURL(buffer, esc_OnlyNonASCII | esc_AlwaysCopy, _spec);
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::GetHost(nsACString& _host) {
_host.Truncate();
return NS_OK;
}
nsresult NullPrincipalURI::SetHost(const nsACString& aHost) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetHostPort(nsACString& _host) {
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetHostPort(const nsACString& aHost) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetPassword(nsACString& _password) {
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetPassword(const nsACString& aPassword) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetPathQueryRef(nsACString& _path) {
_path = mPath;
return NS_OK;
}
nsresult NullPrincipalURI::SetPathQueryRef(const nsACString& aPath) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetFilePath(nsACString& aFilePath) {
aFilePath.Truncate();
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetFilePath(const nsACString& aFilePath) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetQuery(nsACString& aQuery) {
aQuery.Truncate();
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetQuery(const nsACString& aQuery) {
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetQueryWithEncoding(const nsACString& aQuery,
const Encoding* aEncoding) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetRef(nsACString& _ref) {
_ref.Truncate();
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetRef(const nsACString& aRef) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetPrePath(nsACString& _prePath) {
_prePath = NS_LITERAL_CSTRING(NS_NULLPRINCIPAL_SCHEME ":");
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::GetPort(int32_t* _port) { return NS_ERROR_NOT_IMPLEMENTED; }
nsresult NullPrincipalURI::SetPort(int32_t aPort) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetScheme(nsACString& _scheme) {
_scheme = NS_LITERAL_CSTRING(NS_NULLPRINCIPAL_SCHEME);
return NS_OK;
}
nsresult NullPrincipalURI::SetScheme(const nsACString& aScheme) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetSpec(nsACString& _spec) {
_spec = NS_LITERAL_CSTRING(NS_NULLPRINCIPAL_SCHEME ":") + mPath;
return NS_OK;
}
// result may contain unescaped UTF-8 characters
NS_IMETHODIMP
NullPrincipalURI::GetSpecIgnoringRef(nsACString& _result) {
return GetSpec(_result);
}
NS_IMETHODIMP
NullPrincipalURI::GetHasRef(bool* _result) {
*_result = false;
return NS_OK;
}
nsresult NullPrincipalURI::SetSpecInternal(const nsACString& aSpec) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetUsername(nsACString& _username) {
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetUsername(const nsACString& aUsername) {
return NS_ERROR_NOT_IMPLEMENTED;
}
NS_IMETHODIMP
NullPrincipalURI::GetUserPass(nsACString& _userPass) {
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::SetUserPass(const nsACString& aUserPass) {
return NS_ERROR_NOT_IMPLEMENTED;
}
nsresult NullPrincipalURI::Clone(nsIURI** _newURI) {
nsCOMPtr<nsIURI> uri = new NullPrincipalURI(*this);
uri.forget(_newURI);
return NS_OK;
}
NS_IMPL_ISUPPORTS(NullPrincipalURI::Mutator, nsIURISetters, nsIURIMutator)
NS_IMETHODIMP
NullPrincipalURI::Mutate(nsIURIMutator** aMutator) {
RefPtr<NullPrincipalURI::Mutator> mutator = new NullPrincipalURI::Mutator();
nsresult rv = mutator->InitFromURI(this);
if (NS_FAILED(rv)) {
return rv;
}
mutator.forget(aMutator);
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::Equals(nsIURI* aOther, bool* _equals) {
*_equals = false;
RefPtr<NullPrincipalURI> otherURI;
nsresult rv = aOther->QueryInterface(kNullPrincipalURIImplementationCID,
getter_AddRefs(otherURI));
if (NS_SUCCEEDED(rv)) {
*_equals = mPath == otherURI->mPath;
}
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::EqualsExceptRef(nsIURI* aOther, bool* _equals) {
// GetRef/SetRef not supported by NullPrincipalURI, so
// EqualsExceptRef() is the same as Equals().
return Equals(aOther, _equals);
}
NS_IMETHODIMP
NullPrincipalURI::Resolve(const nsACString& aRelativePath,
nsACString& _resolvedURI) {
_resolvedURI = aRelativePath;
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::SchemeIs(const char* aScheme, bool* _schemeIs) {
*_schemeIs = (0 == nsCRT::strcasecmp(NS_NULLPRINCIPAL_SCHEME, aScheme));
return NS_OK;
}
NS_IMETHODIMP
NullPrincipalURI::GetDisplaySpec(nsACString& aUnicodeSpec) {
return GetSpec(aUnicodeSpec);
}
NS_IMETHODIMP
NullPrincipalURI::GetDisplayHostPort(nsACString& aUnicodeHostPort) {
return GetHostPort(aUnicodeHostPort);
}
NS_IMETHODIMP
NullPrincipalURI::GetDisplayHost(nsACString& aUnicodeHost) {
return GetHost(aUnicodeHost);
}
NS_IMETHODIMP
NullPrincipalURI::GetDisplayPrePath(nsACString& aPrePath) {
return GetPrePath(aPrePath);
}
void NullPrincipalURI::Serialize(mozilla::ipc::URIParams& aParams) {
aParams = mozilla::ipc::NullPrincipalURIParams();
}
bool NullPrincipalURI::Deserialize(const mozilla::ipc::URIParams& aParams) {
if (aParams.type() != mozilla::ipc::URIParams::TNullPrincipalURIParams) {
MOZ_ASSERT_UNREACHABLE("unexpected URIParams type");
return false;
}
nsresult rv = Init();
NS_ENSURE_SUCCESS(rv, false);
return true;
}
////////////////////////////////////////////////////////////////////////////////
//// nsISizeOf
size_t NullPrincipalURI::SizeOfExcludingThis(MallocSizeOf aMallocSizeOf) const {
return mPath.SizeOfExcludingThisIfUnshared(aMallocSizeOf);
}
size_t NullPrincipalURI::SizeOfIncludingThis(MallocSizeOf aMallocSizeOf) const {
return aMallocSizeOf(this) + SizeOfExcludingThis(aMallocSizeOf);
}