2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright © 2017-2018 AT&T Intellectual Property. All rights reserved.
6 * Copyright © 2017-2018 Amdocs
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END=========================================================
21 package org.onap.crud.service;
23 import javax.servlet.http.HttpServletRequest;
24 import javax.ws.rs.GET;
25 import javax.ws.rs.Path;
26 import javax.ws.rs.PathParam;
27 import javax.ws.rs.Produces;
28 import javax.ws.rs.core.Context;
29 import javax.ws.rs.core.HttpHeaders;
30 import javax.ws.rs.core.Response;
31 import javax.ws.rs.core.Response.ResponseBuilder;
32 import javax.ws.rs.core.Response.Status;
33 import javax.ws.rs.core.UriInfo;
34 import org.onap.aai.cl.api.Logger;
35 import org.onap.aai.cl.eelf.LoggerFactory;
36 import org.onap.crud.logging.LoggingUtil;
37 import org.springframework.stereotype.Component;
40 @Path("/services/gizmo/v1/echo-service/")
41 public class JaxrsEchoService {
43 private static Logger logger = LoggerFactory.getInstance().getLogger(JaxrsEchoService.class.getName());
44 private static Logger auditLogger = LoggerFactory.getInstance().getAuditLogger(JaxrsEchoService.class.getName());
46 public static final String TRANSACTIONID_HEADER = "X-TransactionId";
50 @Produces("text/plain")
51 public Response ping(@PathParam("input") String input, @Context HttpHeaders headers, @Context UriInfo info,
52 @Context HttpServletRequest req) {
54 LoggingUtil.initMdcContext(req, headers);
56 ResponseBuilder responseBuilder = Response.status(Status.OK).entity("Hello, " + input + ".");
58 String txId = headers.getHeaderString(TRANSACTIONID_HEADER);
60 responseBuilder.header(TRANSACTIONID_HEADER, txId);
63 Response response = responseBuilder.build();
64 LoggingUtil.logRestRequest(logger, auditLogger, req, response);