X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=security%2Fplugins%2Forg.argeo.security.ui.admin%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fsecurity%2Fui%2Fadmin%2Fwizards%2FMainUserInfoWizardPage.java;h=e00decd537bc57a4e4714319bfe714ae76d687d5;hb=f763d5bc49fa5cae85e85ca8ae69f51d10a86060;hp=066c376a1d3f27b9ec9d8bfc43e6b6852cc8f5f0;hpb=5266ec50ddbf3247a5033d98a1dbceec6673a5b8;p=lgpl%2Fargeo-commons.git diff --git a/security/plugins/org.argeo.security.ui.admin/src/main/java/org/argeo/security/ui/admin/wizards/MainUserInfoWizardPage.java b/security/plugins/org.argeo.security.ui.admin/src/main/java/org/argeo/security/ui/admin/wizards/MainUserInfoWizardPage.java index 066c376a1..e00decd53 100644 --- a/security/plugins/org.argeo.security.ui.admin/src/main/java/org/argeo/security/ui/admin/wizards/MainUserInfoWizardPage.java +++ b/security/plugins/org.argeo.security.ui.admin/src/main/java/org/argeo/security/ui/admin/wizards/MainUserInfoWizardPage.java @@ -15,14 +15,18 @@ import org.eclipse.swt.events.ModifyListener; import org.eclipse.swt.layout.GridLayout; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Text; +import org.springframework.security.userdetails.UserDetails; +import org.springframework.security.userdetails.UsernameNotFoundException; public class MainUserInfoWizardPage extends WizardPage implements ModifyListener, ArgeoNames { private Text username, firstName, lastName, primaryEmail, password1, password2; + private UserAdminService userAdminService; - public MainUserInfoWizardPage() { + public MainUserInfoWizardPage(UserAdminService userAdminService) { super("Main"); + this.userAdminService = userAdminService; setTitle("Required Information"); } @@ -55,6 +59,13 @@ public class MainUserInfoWizardPage extends WizardPage implements protected String checkComplete() { if (!username.getText().matches(UserAdminService.USERNAME_PATTERN)) return "Wrong user name format, should be lower case, between 3 and 15 characters with only '_' as acceptable special character."; + try { + UserDetails userDetails = userAdminService + .loadUserByUsername(username.getText()); + return "User " + userDetails.getUsername() + " alreayd exists"; + } catch (UsernameNotFoundException e) { + // silent + } if (!primaryEmail.getText().matches(UserAdminService.EMAIL_PATTERN)) return "Not a valid email address"; if (firstName.getText().trim().equals(""))