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

com.openshift.restclient.IClient Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2015-2019 Red Hat, Inc. Distributed under license by Red Hat, Inc.
 * All rights reserved. This program is 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: Red Hat, Inc.
 ******************************************************************************/

package com.openshift.restclient;

import java.io.InputStream;
import java.net.URL;
import java.util.Collection;
import java.util.List;
import java.util.Map;

import com.openshift.internal.restclient.KubernetesVersion;
import com.openshift.restclient.api.ITypeFactory;
import com.openshift.restclient.authorization.IAuthorizationContext;
import com.openshift.restclient.capability.ICapable;
import com.openshift.restclient.model.IList;
import com.openshift.restclient.model.IResource;
import com.openshift.restclient.model.JSONSerializeable;

/**
 * Client is the the simplest interface for interacting with the OpenShift
 * master server.
 *
 */
public interface IClient extends ICapable, Cloneable {

    /*
     * Watch for changes scoped to a specific namespace
     *
     * @param namespace The namespace to watch for changes in
     * 
     * @param listener The listener to be notified on events
     * 
     * @param kids The kinds to watch for
     * 
     */
    IWatcher watch(String namespace, IOpenShiftWatchListener listener, String... kinds);

    /*
     * Watch for changes in the default namespace
     *
     * @param listener The listener to be notified on events
     * 
     * @param kids The kinds to watch for
     */
    IWatcher watch(IOpenShiftWatchListener listener, String... kinds);

    /**
     * Lists all possible resources of the given kind in the default namespace
     * 
     * @param kind
     * @return
     */
     List list(String kind);

    /**
     * Lists the given given resource kind in the default namespace
     *
     * @param kind
     * @param labels
     *            The label used to filter the resource
     * @return
     */
     List list(String kind, Map labels);

    /**
     * Lists the given given resource kind scoping it to a specific namespace
     * 
     * @param kind
     * @param namespace
     *            The namespace to scope the possible results of this list
     * @return
     */
     List list(String kind, String namespace);

    /**
     * Lists the given given resource kind scoping it to a specific namespace
     *
     * @param kind
     * @param namespace
     *            The namespace to scope the possible results of this list
     * @param labels
     *            The label used to filter the resource
     * @return
     */
     List list(String kind, String namespace, Map labels);

    /**
     * Lists the given given resource kind scoping it to a specific namespace
     *
     * @param kind
     * @param namespace
     *            The namespace to scope the possible results of this list
     * @param labelQuery
     *            The label used to filter the resource
     * @return
     */
     List list(String kind, String namespace, String labelQuery);

    /**
     *
     * @param kind
     * @param name
     * @param namespace
     * @return
     * @throws OpenShiftException
     *             if operation not supported for resource type
     */
     T get(String kind, String name, String namespace);

    /**
     * 
     * @return A raw list of the kind in the given namespace (e.g. ServiceList)
     */
    IList get(String kind, String namespace);

    /**
     * Creates the given resource in the namespace defined on the resource or the
     * default namspace if undefined
     * 
     * @param resource
     * @return
     * @throws UnsupportedOperationException
     *             if the resource is a list
     */
     T create(T resource);

    /**
     * Creates the given resource in the given namespace
     * 
     * @param resource
     * @param namespace
     * @return
     */
     T create(T resource, String namespace);

    /**
     * Creates the given resource in the given namespace using the subresource
     * 
     * @param kind
     * @param namespace
     * @param name
     * @param subresource
     * @param payload
     * @return
     */
     T create(String kind, String namespace, String name, String subresource, IResource payload);

    /**
     * Creates the given resource in the given namespace using the subresource
     * 
     * @param kind
     * @param version
     * @param namespace
     * @param name
     * @param subresource
     * @param payload
     * @return
     */
     T create(String kind, String version, String namespace, String name, String subresource, InputStream payload);

    /**
     * Creates the given resource in the given namespace using the subresource
     * 
     * @param kind
     * @param version
     * @param namespace
     * @param name
     * @param subresource
     * @param payload
     * @param parameters
     * @return
     */
     T create(String kind, String version, String namespace, String name, String subresource, InputStream payload, Map parameters);
    
    /**
     * Creates a list of resources in the given namespace
     * 
     * @param list
     *            The resource definitions
     * @param namespace
     *            the namespace for the resources
     * @return A collection of the resources created or the status instance of why
     *         the creation failed.
     * @throws OpenShiftException
     *             if a status can not be determined from the exception
     */
    Collection create(IList list, String namespace);

    /**
     * Updates the given resource
     * 
     * @param resource
     * @return
     * @throws UnsupportedOperationException
     *             if the resource is a list
     */
     T update(T resource);

    /**
     * Deletes the given resource.
     * 
     * @param resource
     * @throws UnsupportedOperationException
     *             if the resource is a list
     */
     void delete(T resource);

    /**
     * Deletes a resource of  given name and kind in the given namespace.
     * 
     * @param kind the kind of resource
     * @param namespace the namespace 
     * @param name the name of the resource
     * @throws UnsupportedOperationException
     *             if the resource is a list
     */
    void delete(String kind, String namespace, String name);
    
    /**
     * Raw execution of a request
     * 
     * @param httpMethod
     *            HttpMethod (e.g. POST)
     * @param kind
     * @param namespace
     * @param name
     * @param subresource
     *            subresource or capability
     * @param payload
     *            the payload to sumit. only valid on non-get operations
     * @return
     * 
     */
     T execute(String httpMethod, String kind, String namespace, String name, String subresource,
            IResource payload);
    
     T execute(String method, String kind, String version, String namespace, String name, String subresource, InputStream payload);

     T execute(String method, String kind, String version, String namespace, String name,
            String subresource, InputStream payload, Map parameters);

    /**
     * Raw execution of a request
     * 
     * @param httpMethod
     *            HttpMethod (e.g. POST)
     * @param kind
     * @param namespace
     * @param name
     * @param subresource
     *            subresource or capability
     * @param payload
     *            the payload to sumit. only valid on non-get operations
     * @param params
     *            map of query parameters
     * @return
     *
     */
     T execute(String httpMethod, String kind, String namespace, String name, String subresource,
            IResource payload, Map params);

    /**
     * Raw execution of a request
     * 
     * @param httpMethod
     *            HttpMethod (e.g. POST)
     * @param kind
     * @param namespace
     * @param name
     * @param subresource
     *            subresource or capability
     * @param subcontext
     *            additional subContext (e.g. jolokia endpoint) Raw execution of a
     *            request that requires consumers to handle the response
     * @return
     */
     T execute(String httpMethod, String kind, String namespace, String name, String subresource,
            IResource payload, String subcontext);
    
    

    /**
     * @param factory
     *            The factory to use for interpreting the response
     * @param httpMethod
     *            HttpMethod (e.g. POST)
     * @param kind
     * @param namespace
     * @param name
     * @param subresource
     *            subresource or capability
     * @param payload
     *            the payload to sumit. only valid on non-get operations
     * @param subContext
     *            additional subContext
     * @param params
     * @return the raw payload string
     */
     T execute(ITypeFactory factory, String httpMethod, String kind, String namespace, String name,
            String subresource, String subContext, JSONSerializeable payload, Map params);

    /**
     * 
     * @return the base URL of this endpoint
     */
    URL getBaseURL();
    
    /**
     * @return the authentication endpoint to be used when login
     * @throws OpenShiftException if endpoint retrieval fails
     */
    URL getAuthorizationEndpoint();
    
    /**
     * @return the token endpoint to be used when login
     * @throws OpenShiftException if endpoint retrieval fails
     */
    URL getTokenEndpoint();

    /**
     * 
     * @return the uri to the resource (e.g. for crafting webhooks)
     */
    String getResourceURI(IResource resource);

    /**
     * Returns the OpenShift API version for this client
     * 
     * @throws {@link
     *             UnauthorizedException}
     */
    String getOpenShiftAPIVersion() throws UnsupportedVersionException;

    /**
     * The authorization context for this client.
     * 
     * @return The context which will never be null
     */
    IAuthorizationContext getAuthorizationContext();

    /**
     * Returns the resource factory used to create resources based on the response
     * from the server
     * 
     */
    IResourceFactory getResourceFactory();

    /**
     * Adapt this class to the given type
     * 
     * @return an instance of the class or null if it can not
     */
    default  T adapt(Class klass) {
        return null;
    }

    /**
     * Query the server to determine if it is ready
     * 
     */
    String getServerReadyStatus();

    /**
     * Query the server to determine the Openshift version
     * 
     */
    String getOpenshiftMasterVersion();

    /**
     * Query the server to determine the Kubernetes version
     * 
     */
    String getKubernetesMasterVersion();

    IClient clone();
    
    /**
     * Returns the major version for OpenShift or
     * {@link KubernetesVersion#NO_VERSION} if it could not be detected.
     * 
     * @return the major version of openshift that this client talks to.
     */
    int getOpenShiftMajorVersion();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy