summaryrefslogtreecommitdiffstats
path: root/src/main/java/com/google/gerrit/server/ssh/commands/AdminCreateProject.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/com/google/gerrit/server/ssh/commands/AdminCreateProject.java')
-rw-r--r--src/main/java/com/google/gerrit/server/ssh/commands/AdminCreateProject.java150
1 files changed, 0 insertions, 150 deletions
diff --git a/src/main/java/com/google/gerrit/server/ssh/commands/AdminCreateProject.java b/src/main/java/com/google/gerrit/server/ssh/commands/AdminCreateProject.java
deleted file mode 100644
index 1c76b05af3..0000000000
--- a/src/main/java/com/google/gerrit/server/ssh/commands/AdminCreateProject.java
+++ /dev/null
@@ -1,150 +0,0 @@
-// Copyright (C) 2009 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.server.ssh.commands;
-
-import com.google.gerrit.client.reviewdb.AccountGroup;
-import com.google.gerrit.client.reviewdb.ApprovalCategory;
-import com.google.gerrit.client.reviewdb.Project;
-import com.google.gerrit.client.reviewdb.ProjectRight;
-import com.google.gerrit.client.reviewdb.ReviewDb;
-import com.google.gerrit.client.reviewdb.Project.SubmitType;
-import com.google.gerrit.git.GitRepositoryManager;
-import com.google.gerrit.git.ReplicationQueue;
-import com.google.gerrit.server.config.AuthConfig;
-import com.google.gerrit.server.ssh.AdminCommand;
-import com.google.gerrit.server.ssh.BaseCommand;
-import com.google.gwtorm.client.OrmException;
-import com.google.gwtorm.client.Transaction;
-import com.google.inject.Inject;
-
-import org.eclipse.jgit.lib.Constants;
-import org.eclipse.jgit.lib.Repository;
-import org.kohsuke.args4j.Option;
-
-import java.io.PrintWriter;
-import java.util.Collections;
-
-/** Create a new project. **/
-@AdminCommand
-final class AdminCreateProject extends BaseCommand {
- @Option(name = "--name", required = true, aliases = {"-n"}, metaVar = "NAME", usage = "name of project to be created")
- private String projectName;
-
- @Option(name = "--owner", aliases = {"-o"}, usage = "owner of project\n"
- + "(default: Administrators)")
- private AccountGroup.Id ownerId;
-
- @Option(name = "--description", aliases = {"-d"}, metaVar = "DESC", 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 = SubmitType.MERGE_IF_NECESSARY;
-
- @Option(name = "--use-contributor-agreements", aliases = {"--ca"}, usage = "if contributor agreement is required")
- private boolean contributorAgreements;
-
- @Option(name = "--use-signed-off-by", aliases = {"--so"}, usage = "if signed-off-by is required")
- private boolean signedOffBy;
-
- @Option(name = "--branch", aliases = {"-b"}, metaVar = "BRANCH", usage = "initial branch name\n"
- + "(default: master)")
- private String branch = Constants.MASTER;
-
- @Inject
- private ReviewDb db;
-
- @Inject
- private GitRepositoryManager repoManager;
-
- @Inject
- private AuthConfig authConfig;
-
- @Inject
- private ReplicationQueue rq;
-
- @Override
- public void start() {
- startThread(new CommandRunnable() {
- @Override
- public void run() throws Exception {
- PrintWriter p = toPrintWriter(out);
-
- ownerId = authConfig.getAdministratorsGroup();
- parseCommandLine();
-
- try {
- validateParameters();
-
- Transaction txn = db.beginTransaction();
-
- createProject(txn);
-
- Repository repo = repoManager.createRepository(projectName);
- repo.create(true);
- repo.writeSymref(Constants.HEAD, branch);
- repoManager.setProjectDescription(projectName, projectDescription);
-
- txn.commit();
-
- rq.replicateNewProject(new Project.NameKey(projectName), branch);
- } catch (Exception e) {
- p.print("Error when trying to create project: " + e.getMessage()
- + "\n");
- p.flush();
- }
-
- }
- });
- }
-
- private void createProject(Transaction txn) throws OrmException {
- final Project.NameKey newProjectNameKey = new Project.NameKey(projectName);
-
- final Project newProject =
- new Project(newProjectNameKey, new Project.Id(db.nextProjectId()));
-
- newProject.setDescription(projectDescription);
- newProject.setSubmitType(submitType);
- newProject.setUseContributorAgreements(contributorAgreements);
- newProject.setUseSignedOffBy(signedOffBy);
-
- db.projects().insert(Collections.singleton(newProject), txn);
-
- final ProjectRight.Key prk =
- new ProjectRight.Key(newProjectNameKey, ApprovalCategory.OWN, ownerId);
- final ProjectRight pr = new ProjectRight(prk);
- pr.setMaxValue((short) 1);
- pr.setMinValue((short) 1);
- db.projectRights().insert(Collections.singleton(pr), txn);
- }
-
- private void validateParameters() throws Failure {
- if (projectName.endsWith(".git")) {
- projectName =
- projectName.substring(0, projectName.length() - ".git".length());
- }
-
- while (branch.startsWith("/")) {
- branch = branch.substring(1);
- }
- if (!branch.startsWith(Constants.R_HEADS)) {
- branch = Constants.R_HEADS + branch;
- }
- if (!Repository.isValidRefName(branch)) {
- throw new Failure(1, "--branch \"" + branch + "\" is not a valid name");
- }
- }
-}