| | |
| | |
|
| | | import com.gitblit.Constants;
|
| | | import com.gitblit.Constants.AccessRestrictionType;
|
| | | import com.gitblit.Gitblit;
|
| | | import com.gitblit.IStoredSettings;
|
| | | import com.gitblit.Keys;
|
| | | import com.gitblit.client.Translation;
|
| | | import com.gitblit.manager.IGitblit;
|
| | | import com.gitblit.models.RepositoryModel;
|
| | | import com.gitblit.models.UserModel;
|
| | | import com.gitblit.utils.ArrayUtils;
|
| | |
| | |
|
| | | protected String gitblitUrl;
|
| | |
|
| | | protected String repositoryUrl;
|
| | |
|
| | | protected GroovyScriptEngine gse;
|
| | |
|
| | | private final IStoredSettings settings;
|
| | | protected final IStoredSettings settings;
|
| | |
|
| | | private final Gitblit gitblit;
|
| | | protected final IGitblit gitblit;
|
| | |
|
| | | public GitblitReceivePack(
|
| | | Gitblit gitblit,
|
| | | IGitblit gitblit,
|
| | | Repository db,
|
| | | RepositoryModel repository,
|
| | | UserModel user) {
|
| | |
| | | this.settings = gitblit.getSettings();
|
| | | this.gitblit = gitblit;
|
| | | this.repository = repository;
|
| | | this.user = user == null ? UserModel.ANONYMOUS : user;
|
| | | this.user = user;
|
| | | this.groovyDir = gitblit.getHooksFolder();
|
| | | try {
|
| | | // set Grape root
|
| | |
| | | if (repository.accessRestriction.atLeast(AccessRestrictionType.PUSH) && repository.verifyCommitter) {
|
| | | // enforce committer verification
|
| | | if (StringUtils.isEmpty(user.emailAddress)) {
|
| | | // emit warning if user does not have an email address
|
| | | LOGGER.warn(MessageFormat.format("Consider setting an email address for {0} ({1}) to improve committer verification.", user.getDisplayName(), user.username));
|
| | | // reject the push because the pushing account does not have an email address
|
| | | for (ReceiveCommand cmd : commands) {
|
| | | sendRejection(cmd, "Sorry, the account \"{0}\" does not have an email address set for committer verification!", user.username);
|
| | | }
|
| | | return;
|
| | | }
|
| | |
|
| | | // Optionally enforce that the committer of first parent chain
|
| | |
| | |
|
| | | PersonIdent committer = commit.getCommitterIdent();
|
| | | if (!user.is(committer.getName(), committer.getEmailAddress())) {
|
| | | String reason;
|
| | | if (StringUtils.isEmpty(user.emailAddress)) {
|
| | | // account does not have an email address
|
| | | reason = MessageFormat.format("{0} by {1} <{2}> was not committed by {3} ({4})",
|
| | | commit.getId().name(), committer.getName(), StringUtils.isEmpty(committer.getEmailAddress()) ? "?":committer.getEmailAddress(), user.getDisplayName(), user.username);
|
| | | } else {
|
| | | // account has an email address
|
| | | reason = MessageFormat.format("{0} by {1} <{2}> was not committed by {3} ({4}) <{5}>",
|
| | | commit.getId().name(), committer.getName(), StringUtils.isEmpty(committer.getEmailAddress()) ? "?":committer.getEmailAddress(), user.getDisplayName(), user.username, user.emailAddress);
|
| | | }
|
| | | // verification failed
|
| | | String reason = MessageFormat.format("{0} by {1} <{2}> was not committed by {3} ({4}) <{5}>",
|
| | | commit.getId().name(), committer.getName(), StringUtils.isEmpty(committer.getEmailAddress()) ? "?":committer.getEmailAddress(), user.getDisplayName(), user.username, user.emailAddress);
|
| | | LOGGER.warn(reason);
|
| | | cmd.setResult(Result.REJECTED_OTHER_REASON, reason);
|
| | | allRejected &= true;
|
| | |
| | | }
|
| | | }
|
| | |
|
| | | // reset branch commit cache on REWIND and DELETE
|
| | | for (ReceiveCommand cmd : commands) {
|
| | | String ref = cmd.getRefName();
|
| | | if (ref.startsWith(Constants.R_HEADS)) {
|
| | | switch (cmd.getType()) {
|
| | | case UPDATE_NONFASTFORWARD:
|
| | | case DELETE:
|
| | | // reset branch commit cache on REWIND and DELETE
|
| | | CommitCache.instance().clear(repository.name, ref);
|
| | | break;
|
| | | default:
|
| | |
| | | this.gitblitUrl = url;
|
| | | }
|
| | |
|
| | | protected void setRepositoryUrl(String url) {
|
| | | this.repositoryUrl = url;
|
| | | }
|
| | |
|
| | | protected void sendRejection(final ReceiveCommand cmd, final String why, Object... objects) {
|
| | | String text;
|
| | | if (ArrayUtils.isEmpty(objects)) {
|
| | |
| | | }
|
| | |
|
| | | protected void sendHeader(String msg, Object... objects) {
|
| | | sendMessage("--->", msg, objects);
|
| | | sendInfo("--> ", msg, objects);
|
| | | }
|
| | |
|
| | | protected void sendMessage(String msg, Object... objects) {
|
| | | sendMessage(" ", msg, objects);
|
| | | protected void sendInfo(String msg, Object... objects) {
|
| | | sendInfo(" ", msg, objects);
|
| | | }
|
| | |
|
| | | protected void sendMessage(String prefix, String msg, Object... objects) {
|
| | | protected void sendInfo(String prefix, String msg, Object... objects) {
|
| | | String text;
|
| | | if (ArrayUtils.isEmpty(objects)) {
|
| | | text = msg;
|