blob: dc0eaa80c9fe99c06f6df756573a50ca0f00c0e9 [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;
alshabib3d643ec2014-10-22 18:33:00 -07007import java.util.HashSet;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -07008
9import org.onlab.onos.cluster.ControllerNode;
10import org.onlab.onos.cluster.DefaultControllerNode;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070011import org.onlab.onos.cluster.NodeId;
Yuta HIGUCHI40d01772014-10-21 00:08:44 -070012import org.onlab.onos.cluster.RoleInfo;
Yuta HIGUCHI80912e62014-10-12 00:15:47 -070013import org.onlab.onos.mastership.MastershipTerm;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070014import org.onlab.onos.net.ConnectPoint;
15import org.onlab.onos.net.DefaultAnnotations;
16import org.onlab.onos.net.DefaultDevice;
17import org.onlab.onos.net.DefaultLink;
18import org.onlab.onos.net.DefaultPort;
19import org.onlab.onos.net.Device;
20import org.onlab.onos.net.DeviceId;
21import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070022import org.onlab.onos.net.HostId;
23import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070024import org.onlab.onos.net.Link;
25import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070026import org.onlab.onos.net.Port;
27import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070028import org.onlab.onos.net.device.DefaultDeviceDescription;
29import org.onlab.onos.net.device.DefaultPortDescription;
alshabib3d643ec2014-10-22 18:33:00 -070030import org.onlab.onos.net.flow.DefaultFlowEntry;
Madan Jampani38b250d2014-10-17 11:02:38 -070031import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070032import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070033import org.onlab.onos.net.flow.DefaultTrafficTreatment;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070034import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070035import org.onlab.onos.net.flow.criteria.Criteria;
36import org.onlab.onos.net.flow.criteria.Criterion;
37import org.onlab.onos.net.flow.instructions.Instructions;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070038import org.onlab.onos.net.host.DefaultHostDescription;
39import org.onlab.onos.net.host.HostDescription;
Madan Jampani2ff05592014-10-10 15:42:47 -070040import org.onlab.onos.net.link.DefaultLinkDescription;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070041import org.onlab.onos.net.provider.ProviderId;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070042import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070043import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070044import org.onlab.packet.IpAddress;
45import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070046import org.onlab.packet.MacAddress;
47import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070048import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070049
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070050import com.google.common.collect.ImmutableList;
51import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070052import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070053
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070054public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070055
56 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070057 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070058 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070059 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070060 .register(IpPrefix.class, new IpPrefixSerializer())
61 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070062 .register(MacAddress.class, new MacAddressSerializer())
63 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070064 .build();
65
66 // TODO: Populate other classes
67 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070068 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070069 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070070 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070071 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070072 .register(ImmutableMap.class, new ImmutableMapSerializer())
73 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070074 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070075 .register(
76 //
77 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070078 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070079 HashMap.class,
alshabib3d643ec2014-10-22 18:33:00 -070080 HashSet.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070081 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070082 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070083 ControllerNode.State.class,
84 Device.Type.class,
alshabib7911a052014-10-16 17:49:37 -070085 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070086 DefaultAnnotations.class,
87 DefaultControllerNode.class,
88 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070089 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -070090 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070091 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070092 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070093 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070094 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070095 Timestamp.class,
96 HostId.class,
97 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -070098 DefaultHostDescription.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070099 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700100 DefaultFlowEntry.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700101 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700102 DefaultTrafficSelector.class,
103 Criteria.PortCriterion.class,
104 Criteria.EthCriterion.class,
105 Criteria.EthTypeCriterion.class,
106 Criteria.IPCriterion.class,
107 Criteria.IPProtocolCriterion.class,
108 Criteria.VlanIdCriterion.class,
109 Criteria.VlanPcpCriterion.class,
110 Criteria.TcpPortCriterion.class,
111 Criterion.class,
112 Criterion.Type.class,
113 DefaultTrafficTreatment.class,
114 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700115 Instructions.OutputInstruction.class,
116 RoleInfo.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700117 )
118 .register(URI.class, new URISerializer())
119 .register(NodeId.class, new NodeIdSerializer())
120 .register(ProviderId.class, new ProviderIdSerializer())
121 .register(DeviceId.class, new DeviceIdSerializer())
122 .register(PortNumber.class, new PortNumberSerializer())
123 .register(DefaultPort.class, new DefaultPortSerializer())
124 .register(LinkKey.class, new LinkKeySerializer())
125 .register(ConnectPoint.class, new ConnectPointSerializer())
126 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700127 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700128 .register(HostLocation.class, new HostLocationSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700129
130 .build();
131
132
133 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700134 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700135}