aboutsummaryrefslogtreecommitdiffstats
path: root/appc-metric/appc-metric-bundle/src/main/java/org/openecomp/appc/metricservice/metric/Metric.java
blob: ce4297c88ddc9783ee32e9b52c4dfd3de009dcd6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*-
 * ============LICENSE_START=======================================================
 * ONAP : APPC
 * ================================================================================
 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
 * ================================================================================
 * Copyright (C) 2017 Amdocs
 * =============================================================================
 * 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.
 * 
 * ECOMP is a trademark and service mark of AT&T Intellectual Property.
 * ============LICENSE_END=========================================================
 */

package org.onap.appc.metricservice.metric;

import java.util.HashMap;

/**
 *
 * a measure of system parameter at the current moment. Each metric is identified by name.
 * In general case, a metric just reflects its (almost) real-time value and is not responsible for maintaining its historical data.
 * One that needs to build series of a metric values for statistical/analytic purposes should query the value and store it for further processing.
 * Metrics can be of different types - counters, timers etc.
 * The initial service implementation supports simple (flat) counters only.
 *
 */
public interface Metric {
    String name();
    void reset();
    MetricType type();
    /**
     * This API will be used to get all the running Metrics Output.
     * @return HashMap <String,String> in which
     * the First String(Key) will be the name of the KPI property
     * and another String(Value of the Key) will be the Value of
     * that property for that KPI
     */
    HashMap<String,String> getMetricsOutput();
    /**
     * Return last modified date for  KPI in string format
     * @return - last modified date for KPI
     */
    String getLastModified();
}