123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- /*
- * Copyright 2011 gitblit.com.
- *
- * Licensed 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 com.gitblit.wicket.pages;
-
- import java.text.MessageFormat;
-
- import org.apache.wicket.RestartResponseException;
- import org.apache.wicket.markup.html.form.Button;
- import org.apache.wicket.markup.html.form.StatelessForm;
- import org.apache.wicket.model.IModel;
- import org.apache.wicket.model.Model;
- import org.apache.wicket.protocol.http.WebRequest;
- import org.apache.wicket.protocol.http.WebResponse;
-
- import com.gitblit.GitBlitException;
- import com.gitblit.Keys;
- import com.gitblit.models.UserModel;
- import com.gitblit.utils.PasswordHash;
- import com.gitblit.wicket.GitBlitWebSession;
- import com.gitblit.wicket.NonTrimmedPasswordTextField;
-
- public class ChangePasswordPage extends RootSubPage {
-
- private IModel<String> password = new Model<String>("");
- private IModel<String> confirmPassword = new Model<String>("");
-
- public ChangePasswordPage() {
- super();
-
- if (!GitBlitWebSession.get().isLoggedIn()) {
- // Change password requires a login
- throw new RestartResponseException(getApplication().getHomePage());
- }
-
- if (!app().settings().getBoolean(Keys.web.authenticateAdminPages, true)
- && !app().settings().getBoolean(Keys.web.authenticateViewPages, false)) {
- // no authentication enabled
- throw new RestartResponseException(getApplication().getHomePage());
- }
-
- UserModel user = GitBlitWebSession.get().getUser();
- if (!app().authentication().supportsCredentialChanges(user)) {
- error(MessageFormat.format(getString("gb.userServiceDoesNotPermitPasswordChanges"),
- app().settings().getString(Keys.realm.userService, "${baseFolder}/users.conf")), true);
- }
-
- setupPage(getString("gb.changePassword"), user.username);
-
- StatelessForm<Void> form = new StatelessForm<Void>("passwordForm") {
-
- private static final long serialVersionUID = 1L;
-
- @Override
- public void onSubmit() {
- String password = ChangePasswordPage.this.password.getObject();
- String confirmPassword = ChangePasswordPage.this.confirmPassword.getObject();
- // ensure passwords match
- if (!password.equals(confirmPassword)) {
- error(getString("gb.passwordsDoNotMatch"));
- return;
- }
-
- // ensure password satisfies minimum length requirement
- int minLength = app().settings().getInteger(Keys.realm.minPasswordLength, 5);
- if (minLength < 4) {
- minLength = 4;
- }
- if (password.length() < minLength) {
- error(MessageFormat.format(getString("gb.passwordTooShort"), minLength));
- return;
- }
-
- UserModel user = GitBlitWebSession.get().getUser();
-
- // convert to digest, if appropriate
- String type = app().settings().getString(Keys.realm.passwordStorage, PasswordHash.getDefaultType().name());
- PasswordHash pwdHash = PasswordHash.instanceOf(type);
- if (pwdHash != null) {
- password = pwdHash.toHashedEntry(password, user.username);
- }
-
- user.password = password;
- try {
- app().gitblit().reviseUser(user.username, user);
- if (app().settings().getBoolean(Keys.web.allowCookieAuthentication, false)) {
- WebRequest request = (WebRequest) getRequestCycle().getRequest();
- WebResponse response = (WebResponse) getRequestCycle().getResponse();
- app().authentication().setCookie(request.getHttpServletRequest(),
- response.getHttpServletResponse(), user);
- }
- } catch (GitBlitException e) {
- error(e.getMessage());
- return;
- }
- setRedirect(false);
- info(getString("gb.passwordChanged"));
- setResponsePage(RepositoriesPage.class);
- }
- };
- NonTrimmedPasswordTextField passwordField = new NonTrimmedPasswordTextField("password", password);
- passwordField.setResetPassword(false);
- form.add(passwordField);
- NonTrimmedPasswordTextField confirmPasswordField = new NonTrimmedPasswordTextField("confirmPassword",
- confirmPassword);
- confirmPasswordField.setResetPassword(false);
- form.add(confirmPasswordField);
-
- form.add(new Button("save"));
- Button cancel = new Button("cancel") {
- private static final long serialVersionUID = 1L;
-
- @Override
- public void onSubmit() {
- setRedirect(false);
- error(getString("gb.passwordChangeAborted"));
- setResponsePage(RepositoriesPage.class);
- }
- };
- cancel.setDefaultFormProcessing(false);
- form.add(cancel);
-
- add(form);
- }
- }
|