/*
* Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
*
* WSO2 Inc. 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 org.wso2.carbon.databridge.agent.endpoint.thrift;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.*;
import org.wso2.carbon.databridge.agent.AgentHolder;
import org.wso2.carbon.databridge.agent.exception.DataEndpointAgentConfigurationException;
import org.wso2.carbon.databridge.agent.exception.DataEndpointException;
import org.wso2.carbon.databridge.agent.client.AbstractClientPoolFactory;
import org.wso2.carbon.databridge.agent.conf.DataEndpointConfiguration;
import org.wso2.carbon.databridge.agent.util.DataEndpointConstants;
import org.wso2.carbon.databridge.commons.thrift.service.general.ThriftEventTransmissionService;
/**
* This is a Thrift Transport implementation for AbstractClientPoolFactory for Thrift Endpoint.
*/
public class ThriftClientPoolFactory extends AbstractClientPoolFactory {
@Override
public Object createClient(String protocol, String hostName, int port) throws DataEndpointException,
DataEndpointAgentConfigurationException {
if (protocol.equalsIgnoreCase(DataEndpointConfiguration.Protocol.TCP.toString())) {
int socketTimeout = AgentHolder.getInstance().getDataEndpointAgent(DataEndpointConstants.THRIFT_DATA_AGENT_TYPE).
getAgentConfiguration().getSocketTimeoutMS();
TTransport receiverTransport = new TSocket(hostName, port, socketTimeout);
TProtocol tProtocol = new TBinaryProtocol(receiverTransport);
ThriftEventTransmissionService.Client client = new ThriftEventTransmissionService.Client(tProtocol);
try {
receiverTransport.open();
} catch (TTransportException e) {
throw new DataEndpointException("Error while making the connection." + e.getMessage(), e);
}
return client;
}
throw new DataEndpointException("Unsupported protocol :" + protocol
+ " used to authenticate the client, only " + DataEndpointConfiguration.Protocol.TCP.toString()
+ " is supported");
}
@Override
public boolean validateClient(Object client) {
ThriftEventTransmissionService.Client thriftClient = (ThriftEventTransmissionService.Client) client;
return thriftClient.getOutputProtocol().getTransport().isOpen();
}
@Override
public void terminateClient(Object client) {
ThriftEventTransmissionService.Client thriftClient = (ThriftEventTransmissionService.Client) client;
thriftClient.getOutputProtocol().getTransport().close();
}
}