2 * ============LICENSE_START=======================================================
3 * feature-state-management
4 * ================================================================================
5 * Copyright (C) 2017-2018, 2020-2021 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.policy.drools.statemanagement;
23 import java.util.Properties;
24 import lombok.AccessLevel;
26 import lombok.NoArgsConstructor;
27 import org.eclipse.persistence.config.PersistenceUnitProperties;
28 import org.onap.policy.common.endpoints.properties.PolicyEndPointProperties;
29 import org.slf4j.Logger;
30 import org.slf4j.LoggerFactory;
32 @NoArgsConstructor(access = AccessLevel.PRIVATE)
33 public final class StateManagementProperties {
34 // get an instance of logger
35 private static final Logger logger = LoggerFactory.getLogger(StateManagementProperties.class);
37 public static final String NODE_NAME = "resource.name";
38 public static final String NODE_TYPE = "node_type";
39 public static final String SITE_NAME = "site_name";
41 public static final String DB_DRIVER = PersistenceUnitProperties.JDBC_DRIVER;
42 public static final String DB_URL = PersistenceUnitProperties.JDBC_URL;
43 public static final String DB_USER = PersistenceUnitProperties.JDBC_USER;
44 public static final String DB_PWD = PersistenceUnitProperties.JDBC_PASSWORD;
45 public static final String DB_TYPE = PersistenceUnitProperties.TARGET_DATABASE;
47 public static final String TEST_SERVICES = PolicyEndPointProperties.PROPERTY_HTTP_SERVER_SERVICES;
48 public static final String TEST_SERVICES_DEFAULT = "TEST";
49 public static final String TEST_HOST =
50 TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyEndPointProperties.PROPERTY_HTTP_HOST_SUFFIX;
51 public static final String TEST_PORT =
52 TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyEndPointProperties.PROPERTY_HTTP_PORT_SUFFIX;
53 public static final String TEST_REST_CLASSES =
54 TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyEndPointProperties.PROPERTY_HTTP_REST_CLASSES_SUFFIX;
55 public static final String TEST_REST_CLASSES_DEFAULT = IntegrityMonitorRestManager.class.getName();
56 public static final String TEST_MANAGED =
57 TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyEndPointProperties.PROPERTY_MANAGED_SUFFIX;
58 public static final String TEST_MANAGED_DEFAULT = "false";
59 public static final String TEST_SWAGGER =
60 TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyEndPointProperties.PROPERTY_HTTP_SWAGGER_SUFFIX;
61 public static final String TEST_SWAGGER_DEFAULT = "true";
62 public static final String RESOURCE_NAME = "resource.name";
63 public static final String FP_MONITOR_INTERVAL = "fp_monitor_interval";
64 public static final String FAILED_COUNTER_THRESHOLD = "failed_counter_threshold";
65 public static final String TEST_TRANS_INTERVAL = "test_trans_interval";
66 public static final String WRITE_FPC_INTERVAL = "write_fpc_interval";
67 public static final String DEPENDENCY_GROUPS = "dependency_groups";
70 private static Properties properties = null;
73 * Initialize the parameter values from the feature-state-management.properties file values.
75 * <p>This is designed so that the Properties object is obtained from the
76 * feature-state-management.properties file and then is passed to this method to initialize the
77 * value of the parameters. This allows the flexibility of JUnit tests using
78 * getProperties(filename) to get the properties while runtime methods can use
79 * getPropertiesFromClassPath(filename).
81 * @param prop properties
83 public static void initProperties(Properties prop) {
84 logger.info("StateManagementProperties.initProperties(Properties): entry");
85 logger.info("\n\nStateManagementProperties.initProperties: Properties = \n{}\n\n", prop);
90 public static String getProperty(String key) {
91 return properties.getProperty(key);