
org.apache.geronimo.system.util.ConfiguredEncryption Maven / Gradle / Ivy
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
package org.apache.geronimo.system.util;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.security.SecureRandom;
import javax.crypto.spec.SecretKeySpec;
import org.apache.geronimo.gbean.GBeanInfo;
import org.apache.geronimo.gbean.GBeanInfoBuilder;
import org.apache.geronimo.gbean.GBeanLifecycle;
import org.apache.geronimo.system.serverinfo.ServerInfo;
import org.apache.geronimo.util.AbstractEncryption;
import org.apache.geronimo.util.EncryptionManager;
/**
* Like SimpleEncryption except it uses a stored secret key. If the key file is missing, it makes up a new one.
*
* WARNING: NOT RECOMMENDED. If you lose the secret key file your encrypted passwords will be unavailable. Instead, secure
* your operationg environment and use something like ldap or a database to store passwords in.
*
* To use, include something like this in the rmi-naming module of var/config/config.xml:
*
*
* var/security/ConfiguredSecretKey.ser
* ServerInfo
*
*
* @version $Rev: 576668 $ $Date: 2007-09-17 22:40:01 -0400 (Mon, 17 Sep 2007) $
*/
public class ConfiguredEncryption extends AbstractEncryption implements GBeanLifecycle {
private final SecretKeySpec spec;
public ConfiguredEncryption(String path, ServerInfo serverInfo) throws IOException, ClassNotFoundException {
File location = serverInfo.resolve(path);
if (location.exists()) {
FileInputStream in = new FileInputStream(location);
try {
ObjectInputStream oin = new ObjectInputStream(in);
try {
spec = (SecretKeySpec) oin.readObject();
} finally {
oin.close();
}
} finally {
in.close();
}
} else {
SecureRandom random = new SecureRandom();
random.setSeed(System.currentTimeMillis());
byte[] bytes = new byte[16];
random.nextBytes(bytes);
spec = new SecretKeySpec(bytes, "AES");
File dir = location.getParentFile();
if (!dir.exists()) {
dir.mkdirs();
}
if (!dir.exists() || !dir.isDirectory()) {
throw new IllegalStateException("Could not create directory for secret key spec: " + dir);
}
FileOutputStream out = new FileOutputStream(location);
try {
ObjectOutputStream oout = new ObjectOutputStream(out);
try {
oout.writeObject(spec);
oout.flush();
} finally {
oout.close();
}
} finally {
out.close();
}
}
}
public void doStart() throws Exception {
EncryptionManager.setEncryptionPrefix("{Configured}", this);
}
public void doStop() throws Exception {
}
public void doFail() {
}
protected SecretKeySpec getSecretKeySpec() {
return spec;
}
public static final GBeanInfo GBEAN_INFO;
static {
GBeanInfoBuilder infoBuilder = GBeanInfoBuilder.createStatic(ConfiguredEncryption.class, "GBean");
infoBuilder.addAttribute("path", String.class, true, true);
infoBuilder.addReference("ServerInfo", ServerInfo.class, "GBean");
infoBuilder.setConstructor(new String[]{"path", "ServerInfo"});
GBEAN_INFO = infoBuilder.getBeanInfo();
}
public static GBeanInfo getGBeanInfo() {
return GBEAN_INFO;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy