Set maxObjectSizeLimit when project is created via REST
Change-Id: I28f7239bc2095909eaa011b01c38be1eecd856df
This commit is contained in:
@@ -1210,6 +1210,9 @@ Whether content merge should be enabled for the project (`TRUE`,
|
|||||||
|`require_change_id` |`INHERIT` if not set|
|
|`require_change_id` |`INHERIT` if not set|
|
||||||
Whether the usage of Change-Ids is required for the project (`TRUE`,
|
Whether the usage of Change-Ids is required for the project (`TRUE`,
|
||||||
`FALSE`, `INHERIT`).
|
`FALSE`, `INHERIT`).
|
||||||
|
|`max_object_size_limit` |optional|
|
||||||
|
Max allowed Git object size for this project.
|
||||||
|
Common unit suffixes of 'k', 'm', or 'g' are supported.
|
||||||
|=========================================
|
|=========================================
|
||||||
|
|
||||||
[[project-parent-input]]
|
[[project-parent-input]]
|
||||||
|
@@ -746,7 +746,7 @@ public class ProjectConfig extends VersionedMetaData {
|
|||||||
saveGroupList();
|
saveGroupList();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final String validMaxObjectSizeLimit(String value)
|
public static final String validMaxObjectSizeLimit(String value)
|
||||||
throws ConfigInvalidException {
|
throws ConfigInvalidException {
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
return null;
|
return null;
|
||||||
|
@@ -29,12 +29,15 @@ import com.google.gerrit.reviewdb.client.AccountGroup;
|
|||||||
import com.google.gerrit.reviewdb.client.Project;
|
import com.google.gerrit.reviewdb.client.Project;
|
||||||
import com.google.gerrit.reviewdb.client.Project.InheritableBoolean;
|
import com.google.gerrit.reviewdb.client.Project.InheritableBoolean;
|
||||||
import com.google.gerrit.reviewdb.client.Project.SubmitType;
|
import com.google.gerrit.reviewdb.client.Project.SubmitType;
|
||||||
|
import com.google.gerrit.server.git.ProjectConfig;
|
||||||
import com.google.gerrit.server.group.GroupsCollection;
|
import com.google.gerrit.server.group.GroupsCollection;
|
||||||
import com.google.gerrit.server.project.CreateProject.Input;
|
import com.google.gerrit.server.project.CreateProject.Input;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.google.inject.Provider;
|
import com.google.inject.Provider;
|
||||||
import com.google.inject.assistedinject.Assisted;
|
import com.google.inject.assistedinject.Assisted;
|
||||||
|
|
||||||
|
import org.eclipse.jgit.errors.ConfigInvalidException;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@@ -53,6 +56,7 @@ class CreateProject implements RestModifyView<TopLevelResource, Input> {
|
|||||||
InheritableBoolean useSignedOffBy;
|
InheritableBoolean useSignedOffBy;
|
||||||
InheritableBoolean useContentMerge;
|
InheritableBoolean useContentMerge;
|
||||||
InheritableBoolean requireChangeId;
|
InheritableBoolean requireChangeId;
|
||||||
|
String maxObjectSizeLimit;
|
||||||
}
|
}
|
||||||
|
|
||||||
static interface Factory {
|
static interface Factory {
|
||||||
@@ -118,6 +122,11 @@ class CreateProject implements RestModifyView<TopLevelResource, Input> {
|
|||||||
input.useContentMerge, InheritableBoolean.INHERIT);
|
input.useContentMerge, InheritableBoolean.INHERIT);
|
||||||
args.changeIdRequired =
|
args.changeIdRequired =
|
||||||
Objects.firstNonNull(input.requireChangeId, InheritableBoolean.INHERIT);
|
Objects.firstNonNull(input.requireChangeId, InheritableBoolean.INHERIT);
|
||||||
|
try {
|
||||||
|
args.maxObjectSizeLimit = ProjectConfig.validLong(input.maxObjectSizeLimit);
|
||||||
|
} catch (ConfigInvalidException e) {
|
||||||
|
throw new BadRequestException(e.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
Project p = createProjectFactory.create(args).createProject();
|
Project p = createProjectFactory.create(args).createProject();
|
||||||
return Response.created(json.format(p));
|
return Response.created(json.format(p));
|
||||||
|
Reference in New Issue
Block a user