blob: 9b75cea2f9ae08d90b1975967ec1552f9fcb9f5b [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;
alshabibf6c2ede2014-10-22 23:31:50 -070034import org.onlab.onos.net.flow.FlowEntry;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070035import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070036import org.onlab.onos.net.flow.criteria.Criteria;
37import org.onlab.onos.net.flow.criteria.Criterion;
38import org.onlab.onos.net.flow.instructions.Instructions;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070039import org.onlab.onos.net.host.DefaultHostDescription;
40import org.onlab.onos.net.host.HostDescription;
Madan Jampani2ff05592014-10-10 15:42:47 -070041import org.onlab.onos.net.link.DefaultLinkDescription;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070042import org.onlab.onos.net.provider.ProviderId;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070043import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070044import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070045import org.onlab.packet.IpAddress;
46import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070047import org.onlab.packet.MacAddress;
48import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070049import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070050
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070051import com.google.common.collect.ImmutableList;
52import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070053import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070054
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070055public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070056
57 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070058 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070059 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070060 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070061 .register(IpPrefix.class, new IpPrefixSerializer())
62 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070063 .register(MacAddress.class, new MacAddressSerializer())
64 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070065 .build();
66
67 // TODO: Populate other classes
68 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070069 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070070 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070071 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070072 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070073 .register(ImmutableMap.class, new ImmutableMapSerializer())
74 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070075 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070076 .register(
77 //
78 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070079 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070080 HashMap.class,
alshabib3d643ec2014-10-22 18:33:00 -070081 HashSet.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070082 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070083 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070084 ControllerNode.State.class,
85 Device.Type.class,
alshabib7911a052014-10-16 17:49:37 -070086 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070087 DefaultAnnotations.class,
88 DefaultControllerNode.class,
89 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070090 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -070091 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070092 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070093 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070094 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070095 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070096 Timestamp.class,
97 HostId.class,
98 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -070099 DefaultHostDescription.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700100 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700101 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700102 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700103 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700104 DefaultTrafficSelector.class,
105 Criteria.PortCriterion.class,
106 Criteria.EthCriterion.class,
107 Criteria.EthTypeCriterion.class,
108 Criteria.IPCriterion.class,
109 Criteria.IPProtocolCriterion.class,
110 Criteria.VlanIdCriterion.class,
111 Criteria.VlanPcpCriterion.class,
112 Criteria.TcpPortCriterion.class,
113 Criterion.class,
114 Criterion.Type.class,
115 DefaultTrafficTreatment.class,
116 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700117 Instructions.OutputInstruction.class,
118 RoleInfo.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700119 )
120 .register(URI.class, new URISerializer())
121 .register(NodeId.class, new NodeIdSerializer())
122 .register(ProviderId.class, new ProviderIdSerializer())
123 .register(DeviceId.class, new DeviceIdSerializer())
124 .register(PortNumber.class, new PortNumberSerializer())
125 .register(DefaultPort.class, new DefaultPortSerializer())
126 .register(LinkKey.class, new LinkKeySerializer())
127 .register(ConnectPoint.class, new ConnectPointSerializer())
128 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700129 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700130 .register(HostLocation.class, new HostLocationSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700131
132 .build();
133
134
135 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700136 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700137}