All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.kohsuke.github.GHApp Maven / Gradle / Ivy

There is a newer version: 2.0.0-alpha-2
Show newest version
package org.kohsuke.github;

import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
import org.kohsuke.github.internal.EnumUtils;

import java.io.IOException;
import java.net.URL;
import java.util.Collections;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

// TODO: Auto-generated Javadoc
/**
 * A Github App.
 *
 * @author Paulo Miguel Almeida
 * @see GitHub#getApp() GitHub#getApp()
 */
public class GHApp extends GHObject {

    /**
     * Create default GHApp instance
     */
    public GHApp() {
    }

    private GHUser owner;
    private String name;
    private String slug;
    private String description;
    private String externalUrl;
    private Map permissions;
    private List events;
    private long installationsCount;
    private String htmlUrl;

    /**
     * Gets owner.
     *
     * @return the owner
     */
    @SuppressFBWarnings(value = { "EI_EXPOSE_REP" }, justification = "Expected behavior")
    public GHUser getOwner() {
        return owner;
    }

    /**
     * Sets owner.
     *
     * @param owner
     *            the owner
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setOwner(GHUser owner) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Gets name.
     *
     * @return the name
     */
    public String getName() {
        return name;
    }

    /**
     * Gets the slug name of the GitHub app.
     *
     * @return the slug name of the GitHub app
     */
    public String getSlug() {
        return slug;
    }

    /**
     * Sets name.
     *
     * @param name
     *            the name
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setName(String name) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Gets description.
     *
     * @return the description
     */
    public String getDescription() {
        return description;
    }

    /**
     * Sets description.
     *
     * @param description
     *            the description
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setDescription(String description) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Gets external url.
     *
     * @return the external url
     */
    public String getExternalUrl() {
        return externalUrl;
    }

    /**
     * Sets external url.
     *
     * @param externalUrl
     *            the external url
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setExternalUrl(String externalUrl) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Gets events.
     *
     * @return the events
     */
    public List getEvents() {
        return events.stream()
                .map(e -> EnumUtils.getEnumOrDefault(GHEvent.class, e, GHEvent.UNKNOWN))
                .collect(Collectors.toList());
    }

    /**
     * Sets events.
     *
     * @param events
     *            the events
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setEvents(List events) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Gets installations count.
     *
     * @return the installations count
     */
    public long getInstallationsCount() {
        return installationsCount;
    }

    /**
     * Sets installations count.
     *
     * @param installationsCount
     *            the installations count
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setInstallationsCount(long installationsCount) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Gets the html url.
     *
     * @return the html url
     */
    public URL getHtmlUrl() {
        return GitHubClient.parseURL(htmlUrl);
    }

    /**
     * Gets permissions.
     *
     * @return the permissions
     */
    public Map getPermissions() {
        return Collections.unmodifiableMap(permissions);
    }

    /**
     * Sets permissions.
     *
     * @param permissions
     *            the permissions
     * @deprecated Do not use this method. It was added due to incomplete understanding of Jackson binding.
     */
    @Deprecated
    public void setPermissions(Map permissions) {
        throw new RuntimeException("Do not use this method.");
    }

    /**
     * Obtains all the installations associated with this app.
     * 

* You must use a JWT to access this endpoint. * * @return a list of App installations * @see List installations */ public PagedIterable listInstallations() { return listInstallations(null); } /** * Obtains all the installations associated with this app since a given date. *

* You must use a JWT to access this endpoint. * * @param since * - Allows users to get installations that have been updated since a given date. * @return a list of App installations since a given time. * @see List installations */ public PagedIterable listInstallations(final Date since) { Requester requester = root().createRequest().withUrlPath("/app/installations"); if (since != null) { requester.with("since", GitHubClient.printDate(since)); } return requester.toIterable(GHAppInstallation[].class, null); } /** * Obtain an installation associated with this app. *

* You must use a JWT to access this endpoint. * * @param id * Installation Id * @return a GHAppInstallation * @throws IOException * on error * @see Get an installation */ public GHAppInstallation getInstallationById(long id) throws IOException { return root().createRequest() .withUrlPath(String.format("/app/installations/%d", id)) .fetch(GHAppInstallation.class); } /** * Obtain an organization installation associated with this app. *

* You must use a JWT to access this endpoint. * * @param name * Organization name * @return a GHAppInstallation * @throws IOException * on error * @see Get an organization * installation */ public GHAppInstallation getInstallationByOrganization(String name) throws IOException { return root().createRequest() .withUrlPath(String.format("/orgs/%s/installation", name)) .fetch(GHAppInstallation.class); } /** * Obtain an repository installation associated with this app. *

* You must use a JWT to access this endpoint. * * @param ownerName * Organization or user name * @param repositoryName * Repository name * @return a GHAppInstallation * @throws IOException * on error * @see Get a repository * installation */ public GHAppInstallation getInstallationByRepository(String ownerName, String repositoryName) throws IOException { return root().createRequest() .withUrlPath(String.format("/repos/%s/%s/installation", ownerName, repositoryName)) .fetch(GHAppInstallation.class); } /** * Obtain a user installation associated with this app. *

* You must use a JWT to access this endpoint. * * @param name * user name * @return a GHAppInstallation * @throws IOException * on error * @see Get a user installation */ public GHAppInstallation getInstallationByUser(String name) throws IOException { return root().createRequest() .withUrlPath(String.format("/users/%s/installation", name)) .fetch(GHAppInstallation.class); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy