Class IMAPFolder
- java.lang.Object
-
- javax.mail.Folder
-
- com.sun.mail.imap.IMAPFolder
-
- All Implemented Interfaces:
ResponseHandler,java.lang.AutoCloseable,UIDFolder
- Direct Known Subclasses:
DefaultFolder
public class IMAPFolder extends Folder implements UIDFolder, ResponseHandler
This class implements an IMAP folder.A closed IMAPFolder object shares a protocol connection with its IMAPStore object. When the folder is opened, it gets its own protocol connection.
Applications that need to make use of IMAP-specific features may cast a
Folderobject to anIMAPFolderobject and use the methods on this class.The
getQuotaandsetQuotamethods support the IMAP QUOTA extension. Refer to RFC 2087 for more information.The
getACL,addACL,removeACL,addRights,removeRights,listRights, andmyRightsmethods support the IMAP ACL extension. Refer to RFC 2086 for more information.The
getSortedMessagesmethods support the IMAP SORT extension. Refer to RFC 5256 for more information.The
open(int,ResyncData)method andResyncDataclass supports the IMAP CONDSTORE and QRESYNC extensions. Refer to RFC 4551 and RFC 5162 for more information.The
doCommandmethod andIMAPFolder.ProtocolCommandinterface support use of arbitrary IMAP protocol commands.See the com.sun.mail.imap package documentation for further information on the IMAP protocol provider.
WARNING: The APIs unique to this class should be considered EXPERIMENTAL. They may be changed in the future in ways that are incompatible with applications using the current APIs.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classIMAPFolder.FetchProfileItemA fetch profile item for fetching headers.static interfaceIMAPFolder.ProtocolCommandA simple interface for user-defined IMAP protocol commands.
-
Field Summary
-
Fields inherited from class javax.mail.Folder
HOLDS_FOLDERS, HOLDS_MESSAGES, READ_ONLY, READ_WRITE
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddACL(ACL acl)Add an access control list entry to the access control list for this folder.voidaddMessageCountListener(MessageCountListener l)Add a listener for MessageCount events on this Folder.Message[]addMessages(Message[] msgs)Append the given messages into this folder.voidaddRights(ACL acl)Add the rights specified in the ACL to the entry for the identifier specified in the ACL.voidappendMessages(Message[] msgs)Append the given messages into this folder.AppendUID[]appendUIDMessages(Message[] msgs)Append the given messages into this folder.voidclose(boolean expunge)Close this folder.voidcopyMessages(Message[] msgs, Folder folder)Copy the specified messages from this folder, to the specified destination.AppendUID[]copyUIDMessages(Message[] msgs, Folder folder)Copy the specified messages from this folder, to the specified destination.booleancreate(int type)Create this folder, with the specified type.booleandelete(boolean recurse)Delete this folder.java.lang.ObjectdoCommand(IMAPFolder.ProtocolCommand cmd)Execute a user-supplied IMAP command.java.lang.ObjectdoCommandIgnoreFailure(IMAPFolder.ProtocolCommand cmd)java.lang.ObjectdoOptionalCommand(java.lang.String err, IMAPFolder.ProtocolCommand cmd)booleanexists()Check whether this folder really exists on the server.Message[]expunge()Expunge all messages marked as DELETED.Message[]expunge(Message[] msgs)Expunge the indicated messages, which must have been marked as DELETED.voidfetch(Message[] msgs, FetchProfile fp)Prefetch attributes, based on the given FetchProfile.voidforceClose()Close this folder without waiting for the server.ACL[]getACL()Get the access control list entries for this folder.java.lang.String[]getAttributes()Get the attributes that the IMAP server returns with the LIST response.intgetDeletedMessageCount()Get the deleted message count.FoldergetFolder(java.lang.String name)Get the named subfolder.java.lang.StringgetFullName()Get the fullname of this folder.longgetHighestModSeq()Returns the HIGHESTMODSEQ for this folder.MessagegetMessage(int msgnum)Get the specified message.MessagegetMessageByUID(long uid)Get the Message corresponding to the given UID.intgetMessageCount()Get the total message count.Message[]getMessages()Get all Message objects from this Folder.Message[]getMessagesByUID(long[] uids)Get the Messages specified by the given array.Message[]getMessagesByUID(long start, long end)Get the Messages specified by the given range.Message[]getMessagesByUIDChangedSince(long start, long end, long modseq)Get the messages that have been changed since the given MODSEQ value.java.lang.StringgetName()Get the name of this folder.intgetNewMessageCount()Get the new message count.FoldergetParent()Get this folder's parent.FlagsgetPermanentFlags()Return the permanent flags supported by the server.Quota[]getQuota()Get the quotas for the quotaroot associated with this folder.chargetSeparator()Get the separator character.Message[]getSortedMessages(SortTerm[] term)Sort the messages in the folder according to the sort criteria.Message[]getSortedMessages(SortTerm[] term, SearchTerm sterm)Sort the messages in the folder according to the sort criteria.longgetStatusItem(java.lang.String item)Use the IMAP STATUS command to get the indicated item.intgetType()Get the type of this folder.longgetUID(Message message)Get the UID for the specified message.longgetUIDNext()Returns the predicted UID that will be assigned to the next message that is appended to this folder.booleangetUIDNotSticky()Servers that support the UIDPLUS extension (RFC 4315) may indicate that this folder does not support persistent UIDs; that is, UIDVALIDITY will be different each time the folder is opened.longgetUIDValidity()Returns the UIDValidity for this folder.intgetUnreadMessageCount()Get the unread message count.voidhandleResponse(Response r)The response handler.booleanhasNewMessages()Check whether this folder has new messages.java.util.Map<java.lang.String,java.lang.String>id(java.util.Map<java.lang.String,java.lang.String> clientParams)Send the IMAP ID command (if supported by the server) and return the result from the server.voididle()Use the IMAP IDLE command (see RFC 2177), if supported by the server, to enter idle mode so that the server can send unsolicited notifications of new messages arriving, etc.voididle(boolean once)Likeidle(), but ifonceis true, abort the IDLE command after the first notification, to allow the caller to process any notification synchronously.booleanisOpen()Check whether this connection is really open.booleanisSubscribed()Check whether this folder is subscribed.Folder[]list(java.lang.String pattern)List all subfolders matching the specified pattern.Rights[]listRights(java.lang.String name)Get all the rights that may be allowed to the given identifier.Folder[]listSubscribed(java.lang.String pattern)List all subscribed subfolders matching the specified pattern.voidmoveMessages(Message[] msgs, Folder folder)Move the specified messages from this folder, to the specified destination.AppendUID[]moveUIDMessages(Message[] msgs, Folder folder)Move the specified messages from this folder, to the specified destination.RightsmyRights()Get the rights allowed to the currently authenticated user.voidopen(int mode)Open this folder in the given mode.java.util.List<MailEvent>open(int mode, ResyncData rd)Open this folder in the given mode, with the given resynchronization data.voidremoveACL(java.lang.String name)Remove any access control list entry for the given identifier from the access control list for this folder.voidremoveRights(ACL acl)Remove the rights specified in the ACL from the entry for the identifier specified in the ACL.booleanrenameTo(Folder f)Rename this folder.Message[]search(SearchTerm term)Search whole folder for messages matching the given term.Message[]search(SearchTerm term, Message[] msgs)Search the folder for messages matching the given term.voidsetFlags(int[] msgnums, Flags flag, boolean value)Set the specified flags for the given array of message numbers.voidsetFlags(int start, int end, Flags flag, boolean value)Set the specified flags for the given range of message numbers.voidsetFlags(Message[] msgs, Flags flag, boolean value)Set the specified flags for the given array of messages.voidsetQuota(Quota quota)Set the quotas for the quotaroot specified in the quota argument.voidsetSubscribed(boolean subscribe)Subscribe/Unsubscribe this folder.-
Methods inherited from class javax.mail.Folder
addConnectionListener, addFolderListener, addMessageChangedListener, close, getMessages, getMessages, getMode, getStore, getURLName, list, listSubscribed, removeConnectionListener, removeFolderListener, removeMessageChangedListener, removeMessageCountListener, toString
-
-
-
-
Method Detail
-
getName
public java.lang.String getName()
Get the name of this folder.
-
getFullName
public java.lang.String getFullName()
Get the fullname of this folder.- Specified by:
getFullNamein classFolder- Returns:
- full name of the Folder
-
getParent
public Folder getParent() throws MessagingException
Get this folder's parent.- Specified by:
getParentin classFolder- Returns:
- Parent folder
- Throws:
MessagingException- for failures
-
exists
public boolean exists() throws MessagingExceptionCheck whether this folder really exists on the server.- Specified by:
existsin classFolder- Returns:
- true if the folder exists, otherwise false
- Throws:
MessagingException- typically if the connection to the server is lost.- See Also:
Folder.create(int)
-
list
public Folder[] list(java.lang.String pattern) throws MessagingException
List all subfolders matching the specified pattern.- Specified by:
listin classFolder- Parameters:
pattern- the match pattern- Returns:
- array of matching Folder objects. An empty array is returned if no matching Folders exist.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures- See Also:
Folder.listSubscribed(java.lang.String)
-
listSubscribed
public Folder[] listSubscribed(java.lang.String pattern) throws MessagingException
List all subscribed subfolders matching the specified pattern.- Overrides:
listSubscribedin classFolder- Parameters:
pattern- the match pattern- Returns:
- array of matching subscribed Folder objects. An empty array is returned if no matching subscribed folders exist.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures- See Also:
Folder.list(java.lang.String)
-
getSeparator
public char getSeparator() throws MessagingExceptionGet the separator character.- Specified by:
getSeparatorin classFolder- Returns:
- Hierarchy separator character
- Throws:
FolderNotFoundException- if the implementation requires the folder to exist, but it does notMessagingException
-
getType
public int getType() throws MessagingExceptionGet the type of this folder.- Specified by:
getTypein classFolder- Returns:
- integer with appropriate bits set
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- See Also:
Folder.HOLDS_FOLDERS,Folder.HOLDS_MESSAGES
-
isSubscribed
public boolean isSubscribed()
Check whether this folder is subscribed.- Overrides:
isSubscribedin classFolder- Returns:
- true if this Folder is subscribed
-
setSubscribed
public void setSubscribed(boolean subscribe) throws MessagingExceptionSubscribe/Unsubscribe this folder.- Overrides:
setSubscribedin classFolder- Parameters:
subscribe- true to subscribe, false to unsubscribe- Throws:
FolderNotFoundException- if this folder does not exist.MethodNotSupportedException- if this store does not support subscriptionMessagingException- for other failures
-
create
public boolean create(int type) throws MessagingExceptionCreate this folder, with the specified type.- Specified by:
createin classFolder- Parameters:
type- The type of this folder.- Returns:
- true if the creation succeeds, else false.
- Throws:
MessagingException- for failures- See Also:
Folder.HOLDS_FOLDERS,Folder.HOLDS_MESSAGES,FolderEvent
-
hasNewMessages
public boolean hasNewMessages() throws MessagingExceptionCheck whether this folder has new messages.- Specified by:
hasNewMessagesin classFolder- Returns:
- true if the Store has new Messages
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures
-
getFolder
public Folder getFolder(java.lang.String name) throws MessagingException
Get the named subfolder.- Specified by:
getFolderin classFolder- Parameters:
name- name of the Folder- Returns:
- Folder object
- Throws:
MessagingException- for failures
-
delete
public boolean delete(boolean recurse) throws MessagingExceptionDelete this folder.- Specified by:
deletein classFolder- Parameters:
recurse- also delete subfolders?- Returns:
- true if the Folder is deleted successfully
- Throws:
FolderNotFoundException- if this folder does not existMessagingException- for other failures- See Also:
FolderEvent
-
renameTo
public boolean renameTo(Folder f) throws MessagingException
Rename this folder.- Specified by:
renameToin classFolder- Parameters:
f- a folder representing the new name for this Folder- Returns:
- true if the Folder is renamed successfully
- Throws:
FolderNotFoundException- if this folder does not existMessagingException- for other failures- See Also:
FolderEvent
-
open
public void open(int mode) throws MessagingExceptionOpen this folder in the given mode.- Specified by:
openin classFolder- Parameters:
mode- open the Folder READ_ONLY or READ_WRITE- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures- See Also:
Folder.READ_ONLY,Folder.READ_WRITE,Folder.getType(),ConnectionEvent
-
open
public java.util.List<MailEvent> open(int mode, ResyncData rd) throws MessagingException
Open this folder in the given mode, with the given resynchronization data.- Parameters:
mode- the open mode (Folder.READ_WRITE or Folder.READ_ONLY)rd- the ResyncData instance- Returns:
- a List of MailEvent instances, or null if none
- Throws:
MessagingException- if the open fails- Since:
- JavaMail 1.5.1
-
fetch
public void fetch(Message[] msgs, FetchProfile fp) throws MessagingException
Prefetch attributes, based on the given FetchProfile.- Overrides:
fetchin classFolder- Parameters:
msgs- fetch items for these messagesfp- the FetchProfile- Throws:
MessagingException- for other failures
-
setFlags
public void setFlags(Message[] msgs, Flags flag, boolean value) throws MessagingException
Set the specified flags for the given array of messages.- Overrides:
setFlagsin classFolder- Parameters:
msgs- the array of message objectsflag- Flags object containing the flags to be setvalue- set the flags to this boolean value- Throws:
MessagingException- for other failures- See Also:
Message.setFlags(javax.mail.Flags, boolean),MessageChangedEvent
-
setFlags
public void setFlags(int start, int end, Flags flag, boolean value) throws MessagingExceptionSet the specified flags for the given range of message numbers.- Overrides:
setFlagsin classFolder- Parameters:
start- the number of the first messageend- the number of the last messageflag- Flags object containing the flags to be setvalue- set the flags to this boolean value- Throws:
MessagingException- for other failures- See Also:
Message.setFlags(javax.mail.Flags, boolean),MessageChangedEvent
-
setFlags
public void setFlags(int[] msgnums, Flags flag, boolean value) throws MessagingExceptionSet the specified flags for the given array of message numbers.- Overrides:
setFlagsin classFolder- Parameters:
msgnums- the array of message numbersflag- Flags object containing the flags to be setvalue- set the flags to this boolean value- Throws:
MessagingException- for other failures- See Also:
Message.setFlags(javax.mail.Flags, boolean),MessageChangedEvent
-
close
public void close(boolean expunge) throws MessagingExceptionClose this folder.- Specified by:
closein classFolder- Parameters:
expunge- expunges all deleted messages if this flag is true- Throws:
MessagingException- for other failures- See Also:
ConnectionEvent
-
forceClose
public void forceClose() throws MessagingExceptionClose this folder without waiting for the server.- Throws:
MessagingException- for failures
-
isOpen
public boolean isOpen()
Check whether this connection is really open.
-
getPermanentFlags
public Flags getPermanentFlags()
Return the permanent flags supported by the server.- Specified by:
getPermanentFlagsin classFolder- Returns:
- permanent flags, or null if not known
-
getMessageCount
public int getMessageCount() throws MessagingExceptionGet the total message count.- Specified by:
getMessageCountin classFolder- Returns:
- total number of messages. -1 may be returned by certain implementations if this method is invoked on a closed folder.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures
-
getNewMessageCount
public int getNewMessageCount() throws MessagingExceptionGet the new message count.- Overrides:
getNewMessageCountin classFolder- Returns:
- number of new messages. -1 may be returned by certain implementations if this method is invoked on a closed folder.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures
-
getUnreadMessageCount
public int getUnreadMessageCount() throws MessagingExceptionGet the unread message count.- Overrides:
getUnreadMessageCountin classFolder- Returns:
- total number of unread messages. -1 may be returned by certain implementations if this method is invoked on a closed folder.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures
-
getDeletedMessageCount
public int getDeletedMessageCount() throws MessagingExceptionGet the deleted message count.- Overrides:
getDeletedMessageCountin classFolder- Returns:
- number of deleted messages. -1 may be returned by certain implementations if this method is invoked on a closed folder.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures
-
getMessage
public Message getMessage(int msgnum) throws MessagingException
Get the specified message.- Specified by:
getMessagein classFolder- Parameters:
msgnum- the message number- Returns:
- the Message object
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures- See Also:
Folder.getMessageCount(),Folder.fetch(javax.mail.Message[], javax.mail.FetchProfile)
-
getMessages
public Message[] getMessages() throws MessagingException
Get all Message objects from this Folder. Returns an empty array if the folder is empty. Clients can use Message objects (instead of sequence numbers) as references to the messages within a folder; this method supplies the Message objects to the client. Folder implementations are expected to provide light-weight Message objects, which get filled on demand.This implementation invokes
getMessageCount()to get the current message count and then usesgetMessage()to get Message objects from 1 till the message count.- Overrides:
getMessagesin classFolder- Returns:
- array of Message objects, empty array if folder is empty.
- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- for other failures- See Also:
Folder.fetch(javax.mail.Message[], javax.mail.FetchProfile)
-
appendMessages
public void appendMessages(Message[] msgs) throws MessagingException
Append the given messages into this folder.- Specified by:
appendMessagesin classFolder- Parameters:
msgs- array of Messages to be appended- Throws:
FolderNotFoundException- if this folder does not exist.MessagingException- if the append failed.
-
appendUIDMessages
public AppendUID[] appendUIDMessages(Message[] msgs) throws MessagingException
Append the given messages into this folder. Return array of AppendUID objects containing UIDs of these messages in the destination folder. Each element of the returned array corresponds to an element of themsgsarray. A null element means the server didn't return UID information for the appended message.Depends on the APPENDUID response code defined by the UIDPLUS extension - RFC 4315.
- Parameters:
msgs- the messages to append- Returns:
- array of AppendUID objects
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.4
-
addMessages
public Message[] addMessages(Message[] msgs) throws MessagingException
Append the given messages into this folder. Return array of Message objects representing the messages in the destination folder. Note that the folder must be open. Each element of the returned array corresponds to an element of themsgsarray. A null element means the server didn't return UID information for the appended message.Depends on the APPENDUID response code defined by the UIDPLUS extension - RFC 4315.
- Parameters:
msgs- the messages to add- Returns:
- the messages in this folder
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.4
-
copyMessages
public void copyMessages(Message[] msgs, Folder folder) throws MessagingException
Copy the specified messages from this folder, to the specified destination.- Overrides:
copyMessagesin classFolder- Parameters:
msgs- the array of message objectsfolder- the folder to copy the messages to- Throws:
FolderNotFoundException- if the destination folder does not exist.MessagingException- for other failures- See Also:
Folder.appendMessages(javax.mail.Message[])
-
copyUIDMessages
public AppendUID[] copyUIDMessages(Message[] msgs, Folder folder) throws MessagingException
Copy the specified messages from this folder, to the specified destination. Return array of AppendUID objects containing UIDs of these messages in the destination folder. Each element of the returned array corresponds to an element of themsgsarray. A null element means the server didn't return UID information for the copied message.Depends on the COPYUID response code defined by the UIDPLUS extension - RFC 4315.
- Parameters:
msgs- the messages to copyfolder- the folder to copy the messages to- Returns:
- array of AppendUID objects
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.5.1
-
moveMessages
public void moveMessages(Message[] msgs, Folder folder) throws MessagingException
Move the specified messages from this folder, to the specified destination. Depends on the MOVE extension (RFC 6851).- Parameters:
msgs- the messages to movefolder- the folder to move the messages to- Throws:
MessagingException- for failures- Since:
- JavaMail 1.5.4
-
moveUIDMessages
public AppendUID[] moveUIDMessages(Message[] msgs, Folder folder) throws MessagingException
Move the specified messages from this folder, to the specified destination. Return array of AppendUID objects containing UIDs of these messages in the destination folder. Each element of the returned array corresponds to an element of themsgsarray. A null element means the server didn't return UID information for the moved message.Depends on the MOVE extension (RFC 6851) and the COPYUID response code defined by the UIDPLUS extension (RFC 4315).
- Parameters:
msgs- the messages to movefolder- the folder to move the messages to- Returns:
- array of AppendUID objects
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.5.4
-
expunge
public Message[] expunge() throws MessagingException
Expunge all messages marked as DELETED.- Specified by:
expungein classFolder- Returns:
- array of expunged Message objects
- Throws:
FolderNotFoundException- if this folder does not existMessagingException- for other failures- See Also:
Message.isExpunged(),MessageCountEvent
-
expunge
public Message[] expunge(Message[] msgs) throws MessagingException
Expunge the indicated messages, which must have been marked as DELETED. Depends on the UIDPLUS extension - RFC 4315.- Parameters:
msgs- the messages to expunge- Returns:
- the expunged messages
- Throws:
MessagingException- for failures
-
search
public Message[] search(SearchTerm term) throws MessagingException
Search whole folder for messages matching the given term. If the propertymail.imap.throwsearchexceptionis true, and the search term is too complex for the IMAP protocol, SearchException is thrown. Otherwise, if the search term is too complex,super.searchis called to do the search on the client.- Overrides:
searchin classFolder- Parameters:
term- the search term- Returns:
- the messages that match
- Throws:
SearchException- if mail.imap.throwsearchexception is true and the search is too complex for the IMAP protocolMessagingException- for other failures- See Also:
SearchTerm
-
search
public Message[] search(SearchTerm term, Message[] msgs) throws MessagingException
Search the folder for messages matching the given term. Returns array of matching messages. Returns an empty array if no matching messages are found.- Overrides:
searchin classFolder- Parameters:
term- the search criterionmsgs- the messages to be searched- Returns:
- array of matching messages
- Throws:
SearchException- if the search term is too complex for the implementation to handle.MessagingException- for other failures- See Also:
SearchTerm
-
getSortedMessages
public Message[] getSortedMessages(SortTerm[] term) throws MessagingException
Sort the messages in the folder according to the sort criteria. The messages are returned in the sorted order, but the order of the messages in the folder is not changed.Depends on the SORT extension - RFC 5256.
- Parameters:
term- the SortTerms- Returns:
- the messages in sorted order
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.4.4
-
getSortedMessages
public Message[] getSortedMessages(SortTerm[] term, SearchTerm sterm) throws MessagingException
Sort the messages in the folder according to the sort criteria. The messages are returned in the sorted order, but the order of the messages in the folder is not changed. Only messages matching the search criteria are considered.Depends on the SORT extension - RFC 5256.
- Parameters:
term- the SortTermssterm- the SearchTerm- Returns:
- the messages in sorted order
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.4.4
-
addMessageCountListener
public void addMessageCountListener(MessageCountListener l)
Description copied from class:FolderAdd a listener for MessageCount events on this Folder.The implementation provided here adds this listener to an internal list of MessageCountListeners.
- Overrides:
addMessageCountListenerin classFolder- Parameters:
l- the Listener for MessageCount events- See Also:
MessageCountEvent
-
getUIDValidity
public long getUIDValidity() throws MessagingExceptionReturns the UIDValidity for this folder.- Specified by:
getUIDValidityin interfaceUIDFolder- Returns:
- UIDValidity
- Throws:
MessagingException- for failures
-
getUIDNext
public long getUIDNext() throws MessagingExceptionReturns the predicted UID that will be assigned to the next message that is appended to this folder. If the folder is closed, the STATUS command is used to retrieve this value. If the folder is open, the value returned from the SELECT or EXAMINE command is returned. Note that messages may have been appended to the folder while it was open and thus this value may be out of date.Servers implementing RFC2060 likely won't return this value when a folder is opened. Servers implementing RFC3501 should return this value when a folder is opened.
- Specified by:
getUIDNextin interfaceUIDFolder- Returns:
- the UIDNEXT value, or -1 if unknown
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.3.3
-
getMessageByUID
public Message getMessageByUID(long uid) throws MessagingException
Get the Message corresponding to the given UID. If no such message exists,nullis returned.- Specified by:
getMessageByUIDin interfaceUIDFolder- Parameters:
uid- UID for the desired message- Returns:
- the Message object.
nullis returned if no message corresponding to this UID is obtained. - Throws:
MessagingException- for failures
-
getMessagesByUID
public Message[] getMessagesByUID(long start, long end) throws MessagingException
Get the Messages specified by the given range.Returns Message objects for all valid messages in this range. Returns an empty array if no messages are found.
- Specified by:
getMessagesByUIDin interfaceUIDFolder- Parameters:
start- start UIDend- end UID- Returns:
- array of Message objects
- Throws:
MessagingException- for failures- See Also:
UIDFolder.LASTUID
-
getMessagesByUID
public Message[] getMessagesByUID(long[] uids) throws MessagingException
Get the Messages specified by the given array.uids.length()elements are returned. If any UID in the array is invalid, anullentry is returned for that element.- Specified by:
getMessagesByUIDin interfaceUIDFolder- Parameters:
uids- array of UIDs- Returns:
- array of Message objects
- Throws:
MessagingException- for failures
-
getUID
public long getUID(Message message) throws MessagingException
Get the UID for the specified message.- Specified by:
getUIDin interfaceUIDFolder- Parameters:
message- Message from this folder- Returns:
- UID for this message
- Throws:
MessagingException- for other failures
-
getUIDNotSticky
public boolean getUIDNotSticky() throws MessagingExceptionServers that support the UIDPLUS extension (RFC 4315) may indicate that this folder does not support persistent UIDs; that is, UIDVALIDITY will be different each time the folder is opened. Only valid when the folder is open.- Returns:
- true if UIDs are not sticky
- Throws:
MessagingException- for failuresjava.lang.IllegalStateException- if the folder isn't open- Since:
- JavaMail 1.6.0
- See Also:
- "RFC 4315"
-
getHighestModSeq
public long getHighestModSeq() throws MessagingExceptionReturns the HIGHESTMODSEQ for this folder.- Returns:
- the HIGHESTMODSEQ value
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.5.1
- See Also:
- "RFC 4551"
-
getMessagesByUIDChangedSince
public Message[] getMessagesByUIDChangedSince(long start, long end, long modseq) throws MessagingException
Get the messages that have been changed since the given MODSEQ value. Also, prefetch the flags for the messages.The server must support the CONDSTORE extension.
- Parameters:
start- the first message numberend- the last message numbermodseq- the MODSEQ value- Returns:
- the changed messages
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.5.1
- See Also:
- "RFC 4551"
-
getQuota
public Quota[] getQuota() throws MessagingException
Get the quotas for the quotaroot associated with this folder. Note that many folders may have the same quotaroot. Quotas are controlled on the basis of a quotaroot, not (necessarily) a folder. The relationship between folders and quotaroots depends on the IMAP server. Some servers might implement a single quotaroot for all folders owned by a user. Other servers might implement a separate quotaroot for each folder. A single folder can even have multiple quotaroots, perhaps controlling quotas for different resources.- Returns:
- array of Quota objects for the quotaroots associated with this folder
- Throws:
MessagingException- if the server doesn't support the QUOTA extension
-
setQuota
public void setQuota(Quota quota) throws MessagingException
Set the quotas for the quotaroot specified in the quota argument. Typically this will be one of the quotaroots associated with this folder, as obtained from thegetQuotamethod, but it need not be.- Parameters:
quota- the quota to set- Throws:
MessagingException- if the server doesn't support the QUOTA extension
-
getACL
public ACL[] getACL() throws MessagingException
Get the access control list entries for this folder.- Returns:
- array of access control list entries
- Throws:
MessagingException- if the server doesn't support the ACL extension
-
addACL
public void addACL(ACL acl) throws MessagingException
Add an access control list entry to the access control list for this folder.- Parameters:
acl- the access control list entry to add- Throws:
MessagingException- if the server doesn't support the ACL extension
-
removeACL
public void removeACL(java.lang.String name) throws MessagingExceptionRemove any access control list entry for the given identifier from the access control list for this folder.- Parameters:
name- the identifier for which to remove all ACL entries- Throws:
MessagingException- if the server doesn't support the ACL extension
-
addRights
public void addRights(ACL acl) throws MessagingException
Add the rights specified in the ACL to the entry for the identifier specified in the ACL. If an entry for the identifier doesn't already exist, add one.- Parameters:
acl- the identifer and rights to add- Throws:
MessagingException- if the server doesn't support the ACL extension
-
removeRights
public void removeRights(ACL acl) throws MessagingException
Remove the rights specified in the ACL from the entry for the identifier specified in the ACL.- Parameters:
acl- the identifer and rights to remove- Throws:
MessagingException- if the server doesn't support the ACL extension
-
listRights
public Rights[] listRights(java.lang.String name) throws MessagingException
Get all the rights that may be allowed to the given identifier. Rights are grouped per RFC 2086 and each group is returned as an element of the array. The first element of the array is the set of rights that are always granted to the identifier. Later elements are rights that may be optionally granted to the identifier.Note that this method lists the rights that it is possible to assign to the given identifier, not the rights that are actually granted to the given identifier. For the latter, see the
getACLmethod.- Parameters:
name- the identifier to list rights for- Returns:
- array of Rights objects representing possible rights for the identifier
- Throws:
MessagingException- if the server doesn't support the ACL extension
-
myRights
public Rights myRights() throws MessagingException
Get the rights allowed to the currently authenticated user.- Returns:
- the rights granted to the current user
- Throws:
MessagingException- if the server doesn't support the ACL extension
-
getAttributes
public java.lang.String[] getAttributes() throws MessagingExceptionGet the attributes that the IMAP server returns with the LIST response.- Returns:
- array of attributes for this folder
- Throws:
MessagingException- for failures- Since:
- JavaMail 1.3.3
-
idle
public void idle() throws MessagingExceptionUse the IMAP IDLE command (see RFC 2177), if supported by the server, to enter idle mode so that the server can send unsolicited notifications of new messages arriving, etc. without the need for the client to constantly poll the server. Use an appropriate listener to be notified of new messages or other events. When another thread (e.g., the listener thread) needs to issue an IMAP comand for this folder, the idle mode will be terminated and this method will return. Typically the caller will invoke this method in a loop.The mail.imap.minidletime property enforces a minimum delay before returning from this method, to ensure that other threads have a chance to issue commands before the caller invokes this method again. The default delay is 10 milliseconds.
- Throws:
MessagingException- if the server doesn't support the IDLE extensionjava.lang.IllegalStateException- if the folder isn't open- Since:
- JavaMail 1.4.1
-
idle
public void idle(boolean once) throws MessagingExceptionLikeidle(), but ifonceis true, abort the IDLE command after the first notification, to allow the caller to process any notification synchronously.- Parameters:
once- only do one notification?- Throws:
MessagingException- if the server doesn't support the IDLE extensionjava.lang.IllegalStateException- if the folder isn't open- Since:
- JavaMail 1.4.3
-
id
public java.util.Map<java.lang.String,java.lang.String> id(java.util.Map<java.lang.String,java.lang.String> clientParams) throws MessagingExceptionSend the IMAP ID command (if supported by the server) and return the result from the server. The ID command identfies the client to the server and returns information about the server to the client. See RFC 2971. The returned Map is unmodifiable.- Parameters:
clientParams- a Map of keys and values identifying the client- Returns:
- a Map of keys and values identifying the server
- Throws:
MessagingException- if the server doesn't support the ID extension- Since:
- JavaMail 1.5.1
-
getStatusItem
public long getStatusItem(java.lang.String item) throws MessagingExceptionUse the IMAP STATUS command to get the indicated item. The STATUS item may be a standard item such as "RECENT" or "UNSEEN", or may be a server-specific item. The folder must be closed. If the item is not found, or the folder is open, -1 is returned.- Parameters:
item- the STATUS item to fetch- Returns:
- the value of the STATUS item, or -1
- Throws:
MessagingException- for errors- Since:
- JavaMail 1.5.2
-
handleResponse
public void handleResponse(Response r)
The response handler. This is the callback routine that is invoked by the protocol layer.- Specified by:
handleResponsein interfaceResponseHandler
-
doCommand
public java.lang.Object doCommand(IMAPFolder.ProtocolCommand cmd) throws MessagingException
Execute a user-supplied IMAP command. The command is executed in the appropriate context with the necessary locks held and using the appropriateIMAPProtocolobject.This method returns whatever the
ProtocolCommandobject'sdoCommandmethod returns. If thedoCommandmethod throws aConnectionExceptionit is translated into aStoreClosedExceptionorFolderClosedExceptionas appropriate. If thedoCommandmethod throws aProtocolExceptionit is translated into aMessagingException.The following example shows how to execute the IMAP NOOP command. Executing more complex IMAP commands requires intimate knowledge of the
com.sun.mail.iapandcom.sun.mail.imap.protocolpackages, best acquired by reading the source code.import com.sun.mail.iap.*; import com.sun.mail.imap.*; import com.sun.mail.imap.protocol.*; ... IMAPFolder f = (IMAPFolder)folder; Object val = f.doCommand(new IMAPFolder.ProtocolCommand() { public Object doCommand(IMAPProtocol p) throws ProtocolException { p.simpleCommand("NOOP", null); return null; } });Here's a more complex example showing how to use the proposed IMAP SORT extension:
import com.sun.mail.iap.*; import com.sun.mail.imap.*; import com.sun.mail.imap.protocol.*; ... IMAPFolder f = (IMAPFolder)folder; Object val = f.doCommand(new IMAPFolder.ProtocolCommand() { public Object doCommand(IMAPProtocol p) throws ProtocolException { // Issue command Argument args = new Argument(); Argument list = new Argument(); list.writeString("SUBJECT"); args.writeArgument(list); args.writeString("UTF-8"); args.writeString("ALL"); Response[] r = p.command("SORT", args); Response response = r[r.length-1]; // Grab response Vector v = new Vector(); if (response.isOK()) { // command succesful for (int i = 0, len = r.length; i < len; i++) { if (!(r[i] instanceof IMAPResponse)) continue; IMAPResponse ir = (IMAPResponse)r[i]; if (ir.keyEquals("SORT")) { String num; while ((num = ir.readAtomString()) != null) System.out.println(num); r[i] = null; } } } // dispatch remaining untagged responses p.notifyResponseHandlers(r); p.handleResult(response); return null; } });- Parameters:
cmd- the protocol command- Returns:
- the result of the command
- Throws:
MessagingException- for failures
-
doOptionalCommand
public java.lang.Object doOptionalCommand(java.lang.String err, IMAPFolder.ProtocolCommand cmd) throws MessagingException- Throws:
MessagingException
-
doCommandIgnoreFailure
public java.lang.Object doCommandIgnoreFailure(IMAPFolder.ProtocolCommand cmd) throws MessagingException
- Throws:
MessagingException
-
-