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

io.fabric8.taiga.TaigaClient Maven / Gradle / Ivy

/**
 *  Copyright 2005-2016 Red Hat, Inc.
 *
 *  Red Hat licenses this file to you 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 io.fabric8.taiga;

import io.fabric8.utils.Strings;
import io.fabric8.utils.cxf.WebClients;
import org.apache.cxf.jaxrs.client.JAXRSClientFactory;
import org.apache.cxf.jaxrs.client.WebClient;

import javax.ws.rs.client.ClientRequestContext;
import javax.ws.rs.client.ClientRequestFilter;
import javax.ws.rs.core.MultivaluedMap;
import javax.xml.bind.DatatypeConverter;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.List;

import static io.fabric8.utils.cxf.WebClients.disableSslChecks;

/**
 * A client API for working with git hosted repositories using back ends like
 * gogs or github
 */
public class TaigaClient extends TaigaClientSupport {

    public TaigaClient(String address, String username, String password) {
        super(address, username, password);
    }


    /**
     * Creates a JAXRS web client for the given JAXRS client
     */
    @Override
    protected  T createWebClient(Class clientType) {
        List providers = WebClients.createProviders();
        providers.add(new Authenticator());
        WebClient webClient = WebClient.create(address, providers);
        disableSslChecks(webClient);
        //configureUserAndPassword(webClient, username, password);
        return JAXRSClientFactory.fromClient(webClient, clientType);
    }


    protected class Authenticator implements ClientRequestFilter {

        public void filter(ClientRequestContext requestContext) throws IOException {
            MultivaluedMap headers = requestContext.getHeaders();
            String authenticationHeader = getAuthenticationHeader();
            if (Strings.isNotBlank(authenticationHeader)) {
                headers.add("Authorization", authenticationHeader);
            }
        }

        private String getAuthenticationHeader() {
            String token = getAuthToken();
            if (Strings.isNotBlank(token)) {
                return "Bearer " + token;
            } else {
                return null;
            }
        }
    }

}