com.spotify.github.v3.clients.GithubAppClient Maven / Gradle / Ivy
The newest version!
/*-
* -\-\-
* github-api
* --
* Copyright (C) 2016 - 2020 Spotify AB
* --
* 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.spotify.github.v3.clients;
import com.fasterxml.jackson.core.type.TypeReference;
import com.google.common.collect.ImmutableMap;
import com.spotify.github.v3.apps.InstallationRepositoriesResponse;
import com.spotify.github.v3.checks.AccessToken;
import com.spotify.github.v3.checks.Installation;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.CompletableFuture;
import javax.ws.rs.core.HttpHeaders;
/** Apps API client */
public class GithubAppClient {
private static final String GET_INSTALLATION_BY_ID_URL = "/app/installations/%s";
private static final String GET_ACCESS_TOKEN_URL = "/app/installations/%s/access_tokens";
private static final String GET_INSTALLATIONS_URL = "/app/installations?per_page=100";
private static final String GET_INSTALLATION_REPO_URL = "/repos/%s/%s/installation";
private static final String LIST_ACCESSIBLE_REPOS_URL = "/installation/repositories";
/*
Owner and org are interchangeable and therefore "owner" is used to
refer to the organisation in the installation endpoint
*/
private static final String GET_INSTALLATION_ORG_URL = "/orgs/%s/installation";
private static final String GET_INSTALLATION_USER_URL = "/users/%s/installation";
private final GitHubClient github;
private final String owner;
private final Optional maybeRepo;
private final Map extraHeaders =
ImmutableMap.of(HttpHeaders.ACCEPT, "application/vnd.github.machine-man-preview+json");
private static final TypeReference> INSTALLATION_LIST_TYPE_REFERENCE =
new TypeReference<>() {};
GithubAppClient(final GitHubClient github, final String owner, final String repo) {
this.github = github;
this.owner = owner;
this.maybeRepo = Optional.of(repo);
}
GithubAppClient(final GitHubClient github, final String owner) {
this.github = github;
this.owner = owner;
this.maybeRepo = Optional.empty();
}
/**
* List Installations of an app.
*
* @return a list of Installation
*/
public CompletableFuture> getInstallations() {
return github.request(GET_INSTALLATIONS_URL, INSTALLATION_LIST_TYPE_REFERENCE, extraHeaders);
}
/**
* Get Installation of repo or org
*
* @return an Installation
*/
public CompletableFuture getInstallation() {
return maybeRepo.map(this::getRepoInstallation).orElseGet(this::getOrgInstallation);
}
/**
* Get Installation identified by its installation id
*
* @return an Installation
*/
public CompletableFuture getInstallation(final Integer installationId) {
return github.request(
String.format(GET_INSTALLATION_BY_ID_URL, installationId), Installation.class);
}
/**
* Get an installation of a repo
* @return an Installation
*/
private CompletableFuture getRepoInstallation(final String repo) {
return github.request(
String.format(GET_INSTALLATION_REPO_URL, owner, repo), Installation.class);
}
/**
* Get an installation of an org
* @return an Installation
*/
private CompletableFuture getOrgInstallation() {
return github.request(
String.format(GET_INSTALLATION_ORG_URL, owner), Installation.class);
}
/**
* Get an installation of a user
* @return an Installation
*/
public CompletableFuture getUserInstallation() {
return github.request(
String.format(GET_INSTALLATION_USER_URL, owner), Installation.class);
}
/**
* Authenticates as an installation
*
* @return an Installation Token
*/
public CompletableFuture getAccessToken(final Integer installationId) {
final String path = String.format(GET_ACCESS_TOKEN_URL, installationId);
return github.post(path, "", AccessToken.class, extraHeaders);
}
/**
* Lists the repositories that an app installation can access.
*
* see
* https://docs.github.com/en/free-pro-team@latest/rest/reference/apps#list-repositories-accessible-to-the-app-installation
*/
public CompletableFuture listAccessibleRepositories(
final int installationId) {
return GitHubClient.scopeForInstallationId(github, installationId)
.request(LIST_ACCESSIBLE_REPOS_URL, InstallationRepositoriesResponse.class, extraHeaders);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy