Commit 328e07eb authored by Stephane Nicoll's avatar Stephane Nicoll

polish mail jndi support

Closes gh-2419
parent 28cb13c3
......@@ -16,35 +16,30 @@
package org.springframework.boot.autoconfigure.mail;
import javax.mail.Session;
import javax.naming.NamingException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnJndi;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jndi.JndiLocatorDelegate;
import javax.mail.Session;
import javax.naming.NamingException;
/**
* {@link EnableAutoConfiguration Auto-configuration} for Mail provided from JNDI.
* Auto-configure a {@link Session} available on JNDI.
*
* @author Eddú Meléndez
* @author Stephane Nicoll
* @since 1.3.0
*/
@Configuration
@AutoConfigureBefore(MailSenderAutoConfiguration.class)
@ConditionalOnClass(Session.class)
@ConditionalOnMissingBean(Session.class)
@ConditionalOnProperty(prefix = "spring.mail", name = "jndi-name")
@EnableConfigurationProperties(MailProperties.class)
@ConditionalOnJndi
public class JndiMailAutoConfiguration {
class JndiSessionConfiguration {
@Autowired
private MailProperties properties;
......@@ -54,13 +49,12 @@ public class JndiMailAutoConfiguration {
public Session session() {
try {
return new JndiLocatorDelegate()
.lookup(this.properties.getJndiName(), Session.class);
} catch (NamingException e) {
.lookup(this.properties.getJndiName(), Session.class);
}
catch (NamingException e) {
throw new IllegalStateException(String.format(
"Unable to find Session in JNDI location %s", this.properties.getJndiName()));
}
throw new IllegalStateException(String
.format("Unable to find Session in JNDI location %s", this.properties.getJndiName()));
}
}
/*
* Copyright 2012-2014 the original author or authors.
* Copyright 2012-2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
......@@ -63,7 +63,7 @@ public class MailProperties {
private Map<String, String> properties = new HashMap<String, String>();
/**
* JNDI location of the session. Host, port, username, password are ignored when set.
* Session JNDI name. When set, takes precedence to others mail settings.
*/
private String jndiName;
......
......@@ -17,10 +17,9 @@
package org.springframework.boot.autoconfigure.mail;
import java.util.Properties;
import javax.activation.MimeType;
import javax.mail.internet.MimeMessage;
import javax.mail.Session;
import javax.mail.internet.MimeMessage;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
......@@ -28,11 +27,12 @@ import org.springframework.boot.autoconfigure.condition.AnyNestedCondition;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.autoconfigure.mail.MailSenderAutoConfiguration.PropertiesCondition;
import org.springframework.boot.autoconfigure.mail.MailSenderAutoConfiguration.MailSenderCondition;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Conditional;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.mail.MailSender;
import org.springframework.mail.javamail.JavaMailSenderImpl;
......@@ -47,8 +47,9 @@ import org.springframework.mail.javamail.JavaMailSenderImpl;
@Configuration
@ConditionalOnClass({ MimeMessage.class, MimeType.class })
@ConditionalOnMissingBean(MailSender.class)
@Conditional(PropertiesCondition.class)
@Conditional(MailSenderCondition.class)
@EnableConfigurationProperties(MailProperties.class)
@Import(JndiSessionConfiguration.class)
public class MailSenderAutoConfiguration {
@Autowired(required = false)
......@@ -62,7 +63,8 @@ public class MailSenderAutoConfiguration {
JavaMailSenderImpl sender = new JavaMailSenderImpl();
if (this.session != null) {
sender.setSession(this.session);
} else {
}
else {
sender.setHost(this.properties.getHost());
if (this.properties.getPort() != null) {
sender.setPort(this.properties.getPort());
......@@ -80,22 +82,23 @@ public class MailSenderAutoConfiguration {
}
/**
* Condition for jndi-name or host property
* Condition to trigger the creation of a {@link JavaMailSenderImpl}. This kicks in
* if either the host or jndi name property is set.
*/
static class PropertiesCondition extends AnyNestedCondition {
static class MailSenderCondition extends AnyNestedCondition {
public PropertiesCondition() {
public MailSenderCondition() {
super(ConfigurationPhase.PARSE_CONFIGURATION);
}
@ConditionalOnProperty(prefix = "spring.mail", name = "jndi-name")
static class JndiNameProperty {
}
@ConditionalOnProperty(prefix = "spring.mail", name = "host")
static class HostProperty {
}
@ConditionalOnProperty(prefix = "spring.mail", name = "jndi-name")
static class JndiNameProperty {
}
}
}
......@@ -40,7 +40,6 @@ org.springframework.boot.autoconfigure.groovy.template.GroovyTemplateAutoConfigu
org.springframework.boot.autoconfigure.jersey.JerseyAutoConfiguration,\
org.springframework.boot.autoconfigure.liquibase.LiquibaseAutoConfiguration,\
org.springframework.boot.autoconfigure.mail.MailSenderAutoConfiguration,\
org.springframework.boot.autoconfigure.mail.JndiMailAutoConfiguration,\
org.springframework.boot.autoconfigure.mobile.DeviceResolverAutoConfiguration,\
org.springframework.boot.autoconfigure.mobile.DeviceDelegatingViewResolverAutoConfiguration,\
org.springframework.boot.autoconfigure.mobile.SitePreferenceAutoConfiguration,\
......
......@@ -137,57 +137,49 @@ public class MailSenderAutoConfigurationTests {
}
@Test
public void sessionIsAvailableFromJndiAndJndiNameIsSet() throws IllegalStateException,
NamingException {
Properties properties = new Properties();
Session session = Session.getDefaultInstance(properties);
configureJndi("foo", session);
load(JndiMailAutoConfiguration.class, "spring.mail.jndi-name:foo");
public void jndiSessionAvailable() throws NamingException {
Session session = configureJndiSession("foo");
load(EmptyConfig.class, "spring.mail.jndi-name:foo");
assertNotNull(this.context.getBean(Session.class));
assertEquals(session, this.context.getBean(Session.class));
assertNotNull(this.context.getBean(JavaMailSender.class));
Session sessionBean = this.context.getBean(Session.class);
assertEquals(session, sessionBean);
assertEquals(sessionBean, this.context.getBean(JavaMailSenderImpl.class).getSession());
}
@Test
public void sessionIsAvailableFromJndiAndHostIsSet() throws IllegalStateException,
NamingException {
Properties properties = new Properties();
Session session = Session.getDefaultInstance(properties);
configureJndi("foo", session);
public void jndiSessionIgnoredIfJndiNameNotSet() throws NamingException {
configureJndiSession("foo");
load(JndiMailAutoConfiguration.class, "spring.mail.host:smtp.acme.org");
load(EmptyConfig.class, "spring.mail.host:smtp.acme.org");
assertEquals(0, this.context.getBeanNamesForType(Session.class).length);
assertNotNull(this.context.getBean(JavaMailSender.class));
}
@Test
public void sessionIsAvailableFromJndiAndPropertiesNotUsed() throws IllegalStateException,
NamingException {
Properties properties = new Properties();
Session session = Session.getDefaultInstance(properties);
configureJndi("foo", session);
public void jndiSessionNotUsedIfJndiNameNotSet() throws NamingException {
configureJndiSession("foo");
load(JndiMailAutoConfiguration.class);
load(EmptyConfig.class);
assertEquals(0, this.context.getBeanNamesForType(Session.class).length);
assertEquals(0, this.context.getBeanNamesForType(JavaMailSender.class).length);
}
@Test
public void sessionIsNotAvailableFromJndiAndJndiNameIsSet() throws IllegalStateException,
NamingException {
public void jndiSessionNotAvailableWithJndiName() throws NamingException {
thrown.expect(BeanCreationException.class);
thrown.expectMessage("Unable to find Session in JNDI location foo");
load(JndiMailAutoConfiguration.class, "spring.mail.jndi-name:foo");
load(EmptyConfig.class, "spring.mail.jndi-name:foo");
}
private void configureJndi(String name, Session session)
private Session configureJndiSession(String name)
throws IllegalStateException, NamingException {
Properties properties = new Properties();
Session session = Session.getDefaultInstance(properties);
TestableInitialContextFactory.bind(name, session);
return session;
}
private void load(Class<?> config, String... environment) {
......
......@@ -486,7 +486,7 @@ content into your application; rather pick only the properties that you need.
spring.mail.password=
spring.mail.default-encoding=UTF-8 # encoding to use for MimeMessages
spring.mail.properties.*= # properties to set on the JavaMail session
spring.mail.jndi-name= # For JNDI lookup (host, port, username & password are ignored when set)
spring.mail.jndi-name= # JNDI location of a Mail Session
# SPRING BATCH ({sc-spring-boot-autoconfigure}/batch/BatchProperties.{sc-ext}[BatchProperties])
spring.batch.job.names=job1,job2
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment