blob: b366dbf46df9da76ba5abb2794bcee6d5cc17cf0 [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 HIGUCHI91768e32014-11-22 05:06:35 -080022import java.util.Collections;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070023import java.util.HashMap;
alshabib3d643ec2014-10-22 18:33:00 -070024import java.util.HashSet;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070025import java.util.LinkedList;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070026
27import org.onlab.onos.cluster.ControllerNode;
28import org.onlab.onos.cluster.DefaultControllerNode;
Madan Jampani1ee91782014-11-20 20:24:24 -080029import org.onlab.onos.cluster.Leadership;
30import org.onlab.onos.cluster.LeadershipEvent;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070031import org.onlab.onos.cluster.NodeId;
Yuta HIGUCHI40d01772014-10-21 00:08:44 -070032import org.onlab.onos.cluster.RoleInfo;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070033import org.onlab.onos.core.DefaultApplicationId;
Yuta HIGUCHIf6171232014-11-25 15:14:44 -080034import org.onlab.onos.core.DefaultGroupId;
Yuta HIGUCHI80912e62014-10-12 00:15:47 -070035import org.onlab.onos.mastership.MastershipTerm;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070036import org.onlab.onos.net.ConnectPoint;
37import org.onlab.onos.net.DefaultAnnotations;
38import org.onlab.onos.net.DefaultDevice;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070039import org.onlab.onos.net.DefaultEdgeLink;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070040import org.onlab.onos.net.DefaultLink;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070041import org.onlab.onos.net.DefaultPath;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070042import org.onlab.onos.net.DefaultPort;
43import org.onlab.onos.net.Device;
44import org.onlab.onos.net.DeviceId;
45import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070046import org.onlab.onos.net.HostId;
47import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070048import org.onlab.onos.net.Link;
49import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070050import org.onlab.onos.net.Port;
51import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070052import org.onlab.onos.net.device.DefaultDeviceDescription;
53import org.onlab.onos.net.device.DefaultPortDescription;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070054import org.onlab.onos.net.flow.CompletedBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070055import org.onlab.onos.net.flow.DefaultFlowEntry;
Madan Jampani38b250d2014-10-17 11:02:38 -070056import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070057import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070058import org.onlab.onos.net.flow.DefaultTrafficTreatment;
alshabibf6c2ede2014-10-22 23:31:50 -070059import org.onlab.onos.net.flow.FlowEntry;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070060import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070061import org.onlab.onos.net.flow.FlowRuleBatchEntry;
62import org.onlab.onos.net.flow.FlowRuleBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070063import org.onlab.onos.net.flow.StoredFlowEntry;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070064import org.onlab.onos.net.flow.criteria.Criteria;
65import org.onlab.onos.net.flow.criteria.Criterion;
66import org.onlab.onos.net.flow.instructions.Instructions;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070067import org.onlab.onos.net.flow.instructions.L0ModificationInstruction;
68import org.onlab.onos.net.flow.instructions.L2ModificationInstruction;
69import org.onlab.onos.net.flow.instructions.L3ModificationInstruction;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070070import org.onlab.onos.net.host.DefaultHostDescription;
71import org.onlab.onos.net.host.HostDescription;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070072import org.onlab.onos.net.intent.ConnectivityIntent;
73import org.onlab.onos.net.intent.HostToHostIntent;
74import org.onlab.onos.net.intent.Intent;
75import org.onlab.onos.net.intent.IntentId;
76import org.onlab.onos.net.intent.IntentState;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070077import org.onlab.onos.net.intent.LinkCollectionIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070078import org.onlab.onos.net.intent.MultiPointToSinglePointIntent;
Brian O'Connor41718fc2014-10-30 16:57:21 -070079import org.onlab.onos.net.intent.OpticalConnectivityIntent;
80import org.onlab.onos.net.intent.OpticalPathIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070081import org.onlab.onos.net.intent.PathIntent;
82import org.onlab.onos.net.intent.PointToPointIntent;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080083import org.onlab.onos.net.intent.constraint.AnnotationConstraint;
Michele Santuari4a338072014-11-05 18:38:55 +010084import org.onlab.onos.net.intent.SinglePointToMultiPointIntent;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080085import org.onlab.onos.net.intent.constraint.BandwidthConstraint;
86import org.onlab.onos.net.intent.constraint.BooleanConstraint;
87import org.onlab.onos.net.intent.constraint.LambdaConstraint;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080088import org.onlab.onos.net.intent.constraint.LatencyConstraint;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080089import org.onlab.onos.net.intent.constraint.LinkTypeConstraint;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080090import org.onlab.onos.net.intent.constraint.ObstacleConstraint;
91import org.onlab.onos.net.intent.constraint.WaypointConstraint;
Madan Jampani2ff05592014-10-10 15:42:47 -070092import org.onlab.onos.net.link.DefaultLinkDescription;
Jonathan Hart4f60f982014-10-27 08:11:17 -070093import org.onlab.onos.net.packet.DefaultOutboundPacket;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070094import org.onlab.onos.net.provider.ProviderId;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080095import org.onlab.onos.net.resource.Bandwidth;
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -080096import org.onlab.onos.net.resource.BandwidthResourceAllocation;
97import org.onlab.onos.net.resource.BandwidthResourceRequest;
98import org.onlab.onos.net.resource.DefaultLinkResourceAllocations;
99import org.onlab.onos.net.resource.DefaultLinkResourceRequest;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800100import org.onlab.onos.net.resource.Lambda;
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800101import org.onlab.onos.net.resource.LambdaResourceAllocation;
102import org.onlab.onos.net.resource.LambdaResourceRequest;
Brian O'Connor41718fc2014-10-30 16:57:21 -0700103import org.onlab.onos.net.resource.LinkResourceRequest;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700104import org.onlab.onos.store.Timestamp;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800105import org.onlab.onos.store.service.BatchReadRequest;
106import org.onlab.onos.store.service.BatchWriteRequest;
107import org.onlab.onos.store.service.ReadRequest;
108import org.onlab.onos.store.service.ReadResult;
109import org.onlab.onos.store.service.ReadStatus;
110import org.onlab.onos.store.service.VersionedValue;
111import org.onlab.onos.store.service.WriteRequest;
112import org.onlab.onos.store.service.WriteResult;
113import org.onlab.onos.store.service.WriteStatus;
alshabib7911a052014-10-16 17:49:37 -0700114import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700115import org.onlab.packet.IpAddress;
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800116import org.onlab.packet.Ip4Address;
117import org.onlab.packet.Ip6Address;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700118import org.onlab.packet.IpPrefix;
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800119import org.onlab.packet.Ip4Prefix;
120import org.onlab.packet.Ip6Prefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700121import org.onlab.packet.MacAddress;
122import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700123import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700124
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700125import com.google.common.collect.ImmutableList;
126import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700127import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700128
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700129public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700130
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800131 public static final KryoNamespace BASIC = KryoNamespace.newBuilder()
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800132 .nextId(KryoNamespace.FLOATING_ID)
133 .register(byte[].class)
134 .register(new ImmutableListSerializer(),
135 ImmutableList.class,
136 ImmutableList.of(1).getClass(),
137 ImmutableList.of(1, 2).getClass())
138 .register(new ImmutableSetSerializer(),
139 ImmutableSet.class,
140 ImmutableSet.of().getClass(),
141 ImmutableSet.of(1).getClass(),
142 ImmutableSet.of(1, 2).getClass())
143 .register(new ImmutableMapSerializer(),
144 ImmutableMap.class,
145 ImmutableMap.of().getClass(),
146 ImmutableMap.of("a", 1).getClass(),
147 ImmutableMap.of("R", 2, "D", 2).getClass())
148 .register(HashMap.class)
149 .register(ArrayList.class,
150 LinkedList.class,
151 HashSet.class
152 )
153 .register(new ArraysAsListSerializer(), Arrays.asList().getClass())
154 .register(Collections.singletonList(1).getClass())
155 .register(Duration.class)
Yuta HIGUCHIae1d2102014-11-25 19:26:01 -0800156 .register(Collections.emptySet().getClass())
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800157 .build();
158
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700159 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700160 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700161 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700162 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800163 .nextId(KryoNamespace.FLOATING_ID)
164 .register(new IpPrefixSerializer(), IpPrefix.class)
165 .register(new Ip4PrefixSerializer(), Ip4Prefix.class)
166 .register(new Ip6PrefixSerializer(), Ip6Prefix.class)
167 .register(new IpAddressSerializer(), IpAddress.class)
168 .register(new Ip4AddressSerializer(), Ip4Address.class)
169 .register(new Ip6AddressSerializer(), Ip6Address.class)
170 .register(new MacAddressSerializer(), MacAddress.class)
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700171 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700172 .build();
173
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800174 /**
175 * Kryo registration Id for user custom registration.
176 */
177 public static final int BEGIN_USER_CUSTOM_ID = 300;
178
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700179 // TODO: Populate other classes
180 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700181 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700182 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700183 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800184 .nextId(KryoNamespace.INITIAL_ID)
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800185 .register(BASIC)
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800186 .nextId(KryoNamespace.INITIAL_ID + 30)
187 .register(MISC)
188 .nextId(KryoNamespace.INITIAL_ID + 30 + 10)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700189 .register(
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700190 ControllerNode.State.class,
191 Device.Type.class,
Thomas Vachuskad16ce182014-10-29 17:25:29 -0700192 Port.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700193 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700194 DefaultAnnotations.class,
195 DefaultControllerNode.class,
196 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700197 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700198 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700199 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700200 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700201 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700202 Link.Type.class,
Thomas Vachuska57126fe2014-11-11 17:13:24 -0800203 Link.State.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700204 Timestamp.class,
Madan Jampani1ee91782014-11-20 20:24:24 -0800205 Leadership.class,
206 LeadershipEvent.class,
207 LeadershipEvent.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700208 HostId.class,
209 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700210 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700211 DefaultFlowEntry.class,
212 StoredFlowEntry.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700213 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700214 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700215 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700216 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700217 DefaultTrafficSelector.class,
218 Criteria.PortCriterion.class,
219 Criteria.EthCriterion.class,
220 Criteria.EthTypeCriterion.class,
221 Criteria.IPCriterion.class,
222 Criteria.IPProtocolCriterion.class,
223 Criteria.VlanIdCriterion.class,
224 Criteria.VlanPcpCriterion.class,
225 Criteria.TcpPortCriterion.class,
226 Criterion.class,
227 Criterion.Type.class,
228 DefaultTrafficTreatment.class,
229 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700230 Instructions.OutputInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700231 L0ModificationInstruction.class,
232 L0ModificationInstruction.L0SubType.class,
233 L0ModificationInstruction.ModLambdaInstruction.class,
234 L2ModificationInstruction.class,
235 L2ModificationInstruction.L2SubType.class,
236 L2ModificationInstruction.ModEtherInstruction.class,
237 L2ModificationInstruction.ModVlanIdInstruction.class,
238 L2ModificationInstruction.ModVlanPcpInstruction.class,
239 L3ModificationInstruction.class,
240 L3ModificationInstruction.L3SubType.class,
241 L3ModificationInstruction.ModIPInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700242 RoleInfo.class,
243 FlowRuleBatchOperation.class,
244 CompletedBatchOperation.class,
245 FlowRuleBatchEntry.class,
Yuta HIGUCHI087019b2014-10-28 21:07:56 -0700246 FlowRuleBatchEntry.FlowRuleOperation.class,
247 IntentId.class,
248 IntentState.class,
249 Intent.class,
250 ConnectivityIntent.class,
251 PathIntent.class,
252 DefaultPath.class,
253 DefaultEdgeLink.class,
254 HostToHostIntent.class,
255 PointToPointIntent.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700256 MultiPointToSinglePointIntent.class,
Michele Santuari4a338072014-11-05 18:38:55 +0100257 SinglePointToMultiPointIntent.class,
Brian O'Connor41718fc2014-10-30 16:57:21 -0700258 LinkCollectionIntent.class,
259 OpticalConnectivityIntent.class,
260 OpticalPathIntent.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800261 LinkResourceRequest.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800262 DefaultLinkResourceRequest.class,
263 BandwidthResourceRequest.class,
264 LambdaResourceRequest.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800265 Lambda.class,
266 Bandwidth.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800267 DefaultLinkResourceAllocations.class,
268 BandwidthResourceAllocation.class,
269 LambdaResourceAllocation.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800270 // Constraints
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800271 LambdaConstraint.class,
272 BandwidthConstraint.class,
273 LinkTypeConstraint.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800274 LatencyConstraint.class,
275 WaypointConstraint.class,
276 ObstacleConstraint.class,
277 AnnotationConstraint.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800278 BooleanConstraint.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700279 )
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800280 .register(new DefaultApplicationIdSerializer(), DefaultApplicationId.class)
281 .register(new URISerializer(), URI.class)
282 .register(new NodeIdSerializer(), NodeId.class)
283 .register(new ProviderIdSerializer(), ProviderId.class)
284 .register(new DeviceIdSerializer(), DeviceId.class)
285 .register(new PortNumberSerializer(), PortNumber.class)
286 .register(new DefaultPortSerializer(), DefaultPort.class)
287 .register(new LinkKeySerializer(), LinkKey.class)
288 .register(new ConnectPointSerializer(), ConnectPoint.class)
289 .register(new DefaultLinkSerializer(), DefaultLink.class)
290 .register(new MastershipTermSerializer(), MastershipTerm.class)
291 .register(new HostLocationSerializer(), HostLocation.class)
292 .register(new DefaultOutboundPacketSerializer(), DefaultOutboundPacket.class)
293 .register(ReadRequest.class)
294 .register(WriteRequest.class)
295 .register(WriteRequest.Type.class)
296 .register(WriteResult.class)
297 .register(ReadResult.class)
298 .register(BatchReadRequest.class)
299 .register(BatchWriteRequest.class)
300 .register(ReadStatus.class)
301 .register(WriteStatus.class)
302 .register(VersionedValue.class)
Yuta HIGUCHIf6171232014-11-25 15:14:44 -0800303 .register(DefaultGroupId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700304
305 .build();
306
307
308 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700309 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700310}