192acc1622a4a6804ba5d1a10c2ff697aa75ece2
[policy/drools-pdp.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * feature-state-management
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
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
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=========================================================
19  */
20
21 package org.onap.policy.drools.statemanagement;
22
23 import java.util.Properties;
24
25 import org.onap.policy.drools.properties.PolicyProperties;
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
28
29 public class StateManagementProperties {
30         // get an instance of logger 
31         private static final Logger  logger = LoggerFactory.getLogger(StateManagementProperties.class);
32                 
33         public static final String NODE_NAME = "resource.name";
34         public static final String NODE_TYPE = "node_type";
35         public static final String SITE_NAME = "site_name";
36         
37         public static final String DB_DRIVER = "javax.persistence.jdbc.driver";
38         public static final String DB_URL = "javax.persistence.jdbc.url";
39         public static final String DB_USER = "javax.persistence.jdbc.user";
40         public static final String DB_PWD = "javax.persistence.jdbc.password";
41         
42         public static final String TEST_SERVICES = PolicyProperties.PROPERTY_HTTP_SERVER_SERVICES;
43         public static final String TEST_SERVICES_DEFAULT = "TEST";
44         public static final String TEST_HOST = TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyProperties.PROPERTY_HTTP_HOST_SUFFIX;
45         public static final String TEST_PORT = TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyProperties.PROPERTY_HTTP_PORT_SUFFIX;
46         public static final String TEST_REST_CLASSES = TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyProperties.PROPERTY_HTTP_REST_CLASSES_SUFFIX;
47         public static final String TEST_REST_CLASSES_DEFAULT = IntegrityMonitorRestManager.class.getName(); 
48         public static final String TEST_MANAGED = TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyProperties.PROPERTY_MANAGED_SUFFIX;
49         public static final String TEST_MANAGED_DEFAULT = "false";
50         public static final String TEST_SWAGGER = TEST_SERVICES + "." + TEST_SERVICES_DEFAULT + PolicyProperties.PROPERTY_HTTP_SWAGGER_SUFFIX;
51         public static final String TEST_SWAGGER_DEFAULT = "true";
52         public static final String RESOURCE_NAME = "resource.name";
53         public static final String FP_MONITOR_INTERVAL = "fp_monitor_interval";
54         public static final String FAILED_COUNTER_THRESHOLD = "failed_counter_threshold";
55         public static final String TEST_TRANS_INTERVAL = "test_trans_interval";
56         public static final String WRITE_FPC_INTERVAL = "write_fpc_interval";
57         public static final String DEPENDENCY_GROUPS = "dependency_groups";
58                 
59         private static Properties properties = null;
60
61         private StateManagementProperties(){
62         }
63         /*
64          * Initialize the parameter values from the feature-state-management.properties file values
65          * 
66          * This is designed so that the Properties object is obtained from the feature-state-management.properties
67          * file and then is passed to this method to initialize the value of the parameters.
68          * This allows the flexibility of JUnit tests using getProperties(filename) to get the
69          * properties while runtime methods can use getPropertiesFromClassPath(filename).
70          * 
71          */
72         public static void initProperties (Properties prop){
73                 logger.info("StateManagementProperties.initProperties(Properties): entry");
74                 logger.info("\n\nStateManagementProperties.initProperties: Properties = \n{}\n\n", prop);
75                 
76                 properties = prop;
77         }
78
79         public static String getProperty(String key){
80                 return properties.getProperty(key);
81         }
82         
83         public static Properties getProperties() {
84                 return properties;
85         }
86 }