/* * * Copyright (c) 2014, WSO2 Inc. (http://www.wso2.org) All Rights Reserved. * * WSO2 Inc. 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.wso2.carbon.identity.mgt.ui; import org.apache.axis2.AxisFault; import org.apache.axis2.client.Options; import org.apache.axis2.client.ServiceClient; import org.apache.axis2.context.ConfigurationContext; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.wso2.carbon.captcha.mgt.beans.xsd.CaptchaInfoBean; import org.wso2.carbon.identity.mgt.stub.UserIdentityManagementServiceStub; import org.wso2.carbon.identity.mgt.stub.beans.VerificationBean; import org.wso2.carbon.identity.mgt.stub.dto.UserChallengesDTO; /** * */ public class IdentityManagementClient { public static final String USER_CHALLENGE_QUESTION = "user.challenge.question"; protected static Log log = LogFactory.getLog(IdentityManagementClient.class); protected UserIdentityManagementServiceStub stub = null; public IdentityManagementClient(String url, ConfigurationContext configContext) throws java.lang.Exception { try { stub = new UserIdentityManagementServiceStub(configContext, url + "UserIdentityManagementService"); } catch (java.lang.Exception e) { handleException(e.getMessage(), e); } } public IdentityManagementClient(String cookie, String url, ConfigurationContext configContext) throws java.lang.Exception { try { stub = new UserIdentityManagementServiceStub(configContext, url + "UserIdentityManagementService"); ServiceClient client = stub._getServiceClient(); Options option = client.getOptions(); option.setManageSession(true); option.setProperty(org.apache.axis2.transport.http.HTTPConstants.COOKIE_STRING, cookie); } catch (java.lang.Exception e) { handleException(e.getMessage(), e); } } public boolean processPasswordRecoveryLink(String userId, String userKey) throws AxisFault { try { return stub.processPasswordRecovery(userId, userKey, "EMAIL"); } catch (Exception e) { handleException(e.getMessage(), e); } return false; } public UserChallengesDTO[] getChallengeQuestionsOfUser(String userId, String userKey) throws AxisFault { try { return stub.getChallengeQuestionsForUser(userId, userKey); } catch (Exception e) { handleException(e.getMessage(), e); } return new UserChallengesDTO[0]; } public VerificationBean verifyChallengeQuestion(String userId, String userKey, String question, String answer) throws AxisFault { try { UserChallengesDTO dto = new UserChallengesDTO(); dto.setQuestion(question); dto.setAnswer(answer); return stub.verifyChallengeQuestion(userId, userKey, new UserChallengesDTO[]{dto}); } catch (Exception e) { handleException(e.getMessage(), e); } return null; } public VerificationBean confirmLink(String confirmationKey) throws AxisFault { try { return stub.confirmUserAccount(confirmationKey); } catch (Exception e) { handleException(e.getMessage(), e); } return null; } public boolean updateCredential(String userId, String userKey, String password, CaptchaInfoBean captchaInfoBean) throws AxisFault { try { VerificationBean bean = stub.updateCredential(userId, userKey, password, captchaInfoBean); return bean.getVerified(); } catch (Exception e) { handleException(e.getMessage(), e); } return false; } public boolean unlockUserAccount(String userId, String userKey) { return false; } // TODO public boolean processAccountRecovery() throws AxisFault { return false; } private String[] handleException(String msg, Exception e) throws AxisFault { log.error(msg, e); throw new AxisFault(msg, e); } }