blob: 3a63cad15596e0323e046ee8facfa49323513c4f [file] [log] [blame]
/*
* 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.syncope.client.enduser.pages;
import java.util.List;
import java.util.stream.Collectors;
import org.apache.commons.lang3.StringUtils;
import org.apache.syncope.client.enduser.SyncopeEnduserSession;
import org.apache.syncope.client.enduser.SyncopeWebApplication;
import org.apache.syncope.client.enduser.commons.EnduserConstants;
import org.apache.syncope.client.enduser.panels.captcha.CaptchaPanel;
import org.apache.syncope.client.enduser.rest.SecurityQuestionRestClient;
import org.apache.syncope.client.enduser.rest.UserSelfRestClient;
import org.apache.syncope.client.ui.commons.Constants;
import org.apache.syncope.client.ui.commons.markup.html.form.AjaxDropDownChoicePanel;
import org.apache.syncope.client.ui.commons.markup.html.form.AjaxTextFieldPanel;
import org.apache.syncope.client.ui.commons.markup.html.form.FieldPanel;
import org.apache.syncope.client.ui.commons.panels.CardPanel;
import org.apache.syncope.common.lib.request.StringReplacePatchItem;
import org.apache.syncope.common.lib.request.UserUR;
import org.apache.syncope.common.lib.to.SecurityQuestionTO;
import org.apache.syncope.common.lib.to.UserTO;
import org.apache.wicket.ajax.AjaxEventBehavior;
import org.apache.wicket.ajax.AjaxRequestTarget;
import org.apache.wicket.ajax.markup.html.form.AjaxButton;
import org.apache.wicket.markup.html.WebMarkupContainer;
import org.apache.wicket.markup.html.form.Button;
import org.apache.wicket.markup.html.form.IChoiceRenderer;
import org.apache.wicket.markup.html.form.StatelessForm;
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.Model;
import org.apache.wicket.model.PropertyModel;
import org.apache.wicket.request.mapper.parameter.PageParameters;
public class EditSecurityQuestion extends BasePage {
private static final long serialVersionUID = -537205681762708502L;
private static final String EDIT_SECURITY_QUESTION = "page.editSecurityQuestion";
private final UserSelfRestClient userSelfRestClient = new UserSelfRestClient();
private final AjaxDropDownChoicePanel<String> securityQuestion;
private final FieldPanel<String> securityAnswer;
private final UserTO userTO;
public EditSecurityQuestion(final PageParameters parameters) {
super(parameters, EDIT_SECURITY_QUESTION);
userTO = SyncopeEnduserSession.get().getSelfTO(true);
WebMarkupContainer content = new WebMarkupContainer("content");
content.setOutputMarkupId(true);
contentWrapper.add(content);
StatelessForm<Void> form = new StatelessForm<>("securityQuestionForm");
form.setOutputMarkupId(true);
content.add(form);
securityQuestion = new AjaxDropDownChoicePanel<>("securityQuestion",
"securityQuestion", new PropertyModel<>(userTO, "securityQuestion"));
securityQuestion.setNullValid(true);
List<SecurityQuestionTO> securityQuestions = SecurityQuestionRestClient.list();
securityQuestion.setChoices(securityQuestions.stream().
map(SecurityQuestionTO::getKey).collect(Collectors.toList()));
securityQuestion.setChoiceRenderer(new IChoiceRenderer<String>() {
private static final long serialVersionUID = -4421146737845000747L;
@Override
public Object getDisplayValue(final String value) {
return securityQuestions.stream().filter(sq -> value.equals(sq.getKey())).
map(SecurityQuestionTO::getContent).findFirst().orElse(null);
}
@Override
public String getIdValue(final String value, final int index) {
return value;
}
@Override
public String getObject(final String id, final IModel<? extends List<? extends String>> choices) {
return id;
}
});
securityQuestion.add(new AjaxEventBehavior(Constants.ON_CHANGE) {
private static final long serialVersionUID = 192359260308762078L;
@Override
protected void onEvent(final AjaxRequestTarget target) {
securityAnswer.setEnabled(StringUtils.isNotBlank(securityQuestion.getModelObject()));
target.add(securityAnswer);
}
});
form.add(securityQuestion);
securityAnswer = new AjaxTextFieldPanel("securityAnswer", "securityAnswer",
new PropertyModel<>(userTO, "securityAnswer"), false);
form.add(securityAnswer.setOutputMarkupId(true).setOutputMarkupPlaceholderTag(true).
setEnabled(StringUtils.isNotBlank(securityQuestion.getModelObject())));
CaptchaPanel<Void> captcha = new CaptchaPanel<>(EnduserConstants.CONTENT_PANEL);
captcha.setOutputMarkupPlaceholderTag(true);
form.add(new CardPanel.Builder<CaptchaPanel<Void>>()
.setName("captcha")
.setComponent(captcha)
.isVisible(SyncopeWebApplication.get().isCaptchaEnabled()).build("captchaPanelCard"));
AjaxButton submitButton = new AjaxButton("submit", new Model<>(getString("submit"))) {
private static final long serialVersionUID = 429178684321093953L;
@Override
protected void onSubmit(final AjaxRequestTarget target) {
if (StringUtils.isBlank(securityQuestion.getModelObject())
|| StringUtils.isBlank(securityAnswer.getModelObject())) {
SyncopeEnduserSession.get().error(getString(Constants.CAPTCHA_ERROR));
((BasePage) getPageReference().getPage()).getNotificationPanel().refresh(target);
} else {
boolean checked = true;
if (SyncopeWebApplication.get().isCaptchaEnabled()) {
checked = captcha.check();
}
if (!checked) {
SyncopeEnduserSession.get().error(getString(Constants.CAPTCHA_ERROR));
((BasePage) getPageReference().getPage()).getNotificationPanel().refresh(target);
} else {
PageParameters parameters = new PageParameters();
try {
UserUR req = new UserUR();
req.setKey(userTO.getKey());
req.setSecurityQuestion(new StringReplacePatchItem.Builder().
value(securityQuestion.getModelObject()).build());
req.setSecurityAnswer(new StringReplacePatchItem.Builder().
value(securityAnswer.getModelObject()).build());
userSelfRestClient.update(userTO.getETagValue(), req);
parameters.add(EnduserConstants.STATUS, Constants.OPERATION_SUCCEEDED);
parameters.add(Constants.NOTIFICATION_TITLE_PARAM,
getString("self.securityquestion.change.success"));
parameters.add(Constants.NOTIFICATION_MSG_PARAM,
getString("self.securityquestion.change.success.msg"));
SyncopeEnduserSession.get().success(getString(Constants.OPERATION_SUCCEEDED));
} catch (Exception e) {
LOG.error("While changing password for {}",
SyncopeEnduserSession.get().getSelfTO().getUsername(), e);
parameters.add(EnduserConstants.STATUS, Constants.OPERATION_ERROR);
parameters.add(Constants.NOTIFICATION_TITLE_PARAM,
getString("self.securityquestion.change.error"));
parameters.add(Constants.NOTIFICATION_MSG_PARAM,
getString("self.securityquestion.change.error.msg"));
SyncopeEnduserSession.get().onException(e);
notificationPanel.refresh(target);
}
parameters.add(
EnduserConstants.LANDING_PAGE,
SyncopeWebApplication.get().getPageClass("profile", Dashboard.class).getName());
setResponsePage(SelfResult.class, parameters);
}
}
}
@Override
protected void onError(final AjaxRequestTarget target) {
notificationPanel.refresh(target);
}
};
form.add(submitButton);
form.setDefaultButton(submitButton);
Button cancel = new Button("cancel") {
private static final long serialVersionUID = 3669569969172391336L;
@Override
public void onSubmit() {
setResponsePage(getApplication().getHomePage());
}
};
cancel.setOutputMarkupId(true);
cancel.setDefaultFormProcessing(false);
form.add(cancel);
}
}