NOTE: This project is a fork since the original project no longer maintained.
Lutung - a Java interface to the Mandrill API. Check out Mandrill's API [Documentation] (https://mandrillapp.com/api/docs/) to see all the possible magic.
Features:
- all public API calls are implemented.
- easy library set up; just provide your api key that you got from Mandrill.
- all API calls are exposed through one simple interface: the MandrillApi class.
- easy, intuitive naming scheme. All function-names are derived from the Mandrill API calls: if there is a call with the address '/messages/send.json', then we have a function for that called 'MandrillApi.messages().send(...)'.
- API request errors are exposed to the user (you!) as a MandrillApiError.
If you're using Maven, just add this dependency to your pom.xml:
<dependency>
<groupId>io.github.dnovitski</groupId>
<artifactId>lutung</artifactId>
<version>0.0.13</version>
</dependency>
If you're not using Maven, see Dependencies below.
The 'whoami' of Mandrill:
MandrillApi mandrillApi = new MandrillApi("<put ur Mandrill API key here>");
MandrillUserInfo user = mandrillApi.users().info();
// pretty-print w/ gson
Gson gson = new GsonBuilder().setPrettyPrinting().create();
System.out.println(gson.toJson(user));
Send a 'Hello World!' email
MandrillApi mandrillApi = new MandrillApi("<put ur Mandrill API key here>");
// create your message
MandrillMessage message = new MandrillMessage();
message.setSubject("Hello World!");
message.setHtml("<h1>Hi pal!</h1><br />Really, I'm just saying hi!");
message.setAutoText(true);
message.setFromEmail("[email protected]");
message.setFromName("Kitty Katz");
// add recipients
List<Recipient> recipients = new ArrayList<>();
Recipient recipient = new Recipient();
recipient.setEmail("[email protected]");
recipient.setName("Claire Annette");
recipients.add(recipient);
Recipient recipient2 = new Recipient();
recipient2.setEmail("[email protected]");
recipients.add(recipient2);
message.setTo(recipients);
message.setPreserveRecipients(true);
List<String> tags = new ArrayList<>();
tags.add("test");
tags.add("helloworld");
message.setTags(tags);
// ... add more message details if you want to!
// then ... send
MandrillMessageStatus[] messageStatusReports = mandrillApi
.messages().send(message, false);
Error handling for Mandrill API errors
MandrillApi mandrillApi = new MandrillApi("<put ur Mandrill API key here>");
try {
MandrillUserInfo user = mandrillApi.users().info();
} catch(MandrillApiError e) {
log.error(e.getMandrillErrorAsJson(), e);
}
Create a new template
MandrillApi mandrillApi = new MandrillApi("<put ur Mandrill API key here>");
MandrillTemplate newTemplate = mandrillApi.templates().add(
"test_template_001",
"<html><body><h1>Hello World!</h1></body></html>",
false);
If you're not using Maven, here's a list of dependencies. Just make sure these jar files are on your classpath:
-
The metadata returned by the mandrill api on /messages/search.json does not get mapped to a member of MandrillMessageInfo
-
So far, I failed to successfully use Mandrills /messages/send-raw.json call. I'm not sure if I fail to create valid MIME contents, but lemme know if you make any experience with this call.
-
Also, I have no inbound-emailing set up with Mandrill. Would be great if anyone out there could test the implemented 'inbound' functionalities.
A monkey!!! The Javan Lutung is the name giver for this project; hat tip to MailChimp's naming scheme.
This library is released under the GNU Lesser General Public License http://www.gnu.org/licenses/lgpl.html.
- Bumped dependency versions of everything to more recent versions
- Removed wrapper around commons logger
- Clean up
- Java 8 is now minimum version (instead of 1.6)
- commons-io updated from 2.5 to 2.7
- Add support for configurable client timeouts. These can be configured via Java system properties (eg passing
-Dxxx=yyy
to the JVM args):mandrill.socket.timeout
(socket timeout in millis, default5000
)mandrill.connection.timeout
(connection timeout in millis, default5000
)mandrill.socket.linger.timeout
(socket linger timeout in seconds, default0
)
- Default timeouts have been changed from no timeout to a more sensible default timeout described above to prevent the HTTP client from blocking indefinitely
- Fixed CVE CVE-2020-13956
- Forked project under new groupid: io.github.dnovitski
- Fixed NPE in httpClient.getParams due to modern httpclient
- Prevent NPE if response does not exist in MandrillRequestDispatcher.java
-
Fixed thread safety issue with
SimpleDateFormat
, create a new one each time. look thanks chrisburrell -
Added additional fields to smtp data look thanks lvogelzang
-
Make the root URL configurable look
- Fixed custom_quota field in the submarkets API look thanks Lokesh-Github123
- Re-enabled headers on MandrillMessageContent look
- Re-enabled metadata on MandrillMessageInfo look
- Catch Json parsing exceptions and throw a MandrillError with the body of the response as the message look
- Support to specify the merge-language when using templates, look
- Fixing endpoint URI for 'parse', look
- Better Android compatibility, look
- Added lables for templates, look
Thanks billoneil
- Added messages/content.json (thanks @benfastmodel)
- Now regarding JVM proxy parameters (thanks @joseanibl138)
- Made commons-logging dependency optional (thanks @aldenquimby)
- Added support for Mandrill sub accounts in MandrillApi.subaccounts.
- More support for rejects (blacklists): add and delete; also, list rejects for sub accounts.
- Added support for whitelists in MandrillApi.whitelists.
- Added support to manage sender-domains in MandrillApi.senders.
- Added support to update templates in MandrillApi.templates.
- Added support for exports in MandrillApi.exports.
- Added support for dedicated IPs and IP Pools in MandrillApi.ips.