blob: ca765af17a093ec9d412d7dd67918f22976225a4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. 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. For additional information regarding
* copyright in this work, please see the NOTICE file in the top level
* directory of this distribution.
*/
package org.apache.roller.weblogger.ui.core.security;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.roller.weblogger.config.AuthMethod;
import org.apache.roller.weblogger.config.WebloggerConfig;
import org.springframework.security.crypto.codec.Hex;
import org.springframework.security.web.authentication.rememberme.TokenBasedRememberMeServices;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class RollerRememberMeServices extends TokenBasedRememberMeServices {
private static final Log log = LogFactory.getLog(RollerRememberMeServices.class);
public RollerRememberMeServices() {
log.debug("initializing: RollerRememberMeServices");
String key = WebloggerConfig.getProperty("rememberme.key", "springRocks");
if ("springRocks".equals(key)) {
throw new RuntimeException(
"If remember-me is to be enabled, rememberme.key must be specified in the roller " +
"properties file. Make sure it is a secret and make sure it is NOT springRocks");
}
setKey(key);
log.debug("initialized: RollerRememberMeServices with key");
}
/**
* Calculates the digital signature to be put in the cookie. Default value is
* MD5 ("username:tokenExpiryTime:password:key")
*
* If LDAP is enabled then a configurable dummy password is used in the calculation.
*/
@Override
protected String makeTokenSignature(long tokenExpiryTime, String username, String password) {
boolean usingLDAP = WebloggerConfig.getAuthMethod() == AuthMethod.LDAP;
if (usingLDAP) {
log.debug("LDAP is enabled; using dummy password in remember me signature.");
// for LDAP we don't store its password in the roller_users table,
// just an string indicating external auth method being used.
password = WebloggerConfig.getProperty("users.passwords.externalAuthValue","<externalAuth>");
}
String data = username + ":" + tokenExpiryTime + ":" + password + ":" + getKey();
MessageDigest digest;
try {
digest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
throw new IllegalStateException("No MD5 algorithm available!");
}
return new String(Hex.encode(digest.digest(data.getBytes())));
}
}