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.openecomp.mso.apihandlerinfra;
23 import javax.ws.rs.GET;
24 import javax.ws.rs.HEAD;
25 import javax.ws.rs.Path;
26 import javax.ws.rs.Produces;
27 import javax.ws.rs.QueryParam;
28 import javax.ws.rs.core.Response;
30 import org.openecomp.mso.HealthCheckUtils;
31 import org.openecomp.mso.logger.MsoLogger;
32 import org.openecomp.mso.utils.UUIDChecker;
34 import com.wordnik.swagger.annotations.Api;
35 import com.wordnik.swagger.annotations.ApiOperation;
38 @Api(value="/healthcheck",description="API Handler Infra Health Check")
39 public class HealthcheckHandler {
41 private static MsoLogger msoLogger = MsoLogger.getMsoLogger (MsoLogger.Catalog.APIH);
45 @Produces("text/html")
46 @ApiOperation(value="Perform Health Check",response=Response.class)
47 public Response healthcheck (@QueryParam("requestId") String requestId) {
48 long startTime = System.currentTimeMillis ();
49 MsoLogger.setServiceName ("Healthcheck");
50 UUIDChecker.verifyOldUUID(requestId, msoLogger);
51 HealthCheckUtils healthCheck = new HealthCheckUtils ();
52 if (!healthCheck.siteStatusCheck(msoLogger)) {
53 return HealthCheckUtils.HEALTH_CHECK_NOK_RESPONSE;
56 if (!healthCheck.configFileCheck(msoLogger, startTime, Constants.MSO_PROP_APIHANDLER_INFRA)) {
57 return HealthCheckUtils.NOT_STARTED_RESPONSE;
60 if (!healthCheck.requestDBCheck (msoLogger, startTime)) {
61 return HealthCheckUtils.NOT_STARTED_RESPONSE;
63 msoLogger.debug("healthcheck - Successful");
64 return HealthCheckUtils.HEALTH_CHECK_RESPONSE;