com.jdroid.github.service.PullRequestService Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2011 GitHub Inc.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Kevin Sawicki (GitHub Inc.) - initial API and implementation
*******************************************************************************/
package com.jdroid.github.service;
import com.google.gson.reflect.TypeToken;
import com.jdroid.github.CommitComment;
import com.jdroid.github.CommitFile;
import com.jdroid.github.IRepositoryIdProvider;
import com.jdroid.github.MergeStatus;
import com.jdroid.github.PullRequest;
import com.jdroid.github.RepositoryCommit;
import com.jdroid.github.client.GitHubClient;
import com.jdroid.github.client.GitHubRequest;
import com.jdroid.github.client.PageIterator;
import com.jdroid.github.client.PagedRequest;
import java.io.IOException;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import static com.jdroid.github.client.IGitHubConstants.SEGMENT_COMMENTS;
import static com.jdroid.github.client.IGitHubConstants.SEGMENT_COMMITS;
import static com.jdroid.github.client.IGitHubConstants.SEGMENT_FILES;
import static com.jdroid.github.client.IGitHubConstants.SEGMENT_MERGE;
import static com.jdroid.github.client.IGitHubConstants.SEGMENT_PULLS;
import static com.jdroid.github.client.IGitHubConstants.SEGMENT_REPOS;
import static com.jdroid.github.client.PagedRequest.PAGE_FIRST;
import static com.jdroid.github.client.PagedRequest.PAGE_SIZE;
/**
* Service class for creating, updating, getting, and listing pull requests as
* well as getting the commits associated with a pull request and the files
* modified by a pull request.
*
* @see GitHub Pull Requests API
* documentation
* @see GitHub Pull
* Request comments API documentation
*/
public class PullRequestService extends GitHubService {
/**
* PR_TITLE
*/
public static final String PR_TITLE = "title"; //$NON-NLS-1$
/**
* PR_BODY
*/
public static final String PR_BODY = "body"; //$NON-NLS-1$
/**
* PR_BASE
*/
public static final String PR_BASE = "base"; //$NON-NLS-1$
/**
* PR_HEAD
*/
public static final String PR_HEAD = "head"; //$NON-NLS-1$
/**
* PR_STATE
*/
public static final String PR_STATE = "state"; //$NON-NLS-1$
public static final String ISSUE = "issue";
/**
* Create pull request service
*/
public PullRequestService() {
super();
}
/**
* Create pull request service
*
* @param client
*/
public PullRequestService(GitHubClient client) {
super(client);
}
/**
* Create request for single pull request
*
* @param repository
* @param id
* @return request
* @throws IOException
*/
public PullRequest getPullRequest(IRepositoryIdProvider repository, int id)
throws IOException {
final String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(id);
GitHubRequest request = createRequest();
request.setUri(uri);
request.setType(PullRequest.class);
return (PullRequest) client.get(request).getBody();
}
/**
* Create request for single pull request
*
* @param repository
* @param state
* @param head
* @param base
* @return request
*/
public PullRequest getPullRequest(IRepositoryIdProvider repository, String state, String head, String base)
throws IOException {
PullRequest pullRequest = null;
List pullRequests = getAll(pagePullRequests(repository, state, head, base));
if (pullRequests.size() > 1) {
throw new RuntimeException("Expected just one pull request");
} else if (!pullRequests.isEmpty()) {
pullRequest = pullRequests.get(0);
}
return pullRequest;
}
/**
* Create paged request for fetching pull requests
*
* @param provider
* @param state
* @param start
* @param size
* @return paged request
*/
protected PagedRequest createPagedRequest(IRepositoryIdProvider provider, String state, String head, String base, int start, int size) {
final String id = getId(provider);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(id);
uri.append(SEGMENT_PULLS);
PagedRequest request = createPagedRequest(start, size);
request.setUri(uri);
Map params = new HashMap<>();
if (state != null) {
params.put(IssueService.FILTER_STATE, state);
}
if (head != null) {
params.put(PR_HEAD, head);
}
if (base != null) {
params.put(PR_BASE, base);
}
if (!params.isEmpty()) {
request.setParams(params);
}
request.setType(new TypeToken>() {
}.getType());
return request;
}
/**
* Get pull requests from repository matching state
*
* @param repository
* @param state
* @return list of pull requests
* @throws IOException
*/
public List getPullRequests(IRepositoryIdProvider repository,
String state) throws IOException {
return getAll(pagePullRequests(repository, state, null, null));
}
/**
* Page pull requests with given state
*
* @param repository
* @param state
* @return iterator over pages of pull requests
*/
public PageIterator pagePullRequests(
IRepositoryIdProvider repository, String state, String head, String base) {
return pagePullRequests(repository, state, head, base, PAGE_SIZE);
}
/**
* Page pull requests with given state
*
* @param repository
* @param state
* @param size
* @return iterator over pages of pull requests
*/
public PageIterator pagePullRequests(
IRepositoryIdProvider repository, String state, String head, String base, int size) {
return pagePullRequests(repository, state, head, base, PAGE_FIRST, size);
}
/**
* Page pull requests with given state
*
* @param repository
* @param state
* @param start
* @param size
* @return iterator over pages of pull requests
*/
public PageIterator pagePullRequests(
IRepositoryIdProvider repository, String state, String head, String base, int start, int size) {
PagedRequest request = createPagedRequest(repository,
state, head, base, start, size);
return createPageIterator(request);
}
/**
* Create pull request
*
* @param repository
* @return created pull request
* @throws IOException
*/
public PullRequest createPullRequest(IRepositoryIdProvider repository, String title, String body, String head, String base) throws IOException {
String id = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(id);
uri.append(SEGMENT_PULLS);
Map params = new HashMap<>();
params.put(PR_TITLE, title);
params.put(PR_BODY, body);
params.put(PR_BASE, base);
params.put(PR_HEAD, head);
return client.post(uri.toString(), params, PullRequest.class);
}
/**
* Create pull request by attaching branch information to an existing issue
*
* @param repository
* @param issueId
* @param head
* @param base
* @return created pull request
* @throws IOException
*/
public PullRequest createPullRequest(IRepositoryIdProvider repository,
int issueId, String head, String base) throws IOException {
String id = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(id);
uri.append(SEGMENT_PULLS);
Map params = new HashMap();
params.put(ISSUE, issueId);
params.put(PR_HEAD, head);
params.put(PR_BASE, base);
return client.post(uri.toString(), params, PullRequest.class);
}
/**
* Edit pull request
*
* @param repository
* @return edited pull request
* @throws IOException
*/
public PullRequest editPullRequest(IRepositoryIdProvider repository, int number, String title, String body, String state, String base) throws IOException {
String id = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(id);
uri.append(SEGMENT_PULLS);
uri.append('/').append(number);
Map params = new HashMap<>();
params.put(PR_TITLE, title);
params.put(PR_BODY, body);
params.put(PR_STATE, state);
params.put(PR_BASE, base);
return client.post(uri.toString(), params, PullRequest.class);
}
public PullRequest closePullRequest(IRepositoryIdProvider repository, int number) throws IOException {
String id = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(id);
uri.append(SEGMENT_PULLS);
uri.append('/').append(number);
Map params = new HashMap<>();
params.put(PR_STATE, IssueService.STATE_CLOSED);
return client.post(uri.toString(), params, PullRequest.class);
}
/**
* Get all commits associated with given pull request id
*
* @param repository
* @param id
* @return list of commits
* @throws IOException
*/
public List getCommits(IRepositoryIdProvider repository,
int id) throws IOException {
final String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(id);
uri.append(SEGMENT_COMMITS);
PagedRequest request = createPagedRequest();
request.setUri(uri);
request.setType(new TypeToken>() {
}.getType());
return getAll(request);
}
/**
* Get all changed files associated with given pull request id
*
* @param repository
* @param id
* @return list of commit files
* @throws IOException
*/
public List getFiles(IRepositoryIdProvider repository, int id)
throws IOException {
final String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(id);
uri.append(SEGMENT_FILES);
PagedRequest request = createPagedRequest();
request.setUri(uri);
request.setType(new TypeToken>() {
}.getType());
return getAll(request);
}
/**
* Is the given pull request id merged?
*
* @param repository
* @param id
* @return true if merge, false otherwise
* @throws IOException
*/
public boolean isMerged(IRepositoryIdProvider repository, int id)
throws IOException {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(id);
uri.append(SEGMENT_MERGE);
return check(uri.toString());
}
/**
* Merge given pull request
*
* @param repository
* @param number
* @param commitMessage
* @return status of merge
* @throws IOException
*/
public MergeStatus merge(IRepositoryIdProvider repository, int number,
String commitMessage) throws IOException {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(number);
uri.append(SEGMENT_MERGE);
return client.put(uri.toString(),
Collections.singletonMap("commit_message", commitMessage), //$NON-NLS-1$
MergeStatus.class);
}
/**
* Get all comments on commits in given pull request
*
* @param repository
* @param id
* @return non-null list of comments
* @throws IOException
*/
public List getComments(IRepositoryIdProvider repository,
int id) throws IOException {
return getAll(pageComments(repository, id));
}
/**
* Page pull request commit comments
*
* @param repository
* @param id
* @return iterator over pages of commit comments
*/
public PageIterator pageComments(
IRepositoryIdProvider repository, int id) {
return pageComments(repository, id, PAGE_SIZE);
}
/**
* Page pull request commit comments
*
* @param repository
* @param id
* @param size
* @return iterator over pages of commit comments
*/
public PageIterator pageComments(
IRepositoryIdProvider repository, int id, int size) {
return pageComments(repository, id, PAGE_FIRST, size);
}
/**
* Page pull request commit comments
*
* @param repository
* @param id
* @param start
* @param size
* @return iterator over pages of commit comments
*/
public PageIterator pageComments(
IRepositoryIdProvider repository, int id, int start, int size) {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(id);
uri.append(SEGMENT_COMMENTS);
PagedRequest request = createPagedRequest(start, size);
request.setUri(uri);
request.setType(new TypeToken>() {
}.getType());
return createPageIterator(request);
}
/**
* Get commit comment with given id
*
* @param repository
* @param commentId
* @return commit comment
* @throws IOException
*/
public CommitComment getComment(IRepositoryIdProvider repository,
long commentId) throws IOException {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append(SEGMENT_COMMENTS);
uri.append('/').append(commentId);
GitHubRequest request = createRequest();
request.setUri(uri);
request.setType(CommitComment.class);
return (CommitComment) client.get(request).getBody();
}
/**
* Create comment on given pull request
*
* @param repository
* @param id
* @param comment
* @return created commit comment
* @throws IOException
*/
public CommitComment createComment(IRepositoryIdProvider repository,
int id, CommitComment comment) throws IOException {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(id);
uri.append(SEGMENT_COMMENTS);
return client.post(uri.toString(), comment, CommitComment.class);
}
/**
* Reply to given comment
*
* @param repository
* @param pullRequestId
* @param commentId
* @param body
* @return created comment
* @throws IOException
*/
public CommitComment replyToComment(IRepositoryIdProvider repository,
int pullRequestId, int commentId, String body) throws IOException {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append('/').append(pullRequestId);
uri.append(SEGMENT_COMMENTS);
Map params = new HashMap();
params.put("in_reply_to", Integer.toString(commentId)); //$NON-NLS-1$
params.put("body", body); //$NON-NLS-1$
return client.post(uri.toString(), params, CommitComment.class);
}
/**
* Edit pull request comment
*
* @param repository
* @param comment
* @return edited comment
* @throws IOException
*/
public CommitComment editComment(IRepositoryIdProvider repository,
CommitComment comment) throws IOException {
String repoId = getId(repository);
if (comment == null)
throw new IllegalArgumentException("Comment cannot be null"); //$NON-NLS-1$
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append(SEGMENT_COMMENTS);
uri.append('/').append(comment.getId());
return client.post(uri.toString(), comment, CommitComment.class);
}
/**
* Delete commit comment with given id
*
* @param repository
* @param commentId
* @throws IOException
*/
public void deleteComment(IRepositoryIdProvider repository, long commentId)
throws IOException {
String repoId = getId(repository);
StringBuilder uri = new StringBuilder(SEGMENT_REPOS);
uri.append('/').append(repoId);
uri.append(SEGMENT_PULLS);
uri.append(SEGMENT_COMMENTS);
uri.append('/').append(commentId);
client.delete(uri.toString());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy