blob: f17c26822247b39a518b1f5575bd4e9e126f5396 [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 HIGUCHId40483d2014-10-09 15:20:30 -070024import org.onlab.onos.net.MastershipRole;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070025import org.onlab.onos.net.Port;
26import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070027import org.onlab.onos.net.device.DefaultDeviceDescription;
28import org.onlab.onos.net.device.DefaultPortDescription;
Madan Jampani38b250d2014-10-17 11:02:38 -070029import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070030import org.onlab.onos.net.host.DefaultHostDescription;
31import org.onlab.onos.net.host.HostDescription;
Madan Jampani2ff05592014-10-10 15:42:47 -070032import org.onlab.onos.net.link.DefaultLinkDescription;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070033import org.onlab.onos.net.provider.ProviderId;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070034import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070035import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070036import org.onlab.packet.IpAddress;
37import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070038import org.onlab.packet.MacAddress;
39import org.onlab.packet.VlanId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070040import org.onlab.util.KryoPool;
41
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070042import com.google.common.collect.ImmutableList;
43import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070044import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070045
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070046public final class KryoPoolUtil {
47
48 /**
49 * KryoPool which can serialize ON.lab misc classes.
50 */
51 public static final KryoPool MISC = KryoPool.newBuilder()
52 .register(IpPrefix.class, new IpPrefixSerializer())
53 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070054 .register(MacAddress.class, new MacAddressSerializer())
55 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070056 .build();
57
58 // TODO: Populate other classes
59 /**
60 * KryoPool which can serialize API bundle classes.
61 */
62 public static final KryoPool API = KryoPool.newBuilder()
63 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070064 .register(ImmutableMap.class, new ImmutableMapSerializer())
65 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070066 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070067 .register(
68 //
69 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070070 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070071 HashMap.class,
72 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070073 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070074 ControllerNode.State.class,
75 Device.Type.class,
alshabib7911a052014-10-16 17:49:37 -070076 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070077 DefaultAnnotations.class,
78 DefaultControllerNode.class,
79 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070080 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -070081 DefaultLinkDescription.class,
Yuta HIGUCHId40483d2014-10-09 15:20:30 -070082 MastershipRole.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070083 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -070084 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070085 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070086 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070087 Timestamp.class,
88 HostId.class,
89 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -070090 DefaultHostDescription.class,
91 DefaultFlowRule.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070092 )
93 .register(URI.class, new URISerializer())
94 .register(NodeId.class, new NodeIdSerializer())
95 .register(ProviderId.class, new ProviderIdSerializer())
96 .register(DeviceId.class, new DeviceIdSerializer())
97 .register(PortNumber.class, new PortNumberSerializer())
98 .register(DefaultPort.class, new DefaultPortSerializer())
99 .register(LinkKey.class, new LinkKeySerializer())
100 .register(ConnectPoint.class, new ConnectPointSerializer())
101 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700102 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHId40483d2014-10-09 15:20:30 -0700103 .register(MastershipRole.class, new MastershipRoleSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700104 .register(HostLocation.class, new HostLocationSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700105
106 .build();
107
108
109 // not to be instantiated
110 private KryoPoolUtil() {}
111}