diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /image/imgICache.idl | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'image/imgICache.idl')
-rw-r--r-- | image/imgICache.idl | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/image/imgICache.idl b/image/imgICache.idl new file mode 100644 index 0000000000..2368dfc961 --- /dev/null +++ b/image/imgICache.idl @@ -0,0 +1,106 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * + * 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 imgIRequest; +interface nsIPrincipal; +interface nsIProperties; +interface nsIURI; + +webidl Document; + +%{ C++ +namespace mozilla { +class OriginAttributes; +} // mozilla namespace +%} + +[ptr] native OriginAttributesPtr(mozilla::OriginAttributes); + +/** + * imgICache interface + * + * @author Stuart Parmenter <pavlov@netscape.com> + * @version 0.1 + * @see imagelib2 + */ +[scriptable, builtinclass, uuid(bfdf23ff-378e-402e-8a6c-840f0c82b6c3)] +interface imgICache : nsISupports +{ + /** + * Evict images from the cache. + * + * @param chrome If TRUE, evict only chrome images. + * If FALSE, evict everything except chrome images. + */ + void clearCache(in boolean chrome); + + /** + * Evict images from the cache. + * + * @param uri The URI to remove. + * @param doc The document to remove the cache entry for. + * @throws NS_ERROR_NOT_AVAILABLE if \a uri was unable to be removed from + * the cache. + */ + [noscript] void removeEntry(in nsIURI uri, [optional] in Document doc); + + /** + * Evict images from the cache with the same origin and the same + * originAttributes of the passed principal, across all processes. May only be + * called from the parent process. + * + * @param aPrincipal The principal to clear cache entries for. The principals + * origin attributes are used to determine whether the private or normal + * browsing cache is cleared. + * @throws NS_ERROR_NOT_AVAILABLE if not called in the parent process. + */ + void removeEntriesFromPrincipalInAllProcesses(in nsIPrincipal aPrincipal); + + /** + * Evict images from the non-chrome cache which match the the given base + * domain. Matching cache entries will be cleared across all origin attributes + * and all processes. + * + * @param aBaseDomain base domain to delete cache entries for. + * @throws NS_ERROR_NOT_AVAILABLE if not called in the parent process. + */ + void removeEntriesFromBaseDomainInAllProcesses(in ACString aBaseDomain); + + /** + * Find Properties + * Used to get properties such as 'type' and 'content-disposition' + * 'type' is a nsISupportsCString containing the images' mime type such as + * 'image/png' + * 'content-disposition' will be a nsISupportsCString containing the header + * If you call this before any data has been loaded from a URI, it will + * succeed, but come back empty. + * + * Hopefully this will be removed with bug 805119 + * + * @param uri The URI to look up. + * @param doc Optional pointer to the document that the cache entry belongs to. + * @returns NULL if the URL was not found in the cache + */ + [must_use] + nsIProperties findEntryProperties(in nsIURI uri, + [optional] in Document doc); + + /** + * Make this cache instance respect private browsing notifications. This + * entails clearing the chrome and content caches whenever the + * last-pb-context-exited notification is observed. + */ + void respectPrivacyNotifications(); + + /** + * Clear the image cache for a document. Controlled documents are responsible + * for doing this manually when they get destroyed. + */ + [noscript, notxpcom] + void clearCacheForControlledDocument(in Document doc); +}; |