/*
* ============LICENSE_START=======================================================
* ONAP - SO
* ================================================================================
* Licensed 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.
* ============LICENSE_END=========================================================
*/
package org.openecomp.mso.bpmn.mock;
import javax.xml.ws.Endpoint;
import org.jboss.resteasy.client.ClientRequest;
import org.jboss.resteasy.client.ClientResponse;
import org.openecomp.mso.logger.MsoLogger;
import com.github.tomakehurst.wiremock.client.ResponseDefinitionBuilder;
import com.github.tomakehurst.wiremock.common.FileSource;
import com.github.tomakehurst.wiremock.extension.ResponseTransformer;
import com.github.tomakehurst.wiremock.http.Request;
import com.github.tomakehurst.wiremock.http.ResponseDefinition;
import org.openecomp.mso.logger.MsoLogger;
/**
* Please describe the VnfAdapterCreateMockTransformer.java class
*
*/
public class VnfAdapterCreateMockTransformer extends ResponseTransformer {
private static final MsoLogger LOGGER = MsoLogger.getMsoLogger(MsoLogger.Catalog.BPEL);
private String notifyCallbackResponse;
private String ackResponse;
public VnfAdapterCreateMockTransformer() {
notifyCallbackResponse = FileUtil.readResourceFile("__files/vnfAdapterMocks/vnfCreateSimResponse.xml"); // default response
}
@Override
public String name() {
return "vnf-adapter-create-transformer";
}
@Override
public ResponseDefinition transform(Request request, ResponseDefinition responseDefinition,
FileSource fileSource) {
String requestBody = request.getBodyAsString();
String notficationUrl = requestBody.substring(requestBody.indexOf("")+17, requestBody.indexOf(""));
String messageId = requestBody.substring(requestBody.indexOf("")+11, requestBody.indexOf(""));
String responseMessageId = "";
String updatedResponse = "";
try {
// try supplied response file (if any)
System.out.println(" Supplied fileName: " + responseDefinition.getBodyFileName());
ackResponse = FileUtil.readResourceFile("__files/" + responseDefinition.getBodyFileName());
notifyCallbackResponse = ackResponse;
responseMessageId = ackResponse.substring(ackResponse.indexOf("")+11, ackResponse.indexOf(""));
updatedResponse = ackResponse.replace(responseMessageId, messageId);
} catch (Exception ex) {
LOGGER.debug("Exception :",ex);
System.out.println(" ******* Use default response file in '__files/vnfAdapterMocks/vnfCreateSimResponse.xml'");
responseMessageId = notifyCallbackResponse.substring(notifyCallbackResponse.indexOf("")+11, notifyCallbackResponse.indexOf(""));
updatedResponse = notifyCallbackResponse.replace(responseMessageId, messageId);
}
System.out.println("response (mock) messageId : " + responseMessageId);
System.out.println("request (replacement) messageId: " + messageId);
System.out.println("vnf Response (before):" + notifyCallbackResponse);
System.out.println("vnf Response (after):" + updatedResponse);
Object vnfDelay = MockResource.getMockProperties().get("vnf_delay");
int delay = 300;
if (vnfDelay != null) {
delay = Integer.parseInt(vnfDelay.toString());
}
//Kick off callback thread
System.out.println("VnfAdapterCreateMockTransformer notficationUrl: " + notficationUrl + ":delay: " + delay);
CallbackResponseThread callbackResponseThread = new CallbackResponseThread(notficationUrl,updatedResponse, delay);
callbackResponseThread.start();
return ResponseDefinitionBuilder
.like(responseDefinition).but()
.withStatus(200).withBody(updatedResponse).withHeader("Content-Type", "text/xml")
.build();
}
@Override
public boolean applyGlobally() {
return false;
}
private class CallbackResponseThread extends Thread {
private String callbackUrl;
private String payLoad;
private int delay;
public CallbackResponseThread(String callbackUrl, String payLoad, int delay) {
this.callbackUrl = callbackUrl;
this.payLoad = payLoad;
this.delay = delay;
}
@SuppressWarnings("deprecation")
public void run () {
try {
//Delay sending callback response
sleep(delay);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
LOGGER.debug("Exception :",e1);
}
LOGGER.debug("Sending callback response to url: " + callbackUrl);
ClientRequest request = new ClientRequest(callbackUrl);
request.body("text/xml", payLoad);
//System.out.println("payLoad: " + payLoad);
try {
ClientResponse result = request.post();
LOGGER.debug("Successfully posted callback? Status: " + result.getStatus());
//System.err.println("Successfully posted callback:" + result.getStatus());
} catch (Exception e) {
// TODO Auto-generated catch block
LOGGER.debug("catch error in - request.post() ");
LOGGER.debug("Exception :",e);
}
}
}
}