James Moger
2012-10-30 a4231d30c4d2765c80f57df79cd1d4d39a9795ea
Added null checkinng and logging for edit user permissions (issue-155)
1 files modified
13 ■■■■ changed files
src/com/gitblit/wicket/pages/EditUserPage.java 13 ●●●● patch | view | raw | blame | history
src/com/gitblit/wicket/pages/EditUserPage.java
@@ -33,13 +33,15 @@
import org.apache.wicket.model.Model;
import org.apache.wicket.model.util.CollectionModel;
import org.apache.wicket.model.util.ListModel;
import org.slf4j.LoggerFactory;
import com.gitblit.Constants.PermissionType;
import com.gitblit.Constants.RegistrantType;
import com.gitblit.GitBlit;
import com.gitblit.GitBlitException;
import com.gitblit.Keys;
import com.gitblit.Constants.PermissionType;
import com.gitblit.Constants.RegistrantType;
import com.gitblit.models.RegistrantAccessPermission;
import com.gitblit.models.RepositoryModel;
import com.gitblit.models.TeamModel;
import com.gitblit.models.UserModel;
import com.gitblit.utils.StringUtils;
@@ -109,7 +111,12 @@
                // Ensure this is NOT an owner permission - which is non-editable
                // We don't know this from within the usermodel, ownership is a
                // property of a repository.
                boolean isOwner = GitBlit.self().getRepositoryModel(permission.registrant).isOwner(oldName);
                RepositoryModel rm = GitBlit.self().getRepositoryModel(permission.registrant);
                if (rm == null) {
                    LoggerFactory.getLogger(getClass()).error("Missing repository " + permission.registrant, new NullPointerException());
                    continue;
                }
                boolean isOwner = rm.isOwner(oldName);
                if (isOwner) {
                    permission.permissionType = PermissionType.OWNER;
                    permission.isEditable = false;