Browse Source
Avoids ClassNotFoundException when RSA is not on the classpath. Fixes gh-334.pull/378/merge
5 changed files with 178 additions and 68 deletions
@ -0,0 +1,73 @@
@@ -0,0 +1,73 @@
|
||||
package org.springframework.cloud.bootstrap.encrypt; |
||||
/* |
||||
* Copyright 2013-2018 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. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; |
||||
import org.springframework.boot.context.properties.ConfigurationProperties; |
||||
import org.springframework.security.rsa.crypto.RsaAlgorithm; |
||||
|
||||
/** |
||||
* @author Ryan Baxter |
||||
*/ |
||||
@ConditionalOnClass(RsaAlgorithm.class) |
||||
@ConfigurationProperties("encrypt.rsa") |
||||
public class RsaProperties { |
||||
|
||||
/** |
||||
* The RSA algorithm to use (DEFAULT or OEAP). Once it is set do not change it (or |
||||
* existing ciphers will not a decryptable). |
||||
*/ |
||||
private RsaAlgorithm algorithm = RsaAlgorithm.DEFAULT; |
||||
|
||||
/** |
||||
* Flag to indicate that "strong" AES encryption should be used internally. If |
||||
* true then the GCM algorithm is applied to the AES encrypted bytes. Default is |
||||
* false (in which case "standard" CBC is used instead). Once it is set do not |
||||
* change it (or existing ciphers will not a decryptable). |
||||
*/ |
||||
private boolean strong = false; |
||||
|
||||
/** |
||||
* Salt for the random secret used to encrypt cipher text. Once it is set do not |
||||
* change it (or existing ciphers will not a decryptable). |
||||
*/ |
||||
private String salt = "deadbeef"; |
||||
|
||||
public RsaAlgorithm getAlgorithm() { |
||||
return this.algorithm; |
||||
} |
||||
|
||||
public void setAlgorithm(RsaAlgorithm algorithm) { |
||||
this.algorithm = algorithm; |
||||
} |
||||
|
||||
public boolean isStrong() { |
||||
return this.strong; |
||||
} |
||||
|
||||
public void setStrong(boolean strong) { |
||||
this.strong = strong; |
||||
} |
||||
|
||||
public String getSalt() { |
||||
return this.salt; |
||||
} |
||||
|
||||
public void setSalt(String salt) { |
||||
this.salt = salt; |
||||
} |
||||
|
||||
} |
@ -0,0 +1,61 @@
@@ -0,0 +1,61 @@
|
||||
package org.springframework.cloud.bootstrap.encrypt; |
||||
/* |
||||
* Copyright 2013-2018 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. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
import java.util.Map; |
||||
import org.junit.After; |
||||
import org.junit.Before; |
||||
import org.junit.Test; |
||||
import org.junit.runner.RunWith; |
||||
import org.springframework.boot.builder.SpringApplicationBuilder; |
||||
import org.springframework.cloud.ClassPathExclusions; |
||||
import org.springframework.cloud.FilteredClassPathRunner; |
||||
import org.springframework.context.ConfigurableApplicationContext; |
||||
|
||||
import static org.hamcrest.MatcherAssert.assertThat; |
||||
import static org.hamcrest.Matchers.hasSize; |
||||
|
||||
/** |
||||
* @author Ryan Baxter |
||||
*/ |
||||
@RunWith(FilteredClassPathRunner.class) |
||||
@ClassPathExclusions({"spring-security-rsa*.jar"}) |
||||
public class RsaDisabledTests { |
||||
|
||||
private ConfigurableApplicationContext context; |
||||
|
||||
@Before |
||||
public void setUp() { |
||||
context = new SpringApplicationBuilder().web(false) |
||||
.sources(EncryptionBootstrapConfiguration.class).web(false).properties( |
||||
"encrypt.key:mykey", |
||||
"encrypt.rsa.strong:true", |
||||
"encrypt.rsa.salt:foobar").run(); |
||||
} |
||||
|
||||
@After |
||||
public void tearDown() { |
||||
if(context != null) { |
||||
context.close(); |
||||
} |
||||
} |
||||
|
||||
@Test |
||||
public void testLoadBalancedRetryFactoryBean() throws Exception { |
||||
Map<String, RsaProperties> properties = context.getBeansOfType(RsaProperties.class); |
||||
assertThat(properties.values(), hasSize(0)); |
||||
} |
||||
} |
Loading…
Reference in new issue