mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
f9e56e1ed1
- Bug 1140767 - Build more files in security/manager in unified mode; r=dkeeler (11ab39c46) - Bug 1141864. Replace a bunch nsAutoPtr.h includes with nsRefPtr.h (Adapted) (ce31bfbcc) - Bug 1141689 - use services::GetObserverService more; r=ehsan (22e6fcf7e) - Bug 1140162 - IPC Proxy for TextAttributes and DefaultTextAttributes, r=tbsaunde (31bb06b0d) - Bug 1140499 - IPC Proxy for text/char bounds, r=tbsaunde (5441444db) - Bug 1140534 - IPC Proxy for offsetAtPoint, r=tbsaunde (24ca5c668) - Bug 1140895 - IPC Proxy for get/set/add/remove Selection, r=tbsaunde (35d3364b8) - Bug 1140900 - IPC Proxy for ScrollSubstringTo*, r=tbsaunde (1f7de020f) - Bug 1140917 - IPC Proxy for replace/insert/copy/cut/delete/paste, r=tbsaunde (b6fe2db79) - Bug 1140917 followup: add missing MOZ_OVERRIDE annotations on new DocAccessibleChild method-decls. r=ehsan (47cce9086) - Pointer style (b63b44d0a) - Bug 1140636 - Test CPOW function identity. r=billm (6ada9597c) - Bug 1134006 - Avoid IPC for domElement.QueryInterface(nsISupports) and nsIClassInfo. r=billm (753758b63) - Bug 1096488 - Detect and handle switching from remote to non-remote pages and back in marionette.;r=automatedtester (048279bd5) - Bug 1096488 - Test that switching browser remoteness leaves marionette in a usable state.;r=automatedtester (207aabadb) - Bug 1138650 - Update remaining callsites to use newChannel2 in toolkit/devtools (r=jryans) (a4ffc704e) - Bug 1138648 - Update remaining callsites to use newChannel2 in netwerk/ (r=sworkman) (cdf6612a9) - bug 1135160 - implement link rel=preconnect r=smaug (cfac502ce) - bug 1135160 - ioservice have speculative connect use proxy-resolve2() r=hurley (238b58f84) - Bug 1140788 - Set headers to immutable. r=bkelly,ehsan (c48c12acf) - Bug 1137037 - Determine the inner window ID in imgRequest::Init. r=baku (12aa73a7c) - Bug 1137019 (Part 1) - Get rid of unused LockImage forwarding methods on imgRequest. r=baku (6ed5c7d25) - Bug 1137019 (Part 2) - Replace imgRequest's image decoding methods with a single minimal method that updates an atomic. r=baku (adeb8797c)
254 lines
8.1 KiB
C++
254 lines
8.1 KiB
C++
/* 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 "nsDiskCache.h"
|
|
#include "nsDiskCacheDeviceSQL.h"
|
|
#include "nsCacheService.h"
|
|
#include "nsApplicationCacheService.h"
|
|
#include "nsCRT.h"
|
|
#include "nsNetUtil.h"
|
|
#include "nsIObserverService.h"
|
|
#include "nsILoadContextInfo.h"
|
|
|
|
using namespace mozilla;
|
|
|
|
static NS_DEFINE_CID(kCacheServiceCID, NS_CACHESERVICE_CID);
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// nsApplicationCacheService
|
|
//-----------------------------------------------------------------------------
|
|
|
|
NS_IMPL_ISUPPORTS(nsApplicationCacheService, nsIApplicationCacheService)
|
|
|
|
nsApplicationCacheService::nsApplicationCacheService()
|
|
{
|
|
nsCOMPtr<nsICacheService> serv = do_GetService(kCacheServiceCID);
|
|
mCacheService = nsCacheService::GlobalInstance();
|
|
}
|
|
|
|
nsApplicationCacheService::~nsApplicationCacheService()
|
|
{
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::BuildGroupID(nsIURI *aManifestURL,
|
|
nsILoadContextInfo *aLoadContextInfo,
|
|
nsACString &_result)
|
|
{
|
|
nsresult rv;
|
|
|
|
uint32_t appId = NECKO_NO_APP_ID;
|
|
bool isInBrowserElement = false;
|
|
|
|
if (aLoadContextInfo) {
|
|
appId = aLoadContextInfo->AppId();
|
|
isInBrowserElement = aLoadContextInfo->IsInBrowserElement();
|
|
}
|
|
|
|
rv = nsOfflineCacheDevice::BuildApplicationCacheGroupID(
|
|
aManifestURL, appId, isInBrowserElement, _result);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::BuildGroupIDForApp(nsIURI *aManifestURL,
|
|
uint32_t aAppId,
|
|
bool aIsInBrowser,
|
|
nsACString &_result)
|
|
{
|
|
nsresult rv = nsOfflineCacheDevice::BuildApplicationCacheGroupID(
|
|
aManifestURL, aAppId, aIsInBrowser, _result);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::CreateApplicationCache(const nsACString &group,
|
|
nsIApplicationCache **out)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->CreateApplicationCache(group, out);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::CreateCustomApplicationCache(const nsACString & group,
|
|
nsIFile *profileDir,
|
|
int32_t quota,
|
|
nsIApplicationCache **out)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetCustomOfflineDevice(profileDir,
|
|
quota,
|
|
getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->CreateApplicationCache(group, out);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::GetApplicationCache(const nsACString &clientID,
|
|
nsIApplicationCache **out)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->GetApplicationCache(clientID, out);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::GetActiveCache(const nsACString &group,
|
|
nsIApplicationCache **out)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->GetActiveCache(group, out);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::DeactivateGroup(const nsACString &group)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->DeactivateGroup(group);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::ChooseApplicationCache(const nsACString &key,
|
|
nsILoadContextInfo *aLoadContextInfo,
|
|
nsIApplicationCache **out)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
return device->ChooseApplicationCache(key, aLoadContextInfo, out);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::CacheOpportunistically(nsIApplicationCache* cache,
|
|
const nsACString &key)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->CacheOpportunistically(cache, key);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::DiscardByAppId(int32_t appID, bool isInBrowser)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->DiscardByAppId(appID, isInBrowser);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::GetGroups(uint32_t *count,
|
|
char ***keys)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->GetGroups(count, keys);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsApplicationCacheService::GetGroupsTimeOrdered(uint32_t *count,
|
|
char ***keys)
|
|
{
|
|
if (!mCacheService)
|
|
return NS_ERROR_UNEXPECTED;
|
|
|
|
nsRefPtr<nsOfflineCacheDevice> device;
|
|
nsresult rv = mCacheService->GetOfflineDevice(getter_AddRefs(device));
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
return device->GetGroupsTimeOrdered(count, keys);
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// AppCacheClearDataObserver: handles clearing appcache data for app uninstall
|
|
// and clearing user data events.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
namespace {
|
|
|
|
class AppCacheClearDataObserver final : public nsIObserver {
|
|
public:
|
|
NS_DECL_ISUPPORTS
|
|
|
|
// nsIObserver implementation.
|
|
NS_IMETHODIMP
|
|
Observe(nsISupports *aSubject, const char *aTopic, const char16_t *aData) override
|
|
{
|
|
MOZ_ASSERT(!nsCRT::strcmp(aTopic, TOPIC_WEB_APP_CLEAR_DATA));
|
|
|
|
uint32_t appId = NECKO_UNKNOWN_APP_ID;
|
|
bool browserOnly = false;
|
|
nsresult rv = NS_GetAppInfoFromClearDataNotification(aSubject, &appId,
|
|
&browserOnly);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
nsCOMPtr<nsIApplicationCacheService> cacheService =
|
|
do_GetService(NS_APPLICATIONCACHESERVICE_CONTRACTID, &rv);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
return cacheService->DiscardByAppId(appId, browserOnly);
|
|
}
|
|
|
|
private:
|
|
~AppCacheClearDataObserver() {}
|
|
};
|
|
|
|
NS_IMPL_ISUPPORTS(AppCacheClearDataObserver, nsIObserver)
|
|
|
|
} // anonymous namespace
|
|
|
|
// Instantiates and registers AppCacheClearDataObserver for notifications
|
|
void
|
|
nsApplicationCacheService::AppClearDataObserverInit()
|
|
{
|
|
nsCOMPtr<nsIObserverService> observerService = services::GetObserverService();
|
|
if (observerService) {
|
|
nsRefPtr<AppCacheClearDataObserver> obs
|
|
= new AppCacheClearDataObserver();
|
|
observerService->AddObserver(obs, TOPIC_WEB_APP_CLEAR_DATA,
|
|
/*holdsWeak=*/ false);
|
|
}
|
|
}
|
|
|