blob: 0e8b4a8a955e2d01e1d6251594ea0bc1e88448f6 [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 */
Brian O'Connorabafb502014-12-02 22:26:20 -080016package org.onosproject.store.serializers;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070017
Jonathan Hart45727852015-01-28 13:35:54 -080018import com.google.common.collect.ImmutableList;
19import com.google.common.collect.ImmutableMap;
20import com.google.common.collect.ImmutableSet;
21import org.onlab.packet.ChassisId;
22import org.onlab.packet.Ip4Address;
23import org.onlab.packet.Ip4Prefix;
24import org.onlab.packet.Ip6Address;
25import org.onlab.packet.Ip6Prefix;
26import org.onlab.packet.IpAddress;
27import org.onlab.packet.IpPrefix;
28import org.onlab.packet.MacAddress;
29import org.onlab.packet.VlanId;
30import org.onlab.util.KryoNamespace;
Thomas Vachuska90b453f2015-01-30 18:57:14 -080031import org.onosproject.app.ApplicationState;
Brian O'Connorabafb502014-12-02 22:26:20 -080032import org.onosproject.cluster.ControllerNode;
33import org.onosproject.cluster.DefaultControllerNode;
34import org.onosproject.cluster.Leadership;
35import org.onosproject.cluster.LeadershipEvent;
36import org.onosproject.cluster.NodeId;
37import org.onosproject.cluster.RoleInfo;
Thomas Vachuska90b453f2015-01-30 18:57:14 -080038import org.onosproject.core.DefaultApplication;
Brian O'Connorabafb502014-12-02 22:26:20 -080039import org.onosproject.core.DefaultApplicationId;
40import org.onosproject.core.DefaultGroupId;
Thomas Vachuska90b453f2015-01-30 18:57:14 -080041import org.onosproject.core.Version;
Brian O'Connorabafb502014-12-02 22:26:20 -080042import org.onosproject.mastership.MastershipTerm;
43import org.onosproject.net.ConnectPoint;
44import org.onosproject.net.DefaultAnnotations;
45import org.onosproject.net.DefaultDevice;
46import org.onosproject.net.DefaultEdgeLink;
47import org.onosproject.net.DefaultLink;
48import org.onosproject.net.DefaultPath;
49import org.onosproject.net.DefaultPort;
50import org.onosproject.net.Device;
51import org.onosproject.net.DeviceId;
52import org.onosproject.net.Element;
53import org.onosproject.net.HostId;
54import org.onosproject.net.HostLocation;
55import org.onosproject.net.Link;
56import org.onosproject.net.LinkKey;
57import org.onosproject.net.Port;
58import org.onosproject.net.PortNumber;
59import org.onosproject.net.device.DefaultDeviceDescription;
60import org.onosproject.net.device.DefaultPortDescription;
61import org.onosproject.net.flow.CompletedBatchOperation;
62import org.onosproject.net.flow.DefaultFlowEntry;
63import org.onosproject.net.flow.DefaultFlowRule;
64import org.onosproject.net.flow.DefaultTrafficSelector;
65import org.onosproject.net.flow.DefaultTrafficTreatment;
66import org.onosproject.net.flow.FlowEntry;
67import org.onosproject.net.flow.FlowId;
Brian O'Connor72cb19a2015-01-16 16:14:41 -080068import org.onosproject.net.flow.FlowRule;
Brian O'Connorabafb502014-12-02 22:26:20 -080069import org.onosproject.net.flow.FlowRuleBatchEntry;
Brian O'Connor72cb19a2015-01-16 16:14:41 -080070import org.onosproject.net.flow.FlowRuleBatchEvent;
Brian O'Connorabafb502014-12-02 22:26:20 -080071import org.onosproject.net.flow.FlowRuleBatchOperation;
Brian O'Connor72cb19a2015-01-16 16:14:41 -080072import org.onosproject.net.flow.FlowRuleBatchRequest;
Brian O'Connorabafb502014-12-02 22:26:20 -080073import org.onosproject.net.flow.StoredFlowEntry;
74import org.onosproject.net.flow.criteria.Criteria;
75import org.onosproject.net.flow.criteria.Criterion;
76import org.onosproject.net.flow.instructions.Instructions;
77import org.onosproject.net.flow.instructions.L0ModificationInstruction;
78import org.onosproject.net.flow.instructions.L2ModificationInstruction;
79import org.onosproject.net.flow.instructions.L3ModificationInstruction;
80import org.onosproject.net.host.DefaultHostDescription;
81import org.onosproject.net.host.HostDescription;
82import org.onosproject.net.intent.ConnectivityIntent;
83import org.onosproject.net.intent.HostToHostIntent;
84import org.onosproject.net.intent.Intent;
85import org.onosproject.net.intent.IntentId;
86import org.onosproject.net.intent.IntentOperation;
Brian O'Connorabafb502014-12-02 22:26:20 -080087import org.onosproject.net.intent.IntentState;
88import org.onosproject.net.intent.LinkCollectionIntent;
89import org.onosproject.net.intent.MultiPointToSinglePointIntent;
90import org.onosproject.net.intent.OpticalConnectivityIntent;
91import org.onosproject.net.intent.OpticalPathIntent;
92import org.onosproject.net.intent.PathIntent;
93import org.onosproject.net.intent.PointToPointIntent;
Brian O'Connorabafb502014-12-02 22:26:20 -080094import org.onosproject.net.intent.SinglePointToMultiPointIntent;
Jonathan Hart45727852015-01-28 13:35:54 -080095import org.onosproject.net.intent.constraint.AnnotationConstraint;
Brian O'Connorabafb502014-12-02 22:26:20 -080096import org.onosproject.net.intent.constraint.BandwidthConstraint;
97import org.onosproject.net.intent.constraint.BooleanConstraint;
98import org.onosproject.net.intent.constraint.LambdaConstraint;
99import org.onosproject.net.intent.constraint.LatencyConstraint;
100import org.onosproject.net.intent.constraint.LinkTypeConstraint;
101import org.onosproject.net.intent.constraint.ObstacleConstraint;
102import org.onosproject.net.intent.constraint.WaypointConstraint;
103import org.onosproject.net.link.DefaultLinkDescription;
104import org.onosproject.net.packet.DefaultOutboundPacket;
105import org.onosproject.net.provider.ProviderId;
106import org.onosproject.net.resource.Bandwidth;
107import org.onosproject.net.resource.BandwidthResourceAllocation;
108import org.onosproject.net.resource.BandwidthResourceRequest;
109import org.onosproject.net.resource.DefaultLinkResourceAllocations;
110import org.onosproject.net.resource.DefaultLinkResourceRequest;
111import org.onosproject.net.resource.Lambda;
112import org.onosproject.net.resource.LambdaResourceAllocation;
113import org.onosproject.net.resource.LambdaResourceRequest;
114import org.onosproject.net.resource.LinkResourceRequest;
115import org.onosproject.store.Timestamp;
116import org.onosproject.store.service.BatchReadRequest;
117import org.onosproject.store.service.BatchWriteRequest;
118import org.onosproject.store.service.ReadRequest;
119import org.onosproject.store.service.ReadResult;
120import org.onosproject.store.service.ReadStatus;
121import org.onosproject.store.service.VersionedValue;
122import org.onosproject.store.service.WriteRequest;
123import org.onosproject.store.service.WriteResult;
124import org.onosproject.store.service.WriteStatus;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700125
Jonathan Hart45727852015-01-28 13:35:54 -0800126import java.net.URI;
127import java.time.Duration;
128import java.util.ArrayList;
129import java.util.Arrays;
130import java.util.Collections;
131import java.util.HashMap;
132import java.util.HashSet;
133import java.util.LinkedList;
134import java.util.Optional;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700135
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700136public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700137
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800138 public static final KryoNamespace BASIC = KryoNamespace.newBuilder()
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800139 .nextId(KryoNamespace.FLOATING_ID)
140 .register(byte[].class)
141 .register(new ImmutableListSerializer(),
142 ImmutableList.class,
143 ImmutableList.of(1).getClass(),
144 ImmutableList.of(1, 2).getClass())
145 .register(new ImmutableSetSerializer(),
146 ImmutableSet.class,
147 ImmutableSet.of().getClass(),
148 ImmutableSet.of(1).getClass(),
149 ImmutableSet.of(1, 2).getClass())
150 .register(new ImmutableMapSerializer(),
151 ImmutableMap.class,
152 ImmutableMap.of().getClass(),
153 ImmutableMap.of("a", 1).getClass(),
154 ImmutableMap.of("R", 2, "D", 2).getClass())
155 .register(HashMap.class)
156 .register(ArrayList.class,
157 LinkedList.class,
158 HashSet.class
159 )
160 .register(new ArraysAsListSerializer(), Arrays.asList().getClass())
161 .register(Collections.singletonList(1).getClass())
162 .register(Duration.class)
Yuta HIGUCHIae1d2102014-11-25 19:26:01 -0800163 .register(Collections.emptySet().getClass())
Sho SHIMIZU166e61e2015-01-21 18:07:12 -0800164 .register(Optional.class)
Jonathan Hart45727852015-01-28 13:35:54 -0800165 .register(Collections.emptyList().getClass())
Brian O'Connor72cb19a2015-01-16 16:14:41 -0800166 .register(Collections.unmodifiableSet(Collections.emptySet()).getClass())
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800167 .build();
168
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700169 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700170 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700171 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700172 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800173 .nextId(KryoNamespace.FLOATING_ID)
174 .register(new IpPrefixSerializer(), IpPrefix.class)
175 .register(new Ip4PrefixSerializer(), Ip4Prefix.class)
176 .register(new Ip6PrefixSerializer(), Ip6Prefix.class)
177 .register(new IpAddressSerializer(), IpAddress.class)
178 .register(new Ip4AddressSerializer(), Ip4Address.class)
179 .register(new Ip6AddressSerializer(), Ip6Address.class)
180 .register(new MacAddressSerializer(), MacAddress.class)
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700181 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700182 .build();
183
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800184 /**
185 * Kryo registration Id for user custom registration.
186 */
187 public static final int BEGIN_USER_CUSTOM_ID = 300;
188
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700189 // TODO: Populate other classes
190 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700191 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700192 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700193 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800194 .nextId(KryoNamespace.INITIAL_ID)
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800195 .register(BASIC)
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800196 .nextId(KryoNamespace.INITIAL_ID + 30)
197 .register(MISC)
198 .nextId(KryoNamespace.INITIAL_ID + 30 + 10)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700199 .register(
Thomas Vachuska90b453f2015-01-30 18:57:14 -0800200 Version.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700201 ControllerNode.State.class,
Thomas Vachuska90b453f2015-01-30 18:57:14 -0800202 ApplicationState.class,
203 DefaultApplication.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700204 Device.Type.class,
Thomas Vachuskad16ce182014-10-29 17:25:29 -0700205 Port.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700206 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700207 DefaultAnnotations.class,
208 DefaultControllerNode.class,
209 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700210 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700211 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700212 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700213 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700214 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700215 Link.Type.class,
Thomas Vachuska57126fe2014-11-11 17:13:24 -0800216 Link.State.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700217 Timestamp.class,
Madan Jampani1ee91782014-11-20 20:24:24 -0800218 Leadership.class,
219 LeadershipEvent.class,
220 LeadershipEvent.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700221 HostId.class,
222 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700223 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700224 DefaultFlowEntry.class,
225 StoredFlowEntry.class,
sangho11c30ac2015-01-22 14:30:55 -0800226 FlowRule.Type.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700227 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700228 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700229 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700230 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700231 DefaultTrafficSelector.class,
232 Criteria.PortCriterion.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800233 Criteria.MetadataCriterion.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700234 Criteria.EthCriterion.class,
235 Criteria.EthTypeCriterion.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700236 Criteria.VlanIdCriterion.class,
237 Criteria.VlanPcpCriterion.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800238 Criteria.IPDscpCriterion.class,
239 Criteria.IPEcnCriterion.class,
240 Criteria.IPProtocolCriterion.class,
241 Criteria.IPCriterion.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700242 Criteria.TcpPortCriterion.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800243 Criteria.UdpPortCriterion.class,
244 Criteria.SctpPortCriterion.class,
245 Criteria.IcmpTypeCriterion.class,
246 Criteria.IcmpCodeCriterion.class,
247 Criteria.IPv6FlowLabelCriterion.class,
248 Criteria.Icmpv6TypeCriterion.class,
249 Criteria.Icmpv6CodeCriterion.class,
250 Criteria.IPv6NDTargetAddressCriterion.class,
251 Criteria.IPv6NDLinkLayerAddressCriterion.class,
Praseed Balakrishnandb8a9d22014-12-03 11:47:55 -0800252 Criteria.MplsCriterion.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800253 Criteria.IPv6ExthdrFlagsCriterion.class,
254 Criteria.LambdaCriterion.class,
255 Criteria.OpticalSignalTypeCriterion.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700256 Criterion.class,
257 Criterion.Type.class,
258 DefaultTrafficTreatment.class,
259 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700260 Instructions.OutputInstruction.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800261 Instructions.GroupInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700262 L0ModificationInstruction.class,
263 L0ModificationInstruction.L0SubType.class,
264 L0ModificationInstruction.ModLambdaInstruction.class,
265 L2ModificationInstruction.class,
266 L2ModificationInstruction.L2SubType.class,
267 L2ModificationInstruction.ModEtherInstruction.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800268 L2ModificationInstruction.PushHeaderInstructions.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700269 L2ModificationInstruction.ModVlanIdInstruction.class,
270 L2ModificationInstruction.ModVlanPcpInstruction.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800271 L2ModificationInstruction.ModMplsLabelInstruction.class,
272 L2ModificationInstruction.ModMplsTtlInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700273 L3ModificationInstruction.class,
274 L3ModificationInstruction.L3SubType.class,
275 L3ModificationInstruction.ModIPInstruction.class,
Pavlin Radoslavovfebe82c2015-02-11 19:08:15 -0800276 L3ModificationInstruction.ModIPv6FlowLabelInstruction.class,
Pavlin Radoslavov1d218662015-02-13 11:34:30 -0800277 L3ModificationInstruction.ModTtlInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700278 RoleInfo.class,
Brian O'Connor72cb19a2015-01-16 16:14:41 -0800279 FlowRuleBatchEvent.class,
280 FlowRuleBatchEvent.Type.class,
281 FlowRuleBatchRequest.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700282 FlowRuleBatchOperation.class,
283 CompletedBatchOperation.class,
284 FlowRuleBatchEntry.class,
Yuta HIGUCHI087019b2014-10-28 21:07:56 -0700285 FlowRuleBatchEntry.FlowRuleOperation.class,
286 IntentId.class,
287 IntentState.class,
288 Intent.class,
289 ConnectivityIntent.class,
290 PathIntent.class,
291 DefaultPath.class,
292 DefaultEdgeLink.class,
293 HostToHostIntent.class,
294 PointToPointIntent.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700295 MultiPointToSinglePointIntent.class,
Michele Santuari4a338072014-11-05 18:38:55 +0100296 SinglePointToMultiPointIntent.class,
Brian O'Connor41718fc2014-10-30 16:57:21 -0700297 LinkCollectionIntent.class,
298 OpticalConnectivityIntent.class,
299 OpticalPathIntent.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800300 LinkResourceRequest.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800301 DefaultLinkResourceRequest.class,
302 BandwidthResourceRequest.class,
303 LambdaResourceRequest.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800304 Lambda.class,
305 Bandwidth.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800306 DefaultLinkResourceAllocations.class,
307 BandwidthResourceAllocation.class,
308 LambdaResourceAllocation.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800309 // Constraints
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800310 LambdaConstraint.class,
311 BandwidthConstraint.class,
312 LinkTypeConstraint.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800313 LatencyConstraint.class,
314 WaypointConstraint.class,
315 ObstacleConstraint.class,
316 AnnotationConstraint.class,
Brian O'Connor72a034c2014-11-26 18:24:23 -0800317 BooleanConstraint.class,
Ray Milkey24226a22015-02-03 16:25:25 -0800318 IntentOperation.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700319 )
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800320 .register(new DefaultApplicationIdSerializer(), DefaultApplicationId.class)
321 .register(new URISerializer(), URI.class)
322 .register(new NodeIdSerializer(), NodeId.class)
323 .register(new ProviderIdSerializer(), ProviderId.class)
324 .register(new DeviceIdSerializer(), DeviceId.class)
325 .register(new PortNumberSerializer(), PortNumber.class)
326 .register(new DefaultPortSerializer(), DefaultPort.class)
327 .register(new LinkKeySerializer(), LinkKey.class)
328 .register(new ConnectPointSerializer(), ConnectPoint.class)
329 .register(new DefaultLinkSerializer(), DefaultLink.class)
330 .register(new MastershipTermSerializer(), MastershipTerm.class)
331 .register(new HostLocationSerializer(), HostLocation.class)
332 .register(new DefaultOutboundPacketSerializer(), DefaultOutboundPacket.class)
333 .register(ReadRequest.class)
334 .register(WriteRequest.class)
335 .register(WriteRequest.Type.class)
336 .register(WriteResult.class)
337 .register(ReadResult.class)
338 .register(BatchReadRequest.class)
339 .register(BatchWriteRequest.class)
340 .register(ReadStatus.class)
341 .register(WriteStatus.class)
342 .register(VersionedValue.class)
Yuta HIGUCHIf6171232014-11-25 15:14:44 -0800343 .register(DefaultGroupId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700344
345 .build();
346
347
348 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700349 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700350}