2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.onap.so.bpmn.mock;
23 import javax.ws.rs.core.Response;
24 import javax.ws.rs.core.UriBuilder;
26 import org.onap.so.client.HttpClient;
27 import org.onap.so.client.HttpClientFactory;
28 import org.onap.so.logger.MsoLogger;
29 import org.onap.so.utils.TargetEntity;
31 import com.github.tomakehurst.wiremock.client.ResponseDefinitionBuilder;
32 import com.github.tomakehurst.wiremock.common.FileSource;
33 import com.github.tomakehurst.wiremock.extension.Parameters;
34 import com.github.tomakehurst.wiremock.extension.ResponseDefinitionTransformer;
35 import com.github.tomakehurst.wiremock.http.Request;
36 import com.github.tomakehurst.wiremock.http.ResponseDefinition;
38 public class SDNCAdapterNetworkTopologyMockTransformer extends ResponseDefinitionTransformer {
40 private static final MsoLogger LOGGER = MsoLogger.getMsoLogger(MsoLogger.Catalog.BPEL, SDNCAdapterNetworkTopologyMockTransformer.class);
42 private String callbackResponse;
43 private String requestId;
45 public SDNCAdapterNetworkTopologyMockTransformer() {
46 callbackResponse = ""; // FileUtil.readResourceFile("__files/sdncDeleteNetworkTopologySimResponse.xml");
49 public SDNCAdapterNetworkTopologyMockTransformer(String requestId) {
50 this.requestId = requestId;
54 public String getName() {
55 return "network-topology-operation-transformer";
59 public ResponseDefinition transform(Request request, ResponseDefinition responseDefinition, FileSource fileSource, Parameters parameters) {
60 String requestBody = request.getBodyAsString();
62 String callbackUrl = requestBody.substring(requestBody.indexOf("<sdncadapter:CallbackUrl>")+25, requestBody.indexOf("</sdncadapter:CallbackUrl>"));
63 String requestId = requestBody.substring(requestBody.indexOf("<sdncadapter:RequestId>")+23, requestBody.indexOf("</sdncadapter:RequestId>"));
64 System.out.println("request callbackUrl : " + callbackUrl);
65 System.out.println("request requestId : " + requestId);
67 System.out.println("file path/name : " + responseDefinition.getBodyFileName());
68 callbackResponse = FileUtil.readResourceFile("__files/" + responseDefinition.getBodyFileName());
69 // extract Response responseRequestId
70 String responseRequestId = callbackResponse.substring(callbackResponse.indexOf("<RequestId>")+11, callbackResponse.indexOf("</RequestId>"));
71 System.out.println("response requestId: " + responseRequestId);
72 System.out.println("callbackResponse (before): " + callbackResponse);
73 callbackResponse = callbackResponse.replace(responseRequestId, requestId);
74 if (this.requestId != null) {
75 callbackResponse = callbackResponse.replace(this.requestId, requestId);
77 callbackResponse = callbackResponse.replace(responseRequestId, requestId);
79 System.out.println("callbackResponse (after):" + callbackResponse);
81 Object sdncDelay = MockResource.getMockProperties().get("sdnc_delay");
83 if (sdncDelay != null) {
84 delay = Integer.parseInt(sdncDelay.toString());
87 //Kick off callback thread
88 System.out.println("(NetworkTopologyMockTransformer) callback Url:" + callbackUrl + ":delay:" + delay);
89 CallbackResponseThread calbackResponseThread = new CallbackResponseThread(callbackUrl,callbackResponse, delay);
90 calbackResponseThread.start();
92 //return 200 OK with body
93 return ResponseDefinitionBuilder
94 .like(responseDefinition).but()
95 .withStatus(200).withBody(callbackResponse).withHeader("Content-Type", "text/xml")
100 public boolean applyGlobally() {
104 private class CallbackResponseThread extends Thread {
106 private String callbackUrl;
107 private String payLoad;
110 public CallbackResponseThread(String callbackUrl, String payLoad, int delay) {
111 this.callbackUrl = callbackUrl;
112 this.payLoad = payLoad;
118 //Delay sending callback response
120 } catch (InterruptedException e1) {
121 // TODO Auto-generated catch block
122 LOGGER.debug("Exception :",e1);
124 LOGGER.debug("Sending callback response to url: " + callbackUrl);
126 HttpClient client = new HttpClientFactory().newTextXmlClient(
127 UriBuilder.fromUri(callbackUrl).build().toURL(),
128 TargetEntity.SDNC_ADAPTER);
129 Response response = client.post(payLoad);
130 LOGGER.debug("Successfully posted callback? Status: " + response.getStatus());
131 } catch (Exception e) {
132 // TODO Auto-generated catch block
133 LOGGER.debug("catch error in - request.post() ");
134 LOGGER.debug("Exception :",e);