/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=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/. */ #include "nsISupports.idl" interface nsIPrincipal; interface nsIQuotaRequest; interface nsIQuotaUsageCallback; interface nsIQuotaUsageRequest; [scriptable, builtinclass, uuid(1b3d0a38-8151-4cf9-89fa-4f92c2ef0e7e)] interface nsIQuotaManagerService : nsISupports { /** * Schedules an asynchronous callback that will return the total amount of * disk space being used by storages for the given origin. * * @param aPrincipal * A principal for the origin whose usage is being queried. * @param aCallback * The callback that will be called when the usage is available. */ nsIQuotaUsageRequest getUsageForPrincipal(in nsIPrincipal aPrincipal, in nsIQuotaUsageCallback aCallback); /** * Removes all storages. The files may not be deleted immediately depending * on prohibitive concurrent operations. * Be careful, this removes *all* the data that has ever been stored! * * If the dom.quotaManager.testing preference is not true the call will be * a no-op. */ nsIQuotaRequest clear(); /** * Removes all storages stored for the given URI. The files may not be * deleted immediately depending on prohibitive concurrent operations. * * @param aPrincipal * A principal for the origin whose storages are to be cleared. */ nsIQuotaRequest clearStoragesForPrincipal(in nsIPrincipal aPrincipal, [optional] in ACString aPersistenceType); /** * Resets quota and storage management. This can be used to force * reinitialization of the temp storage, for example when the pref for * overriding the temp storage limit has changed. * Be carefull, this invalidates all live storages! * * If the dom.quotaManager.testing preference is not true the call will be * a no-op. */ nsIQuotaRequest reset(); };