Add single layer deserialization support
[openflowplugin.git] / openflowplugin-impl / src / main / java / org / opendaylight / openflowplugin / impl / datastore / multipart / QueueStatsMultipartWriter.java
1 /*
2  * Copyright (c) 2017 Pantheon Technologies s.r.o. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.openflowplugin.impl.datastore.multipart;
10
11 import org.opendaylight.openflowplugin.api.openflow.device.TxFacade;
12 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.inventory.rev130819.FlowCapableNodeConnector;
13 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.port.rev130925.queues.Queue;
14 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.port.rev130925.queues.QueueBuilder;
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.port.rev130925.queues.QueueKey;
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.node.NodeConnector;
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.node.NodeConnectorKey;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.FlowCapableNodeConnectorQueueStatisticsData;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.FlowCapableNodeConnectorQueueStatisticsDataBuilder;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.QueueIdAndStatisticsMap;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.flow.capable.node.connector.queue.statistics.FlowCapableNodeConnectorQueueStatisticsBuilder;
23 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
24
25 public class QueueStatsMultipartWriter extends AbstractMultipartWriter<QueueIdAndStatisticsMap> {
26
27     public QueueStatsMultipartWriter(final TxFacade txFacade, final InstanceIdentifier<Node> instanceIdentifier) {
28         super(txFacade, instanceIdentifier);
29     }
30
31     @Override
32     protected Class<QueueIdAndStatisticsMap> getType() {
33         return QueueIdAndStatisticsMap.class;
34     }
35
36     @Override
37     public void storeStatistics(final QueueIdAndStatisticsMap statistics, final boolean withParents) {
38         statistics.getQueueIdAndStatisticsMap()
39             .forEach(stat -> writeToTransaction(
40                 getInstanceIdentifier()
41                     .child(NodeConnector.class, new NodeConnectorKey(stat.getNodeConnectorId()))
42                     .augmentation(FlowCapableNodeConnector.class)
43                     .child(Queue.class, new QueueKey(stat.getQueueId())),
44                 new QueueBuilder()
45                     .setKey(new QueueKey(stat.getQueueId()))
46                     .setQueueId(stat.getQueueId())
47                     .addAugmentation(
48                         FlowCapableNodeConnectorQueueStatisticsData.class,
49                         new FlowCapableNodeConnectorQueueStatisticsDataBuilder()
50                             .setFlowCapableNodeConnectorQueueStatistics(
51                                 new FlowCapableNodeConnectorQueueStatisticsBuilder(stat).build())
52                             .build())
53                     .build(),
54                 withParents));
55     }
56
57 }