/*- * ============LICENSE_START======================================================= * Copyright (C) 2019 Nordix Foundation. * ================================================================================ * 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. * * SPDX-License-Identifier: Apache-2.0 * ============LICENSE_END========================================================= */ package org.onap.policy.models.sim.dmaap.rest; import java.util.ArrayList; import java.util.List; import java.util.Properties; import org.onap.policy.common.capabilities.Startable; import org.onap.policy.common.endpoints.http.server.HttpServletServer; import org.onap.policy.common.endpoints.properties.PolicyEndPointProperties; import org.onap.policy.models.sim.dmaap.parameters.RestServerParameters; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * Class to manage life cycle of DMaaP Simulator rest server. */ public class DmaapSimRestServer implements Startable { private static final Logger LOGGER = LoggerFactory.getLogger(DmaapSimRestServer.class); private List servers = new ArrayList<>(); private RestServerParameters restServerParameters; /** * Constructor for instantiating DmaapSimRestServer. * * @param restServerParameters the rest server parameters */ public DmaapSimRestServer(final RestServerParameters restServerParameters) { this.restServerParameters = restServerParameters; } /** * {@inheritDoc}. */ @Override public boolean start() { try { servers = HttpServletServer.factory.build(getServerProperties()); for (final HttpServletServer server : servers) { server.start(); } } catch (final Exception exp) { LOGGER.error("Failed to start DMaaP simulator http server", exp); return false; } return true; } /** * Creates the server properties object using restServerParameters. * * @return the properties object */ private Properties getServerProperties() { final Properties props = new Properties(); props.setProperty(PolicyEndPointProperties.PROPERTY_HTTP_SERVER_SERVICES, restServerParameters.getName()); final String svcpfx = PolicyEndPointProperties.PROPERTY_HTTP_SERVER_SERVICES + "." + restServerParameters.getName(); props.setProperty(svcpfx + PolicyEndPointProperties.PROPERTY_HTTP_HOST_SUFFIX, restServerParameters.getHost()); props.setProperty(svcpfx + PolicyEndPointProperties.PROPERTY_HTTP_PORT_SUFFIX, Integer.toString(restServerParameters.getPort())); props.setProperty(svcpfx + PolicyEndPointProperties.PROPERTY_HTTP_REST_CLASSES_SUFFIX, String.join(",", DmaapSimRestControllerV1.class.getName())); props.setProperty(svcpfx + PolicyEndPointProperties.PROPERTY_MANAGED_SUFFIX, "false"); props.setProperty(svcpfx + PolicyEndPointProperties.PROPERTY_HTTP_SWAGGER_SUFFIX, "true"); props.setProperty(svcpfx + PolicyEndPointProperties.PROPERTY_HTTP_SERIALIZATION_PROVIDER, CambriaMessageBodyHandler.class.getName() + "," + JsonMessageBodyHandler.class.getName()); return props; } /** * {@inheritDoc}. */ @Override public boolean stop() { for (final HttpServletServer server : servers) { try { server.stop(); } catch (final Exception exp) { LOGGER.error("Failed to stop DMaaP simulator http server", exp); } } return true; } /** * {@inheritDoc}. */ @Override public void shutdown() { stop(); } /** * {@inheritDoc}. */ @Override public boolean isAlive() { return !servers.isEmpty(); } /** * {@inheritDoc}. */ @Override public String toString() { final StringBuilder builder = new StringBuilder(); builder.append("DmaapSimRestServer [servers="); builder.append(servers); builder.append("]"); return builder.toString(); } }