Revision control

Copy as Markdown

Other Tools

/* -*- Mode: IDL; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* 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 nsIURI;
interface nsIImapUrl;
interface nsIImapProtocol;
interface nsIMsgFolder;
interface nsIMsgWindow;
typedef long nsMsgImapDeleteModel;
[scriptable, uuid(bbfc33de-fe89-11d3-a564-0060b0fc04b7)]
interface nsMsgImapDeleteModels : nsISupports
{
const long IMAPDelete = 0; /* delete with a big red x */
const long MoveToTrash = 1; /* delete moves message to the trash */
const long DeleteNoTrash = 2; /* delete is shift delete - don't create or use trash */
};
[scriptable, uuid(ea6a0765-07b8-40df-924c-9004ed707251)]
interface nsIImapIncomingServer : nsISupports {
attribute long maximumConnectionsNumber;
attribute boolean forceSelect;
attribute long timeOutLimits;
attribute AUTF8String adminUrl;
attribute ACString serverDirectory;
/// RFC 2971 ID response stored as a pref
attribute AUTF8String serverIDPref;
attribute boolean cleanupInboxOnExit;
attribute nsMsgImapDeleteModel deleteModel;
attribute boolean dualUseFolders;
attribute ACString personalNamespace;
attribute ACString publicNamespace;
attribute ACString otherUsersNamespace;
attribute boolean offlineDownload;
attribute boolean overrideNamespaces;
attribute boolean usingSubscription;
attribute AUTF8String manageMailAccountUrl;
attribute boolean fetchByChunks;
attribute boolean sendID;
attribute boolean useIdle;
attribute boolean checkAllFoldersForNew;
/// Is this a GMail Server?
attribute boolean isGMailServer;
/**
* See IMAP RFC 4551
**/
attribute boolean useCondStore;
/**
* See IMAP RFC 4978
*/
attribute boolean useCompressDeflate;
/**
* This contains a folder path, for example INBOX/Trash. Note that the
* account manager sets this attribute to the path of the trash folder the
* user has chosen.
*/
attribute AString trashFolderName;
attribute boolean downloadBodiesOnGetNewMail;
attribute boolean autoSyncOfflineStores;
/// Max age of messages we will autosync to, or keep in offline store.
attribute long autoSyncMaxAgeDays;
/** True if there are no busy connections in cache. */
readonly attribute boolean allConnectionsIdle;
/**
* See IMAP RFC 6855
*/
attribute boolean allowUTF8Accept;
void GetImapConnectionAndLoadUrl(in nsIImapUrl aImapUrl,
in nsISupports aConsumer);
void RemoveConnection(in nsIImapProtocol aImapConnection);
void ResetNamespaceReferences();
void pseudoInterruptMsgLoad(in nsIMsgFolder aImapFolder, in nsIMsgWindow aMsgWindow, out boolean interrupted);
void ResetConnection(in AUTF8String folderName);
void CloseConnectionForFolder(in nsIMsgFolder aMsgFolder);
void reDiscoverAllFolders();
nsIURI subscribeToFolder(in AString name, in boolean subscribe);
void GetNewMessagesForNonInboxFolders(in nsIMsgFolder aRootFolder,
in nsIMsgWindow aWindow,
in boolean forceAllFolders,
in boolean performingBiff);
unsigned long long getCapability();
/**
* Get the password from the nsIMsgIncomingServer. May prompt the user
* if there's no password in the password manager or cached in the
* server object.
* @param aWindow msgWindow to associate the password prompt with
* @return Password string.
* @exception NS_ERROR_FAILURE The password could not be obtained.
* @note NS_MSG_PASSWORD_PROMPT_CANCELLED is a success code that is returned
* if the prompt was presented to the user but the user cancelled the
* prompt.
*/
AString PromptPassword(in nsIMsgWindow aWindow);
attribute boolean doingLsub;
ACString getUriWithNamespacePrefixIfNecessary(in long namespaceType, in AUTF8String originalUri);
attribute boolean shuttingDown;
attribute boolean utf8AcceptEnabled;
};