blob: 86d597d5f30f827b7cb9f8f55181e21f63d7f6a7 [file] [log] [blame]
// Copyright (C) 2013 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.extensions.api.projects;
import com.google.errorprone.annotations.CanIgnoreReturnValue;
import com.google.gerrit.extensions.api.access.ProjectAccessInfo;
import com.google.gerrit.extensions.api.access.ProjectAccessInput;
import com.google.gerrit.extensions.api.config.AccessCheckInfo;
import com.google.gerrit.extensions.api.config.AccessCheckInput;
import com.google.gerrit.extensions.common.BatchLabelInput;
import com.google.gerrit.extensions.common.BatchSubmitRequirementInput;
import com.google.gerrit.extensions.common.ChangeInfo;
import com.google.gerrit.extensions.common.LabelDefinitionInfo;
import com.google.gerrit.extensions.common.ListTagSortOption;
import com.google.gerrit.extensions.common.ProjectInfo;
import com.google.gerrit.extensions.common.SubmitRequirementInfo;
import com.google.gerrit.extensions.restapi.RestApiException;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
public interface ProjectApi {
ProjectApi create() throws RestApiException;
ProjectApi create(ProjectInput in) throws RestApiException;
ProjectInfo get() throws RestApiException;
String description() throws RestApiException;
void description(DescriptionInput in) throws RestApiException;
ProjectAccessInfo access() throws RestApiException;
@CanIgnoreReturnValue
ProjectAccessInfo access(ProjectAccessInput p) throws RestApiException;
ChangeInfo accessChange(ProjectAccessInput p) throws RestApiException;
AccessCheckInfo checkAccess(AccessCheckInput in) throws RestApiException;
CheckProjectResultInfo check(CheckProjectInput in) throws RestApiException;
ConfigInfo config() throws RestApiException;
@CanIgnoreReturnValue
ConfigInfo config(ConfigInput in) throws RestApiException;
@CanIgnoreReturnValue
ChangeInfo configReview(ConfigInput in) throws RestApiException;
Map<String, Set<String>> commitsIn(Collection<String> commits, Collection<String> refs)
throws RestApiException;
ListRefsRequest<BranchInfo> branches();
ListRefsRequest<TagInfo> tags();
void deleteBranches(DeleteBranchesInput in) throws RestApiException;
void deleteTags(DeleteTagsInput in) throws RestApiException;
abstract class ListRefsRequest<T extends RefInfo> {
protected int limit;
protected int start;
protected boolean descendingOrder;
protected String substring;
protected String regex;
protected String nextPageToken;
protected ListTagSortOption sortBy = ListTagSortOption.REF;
public abstract List<T> get() throws RestApiException;
public ListRefsRequest<T> withLimit(int limit) {
this.limit = limit;
return this;
}
public ListRefsRequest<T> withStart(int start) {
this.start = start;
return this;
}
public ListRefsRequest<T> withDescendingOrder(boolean descendingOrder) {
this.descendingOrder = descendingOrder;
return this;
}
public ListRefsRequest<T> withSortBy(ListTagSortOption sortBy) {
this.sortBy = sortBy;
return this;
}
public ListRefsRequest<T> withNextPageToken(String token) {
this.nextPageToken = token;
return this;
}
public ListRefsRequest<T> withSubstring(String substring) {
this.substring = substring;
return this;
}
public ListRefsRequest<T> withRegex(String regex) {
this.regex = regex;
return this;
}
public int getLimit() {
return limit;
}
public int getStart() {
return start;
}
public boolean getDescendingOrder() {
return descendingOrder;
}
public ListTagSortOption getSortBy() {
return sortBy;
}
public String getNextPageToken() {
return nextPageToken;
}
public String getSubstring() {
return substring;
}
public String getRegex() {
return regex;
}
}
List<ProjectInfo> children() throws RestApiException;
List<ProjectInfo> children(boolean recursive) throws RestApiException;
List<ProjectInfo> children(int limit) throws RestApiException;
ChildProjectApi child(String name) throws RestApiException;
/**
* Look up a branch by refname.
*
* <p><strong>Note:</strong> This method eagerly reads the branch. Methods that mutate the branch
* do not necessarily re-read the branch. Therefore, calling a getter method on an instance after
* calling a mutation method on that same instance is not guaranteed to reflect the mutation. It
* is not recommended to store references to {@code BranchApi} instances.
*
* @param ref branch name, with or without "refs/heads/" prefix.
* @throws RestApiException if a problem occurred reading the project.
* @return API for accessing the branch.
*/
BranchApi branch(String ref) throws RestApiException;
/**
* Look up a tag by refname.
*
* <p>
*
* @param ref tag name, with or without "refs/tags/" prefix.
* @throws RestApiException if a problem occurred reading the project.
* @return API for accessing the tag.
*/
TagApi tag(String ref) throws RestApiException;
/**
* Lookup a commit by its {@code ObjectId} string.
*
* @param commit the {@code ObjectId} string.
* @return API for accessing the commit.
*/
CommitApi commit(String commit) throws RestApiException;
/**
* Lookup a dashboard by its name.
*
* @param name the name.
* @return API for accessing the dashboard.
*/
DashboardApi dashboard(String name) throws RestApiException;
/**
* Get the project's default dashboard.
*
* @return API for accessing the dashboard.
*/
DashboardApi defaultDashboard() throws RestApiException;
/**
* Set the project's default dashboard.
*
* @param name the dashboard to set as default.
*/
void defaultDashboard(String name) throws RestApiException;
/** Remove the project's default dashboard. */
void removeDefaultDashboard() throws RestApiException;
abstract class ListDashboardsRequest {
public abstract List<DashboardInfo> get() throws RestApiException;
}
ListDashboardsRequest dashboards() throws RestApiException;
/** Get the name of the branch to which {@code HEAD} points. */
String head() throws RestApiException;
/**
* Set the project's {@code HEAD}.
*
* @param head the HEAD
*/
void head(String head) throws RestApiException;
/** Get the name of the project's parent. */
String parent() throws RestApiException;
/**
* Set the project's parent.
*
* @param parent the parent
*/
void parent(String parent) throws RestApiException;
/**
* Reindex the project and children in case {@code indexChildren} is specified.
*
* @param indexChildren decides if children should be indexed recursively
*/
void index(boolean indexChildren) throws RestApiException;
/** Reindexes all changes of the project. */
void indexChanges() throws RestApiException;
ListLabelsRequest labels() throws RestApiException;
abstract class ListLabelsRequest {
protected boolean inherited;
public abstract List<LabelDefinitionInfo> get() throws RestApiException;
public ListLabelsRequest withInherited(boolean inherited) {
this.inherited = inherited;
return this;
}
}
LabelApi label(String labelName) throws RestApiException;
ListSubmitRequirementsRequest submitRequirements() throws RestApiException;
abstract class ListSubmitRequirementsRequest {
protected boolean inherited;
public abstract List<SubmitRequirementInfo> get() throws RestApiException;
public ListSubmitRequirementsRequest withInherited(boolean inherited) {
this.inherited = inherited;
return this;
}
}
SubmitRequirementApi submitRequirement(String name) throws RestApiException;
/**
* Adds, updates and deletes label definitions in a batch.
*
* @param input input that describes additions, updates and deletions of label definitions
*/
void labels(BatchLabelInput input) throws RestApiException;
/** Same as {@link #labels(BatchLabelInput)}, but creates a change with required updates. */
@CanIgnoreReturnValue
ChangeInfo labelsReview(BatchLabelInput input) throws RestApiException;
/**
* Adds, updates and deletes submit requirements definitions in a batch.
*
* @param input input that describes additions, updates and deletions of submit requirements
*/
void submitRequirements(BatchSubmitRequirementInput input) throws RestApiException;
/**
* Creates a change with required submit requirements updates.
*
* <p>See {@link #submitRequirements(BatchSubmitRequirementInput)} for details
*/
@CanIgnoreReturnValue
ChangeInfo submitRequirementsReview(BatchSubmitRequirementInput input) throws RestApiException;
}