summaryrefslogtreecommitdiffstats
path: root/image/imgICache.idl
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /image/imgICache.idl
parentInitial commit. (diff)
downloadthunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz
thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'image/imgICache.idl')
-rw-r--r--image/imgICache.idl106
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);
+};