diff options
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.java | 150 |
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"); - } - } -} |