View Javadoc
1   /**
2    * Copyright 2010-2014 The Kuali Foundation
3    *
4    * Licensed under the Educational Community License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    * http://www.opensource.org/licenses/ecl2.php
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  package org.kuali.common.util.encrypt.jasypt;
17  
18  import static org.kuali.common.util.base.Exceptions.illegalArgument;
19  import static org.kuali.common.util.base.Precondition.checkNotBlank;
20  import static org.kuali.common.util.base.Precondition.checkNotNull;
21  
22  import org.jasypt.util.text.BasicTextEncryptor;
23  import org.jasypt.util.text.StrongTextEncryptor;
24  import org.jasypt.util.text.TextEncryptor;
25  import org.kuali.common.util.encrypt.EncryptionContext;
26  import org.kuali.common.util.encrypt.EncryptionStrength;
27  
28  public class Jasypt {
29  
30  	/**
31  	 * Return a <code>BasicTextEncryptor</code> or <code>StrongTextEncryptor</code> depending on what <code>strength</code> is set to
32  	 */
33  	public static TextEncryptor buildTextEncryptor(EncryptionContext context) {
34  		return buildTextEncryptor(context.getPassword(), context.getStrength());
35  	}
36  
37  	/**
38  	 * Return a <code>BasicTextEncryptor</code> or <code>StrongTextEncryptor</code> depending on what <code>strength</code> is set to
39  	 */
40  	public static TextEncryptor buildTextEncryptor(String password, EncryptionStrength strength) {
41  		checkNotBlank(password, "password");
42  		checkNotNull(strength, "strength");
43  		switch (strength) {
44  		case BASIC_ENCRYPTION_STRENGTH:
45  			BasicTextEncryptor basic = new BasicTextEncryptor();
46  			basic.setPassword(password);
47  			return basic;
48  		case STRONG_ENCRYPTION_STRENGTH:
49  			StrongTextEncryptor strong = new StrongTextEncryptor();
50  			strong.setPassword(password);
51  			return strong;
52  		default:
53  			throw illegalArgument("encryption strength [%s] is unknown", strength);
54  		}
55  	}
56  
57  }