Class Store
- All Implemented Interfaces:
AutoCloseable
Note that Store
extends the Service
class, which provides many common methods for naming stores,
connecting to stores, and listening to connection events.
- Author:
- John Mani, Bill Shannon
- See Also:
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
Add a listener for Folder events on any Folder object obtained from this Store.void
Add a listener for StoreEvents on this Store.abstract Folder
Returns a Folder object that represents the 'root' of the default namespace presented to the user by the Store.abstract Folder
Return a closed Folder object, corresponding to the given URLName.abstract Folder
Return the Folder object corresponding to the given name.Folder[]
Return a set of folders representing the personal namespaces for the current user.Folder[]
Return a set of folders representing the shared namespaces.Folder[]
getUserNamespaces
(String user) Return a set of folders representing the namespaces foruser
.protected void
notifyFolderListeners
(int type, Folder folder) Notify all FolderListeners.protected void
notifyFolderRenamedListeners
(Folder oldF, Folder newF) Notify all FolderListeners about the renaming of a folder.protected void
notifyStoreListeners
(int type, String message) Notify all StoreListeners.void
Remove a listener for Folder events.void
Remove a listener for Store events.Methods inherited from class jakarta.mail.Service
addConnectionListener, close, connect, connect, connect, connect, finalize, getURLName, isConnected, notifyConnectionListeners, protocolConnect, queueEvent, removeConnectionListener, setConnected, setURLName, toString
-
Constructor Details
-
Store
Constructor.- Parameters:
session
- Session object for this Store.urlname
- URLName object to be used for this Store
-
-
Method Details
-
getDefaultFolder
Returns a Folder object that represents the 'root' of the default namespace presented to the user by the Store.- Returns:
- the root Folder
- Throws:
IllegalStateException
- if this Store is not connected.MessagingException
- for other failures
-
getFolder
Return the Folder object corresponding to the given name. Note that a Folder object is returned even if the named folder does not physically exist on the Store. Theexists()
method on the folder object indicates whether this folder really exists.Folder objects are not cached by the Store, so invoking this method on the same name multiple times will return that many distinct Folder objects.
- Parameters:
name
- The name of the Folder. In some Stores, name can be an absolute path if it starts with the hierarchy delimiter. Else it is interpreted relative to the 'root' of this namespace.- Returns:
- Folder object
- Throws:
IllegalStateException
- if this Store is not connected.MessagingException
- for other failures- See Also:
-
getFolder
Return a closed Folder object, corresponding to the given URLName. The store specified in the given URLName should refer to this Store object.Implementations of this method may obtain the name of the actual folder using the
getFile()
method on URLName, and use that name to create the folder.- Parameters:
url
- URLName that denotes a folder- Returns:
- Folder object
- Throws:
IllegalStateException
- if this Store is not connected.MessagingException
- for other failures- See Also:
-
getPersonalNamespaces
Return a set of folders representing the personal namespaces for the current user. A personal namespace is a set of names that is considered within the personal scope of the authenticated user. Typically, only the authenticated user has access to mail folders in their personal namespace. If an INBOX exists for a user, it must appear within the user's personal namespace. In the typical case, there should be only one personal namespace for each user in each Store.This implementation returns an array with a single entry containing the return value of the
getDefaultFolder
method. Subclasses should override this method to return appropriate information.- Returns:
- array of Folder objects
- Throws:
IllegalStateException
- if this Store is not connected.MessagingException
- for other failures- Since:
- JavaMail 1.2
-
getUserNamespaces
Return a set of folders representing the namespaces foruser
. The namespaces returned represent the personal namespaces for the user. To access mail folders in the other user's namespace, the currently authenticated user must be explicitly granted access rights. For example, it is common for a manager to grant to their secretary access rights to their mail folders.This implementation returns an empty array. Subclasses should override this method to return appropriate information.
- Parameters:
user
- the user name- Returns:
- array of Folder objects
- Throws:
IllegalStateException
- if this Store is not connected.MessagingException
- for other failures- Since:
- JavaMail 1.2
-
addStoreListener
Add a listener for StoreEvents on this Store.The default implementation provided here adds this listener to an internal list of StoreListeners.
- Parameters:
l
- the Listener for Store events- See Also:
-
removeStoreListener
Remove a listener for Store events.The default implementation provided here removes this listener from the internal list of StoreListeners.
- Parameters:
l
- the listener- See Also:
-
notifyStoreListeners
Notify all StoreListeners. Store implementations are expected to use this method to broadcast StoreEvents.The provided default implementation queues the event into an internal event queue. An event dispatcher thread dequeues events from the queue and dispatches them to the registered StoreListeners. Note that the event dispatching occurs in a separate thread, thus avoiding potential deadlock problems.
- Parameters:
type
- the StoreEvent typemessage
- a message for the StoreEvent
-
addFolderListener
Add a listener for Folder events on any Folder object obtained from this Store. FolderEvents are delivered to FolderListeners on the affected Folder as well as to FolderListeners on the containing Store.The default implementation provided here adds this listener to an internal list of FolderListeners.
- Parameters:
l
- the Listener for Folder events- See Also:
-
removeFolderListener
Remove a listener for Folder events.The default implementation provided here removes this listener from the internal list of FolderListeners.
- Parameters:
l
- the listener- See Also:
-
notifyFolderListeners
Notify all FolderListeners. Store implementations are expected to use this method to broadcast Folder events.The provided default implementation queues the event into an internal event queue. An event dispatcher thread dequeues events from the queue and dispatches them to the registered FolderListeners. Note that the event dispatching occurs in a separate thread, thus avoiding potential deadlock problems.
- Parameters:
type
- type of FolderEventfolder
- affected Folder- See Also:
-
notifyFolderRenamedListeners
Notify all FolderListeners about the renaming of a folder. Store implementations are expected to use this method to broadcast Folder events indicating the renaming of folders.The provided default implementation queues the event into an internal event queue. An event dispatcher thread dequeues events from the queue and dispatches them to the registered FolderListeners. Note that the event dispatching occurs in a separate thread, thus avoiding potential deadlock problems.
- Parameters:
oldF
- the folder being renamednewF
- the folder representing the new name.- Since:
- JavaMail 1.1
-