/*
* Copyright (c) 2017, 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.transport.http.netty.contentaware;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.wso2.carbon.messaging.CarbonCallback;
import org.wso2.carbon.messaging.CarbonMessage;
import org.wso2.carbon.messaging.CarbonMessageProcessor;
import org.wso2.carbon.messaging.ClientConnector;
import org.wso2.carbon.messaging.TransportSender;
import org.wso2.carbon.messaging.exceptions.ClientConnectorException;
import org.wso2.carbon.transport.http.netty.common.Constants;
import org.wso2.carbon.transport.http.netty.util.TestUtil;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
/**
* Streaming processor which reads from same and write to same message
*/
public class RequestResponseTransformStreamingProcessor implements CarbonMessageProcessor {
private static final Logger logger = LoggerFactory.getLogger(RequestResponseTransformStreamingProcessor.class);
private ExecutorService executor = Executors.newSingleThreadExecutor();
private ClientConnector clientConnector;
@Override
public boolean receive(CarbonMessage carbonMessage, CarbonCallback callback) throws Exception {
executor.execute(new Runnable() {
@Override
public void run() {
try {
if (carbonMessage.getProperty(org.wso2.carbon.messaging.Constants.DIRECTION) != null
&& carbonMessage.getProperty(org.wso2.carbon.messaging.Constants.DIRECTION)
.equals(org.wso2.carbon.messaging.Constants.DIRECTION_RESPONSE)) {
callback.done(carbonMessage);
} else {
InputStream inputStream = carbonMessage.getInputStream();
OutputStream outputStream = carbonMessage.getOutputStream();
byte[] bytes = IOUtils.toByteArray(inputStream);
outputStream.write(bytes);
outputStream.flush();
carbonMessage.setEndOfMsgAdded(true);
carbonMessage.setProperty(Constants.HOST, TestUtil.TEST_HOST);
carbonMessage.setProperty(Constants.PORT, TestUtil.TEST_SERVER_PORT);
EngineCallBack engineCallBack = new EngineCallBack(callback);
clientConnector.send(carbonMessage, engineCallBack);
}
} catch (IOException e) {
logger.error("Error while reading stream", e);
} catch (ClientConnectorException e) {
logger.error("MessageProcessor is not supported ", e);
}
}
});
return false;
}
@Override
public void setTransportSender(TransportSender sender) {
}
@Override
public void setClientConnector(ClientConnector clientConnector) {
this.clientConnector = clientConnector;
}
@Override
public String getId() {
return null;
}
private class EngineCallBack implements CarbonCallback {
CarbonCallback requestCallBack;
EngineCallBack(CarbonCallback carbonCallback) {
requestCallBack = carbonCallback;
}
@Override
public void done(CarbonMessage carbonMessage) {
InputStream inputS = carbonMessage.getInputStream();
OutputStream outputS = carbonMessage.getOutputStream();
try {
byte[] bytes = IOUtils.toByteArray(inputS);
outputS.write(bytes);
outputS.flush();
carbonMessage.setEndOfMsgAdded(true);
} catch (IOException e) {
throw new RuntimeException("Cannot read Input Stream from Response", e);
}
requestCallBack.done(carbonMessage);
}
}
}