- java.lang.Object
-
- jakarta.mail.Folder
-
- com.sun.mail.imap.IMAPFolder
-
- com.sun.mail.imap.DefaultFolder
-
- All Implemented Interfaces:
ResponseHandler
,UIDFolder
,java.lang.AutoCloseable
public class DefaultFolder extends IMAPFolder
The default IMAP folder (root of the naming hierarchy).- Author:
- John Mani
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class com.sun.mail.imap.IMAPFolder
IMAPFolder.FetchProfileItem, IMAPFolder.ProtocolCommand
-
-
Field Summary
-
Fields inherited from class com.sun.mail.imap.IMAPFolder
attributes, availableFlags, exists, fullName, isNamespace, logger, messageCache, messageCacheLock, name, permanentFlags, protocol, separator, type, uidTable, UNKNOWN_SEPARATOR
-
Fields inherited from class jakarta.mail.Folder
HOLDS_FOLDERS, HOLDS_MESSAGES, mode, READ_ONLY, READ_WRITE, store
-
-
Constructor Summary
Constructors Modifier Constructor Description protected
DefaultFolder(IMAPStore store)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
appendMessages(Message[] msgs)
Append the given messages into this folder.boolean
delete(boolean recurse)
Delete this folder.Message[]
expunge()
Expunge all messages marked as DELETED.Folder
getFolder(java.lang.String name)
Get the named subfolder.java.lang.String
getName()
Get the name of this folder.Folder
getParent()
Get this folder's parent.boolean
hasNewMessages()
Check whether this folder has new messages.Folder[]
list(java.lang.String pattern)
List all subfolders matching the specified pattern.Folder[]
listSubscribed(java.lang.String pattern)
List all subscribed subfolders matching the specified pattern.boolean
renameTo(Folder f)
Rename this folder.-
Methods inherited from class com.sun.mail.imap.IMAPFolder
addACL, addMessageCountListener, addMessages, addRights, appendUIDMessages, checkClosed, checkExists, checkOpened, checkRange, close, copyMessages, copyUIDMessages, create, doCommand, doCommandIgnoreFailure, doOptionalCommand, doProtocolCommand, exists, expunge, fetch, forceClose, getACL, getAttributes, getDeletedMessageCount, getEnvelopeCommand, getFullName, getHighestModSeq, getMessage, getMessageBySeqNumber, getMessageByUID, getMessageCount, getMessages, getMessagesBySeqNumbers, getMessagesByUID, getMessagesByUID, getMessagesByUIDChangedSince, getNewMessageCount, getPermanentFlags, getProtocol, getQuota, getSeparator, getSortedMessages, getSortedMessages, getStatusItem, getStoreProtocol, getType, getUID, getUIDNext, getUIDNotSticky, getUIDValidity, getUnreadMessageCount, handleResponse, id, idle, idle, isOpen, isSubscribed, keepConnectionAlive, listRights, moveMessages, moveUIDMessages, myRights, newIMAPMessage, open, open, releaseProtocol, releaseStoreProtocol, removeACL, removeRights, search, search, setFlags, setFlags, setFlags, setQuota, setSubscribed, throwClosedException
-
Methods inherited from class jakarta.mail.Folder
addConnectionListener, addFolderListener, addMessageChangedListener, close, finalize, getMessages, getMessages, getMode, getStore, getURLName, list, listSubscribed, notifyConnectionListeners, notifyFolderListeners, notifyFolderRenamedListeners, notifyMessageAddedListeners, notifyMessageChangedListeners, notifyMessageRemovedListeners, removeConnectionListener, removeFolderListener, removeMessageChangedListener, removeMessageCountListener, toString
-
-
-
-
Constructor Detail
-
DefaultFolder
protected DefaultFolder(IMAPStore store)
-
-
Method Detail
-
getName
public java.lang.String getName()
Description copied from class:IMAPFolder
Get the name of this folder.- Overrides:
getName
in classIMAPFolder
- Returns:
- name of the Folder
-
getParent
public Folder getParent()
Description copied from class:IMAPFolder
Get this folder's parent.- Overrides:
getParent
in classIMAPFolder
- Returns:
- Parent folder
-
list
public Folder[] list(java.lang.String pattern) throws MessagingException
Description copied from class:IMAPFolder
List all subfolders matching the specified pattern.- Overrides:
list
in classIMAPFolder
- 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
Description copied from class:IMAPFolder
List all subscribed subfolders matching the specified pattern.- Overrides:
listSubscribed
in classIMAPFolder
- 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)
-
hasNewMessages
public boolean hasNewMessages() throws MessagingException
Description copied from class:IMAPFolder
Check whether this folder has new messages.- Overrides:
hasNewMessages
in classIMAPFolder
- 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
Description copied from class:IMAPFolder
Get the named subfolder.- Overrides:
getFolder
in classIMAPFolder
- Parameters:
name
- name of the Folder- Returns:
- Folder object
- Throws:
MessagingException
- for failures
-
delete
public boolean delete(boolean recurse) throws MessagingException
Description copied from class:IMAPFolder
Delete this folder.- Overrides:
delete
in classIMAPFolder
- 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
Description copied from class:IMAPFolder
Rename this folder.- Overrides:
renameTo
in classIMAPFolder
- 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
-
appendMessages
public void appendMessages(Message[] msgs) throws MessagingException
Description copied from class:IMAPFolder
Append the given messages into this folder.- Overrides:
appendMessages
in classIMAPFolder
- Parameters:
msgs
- array of Messages to be appended- Throws:
FolderNotFoundException
- if this folder does not exist.MessagingException
- if the append failed.
-
expunge
public Message[] expunge() throws MessagingException
Description copied from class:IMAPFolder
Expunge all messages marked as DELETED.- Overrides:
expunge
in classIMAPFolder
- Returns:
- array of expunged Message objects
- Throws:
FolderNotFoundException
- if this folder does not existMessagingException
- for other failures- See Also:
Message.isExpunged()
,MessageCountEvent
-
-