4640593dc5c9a6c43124133cd0b1e630179e4849
[cps.git] / cps-service / src / main / java / org / onap / cps / utils / TimedYangParser.java
1 /*
2  * ============LICENSE_START=======================================================
3  * Copyright (C) 2023 Nordix Foundation.
4  * ================================================================================
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.cps.utils;
22
23 import io.micrometer.core.annotation.Timed;
24 import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
25 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
26 import org.springframework.stereotype.Service;
27
28 @Service
29 public class TimedYangParser {
30
31     /**
32      * Parses data into Collection of NormalizedNode according to given schema context.
33      *
34      * @param nodeData      data string
35      * @param schemaContext schema context describing associated data model
36      * @return the NormalizedNode object
37      */
38     @Timed(value = "cps.utils.yangparser.nodedata.parse",
39         description = "Time taken to parse node data without a parent")
40     public ContainerNode parseData(final ContentType contentType,
41                                           final String nodeData,
42                                           final SchemaContext schemaContext) {
43         return YangUtils.parseData(contentType, nodeData, schemaContext);
44     }
45
46     /**
47      * Parses data into NormalizedNode according to given schema context.
48      *
49      * @param nodeData      data string
50      * @param schemaContext schema context describing associated data model
51      * @return the NormalizedNode object
52      */
53     @Timed(value = "cps.utils.yangparser.nodedata.with.parent.parse",
54         description = "Time taken to parse node data with a parent")
55     public ContainerNode parseData(final ContentType contentType,
56                                           final String nodeData,
57                                           final SchemaContext schemaContext,
58                                           final String parentNodeXpath) {
59         return YangUtils.parseData(contentType, nodeData, schemaContext, parentNodeXpath);
60     }
61 }