Package com.icegreen.greenmail.store
Interface Store
- All Known Implementing Classes:
InMemoryStore
public interface Store
Represents the complete mail store for an IMAP server, providing access to
and manipulation of all
Mailboxes stored on this server.- Version:
- $Revision: 109034 $
- Author:
- Darrell DeBoer <darrell@apache.org>
-
Method Summary
Modifier and TypeMethodDescriptioncreateMailbox(MailFolder parent, String mailboxName, boolean selectable) Creates a mailbox under the supplied parent with the given name.voiddeleteMailbox(MailFolder folder) Deletes the supplied mailbox from the store.voiddeleteQuota(String qualifiedRootPrefix) Deletes the quota.getChildren(MailFolder parent) getMailbox(MailFolder parent, String mailboxName) Looks up a child mailbox of the supplied parent with the name given.getMailbox(String qualifiedMailboxName) Retrieves a mailbox based on a fully qualified name.jakarta.mail.Quota[]Gets the quotas.booleanChecks if quota capability is activated.listMailboxes(String searchPattern) Lists all the mailboxes in the store which have a name matching the supplied search pattern.voidrenameMailbox(MailFolder existingFolder, String newName) Renames the mailbox with the new name.voidSets the quota.voidsetQuotaSupported(boolean pQuotaSupported) Toggles quota capability.setSelectable(MailFolder folder, boolean selectable) Tells the store to make the supplied mailbox selectable or not (able to store messages).
-
Method Details
-
getMailbox
Retrieves a mailbox based on a fully qualified name.- Parameters:
qualifiedMailboxName- the fully qualified name.- Returns:
- The mailbox if present, or
nullif not.
-
getMailbox
Looks up a child mailbox of the supplied parent with the name given.- Parameters:
parent- The parent mailboxmailboxName- The name of the child to lookup- Returns:
- The child mailbox, or
nullif not found.
-
getChildren
- Parameters:
parent- A mailbox from this store.- Returns:
- A read-only collection of
MailFolderinstances, which are the children of the supplied parent.
-
createMailbox
MailFolder createMailbox(MailFolder parent, String mailboxName, boolean selectable) throws FolderException Creates a mailbox under the supplied parent with the given name. If specified, the mailbox created will be made selectable (able to store messages).- Parameters:
parent- A mailbox from this store.mailboxName- The name of the mailbox to create.selectable- Iftrue, the mailbox will be created to store messages.- Returns:
- The created mailbox
- Throws:
FolderException- If the mailbox couldn't be created.
-
setSelectable
Tells the store to make the supplied mailbox selectable or not (able to store messages). The returned mailbox may be a new instance, and the supplied mailbox may no longer be valid.- Parameters:
folder- The mailbox to modify.selectable- Whether this mailbox should be able to store messages.- Returns:
- The modified mailbox
-
deleteMailbox
Deletes the supplied mailbox from the store. To be deleted, mailboxes must be empty of messages, and not have any children.- Parameters:
folder- A mailbox from this store.- Throws:
FolderException- If the mailbox couldn't be deleted.
-
renameMailbox
Renames the mailbox with the new name.- Parameters:
existingFolder- A mailbox from this store.newName- The new name for the mailbox.- Throws:
FolderException- If the mailbox couldn't be renamed
-
listMailboxes
Lists all the mailboxes in the store which have a name matching the supplied search pattern.Valid wildcards are:
- '*' - matches any number of characters, including the hierarchy delimiter
- '%' - matches any number of characters, but not the hierarchy delimiter
- Parameters:
searchPattern- The pattern to match mailboxes- Returns:
- A read-only collection of mailboxes which match this pattern
- Throws:
FolderException- If the list operation failed
-
getQuota
Gets the quotas. See rfc2087- Parameters:
root- the quota rootqualifiedRootPrefix- the user specific prefix- Returns:
- the quotas, or an empty array.
- See Also:
-
IMAPStore.getQuota(String)
-
setQuota
Sets the quota. See rfc2087- Parameters:
quota- the quota.qualifiedRootPrefix- the user specific prefix- See Also:
-
IMAPStore.setQuota(jakarta.mail.Quota)
-
deleteQuota
Deletes the quota.- Parameters:
qualifiedRootPrefix- the user specific prefix
-
isQuotaSupported
boolean isQuotaSupported()Checks if quota capability is activated.- Returns:
- true, if quota is supported.
-
setQuotaSupported
void setQuotaSupported(boolean pQuotaSupported) Toggles quota capability.- Parameters:
pQuotaSupported- true, if supported.
-