Payara Server includes the Jakarta Mail API along with Jakarta Mail service providers that allow an application component to send email notifications over the Internet and to read email from IMAP and POP3 mail servers.
Instructions for accomplishing the tasks in this chapter by using the Administration Console are contained in the Administration Console online help.
About Jakarta Mail
The Jakarta Mail API is a set of abstract APIs that model a mail system. The Jakarta Mail API provides a platform-independent and protocol-independent framework to build mail and messaging applications and provide facilities for reading and sending electronic messages. Service providers implement particular protocols.
Using the API you can add email capabilities to your applications. Jakarta Mail provides access from Java applications to Internet Message Access Protocol (IMAP) and Simple Mail Transfer Protocol (SMTP) capable mail servers on your network or the Internet.
| The API does not provide mail server functionality; you must have access to a mail server to use Jakarta Mail. | 
The Jakarta Mail API is implemented as an optional package in the Jakarta platform and is also available as part of the Jakarta EE platform.
To learn more about the Jakarta Mail API, consult the Jakarta Mail specification.
Administering Jakarta Mail Resources
When you create a mail session, the server-side components and applications are enabled to access Jakarta Mail services with JNDI, using the session properties you assign for them. When creating a mail session, you can designate the mail hosts, the transport and store protocols, and the default mail user so that components that use Jakarta Mail do not have to set these properties. Applications that are heavy email users benefit because Payara Server creates a single session object and makes the session available to any component that needs it.
| Jakarta Mail settings | Description | 
|---|---|
| JNDI Name | The unique name for the mail session. Use the naming sub-context prefix mail/ for Jakarta Mail resources. For example:  | 
| Mail Host | The host name of the default mail server. The connect methods of the store and transport objects use this value if a protocol-specific host property is not supplied. + The name must be resolvable to an actual host name. | 
| Default User | The default username to provide when connecting to a mail server. The connect methods of the store and transport objects use this value if a protocol-specific username property is not supplied. | 
| Default Return Address | The email address of the default user, in the form:  | 
| Description | A descriptive statement for the component. | 
| Session | Indicates whether the mail session is enabled or disabled at this time | 
To Create a Jakarta Mail Resource
Use the create-javamail-resource subcommand in remote mode to create a Jakarta Mail session resource. The JNDI name for a Jakarta Mail session resource customarily includes the mail/ naming subcontext, For example: mail/MyMailSession.
- 
Ensure that the server is running. Remote subcommands require a running server. 
- 
Create a Jakarta Mail resource by using the create-javamail-resourcesubcommand. Information about the properties for the subcommand is included in this help page.
- 
To apply your changes, restart Payara Server. See To Restart a Domain. 
Example - Creating a Jakarta Mail Resource
asadmin> create-javamail-resource --mailhost localhost
--mailuser sample --fromaddress sample\@sun\.com mail/MyMailSession
Command create-javamail-resource executed successfully.This example creates a Jakarta Mail resource named mail/MyMailSession. The escape character (\) is used in the --fromaddress option to distinguish the dot (.) and at sign (@).
To List JavaMail Resources
Use the list-javamail-resources subcommand in remote mode to list the existing JavaMail session resources.
- 
Ensure that the server is running. Remote subcommands require a running server. 
- 
List the Jakarta Mail resources by using the list-javamail-resourcessubcommand.
To Update a Jakarta Mail Resource
- 
List the Jakarta Mail resources by using the list-javamail-resourcessubcommand.
- 
Modify the values for the specified Jakarta Mail source by using the setsubcommand. The resource is identified by its dotted name.
To Delete a Jakarta Mail Resource
Use the delete-javamail-resource subcommands in remote mode to delete a Jakarta Mail session resource.
References to the specified resource must be removed before running the delete-javamail-resource subcommands.
- 
Ensure that the server is running. Remote subcommands require a running server. 
- 
List the Jakarta Mail resources by using the list-javamail-resourcessubcommands.
- 
Delete a Jakarta Mail resource by using the delete-javamail-resourcesubcommands.
- 
To apply your changes, restart Payara Server. To Restart a Domain. 
Configure a Jakarta Mail session from the Admin Console
Jakarta Mail sessions are added from the Resources tab on the left pane of the Admin Console.
Select New on the Sessions table to create a new Jakarta Mail session:

Emails will be sent with a return address of example@example.com, using SMTP to send mail and IMAP to retrieve mail. With the current implementation of the Jakarta Mail API there is no alternative transport protocol provided by default, though as an alternative to the default store protocol of imap, pop3 is available.
Typically, when setting up SMTP access, three additional properties must be specified in the Additional Properties table: enabling startTLS, enabling authentication, and the password.
These allow for extra security when sending emails and will not always be required - check with your email provider for their specific configuration.
The example below shows the configuration of a mail host:
