3 * Copyright (C) 2007 EDIT
4 * European Distributed Institute of Taxonomy
5 * http://www.e-taxonomy.eu
7 * The contents of this file are subject to the Mozilla Public License Version 1.1
8 * See LICENSE.TXT at the top of this package for the full license terms.
11 package eu
.etaxonomy
.taxeditor
.ui
.password
;
13 import org
.eclipse
.jface
.dialogs
.IInputValidator
;
14 import org
.eclipse
.swt
.SWT
;
15 import org
.eclipse
.swt
.events
.ModifyEvent
;
16 import org
.eclipse
.swt
.events
.ModifyListener
;
17 import org
.eclipse
.swt
.widgets
.Composite
;
18 import org
.eclipse
.swt
.widgets
.Text
;
20 import eu
.etaxonomy
.cdm
.api
.conversation
.ConversationHolder
;
21 import eu
.etaxonomy
.cdm
.api
.service
.IUserService
;
22 import eu
.etaxonomy
.cdm
.model
.common
.User
;
23 import eu
.etaxonomy
.taxeditor
.store
.CdmStore
;
24 import eu
.etaxonomy
.taxeditor
.ui
.element
.AbstractCdmEntityWizardPage
;
25 import eu
.etaxonomy
.taxeditor
.ui
.element
.CdmFormFactory
;
26 import eu
.etaxonomy
.taxeditor
.ui
.element
.ICdmFormElement
;
27 import eu
.etaxonomy
.taxeditor
.ui
.element
.LayoutConstants
;
28 import eu
.etaxonomy
.taxeditor
.ui
.element
.TextWithLabelElement
;
29 import eu
.etaxonomy
.taxeditor
.ui
.section
.AbstractCdmDetailElement
;
36 public class PasswordWizardPage
extends AbstractCdmEntityWizardPage
<User
> implements ModifyListener
{
38 public static final String NAME
= "USER_WIZARD_PAGE";
40 private TextWithLabelElement text_oldPassword
;
41 private TextWithLabelElement text_password
;
42 private TextWithLabelElement text_passwordRepeat
;
43 private final PasswordValidator passwordValidator
;
45 private final UniqueUserNameValidator uniqueUsernameValidator
;
47 protected PasswordWizardPage(CdmFormFactory formFactory
,
48 ConversationHolder conversation
, User entity
) {
49 super(formFactory
, conversation
, entity
);
51 passwordValidator
= new PasswordValidator();
52 uniqueUsernameValidator
= new UniqueUserNameValidator();
56 public void createControl(Composite parent
) {
57 Composite control
= formFactory
.createComposite(parent
);
58 control
.setLayoutData(LayoutConstants
.FILL());
60 setPageComplete(false);
62 control
.setLayout(LayoutConstants
.LAYOUT(2, false));
63 WizardPageRootElement rootElement
= new WizardPageRootElement(formFactory
, control
, getConversationHolder());
65 if(isChangingOwnPassword()) {
66 text_oldPassword
= formFactory
.createTextWithLabelElement(rootElement
, "Old Password", null, SWT
.PASSWORD
);
68 text_password
= formFactory
.createTextWithLabelElement(rootElement
, "New Password", null, SWT
.PASSWORD
);
69 text_passwordRepeat
= formFactory
.createTextWithLabelElement(rootElement
, "Repeat Password", null, SWT
.PASSWORD
);
71 ((Text
)text_passwordRepeat
.getMainControl()).addModifyListener(this);
76 protected boolean isChangingOwnPassword() {
77 return getEntity() != null && getEntity().getUsername().equals(CdmStore
.getCurrentAuthentiation().getName());
82 public AbstractCdmDetailElement
<User
> createElement(
83 ICdmFormElement rootElement
) {
90 public void modifyText(ModifyEvent e
) {
94 private void validate(){
97 if((message
= passwordValidator
.passwordsMatch(text_password
.getText(), text_passwordRepeat
.getText())) != null){
100 else if((message
= passwordValidator
.isValid(text_password
.getText())) != null){
104 setErrorMessage(message
);
107 private class UniqueUserNameValidator
implements IInputValidator
{
109 private static final String USER_EXISTS
= "Username already exists";
110 private static final String NAME_TO_SHORT
= "Username is empty";
113 public String
isValid(String newText
) {
114 // query for username
115 if(newText
.length() < 1){
116 setPageComplete(false);
117 return NAME_TO_SHORT
;
119 if(CdmStore
.getService(IUserService
.class).userExists(newText
)){
120 setPageComplete(false);
124 setPageComplete(true);
129 private class PasswordValidator
implements IInputValidator
{
131 private static final int PW_MIN_LENGTH
= 5;
133 private static final String TO_SHORT
= "Password has to have at least " + PW_MIN_LENGTH
+ " characters";
134 private static final String NO_MATCH
= "The passwords do not match";
137 public String
isValid(String newText
) {
138 if(newText
.length() < PW_MIN_LENGTH
){
139 setPageComplete(false);
143 setPageComplete(true);
147 public String
passwordsMatch(String password1
, String password2
){
149 if(! password1
.equals(password2
)){
150 setPageComplete(false);
154 setPageComplete(true);
160 public String
getOldPassword() {
161 return text_oldPassword
.getText();
164 public String
getNewPassword() {
165 return text_password
.getText();