Error/Experimenter converters
[openflowplugin.git] / openflowplugin / src / main / java / org / opendaylight / openflowplugin / openflow / md / core / translator / ExperimenterTranslator.java
1 package org.opendaylight.openflowplugin.openflow.md.core.translator;
2
3 import java.math.BigInteger;
4
5 import org.opendaylight.openflowplugin.openflow.md.core.IMDMessageTranslator;
6 import org.opendaylight.openflowplugin.openflow.md.core.SwitchConnectionDistinguisher;
7 import org.opendaylight.openflowplugin.openflow.md.core.session.SessionContext;
8 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.service.rev130819.NodeExperimenterErrorNotification;
9 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.service.rev130819.NodeExperimenterErrorNotificationBuilder;
10 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.transaction.rev131103.TransactionId;
11 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ExperimenterMessage;
12 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader;
13 import org.opendaylight.yangtools.yang.binding.DataObject;
14 import org.slf4j.Logger;
15 import org.slf4j.LoggerFactory;
16
17 public class ExperimenterTranslator implements IMDMessageTranslator<OfHeader, DataObject> {
18
19         protected static final Logger LOG = LoggerFactory.getLogger(ExperimenterTranslator.class);
20         
21         @Override
22         public DataObject translate(SwitchConnectionDistinguisher cookie,
23                         SessionContext sc, OfHeader msg) {
24                 if( msg instanceof ExperimenterMessage) {
25                         ExperimenterMessage message = (ExperimenterMessage)msg ;
26                         LOG.error(" Experimenter Error Message received: Exp type={}, Exp Id={}, data={} ", 
27                         message.getExpType(), message.getExperimenter(),
28                         new String(message.getData()) ) ;
29                         
30                         // create a Node Experimenter Error Notification event builder
31                         NodeExperimenterErrorNotificationBuilder nodeErrBuilder = new NodeExperimenterErrorNotificationBuilder() ;
32                         
33                         nodeErrBuilder.setTransactionId(new TransactionId(BigInteger.valueOf( message.getXid() ))) ;
34                         
35                         // This is a fixed value 0xffff ( 65535 ) 
36                         nodeErrBuilder.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.flow.errors.rev131116.ErrorType.Experimenter ) ;
37                         
38                         // The experimenterType is defined as long in ExperimenterMessage where is just needs to be integer
39                         nodeErrBuilder.setExpType(message.getExpType().intValue() ) ; 
40                         
41                         nodeErrBuilder.setExperimenterId(message.getExperimenter()) ;
42                         
43                         nodeErrBuilder.setData(new String (message.getData()) ) ;
44                         
45                         //Not handling Augmentation
46                          
47                         NodeExperimenterErrorNotification nodeExpErrorEvent = nodeErrBuilder.build();
48                                                 
49                         return nodeExpErrorEvent ;
50                 }else {
51                         LOG.error( "Message is not of Experimenter Error Message " ) ;
52                         return null;
53                 }
54         }
55                 
56
57 }