blob: fea74bfe00aed2ee869699ec0e5a2ef98984cf41 [file] [log] [blame]
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07001/*
2 * Copyright 2014 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070016package org.onlab.onos.store.serializers;
17
18import java.net.URI;
Sho SHIMIZU977cb602014-11-13 08:40:50 -080019import java.time.Duration;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070020import java.util.ArrayList;
Madan Jampani53e44e62014-10-07 12:39:51 -070021import java.util.Arrays;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070022import java.util.HashMap;
alshabib3d643ec2014-10-22 18:33:00 -070023import java.util.HashSet;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070024import java.util.LinkedList;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070025
26import org.onlab.onos.cluster.ControllerNode;
27import org.onlab.onos.cluster.DefaultControllerNode;
Madan Jampani1ee91782014-11-20 20:24:24 -080028import org.onlab.onos.cluster.Leadership;
29import org.onlab.onos.cluster.LeadershipEvent;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070030import org.onlab.onos.cluster.NodeId;
Yuta HIGUCHI40d01772014-10-21 00:08:44 -070031import org.onlab.onos.cluster.RoleInfo;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070032import org.onlab.onos.core.DefaultApplicationId;
Yuta HIGUCHI80912e62014-10-12 00:15:47 -070033import org.onlab.onos.mastership.MastershipTerm;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070034import org.onlab.onos.net.ConnectPoint;
35import org.onlab.onos.net.DefaultAnnotations;
36import org.onlab.onos.net.DefaultDevice;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070037import org.onlab.onos.net.DefaultEdgeLink;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070038import org.onlab.onos.net.DefaultLink;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070039import org.onlab.onos.net.DefaultPath;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070040import org.onlab.onos.net.DefaultPort;
41import org.onlab.onos.net.Device;
42import org.onlab.onos.net.DeviceId;
43import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070044import org.onlab.onos.net.HostId;
45import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070046import org.onlab.onos.net.Link;
47import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070048import org.onlab.onos.net.Port;
49import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070050import org.onlab.onos.net.device.DefaultDeviceDescription;
51import org.onlab.onos.net.device.DefaultPortDescription;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070052import org.onlab.onos.net.flow.CompletedBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070053import org.onlab.onos.net.flow.DefaultFlowEntry;
Madan Jampani38b250d2014-10-17 11:02:38 -070054import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070055import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070056import org.onlab.onos.net.flow.DefaultTrafficTreatment;
alshabibf6c2ede2014-10-22 23:31:50 -070057import org.onlab.onos.net.flow.FlowEntry;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070058import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070059import org.onlab.onos.net.flow.FlowRuleBatchEntry;
60import org.onlab.onos.net.flow.FlowRuleBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070061import org.onlab.onos.net.flow.StoredFlowEntry;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070062import org.onlab.onos.net.flow.criteria.Criteria;
63import org.onlab.onos.net.flow.criteria.Criterion;
64import org.onlab.onos.net.flow.instructions.Instructions;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070065import org.onlab.onos.net.flow.instructions.L0ModificationInstruction;
66import org.onlab.onos.net.flow.instructions.L2ModificationInstruction;
67import org.onlab.onos.net.flow.instructions.L3ModificationInstruction;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070068import org.onlab.onos.net.host.DefaultHostDescription;
69import org.onlab.onos.net.host.HostDescription;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070070import org.onlab.onos.net.intent.ConnectivityIntent;
71import org.onlab.onos.net.intent.HostToHostIntent;
72import org.onlab.onos.net.intent.Intent;
73import org.onlab.onos.net.intent.IntentId;
74import org.onlab.onos.net.intent.IntentState;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070075import org.onlab.onos.net.intent.LinkCollectionIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070076import org.onlab.onos.net.intent.MultiPointToSinglePointIntent;
Brian O'Connor41718fc2014-10-30 16:57:21 -070077import org.onlab.onos.net.intent.OpticalConnectivityIntent;
78import org.onlab.onos.net.intent.OpticalPathIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070079import org.onlab.onos.net.intent.PathIntent;
80import org.onlab.onos.net.intent.PointToPointIntent;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080081import org.onlab.onos.net.intent.constraint.AnnotationConstraint;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080082import org.onlab.onos.net.intent.constraint.BandwidthConstraint;
83import org.onlab.onos.net.intent.constraint.BooleanConstraint;
84import org.onlab.onos.net.intent.constraint.LambdaConstraint;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080085import org.onlab.onos.net.intent.constraint.LatencyConstraint;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080086import org.onlab.onos.net.intent.constraint.LinkTypeConstraint;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080087import org.onlab.onos.net.intent.constraint.ObstacleConstraint;
88import org.onlab.onos.net.intent.constraint.WaypointConstraint;
Madan Jampani2ff05592014-10-10 15:42:47 -070089import org.onlab.onos.net.link.DefaultLinkDescription;
Jonathan Hart4f60f982014-10-27 08:11:17 -070090import org.onlab.onos.net.packet.DefaultOutboundPacket;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070091import org.onlab.onos.net.provider.ProviderId;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080092import org.onlab.onos.net.resource.Bandwidth;
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -080093import org.onlab.onos.net.resource.BandwidthResourceAllocation;
94import org.onlab.onos.net.resource.BandwidthResourceRequest;
95import org.onlab.onos.net.resource.DefaultLinkResourceAllocations;
96import org.onlab.onos.net.resource.DefaultLinkResourceRequest;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080097import org.onlab.onos.net.resource.Lambda;
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -080098import org.onlab.onos.net.resource.LambdaResourceAllocation;
99import org.onlab.onos.net.resource.LambdaResourceRequest;
Brian O'Connor41718fc2014-10-30 16:57:21 -0700100import org.onlab.onos.net.resource.LinkResourceRequest;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700101import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -0700102import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700103import org.onlab.packet.IpAddress;
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800104import org.onlab.packet.Ip4Address;
105import org.onlab.packet.Ip6Address;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700106import org.onlab.packet.IpPrefix;
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800107import org.onlab.packet.Ip4Prefix;
108import org.onlab.packet.Ip6Prefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700109import org.onlab.packet.MacAddress;
110import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700111import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700112
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700113import com.google.common.collect.ImmutableList;
114import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700115import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700116
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700117public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700118
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800119 public static final KryoNamespace BASIC = KryoNamespace.newBuilder()
120 .register(ImmutableMap.class, new ImmutableMapSerializer())
121 .register(ImmutableList.class, new ImmutableListSerializer())
122 .register(ImmutableSet.class, new ImmutableSetSerializer())
123 .register(
124 ArrayList.class,
125 Arrays.asList().getClass(),
126 HashMap.class,
127 HashSet.class,
128 LinkedList.class,
Sho SHIMIZU977cb602014-11-13 08:40:50 -0800129 byte[].class,
130 Duration.class
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800131 )
132 .build();
133
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700134 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700135 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700136 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700137 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700138 .register(IpPrefix.class, new IpPrefixSerializer())
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800139 .register(Ip4Prefix.class, new Ip4PrefixSerializer())
140 .register(Ip6Prefix.class, new Ip6PrefixSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700141 .register(IpAddress.class, new IpAddressSerializer())
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800142 .register(Ip4Address.class, new Ip4AddressSerializer())
143 .register(Ip6Address.class, new Ip6AddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700144 .register(MacAddress.class, new MacAddressSerializer())
145 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700146 .build();
147
148 // TODO: Populate other classes
149 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700150 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700151 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700152 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700153 .register(MISC)
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800154 .register(BASIC)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700155 .register(
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700156 ControllerNode.State.class,
157 Device.Type.class,
Thomas Vachuskad16ce182014-10-29 17:25:29 -0700158 Port.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700159 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700160 DefaultAnnotations.class,
161 DefaultControllerNode.class,
162 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700163 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700164 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700165 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700166 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700167 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700168 Link.Type.class,
Thomas Vachuska57126fe2014-11-11 17:13:24 -0800169 Link.State.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700170 Timestamp.class,
Madan Jampani1ee91782014-11-20 20:24:24 -0800171 Leadership.class,
172 LeadershipEvent.class,
173 LeadershipEvent.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700174 HostId.class,
175 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700176 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700177 DefaultFlowEntry.class,
178 StoredFlowEntry.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700179 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700180 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700181 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700182 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700183 DefaultTrafficSelector.class,
184 Criteria.PortCriterion.class,
185 Criteria.EthCriterion.class,
186 Criteria.EthTypeCriterion.class,
187 Criteria.IPCriterion.class,
188 Criteria.IPProtocolCriterion.class,
189 Criteria.VlanIdCriterion.class,
190 Criteria.VlanPcpCriterion.class,
191 Criteria.TcpPortCriterion.class,
192 Criterion.class,
193 Criterion.Type.class,
194 DefaultTrafficTreatment.class,
195 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700196 Instructions.OutputInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700197 L0ModificationInstruction.class,
198 L0ModificationInstruction.L0SubType.class,
199 L0ModificationInstruction.ModLambdaInstruction.class,
200 L2ModificationInstruction.class,
201 L2ModificationInstruction.L2SubType.class,
202 L2ModificationInstruction.ModEtherInstruction.class,
203 L2ModificationInstruction.ModVlanIdInstruction.class,
204 L2ModificationInstruction.ModVlanPcpInstruction.class,
205 L3ModificationInstruction.class,
206 L3ModificationInstruction.L3SubType.class,
207 L3ModificationInstruction.ModIPInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700208 RoleInfo.class,
209 FlowRuleBatchOperation.class,
210 CompletedBatchOperation.class,
211 FlowRuleBatchEntry.class,
Yuta HIGUCHI087019b2014-10-28 21:07:56 -0700212 FlowRuleBatchEntry.FlowRuleOperation.class,
213 IntentId.class,
214 IntentState.class,
215 Intent.class,
216 ConnectivityIntent.class,
217 PathIntent.class,
218 DefaultPath.class,
219 DefaultEdgeLink.class,
220 HostToHostIntent.class,
221 PointToPointIntent.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700222 MultiPointToSinglePointIntent.class,
Brian O'Connor41718fc2014-10-30 16:57:21 -0700223 LinkCollectionIntent.class,
224 OpticalConnectivityIntent.class,
225 OpticalPathIntent.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800226 LinkResourceRequest.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800227 DefaultLinkResourceRequest.class,
228 BandwidthResourceRequest.class,
229 LambdaResourceRequest.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800230 Lambda.class,
231 Bandwidth.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800232 DefaultLinkResourceAllocations.class,
233 BandwidthResourceAllocation.class,
234 LambdaResourceAllocation.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800235 // Constraints
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800236 LambdaConstraint.class,
237 BandwidthConstraint.class,
238 LinkTypeConstraint.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800239 LatencyConstraint.class,
240 WaypointConstraint.class,
241 ObstacleConstraint.class,
242 AnnotationConstraint.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800243 BooleanConstraint.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700244 )
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700245 .register(DefaultApplicationId.class, new DefaultApplicationIdSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700246 .register(URI.class, new URISerializer())
247 .register(NodeId.class, new NodeIdSerializer())
248 .register(ProviderId.class, new ProviderIdSerializer())
249 .register(DeviceId.class, new DeviceIdSerializer())
250 .register(PortNumber.class, new PortNumberSerializer())
251 .register(DefaultPort.class, new DefaultPortSerializer())
252 .register(LinkKey.class, new LinkKeySerializer())
253 .register(ConnectPoint.class, new ConnectPointSerializer())
254 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700255 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700256 .register(HostLocation.class, new HostLocationSerializer())
Jonathan Hart4f60f982014-10-27 08:11:17 -0700257 .register(DefaultOutboundPacket.class, new DefaultOutboundPacketSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700258
259 .build();
260
261
262 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700263 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700264}