View Javadoc

1   /**
2    * Copyright 2010 The Kuali Foundation Licensed under the
3    * Educational Community License, Version 2.0 (the "License"); you may
4    * not use this file except in compliance with the License. You may
5    * obtain a copy of the License at
6    *
7    * http://www.osedu.org/licenses/ECL-2.0
8    *
9    * Unless required by applicable law or agreed to in writing,
10   * software distributed under the License is distributed on an "AS IS"
11   * BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
12   * or implied. See the License for the specific language governing
13   * permissions and limitations under the License.
14   */
15  
16  /**
17   *
18   */
19  package org.kuali.student.lum.kim;
20  
21  import java.security.GeneralSecurityException;
22  
23  import javax.jws.WebService;
24  
25  import org.kuali.rice.core.api.CoreApiServiceLocator;
26  import org.kuali.rice.core.api.encryption.EncryptionService;
27  import org.kuali.rice.kim.api.KimApiConstants;
28  import org.kuali.rice.kim.api.identity.IdentityService;
29  import org.kuali.rice.kim.api.identity.principal.Principal;
30  import org.kuali.rice.kim.impl.identity.IdentityServiceImpl;
31  import org.kuali.rice.krad.service.impl.DocumentServiceImpl;
32  
33  /**
34   * This service override is used to facilitate a fix to the encrypted passwords in the
35   * Rice database.
36   *
37   * @author delyea
38   *
39   */
40  
41  // TODO: RICE=M9 UPGRADE Check that the values for the portName and targetNamespace still make sense for rice-2.0
42  // @see org.kuali.rice.kim.api.KimApiConstants.KIM_NAMESPACE_PREFIX
43  @WebService(endpointInterface = KimIdentityServiceConstants.INTERFACE_CLASS, serviceName = KimApiConstants.ServiceNames.IDENTITY_SERVICE_SOAP, portName = KimIdentityServiceConstants.WEB_SERVICE_PORT, targetNamespace = KimIdentityServiceConstants.MODULE_TARGET_NAMESPACE)
44  public class StudentIdentityServiceImpl extends IdentityServiceImpl implements IdentityService {
45      private static org.apache.log4j.Logger LOG = org.apache.log4j.Logger.getLogger(DocumentServiceImpl.class);
46  
47  	/* (non-Javadoc)
48  	 * @see org.kuali.rice.kim.service.impl.IdentityServiceImpl#getPrincipalByPrincipalNameAndPassword(java.lang.String, java.lang.String)
49  	 */
50  	@Override
51  	public Principal getPrincipalByPrincipalNameAndPassword(String principalName, String password) {
52  		try {
53  		    String finalPassword = CoreApiServiceLocator.getEncryptionService().hash(password)+ EncryptionService.HASH_POST_PREFIX;
54  			return super.getPrincipalByPrincipalNameAndPassword(principalName, finalPassword);
55  		} catch (GeneralSecurityException e) {
56  			String message = "Caught Exception attempting to encrypt password (with length " + password.length() + ") for principalName: " + principalName;
57  			LOG.error(message, e);
58  			throw new RuntimeException(e);
59  		}
60  	}
61  
62  }