summaryrefslogtreecommitdiffstats
path: root/gerrit-sshd/src/main/java/com/google/gerrit/sshd/commands/SetProjectCommand.java
diff options
context:
space:
mode:
Diffstat (limited to 'gerrit-sshd/src/main/java/com/google/gerrit/sshd/commands/SetProjectCommand.java')
-rw-r--r--gerrit-sshd/src/main/java/com/google/gerrit/sshd/commands/SetProjectCommand.java157
1 files changed, 0 insertions, 157 deletions
diff --git a/gerrit-sshd/src/main/java/com/google/gerrit/sshd/commands/SetProjectCommand.java b/gerrit-sshd/src/main/java/com/google/gerrit/sshd/commands/SetProjectCommand.java
deleted file mode 100644
index 6b3fcf2770..0000000000
--- a/gerrit-sshd/src/main/java/com/google/gerrit/sshd/commands/SetProjectCommand.java
+++ /dev/null
@@ -1,157 +0,0 @@
-// Copyright (C) 2012 The Android Open Source Project
-//
-// 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.google.gerrit.sshd.commands;
-
-import com.google.common.base.Strings;
-import com.google.gerrit.extensions.api.projects.ConfigInput;
-import com.google.gerrit.extensions.client.InheritableBoolean;
-import com.google.gerrit.extensions.client.ProjectState;
-import com.google.gerrit.extensions.client.SubmitType;
-import com.google.gerrit.extensions.restapi.RestApiException;
-import com.google.gerrit.server.project.ProjectControl;
-import com.google.gerrit.server.project.ProjectResource;
-import com.google.gerrit.server.project.PutConfig;
-import com.google.gerrit.sshd.CommandMetaData;
-import com.google.gerrit.sshd.SshCommand;
-import com.google.inject.Inject;
-import org.kohsuke.args4j.Argument;
-import org.kohsuke.args4j.Option;
-
-@CommandMetaData(name = "set-project", description = "Change a project's settings")
-final class SetProjectCommand extends SshCommand {
- @Argument(index = 0, required = true, metaVar = "NAME", usage = "name of the project")
- private ProjectControl projectControl;
-
- @Option(
- name = "--description",
- aliases = {"-d"},
- metaVar = "DESCRIPTION",
- usage = "description of project")
- private String projectDescription;
-
- @Option(
- name = "--submit-type",
- aliases = {"-t"},
- usage = "project submit type\n(default: MERGE_IF_NECESSARY)")
- private SubmitType submitType;
-
- @Option(name = "--contributor-agreements", usage = "if contributor agreement is required")
- private InheritableBoolean contributorAgreements;
-
- @Option(name = "--signed-off-by", usage = "if signed-off-by is required")
- private InheritableBoolean signedOffBy;
-
- @Option(name = "--content-merge", usage = "allow automatic conflict resolving within files")
- private InheritableBoolean contentMerge;
-
- @Option(name = "--change-id", usage = "if change-id is required")
- private InheritableBoolean requireChangeID;
-
- @Option(
- name = "--use-contributor-agreements",
- aliases = {"--ca"},
- usage = "if contributor agreement is required")
- void setUseContributorArgreements(@SuppressWarnings("unused") boolean on) {
- contributorAgreements = InheritableBoolean.TRUE;
- }
-
- @Option(
- name = "--no-contributor-agreements",
- aliases = {"--nca"},
- usage = "if contributor agreement is not required")
- void setNoContributorArgreements(@SuppressWarnings("unused") boolean on) {
- contributorAgreements = InheritableBoolean.FALSE;
- }
-
- @Option(
- name = "--use-signed-off-by",
- aliases = {"--so"},
- usage = "if signed-off-by is required")
- void setUseSignedOffBy(@SuppressWarnings("unused") boolean on) {
- signedOffBy = InheritableBoolean.TRUE;
- }
-
- @Option(
- name = "--no-signed-off-by",
- aliases = {"--nso"},
- usage = "if signed-off-by is not required")
- void setNoSignedOffBy(@SuppressWarnings("unused") boolean on) {
- signedOffBy = InheritableBoolean.FALSE;
- }
-
- @Option(name = "--use-content-merge", usage = "allow automatic conflict resolving within files")
- void setUseContentMerge(@SuppressWarnings("unused") boolean on) {
- contentMerge = InheritableBoolean.TRUE;
- }
-
- @Option(
- name = "--no-content-merge",
- usage = "don't allow automatic conflict resolving within files")
- void setNoContentMerge(@SuppressWarnings("unused") boolean on) {
- contentMerge = InheritableBoolean.FALSE;
- }
-
- @Option(
- name = "--require-change-id",
- aliases = {"--id"},
- usage = "if change-id is required")
- void setRequireChangeId(@SuppressWarnings("unused") boolean on) {
- requireChangeID = InheritableBoolean.TRUE;
- }
-
- @Option(
- name = "--no-change-id",
- aliases = {"--nid"},
- usage = "if change-id is not required")
- void setNoChangeId(@SuppressWarnings("unused") boolean on) {
- requireChangeID = InheritableBoolean.FALSE;
- }
-
- @Option(
- name = "--project-state",
- aliases = {"--ps"},
- usage = "project's visibility state")
- private ProjectState state;
-
- @Option(name = "--max-object-size-limit", usage = "max Git object size for this project")
- private String maxObjectSizeLimit;
-
- @Inject private PutConfig putConfig;
-
- @Override
- protected void run() throws Failure {
- ConfigInput configInput = new ConfigInput();
- configInput.requireChangeId = requireChangeID;
- configInput.submitType = submitType;
- configInput.useContentMerge = contentMerge;
- configInput.useContributorAgreements = contributorAgreements;
- configInput.useSignedOffBy = signedOffBy;
- configInput.state = state;
- configInput.maxObjectSizeLimit = maxObjectSizeLimit;
- // Description is different to other parameters, null won't result in
- // keeping the existing description, it would delete it.
- if (Strings.emptyToNull(projectDescription) != null) {
- configInput.description = projectDescription;
- } else {
- configInput.description = projectControl.getProject().getDescription();
- }
-
- try {
- putConfig.apply(new ProjectResource(projectControl), configInput);
- } catch (RestApiException e) {
- throw die(e);
- }
- }
-}