blob: cbb2bc5040ced064926b804c8d4d701e3352fdd4 [file] [log] [blame]
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -07001package org.onlab.onos.store.serializers;
2
3import java.net.URI;
4import java.util.ArrayList;
Madan Jampani53e44e62014-10-07 12:39:51 -07005import java.util.Arrays;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -07006import java.util.HashMap;
7
8import org.onlab.onos.cluster.ControllerNode;
9import org.onlab.onos.cluster.DefaultControllerNode;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070010import org.onlab.onos.cluster.NodeId;
Yuta HIGUCHI80912e62014-10-12 00:15:47 -070011import org.onlab.onos.mastership.MastershipTerm;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070012import org.onlab.onos.net.ConnectPoint;
13import org.onlab.onos.net.DefaultAnnotations;
14import org.onlab.onos.net.DefaultDevice;
15import org.onlab.onos.net.DefaultLink;
16import org.onlab.onos.net.DefaultPort;
17import org.onlab.onos.net.Device;
18import org.onlab.onos.net.DeviceId;
19import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070020import org.onlab.onos.net.HostId;
21import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070022import org.onlab.onos.net.Link;
23import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070024import org.onlab.onos.net.Port;
25import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070026import org.onlab.onos.net.device.DefaultDeviceDescription;
27import org.onlab.onos.net.device.DefaultPortDescription;
Madan Jampani38b250d2014-10-17 11:02:38 -070028import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070029import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070030import org.onlab.onos.net.flow.DefaultTrafficTreatment;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070031import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070032import org.onlab.onos.net.flow.criteria.Criteria;
33import org.onlab.onos.net.flow.criteria.Criterion;
34import org.onlab.onos.net.flow.instructions.Instructions;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070035import org.onlab.onos.net.host.DefaultHostDescription;
36import org.onlab.onos.net.host.HostDescription;
Madan Jampani2ff05592014-10-10 15:42:47 -070037import org.onlab.onos.net.link.DefaultLinkDescription;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070038import org.onlab.onos.net.provider.ProviderId;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070039import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070040import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070041import org.onlab.packet.IpAddress;
42import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070043import org.onlab.packet.MacAddress;
44import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070045import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070046
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070047import com.google.common.collect.ImmutableList;
48import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070049import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070050
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070051public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070052
53 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070054 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070055 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070056 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070057 .register(IpPrefix.class, new IpPrefixSerializer())
58 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070059 .register(MacAddress.class, new MacAddressSerializer())
60 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070061 .build();
62
63 // TODO: Populate other classes
64 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070065 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070066 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070067 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070068 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070069 .register(ImmutableMap.class, new ImmutableMapSerializer())
70 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070071 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070072 .register(
73 //
74 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070075 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070076 HashMap.class,
77 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070078 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070079 ControllerNode.State.class,
80 Device.Type.class,
alshabib7911a052014-10-16 17:49:37 -070081 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070082 DefaultAnnotations.class,
83 DefaultControllerNode.class,
84 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070085 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -070086 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070087 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070088 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070089 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070090 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070091 Timestamp.class,
92 HostId.class,
93 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -070094 DefaultHostDescription.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070095 DefaultFlowRule.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070096 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070097 DefaultTrafficSelector.class,
98 Criteria.PortCriterion.class,
99 Criteria.EthCriterion.class,
100 Criteria.EthTypeCriterion.class,
101 Criteria.IPCriterion.class,
102 Criteria.IPProtocolCriterion.class,
103 Criteria.VlanIdCriterion.class,
104 Criteria.VlanPcpCriterion.class,
105 Criteria.TcpPortCriterion.class,
106 Criterion.class,
107 Criterion.Type.class,
108 DefaultTrafficTreatment.class,
109 Instructions.DropInstruction.class,
110 Instructions.OutputInstruction.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700111 )
112 .register(URI.class, new URISerializer())
113 .register(NodeId.class, new NodeIdSerializer())
114 .register(ProviderId.class, new ProviderIdSerializer())
115 .register(DeviceId.class, new DeviceIdSerializer())
116 .register(PortNumber.class, new PortNumberSerializer())
117 .register(DefaultPort.class, new DefaultPortSerializer())
118 .register(LinkKey.class, new LinkKeySerializer())
119 .register(ConnectPoint.class, new ConnectPointSerializer())
120 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700121 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700122 .register(HostLocation.class, new HostLocationSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700123
124 .build();
125
126
127 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700128 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700129}