Fixing sonar issues
[policy/drools-applications.git] / controlloop / common / eventmanager / src / main / java / org / onap / policy / controlloop / ControlLoopLogger.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * controlloop
4  * ================================================================================
5  * Copyright (C) 2017-2018 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.controlloop;
22
23 import java.lang.reflect.Constructor;
24
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
27
28 public interface ControlLoopLogger {
29
30     public void info(String... parameters);
31
32     public void metrics(String... msgs);
33
34     public void metrics(Object obj);
35
36     public static class Factory {
37         private static final Logger logger = LoggerFactory.getLogger(Factory.class);
38
39         /**
40          * Construct an instance.
41          * 
42          * @param className name of the class
43          * @return the instance
44          * @throws ControlLoopException if an error occurs
45          */
46         public ControlLoopLogger buildLogger(String className) throws ControlLoopException {
47             try {
48                 Constructor<?> constr = Class.forName(className).getConstructor();
49                 return (ControlLoopLogger) constr.newInstance();
50             } catch (Exception e) {
51                 logger.error("buildLogger threw: ", e);
52                 throw new ControlLoopException("Cannot load class " + className + " as a control loop logger");
53             }
54         }
55     }
56 }