You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

EditUserPage.java 6.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. /*
  2. * Copyright 2011 gitblit.com.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package com.gitblit.wicket.pages;
  17. import java.text.MessageFormat;
  18. import java.util.ArrayList;
  19. import java.util.Iterator;
  20. import java.util.List;
  21. import org.apache.wicket.PageParameters;
  22. import org.apache.wicket.extensions.markup.html.form.palette.Palette;
  23. import org.apache.wicket.markup.html.form.CheckBox;
  24. import org.apache.wicket.markup.html.form.ChoiceRenderer;
  25. import org.apache.wicket.markup.html.form.Form;
  26. import org.apache.wicket.markup.html.form.PasswordTextField;
  27. import org.apache.wicket.markup.html.form.TextField;
  28. import org.apache.wicket.model.CompoundPropertyModel;
  29. import org.apache.wicket.model.Model;
  30. import org.apache.wicket.model.util.CollectionModel;
  31. import org.apache.wicket.model.util.ListModel;
  32. import org.eclipse.jetty.http.security.Credential.Crypt;
  33. import org.eclipse.jetty.http.security.Credential.MD5;
  34. import com.gitblit.Constants.AccessRestrictionType;
  35. import com.gitblit.GitBlit;
  36. import com.gitblit.GitBlitException;
  37. import com.gitblit.Keys;
  38. import com.gitblit.utils.StringUtils;
  39. import com.gitblit.wicket.AdminPage;
  40. import com.gitblit.wicket.BasePage;
  41. import com.gitblit.wicket.WicketUtils;
  42. import com.gitblit.wicket.models.RepositoryModel;
  43. import com.gitblit.wicket.models.UserModel;
  44. @AdminPage
  45. public class EditUserPage extends BasePage {
  46. private final boolean isCreate;
  47. public EditUserPage() {
  48. // create constructor
  49. super();
  50. isCreate = true;
  51. setupPage(new UserModel(""));
  52. }
  53. public EditUserPage(PageParameters params) {
  54. // edit constructor
  55. super(params);
  56. isCreate = false;
  57. String name = WicketUtils.getUsername(params);
  58. UserModel model = GitBlit.self().getUserModel(name);
  59. setupPage(model);
  60. }
  61. protected void setupPage(final UserModel userModel) {
  62. if (isCreate) {
  63. super.setupPage("", getString("gb.newUser"));
  64. } else {
  65. super.setupPage("", getString("gb.edit"));
  66. }
  67. final Model<String> confirmPassword = new Model<String>(
  68. StringUtils.isEmpty(userModel.password) ? "" : userModel.password);
  69. CompoundPropertyModel<UserModel> model = new CompoundPropertyModel<UserModel>(userModel);
  70. List<String> repos = new ArrayList<String>();
  71. for (String repo : GitBlit.self().getRepositoryList()) {
  72. RepositoryModel repositoryModel = GitBlit.self().getRepositoryModel(repo);
  73. if (repositoryModel.accessRestriction.exceeds(AccessRestrictionType.NONE)) {
  74. repos.add(repo);
  75. }
  76. }
  77. final String oldName = userModel.username;
  78. final Palette<String> repositories = new Palette<String>("repositories",
  79. new ListModel<String>(userModel.repositories), new CollectionModel<String>(repos),
  80. new ChoiceRenderer<String>("", ""), 10, false);
  81. Form<UserModel> form = new Form<UserModel>("editForm", model) {
  82. private static final long serialVersionUID = 1L;
  83. /*
  84. * (non-Javadoc)
  85. *
  86. * @see org.apache.wicket.markup.html.form.Form#onSubmit()
  87. */
  88. @Override
  89. protected void onSubmit() {
  90. String username = userModel.username;
  91. if (StringUtils.isEmpty(username)) {
  92. error("Please enter a username!");
  93. return;
  94. }
  95. if (isCreate) {
  96. UserModel model = GitBlit.self().getUserModel(username);
  97. if (model != null) {
  98. error(MessageFormat.format("Username ''{0}'' is unavailable.", username));
  99. return;
  100. }
  101. }
  102. if (!userModel.password.equals(confirmPassword.getObject())) {
  103. error("Passwords do not match!");
  104. return;
  105. }
  106. String password = userModel.password;
  107. if (!password.toUpperCase().startsWith(Crypt.__TYPE)
  108. && !password.toUpperCase().startsWith(MD5.__TYPE)) {
  109. // This is a plain text password.
  110. // Check length.
  111. int minLength = GitBlit.getInteger(Keys.realm.minPasswordLength, 5);
  112. if (minLength < 4) {
  113. minLength = 4;
  114. }
  115. if (password.trim().length() < minLength) {
  116. error(MessageFormat.format(
  117. "Password is too short. Minimum length is {0} characters.",
  118. minLength));
  119. return;
  120. }
  121. // Optionally store the password MD5 digest.
  122. String type = GitBlit.getString(Keys.realm.passwordStorage, "md5");
  123. if (type.equalsIgnoreCase("md5")) {
  124. // store MD5 digest of password
  125. userModel.password = MD5.digest(userModel.password);
  126. }
  127. }
  128. Iterator<String> selectedRepositories = repositories.getSelectedChoices();
  129. List<String> repos = new ArrayList<String>();
  130. while (selectedRepositories.hasNext()) {
  131. repos.add(selectedRepositories.next());
  132. }
  133. userModel.setRepositories(repos);
  134. try {
  135. GitBlit.self().editUserModel(oldName, userModel, isCreate);
  136. } catch (GitBlitException e) {
  137. error(e.getMessage());
  138. return;
  139. }
  140. setRedirect(false);
  141. if (isCreate) {
  142. // create another user
  143. info(MessageFormat.format("New user ''{0}'' successfully created.",
  144. userModel.username));
  145. setResponsePage(EditUserPage.class);
  146. } else {
  147. // back to home
  148. setResponsePage(RepositoriesPage.class);
  149. }
  150. }
  151. };
  152. // field names reflective match UserModel fields
  153. form.add(new TextField<String>("username"));
  154. PasswordTextField passwordField = new PasswordTextField("password");
  155. passwordField.setResetPassword(false);
  156. form.add(passwordField);
  157. PasswordTextField confirmPasswordField = new PasswordTextField("confirmPassword",
  158. confirmPassword);
  159. confirmPasswordField.setResetPassword(false);
  160. form.add(confirmPasswordField);
  161. form.add(new CheckBox("canAdmin"));
  162. form.add(repositories);
  163. add(form);
  164. }
  165. }