mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
393bc6639f
- Bug 1209162 - Create OriginAttributes subtypes. IGNORE IDL r=sicking. (c2cbe04ef3) - Bug 1220570 - Potential cookie lost while downgrading from Aurora 44 to 43. r=jduell (1a0111c842) - Bug 1217456: Add a security flag for controlling redirects. Use this flag in fetch() implementation. r=bkelly,jduell (79d449e479) - Bug 1112040 - Add a mochitest. r=bholley (566a05f720) - Bug 1171215 - Compute third-partyness in the loadinfo instead of nsIHttpChannelInternal so that other protocols correctly respect the third-party cookie pref. r=sicking/ckerschb (06f7a10a83) - better backport of Bug 485941 - Stack overflow using overly-deep XML tree (DoS). r=bzbarsky (ac43feeffa) - Bug 1182546 - Use channel->Open2() in parser/htmlparser/nsExpatDriver.cpp (r=bz) (42768f373a) - Bug 1163435 part 1 - [css-grid][css-flexbox] Propagate an explicit CB width/height to the reflow state to resolve percentage lengths for grid items properly. Resolve percent against the size in the same axis for abs.pos. children too. r=dholbert (a55463fb05) - Bug 1163435 part 2 - tests. (bb683c5fc6) - Bug 1223282 - Make NS_AUTOMARGIN be a different value than NS_UNCONSTRAINEDSIZE to avoid having clamped huge margin values be interpreted as auto margins. r=roc (4cdfe0f277) - Bug 1224230 - Explicitly store the lineContainer's writing mode in InlineIntrinsicISizeData. r=dbaron (6474515223) - Bug 1221043. Revert to including trailing whitespace for accessibility APIs. r=marcoz,mats (406018c163) - Bug 1227113 - Fix some indentation issues in ServiceWorkerManager, r=janv (2b343bde09) - Bug 1223116 P1 Expose nsIServiceWorkerManager.shouldReportToWindow(). r=catalinb (02899e429d) - Bug 1226441 - Part 1: Add wpt test verifying fetch event waits for activate to complete; r=catalinb (e8eb3e6e7a) - Bug 1209865 - Add gecko profiler marker when mark() of User Timing API is called. r=baku (f48d76e395) - Bug 1169068 - Performance.translateTime(), r=bz (38cd1c31b2) - Bug 1226441 - Part 2: Delay functional event dispatch until service worker is activated; r=catalinb (778cd3dd24) - Bug 1178233 - [non-e10s] The update process doesn't work within about:serviceworkers in non-e10s mode. Test. r=baku (4f8b6f53f8) - Bug 1188545 - Disable unstable test: test_aboutserviceworkers.html. a=testonly (4bbe106693) - Bug 1219255 - We should be able to attach to a service worker;r=amarchesini (0d6b71b4ec) - Bug 1222464 - Part 2: Implement FetchEvent.clientId; r=jdm (9c8abd62dd) - Bug 1218150 - Mark the members of Clients as NewObject; r=bzbarsky (b6b00a586c) - Bug 1222464 - Part 3: Implement Clients.get(); r=jdm (f5ca60d801) - Bug 1222464 - Part 1: Save a client ID for top-level navigations on the docshell and assign it as the document ID when we start loading the document; r=jdm (7dcb5ce2b6) - Bug 1218141 - Add some SameObject and NewObject annotations to ServiceWorkerGlobalScope; r=bzbarsky (5019f58c7a) - Bug 1218190 - Add a pref to enable Clients.openWindow, r=catalinb (dbb6d007dd) - Bug 1218142 - Remove ServiceWorkerGlobalScope.onbeforeevicted/onevicted; r=bzbarsky (029de6f8ec) - Bug 1218146 - Move WindowClient.frameType to Client.frameType; r=bzbarsky (00f0211276) - Bug 1218147 - Make WindowClient.focus() NewObject; r=bzbarsky (3c6aea4b67) - Bug 1189659 - Part 1 - Continue service worker job queue when life cycle events expire. r=bkelly (aa09cd9c60) - Bug 1227932 - Fix Service Workers SoftUpdate and registration.update code paths. r=ehsan (24567b23c0) - Bug 1189659 - Part 2 - Remove set of scopes being updated from ServiceWorkerManager. r=bkelly (ce581b095c) - Bug 1189659 - Part 3 - Use separate synchronization queues for service worker register jobs and install jobs. r=bkelly (9c408a22ed) - Bug 1189659 - Part 4 - Fix race in test_install_event.html. r=bkelly (3186ffb808) - Bug 1189659 - Part 5 - Fix race in skip-waiting.https.html and add some logging for SkipWaitingFlag in ServiceWorkerManager. r=ehsan (4e5ddda6f3) - Bug 1229056 - Implement ClientQueryOptions.includeUncontrolled; r=jdm (dbe56aa60d) - namespace (3b0863d42d) - Bug 1201127 - Return the same ServiceWorkerRegistration object from service worker APIs dealing with the same underlying registration object; r=jdm (c542688ae0) - Bug 1171583 - Remove mutable warning from |nsSimpleURI::SetUserPass|. r=bz (73934deaad) - Bug 1206199 - Extend channelwrapper to mediate OnStartRequest, OnStopRequest, OnDataAvailable (r=sicking) (758a7ec65c) - Bug 1186783 (part 4) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (681bdba278) - Bug 1186783 (part 3) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (76b8b7191e) - Bug 1186783 (part 2) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (5c0743ac49) - Bug 1186783 (part 1) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (952cc720cc) - Bug 1186783 (part 5) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (25b9735c52) - Bug 1186783 (part 1) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/. r=michal. (ae52425809) - Bug 1186783 (follow-up) - Bustage fix for Gonk. (d4a1b769bd) - add back some hotfix stuff, even if unused (fe32076c5b) - Bug 1068087: Switch about:plugins to run remotely. r=mconley (bc4316dd03) - Bug 1214058: Part 1 - Add a simplified JSON-based add-on update protocol. r=Mossop (a3198884d5) - Bug 1214058: Part 2 - Run add-on update tests against comparable JSON and RDF manifests. r=Mossop (aa6a796e6f) - Bug 1152977 - Enable by default DEAA for desktop platforms that use OpenGL compositor. r=jmuizelaar (bfa9efd5c8)
495 lines
15 KiB
C++
495 lines
15 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set sw=2 ts=8 et 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/. */
|
|
|
|
#include "nsICacheStorage.h"
|
|
#include "nsICacheStorageService.h"
|
|
#include "../../cache2/CacheFileUtils.h"
|
|
#include "mozilla/Logging.h"
|
|
#include "mozilla/DebugOnly.h"
|
|
#include "nsThreadUtils.h"
|
|
#include "PackagedAppVerifier.h"
|
|
#include "nsITimer.h"
|
|
#include "nsIPackagedAppVerifier.h"
|
|
#include "mozilla/Preferences.h"
|
|
#include "nsIPackagedAppUtils.h"
|
|
#include "nsIInputStream.h"
|
|
#include "nsComponentManagerUtils.h"
|
|
#include "nsIURL.h"
|
|
#include "mozilla/BasePrincipal.h"
|
|
|
|
static const short kResourceHashType = nsICryptoHash::SHA256;
|
|
|
|
static bool gSignedAppEnabled = false;
|
|
|
|
namespace mozilla {
|
|
namespace net {
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
NS_IMPL_ISUPPORTS(PackagedAppVerifier, nsIPackagedAppVerifier, nsIVerificationCallback)
|
|
|
|
NS_IMPL_ISUPPORTS(PackagedAppVerifier::ResourceCacheInfo, nsISupports)
|
|
|
|
const char* PackagedAppVerifier::kSignedPakIdMetadataKey = "package-id";
|
|
|
|
PackagedAppVerifier::PackagedAppVerifier()
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(),
|
|
"PackagedAppVerifier::OnResourceVerified must be on main thread");
|
|
|
|
Init(nullptr, EmptyCString(), EmptyCString(), nullptr);
|
|
}
|
|
|
|
PackagedAppVerifier::PackagedAppVerifier(nsIPackagedAppVerifierListener* aListener,
|
|
const nsACString& aPackageOrigin,
|
|
const nsACString& aSignature,
|
|
nsICacheEntry* aPackageCacheEntry)
|
|
{
|
|
Init(aListener, aPackageOrigin, aSignature, aPackageCacheEntry);
|
|
}
|
|
|
|
PackagedAppVerifier::~PackagedAppVerifier()
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(), "mPendingResourceCacheInfoList is not thread safe.");
|
|
while (auto i = mPendingResourceCacheInfoList.popFirst()) {
|
|
// This seems to be the only way that we can manually delete a
|
|
// nsISupports instance with no warning.
|
|
RefPtr<ResourceCacheInfo> deleter(i);
|
|
}
|
|
}
|
|
|
|
NS_IMETHODIMP PackagedAppVerifier::Init(nsIPackagedAppVerifierListener* aListener,
|
|
const nsACString& aPackageOrigin,
|
|
const nsACString& aSignature,
|
|
nsICacheEntry* aPackageCacheEntry)
|
|
{
|
|
static bool onceThru = false;
|
|
if (!onceThru) {
|
|
Preferences::AddBoolVarCache(&gSignedAppEnabled,
|
|
"network.http.signed-packages.enabled", false);
|
|
onceThru = true;
|
|
}
|
|
|
|
mListener = aListener;
|
|
mState = STATE_UNKNOWN;
|
|
mSignature = aSignature;
|
|
mIsPackageSigned = false;
|
|
mPackageCacheEntry = aPackageCacheEntry;
|
|
mIsFirstResource = true;
|
|
mManifest = EmptyCString();
|
|
|
|
NeckoOriginAttributes().PopulateFromOrigin(aPackageOrigin, mPackageOrigin);
|
|
mBypassVerification = (mPackageOrigin ==
|
|
Preferences::GetCString("network.http.signed-packages.trusted-origin"));
|
|
|
|
LOG(("mBypassVerification = %d\n", mBypassVerification));
|
|
LOG(("mPackageOrigin = %s\n", mPackageOrigin.get()));
|
|
|
|
nsresult rv;
|
|
mPackagedAppUtils = do_CreateInstance(NS_PACKAGEDAPPUTILS_CONTRACTID, &rv);
|
|
if (NS_FAILED(rv)) {
|
|
LOG(("create packaged app utils failed"));
|
|
return rv;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
// nsIStreamListener
|
|
//----------------------------------------------------------------------
|
|
|
|
// @param aRequest nullptr.
|
|
// @param aContext The URI of the resource. (nsIURI)
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::OnStartRequest(nsIRequest *aRequest,
|
|
nsISupports *aContext)
|
|
{
|
|
if (mIsFirstResource) {
|
|
// The first resource must be the manifest, hashes not needed
|
|
return NS_OK;
|
|
}
|
|
|
|
if (!mHasher) {
|
|
mHasher = do_CreateInstance("@mozilla.org/security/hash;1");
|
|
}
|
|
|
|
NS_ENSURE_TRUE(mHasher, NS_ERROR_FAILURE);
|
|
|
|
nsCOMPtr<nsIURI> uri = do_QueryInterface(aContext);
|
|
NS_ENSURE_TRUE(uri, NS_ERROR_FAILURE);
|
|
uri->GetAsciiSpec(mHashingResourceURI);
|
|
|
|
return mHasher->Init(kResourceHashType);
|
|
}
|
|
|
|
NS_METHOD
|
|
PackagedAppVerifier::WriteManifest(nsIInputStream* aStream,
|
|
void* aManifest,
|
|
const char* aFromRawSegment,
|
|
uint32_t aToOffset,
|
|
uint32_t aCount,
|
|
uint32_t* aWriteCount)
|
|
{
|
|
LOG(("WriteManifest: length %u", aCount));
|
|
LOG(("%s", nsCString(aFromRawSegment, aCount).get()));
|
|
nsCString* manifest = static_cast<nsCString*>(aManifest);
|
|
manifest->AppendASCII(aFromRawSegment, aCount);
|
|
*aWriteCount = aCount;
|
|
return NS_OK;
|
|
}
|
|
|
|
// @param aRequest nullptr.
|
|
// @param aContext nullptr.
|
|
// @param aInputStream as-is.
|
|
// @param aOffset as-is.
|
|
// @param aCount as-is.
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::OnDataAvailable(nsIRequest *aRequest,
|
|
nsISupports *aContext,
|
|
nsIInputStream *aInputStream,
|
|
uint64_t aOffset,
|
|
uint32_t aCount)
|
|
{
|
|
if (mIsFirstResource) {
|
|
// The first resource must be the manifest, hash value not needed.
|
|
// Instead, we read from the input stream and append to mManifest.
|
|
uint32_t count;
|
|
LOG(("ReadSegments: size = %u", aCount));
|
|
nsresult rv = aInputStream->ReadSegments(WriteManifest, &mManifest, aCount, &count);
|
|
MOZ_ASSERT(count == aCount, "Bytes read by ReadSegments don't match");
|
|
return rv;
|
|
}
|
|
|
|
MOZ_ASSERT(!mHashingResourceURI.IsEmpty(), "MUST call BeginResourceHash first.");
|
|
NS_ENSURE_TRUE(mHasher, NS_ERROR_FAILURE);
|
|
return mHasher->UpdateFromStream(aInputStream, aCount);
|
|
}
|
|
|
|
// @param aRequest nullptr.
|
|
// @param aContext The resource cache info.
|
|
// @param aStatusCode as-is,
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::OnStopRequest(nsIRequest* aRequest,
|
|
nsISupports* aContext,
|
|
nsresult aStatusCode)
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(), "mHashingResourceURI is not thread safe.");
|
|
|
|
if (mIsFirstResource) {
|
|
// The first resource must be the manifest, hash value not needed
|
|
mIsFirstResource = false;
|
|
} else {
|
|
NS_ENSURE_TRUE(mHasher, NS_ERROR_FAILURE);
|
|
|
|
nsAutoCString hash;
|
|
nsresult rv = mHasher->Finish(true, hash);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
LOG(("Hash of %s is %s", mHashingResourceURI.get(), hash.get()));
|
|
|
|
// Store the computated hash associated with the resource URI.
|
|
mResourceHashStore.Put(mHashingResourceURI, new nsCString(hash));
|
|
mHashingResourceURI = EmptyCString();
|
|
}
|
|
|
|
// Get a internal copy and take over the life cycle handling
|
|
// since the linked list we use only supports pointer-based element.
|
|
ResourceCacheInfo* info
|
|
= new ResourceCacheInfo(*(static_cast<ResourceCacheInfo*>(aContext)));
|
|
|
|
ProcessResourceCache(info);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
PackagedAppVerifier::ProcessResourceCache(const ResourceCacheInfo* aInfo)
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(), "ProcessResourceCache must be on main thread");
|
|
|
|
// Queue this info since we might process it asynchronously.
|
|
mPendingResourceCacheInfoList.insertBack(const_cast<ResourceCacheInfo*>(aInfo));
|
|
|
|
switch (mState) {
|
|
case STATE_UNKNOWN:
|
|
// The first resource has to be the manifest.
|
|
VerifyManifest(aInfo);
|
|
break;
|
|
|
|
case STATE_MANIFEST_VERIFYING:
|
|
// A resource is cached in the middle of manifest verification.
|
|
// Verify it until the manifest is verified.
|
|
break;
|
|
|
|
case STATE_MANIFEST_VERIFIED_OK:
|
|
VerifyResource(aInfo);
|
|
break;
|
|
|
|
case STATE_MANIFEST_VERIFIED_FAILED:
|
|
LOG(("Resource not verified because manifest verification failed."));
|
|
FireVerifiedEvent(false, false);
|
|
break;
|
|
|
|
default:
|
|
MOZ_CRASH("Unexpected PackagedAppVerifier state."); // Shouldn't get here.
|
|
break;
|
|
}
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::FireVerifiedEvent(bool aForManifest, bool aSuccess)
|
|
{
|
|
LOG(("FireVerifiedEvent aForManifest=%d aSuccess=%d", aForManifest, aSuccess));
|
|
nsCOMPtr<nsIRunnable> r;
|
|
|
|
if (aForManifest) {
|
|
r = NS_NewRunnableMethodWithArgs<bool>(this,
|
|
&PackagedAppVerifier::OnManifestVerified,
|
|
aSuccess);
|
|
} else {
|
|
r = NS_NewRunnableMethodWithArgs<bool>(this,
|
|
&PackagedAppVerifier::OnResourceVerified,
|
|
aSuccess);
|
|
}
|
|
|
|
NS_DispatchToMainThread(r);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
PackagedAppVerifier::VerifyManifest(const ResourceCacheInfo* aInfo)
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(), "Manifest verification must be on main thread");
|
|
|
|
LOG(("Ready to verify manifest."));
|
|
|
|
if (!aInfo->mURI) { // Broken last part.
|
|
FireVerifiedEvent(false, false);
|
|
mState = STATE_MANIFEST_VERIFIED_FAILED;
|
|
return;
|
|
}
|
|
|
|
mState = STATE_MANIFEST_VERIFYING;
|
|
|
|
if (mSignature.IsEmpty()) {
|
|
LOG(("No signature. No need to do verification."));
|
|
FireVerifiedEvent(true, true);
|
|
return;
|
|
}
|
|
|
|
LOG(("Signature: length = %u\n%s", mSignature.Length(), mSignature.get()));
|
|
LOG(("Manifest: length = %u\n%s", mManifest.Length(), mManifest.get()));
|
|
|
|
bool useDeveloperRoot =
|
|
!Preferences::GetCString("network.http.signed-packages.developer-root").IsEmpty();
|
|
nsresult rv = mPackagedAppUtils->VerifyManifest(mSignature, mManifest,
|
|
this, useDeveloperRoot);
|
|
if (NS_FAILED(rv)) {
|
|
LOG(("VerifyManifest FAILED rv = %u", (unsigned)rv));
|
|
}
|
|
}
|
|
|
|
void
|
|
PackagedAppVerifier::VerifyResource(const ResourceCacheInfo* aInfo)
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(), "Resource verification must be on main thread");
|
|
|
|
if (!aInfo->mURI) { // Broken last part.
|
|
FireVerifiedEvent(false, false);
|
|
return;
|
|
}
|
|
|
|
// Look up the resource hash that we computed and stored to
|
|
// mResourceHashStore before.
|
|
nsAutoCString uriAsAscii;
|
|
aInfo->mURI->GetAsciiSpec(uriAsAscii);
|
|
nsCString* resourceHash = mResourceHashStore.Get(uriAsAscii);
|
|
|
|
if (!resourceHash) {
|
|
LOG(("Hash value for %s is not computed. ERROR!", uriAsAscii.get()));
|
|
MOZ_CRASH();
|
|
}
|
|
|
|
if (mBypassVerification) {
|
|
LOG(("Origin is trusted. Bypass integrity check."));
|
|
FireVerifiedEvent(false, true);
|
|
return;
|
|
}
|
|
|
|
if (mSignature.IsEmpty()) {
|
|
LOG(("No signature. No need to do resource integrity check."));
|
|
FireVerifiedEvent(false, true);
|
|
return;
|
|
}
|
|
|
|
nsAutoCString path;
|
|
nsCOMPtr<nsIURL> url(do_QueryInterface(aInfo->mURI));
|
|
if (url) {
|
|
url->GetFilePath(path);
|
|
}
|
|
int32_t pos = path.Find("!//");
|
|
if (pos == kNotFound) {
|
|
FireVerifiedEvent(false, false);
|
|
return;
|
|
}
|
|
// Only keep the part after "!//"
|
|
path.Cut(0, pos + 3);
|
|
|
|
mPackagedAppUtils->CheckIntegrity(path, *resourceHash, this);
|
|
}
|
|
|
|
void
|
|
PackagedAppVerifier::OnManifestVerified(bool aSuccess)
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(), "OnManifestVerified must be on main thread.");
|
|
|
|
LOG(("PackagedAppVerifier::OnManifestVerified: %d", aSuccess));
|
|
|
|
// The listener could have been removed before we verify the resource.
|
|
if (!mListener) {
|
|
return;
|
|
}
|
|
|
|
|
|
if (!aSuccess && mBypassVerification) {
|
|
aSuccess = true;
|
|
LOG(("Developer mode! Treat junk signature valid."));
|
|
}
|
|
|
|
if (aSuccess && !mSignature.IsEmpty()) {
|
|
// Get the package location from the manifest
|
|
nsAutoCString packageOrigin;
|
|
mPackagedAppUtils->GetPackageOrigin(packageOrigin);
|
|
if (packageOrigin != mPackageOrigin) {
|
|
aSuccess = false;
|
|
LOG(("moz-package-location doesn't match:\nFrom: %s\nManifest: %s\n", mPackageOrigin.get(), packageOrigin.get()));
|
|
}
|
|
}
|
|
|
|
// Only when the manifest verified and package has signature would we
|
|
// regard this package is signed.
|
|
mIsPackageSigned = aSuccess && !mSignature.IsEmpty();
|
|
|
|
mState = aSuccess ? STATE_MANIFEST_VERIFIED_OK
|
|
: STATE_MANIFEST_VERIFIED_FAILED;
|
|
|
|
// Obtain the package identifier from manifest if the package is signed.
|
|
if (mIsPackageSigned) {
|
|
mPackagedAppUtils->GetPackageIdentifier(mPackageIdentifer);
|
|
LOG(("PackageIdentifer is: %s", mPackageIdentifer.get()));
|
|
}
|
|
|
|
// If the signature verification failed, doom the package cache to
|
|
// make its subresources unavailable in the subsequent requests.
|
|
if (!aSuccess && mPackageCacheEntry) {
|
|
mPackageCacheEntry->AsyncDoom(nullptr);
|
|
}
|
|
|
|
// If the package is signed, add related info to the package cache.
|
|
if (mIsPackageSigned && mPackageCacheEntry) {
|
|
LOG(("This package is signed. Add this info to the cache channel."));
|
|
if (mPackageCacheEntry) {
|
|
mPackageCacheEntry->SetMetaDataElement(kSignedPakIdMetadataKey,
|
|
mPackageIdentifer.get());
|
|
mPackageCacheEntry = nullptr; // the cache entry is no longer needed.
|
|
}
|
|
}
|
|
|
|
RefPtr<ResourceCacheInfo> info(mPendingResourceCacheInfoList.popFirst());
|
|
MOZ_ASSERT(info);
|
|
|
|
mListener->OnVerified(true, // aIsManifest.
|
|
info->mURI,
|
|
info->mCacheEntry,
|
|
info->mStatusCode,
|
|
info->mIsLastPart,
|
|
aSuccess);
|
|
|
|
LOG(("Ready to verify resources that were cached during verification"));
|
|
// Verify the resources which were cached during verification accordingly.
|
|
for (auto i = mPendingResourceCacheInfoList.getFirst(); i; i = i->getNext()) {
|
|
VerifyResource(i);
|
|
}
|
|
}
|
|
|
|
void
|
|
PackagedAppVerifier::OnResourceVerified(bool aSuccess)
|
|
{
|
|
MOZ_RELEASE_ASSERT(NS_IsMainThread(),
|
|
"PackagedAppVerifier::OnResourceVerified must be on main thread");
|
|
|
|
// The listener could have been removed before we verify the resource.
|
|
if (!mListener) {
|
|
return;
|
|
}
|
|
|
|
RefPtr<ResourceCacheInfo> info(mPendingResourceCacheInfoList.popFirst());
|
|
MOZ_ASSERT(info);
|
|
|
|
mListener->OnVerified(false, // aIsManifest.
|
|
info->mURI,
|
|
info->mCacheEntry,
|
|
info->mStatusCode,
|
|
info->mIsLastPart,
|
|
aSuccess);
|
|
}
|
|
|
|
void
|
|
PackagedAppVerifier::SetHasBrokenLastPart(nsresult aStatusCode)
|
|
{
|
|
// Append a record with null URI as a broken last part.
|
|
|
|
ResourceCacheInfo* info
|
|
= new ResourceCacheInfo(nullptr, nullptr, aStatusCode, true);
|
|
|
|
mPendingResourceCacheInfoList.insertBack(info);
|
|
}
|
|
|
|
bool
|
|
PackagedAppVerifier::WouldVerify() const
|
|
{
|
|
return gSignedAppEnabled && !mSignature.IsEmpty();
|
|
}
|
|
|
|
//---------------------------------------------------------------
|
|
// nsIPackagedAppVerifier.
|
|
//---------------------------------------------------------------
|
|
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::GetPackageIdentifier(nsACString& aPackageIdentifier)
|
|
{
|
|
aPackageIdentifier = mPackageIdentifer;
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::GetIsPackageSigned(bool* aIsPackagedSigned)
|
|
{
|
|
*aIsPackagedSigned = mIsPackageSigned;
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
PackagedAppVerifier::CreateResourceCacheInfo(nsIURI* aUri,
|
|
nsICacheEntry* aCacheEntry,
|
|
nsresult aStatusCode,
|
|
bool aIsLastPart,
|
|
nsISupports** aReturn)
|
|
{
|
|
nsCOMPtr<nsISupports> info =
|
|
new ResourceCacheInfo(aUri, aCacheEntry, aStatusCode, aIsLastPart);
|
|
|
|
info.forget(aReturn);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
|
|
} // namespace net
|
|
} // namespace mozilla
|