blob: 7043a61358b5e9465e777e4681f453364e4d2d13 [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;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070028import org.onlab.onos.cluster.NodeId;
Yuta HIGUCHI40d01772014-10-21 00:08:44 -070029import org.onlab.onos.cluster.RoleInfo;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070030import org.onlab.onos.core.DefaultApplicationId;
Yuta HIGUCHI80912e62014-10-12 00:15:47 -070031import org.onlab.onos.mastership.MastershipTerm;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070032import org.onlab.onos.net.ConnectPoint;
33import org.onlab.onos.net.DefaultAnnotations;
34import org.onlab.onos.net.DefaultDevice;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070035import org.onlab.onos.net.DefaultEdgeLink;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070036import org.onlab.onos.net.DefaultLink;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070037import org.onlab.onos.net.DefaultPath;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070038import org.onlab.onos.net.DefaultPort;
39import org.onlab.onos.net.Device;
40import org.onlab.onos.net.DeviceId;
41import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070042import org.onlab.onos.net.HostId;
43import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070044import org.onlab.onos.net.Link;
45import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070046import org.onlab.onos.net.Port;
47import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070048import org.onlab.onos.net.device.DefaultDeviceDescription;
49import org.onlab.onos.net.device.DefaultPortDescription;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070050import org.onlab.onos.net.flow.CompletedBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070051import org.onlab.onos.net.flow.DefaultFlowEntry;
Madan Jampani38b250d2014-10-17 11:02:38 -070052import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070053import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070054import org.onlab.onos.net.flow.DefaultTrafficTreatment;
alshabibf6c2ede2014-10-22 23:31:50 -070055import org.onlab.onos.net.flow.FlowEntry;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070056import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070057import org.onlab.onos.net.flow.FlowRuleBatchEntry;
58import org.onlab.onos.net.flow.FlowRuleBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070059import org.onlab.onos.net.flow.StoredFlowEntry;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070060import org.onlab.onos.net.flow.criteria.Criteria;
61import org.onlab.onos.net.flow.criteria.Criterion;
62import org.onlab.onos.net.flow.instructions.Instructions;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070063import org.onlab.onos.net.flow.instructions.L0ModificationInstruction;
64import org.onlab.onos.net.flow.instructions.L2ModificationInstruction;
65import org.onlab.onos.net.flow.instructions.L3ModificationInstruction;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070066import org.onlab.onos.net.host.DefaultHostDescription;
67import org.onlab.onos.net.host.HostDescription;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070068import org.onlab.onos.net.intent.ConnectivityIntent;
69import org.onlab.onos.net.intent.HostToHostIntent;
70import org.onlab.onos.net.intent.Intent;
71import org.onlab.onos.net.intent.IntentId;
72import org.onlab.onos.net.intent.IntentState;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070073import org.onlab.onos.net.intent.LinkCollectionIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070074import org.onlab.onos.net.intent.MultiPointToSinglePointIntent;
Brian O'Connor41718fc2014-10-30 16:57:21 -070075import org.onlab.onos.net.intent.OpticalConnectivityIntent;
76import org.onlab.onos.net.intent.OpticalPathIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070077import org.onlab.onos.net.intent.PathIntent;
78import org.onlab.onos.net.intent.PointToPointIntent;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080079import org.onlab.onos.net.intent.constraint.AnnotationConstraint;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080080import org.onlab.onos.net.intent.constraint.BandwidthConstraint;
81import org.onlab.onos.net.intent.constraint.BooleanConstraint;
82import org.onlab.onos.net.intent.constraint.LambdaConstraint;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080083import org.onlab.onos.net.intent.constraint.LatencyConstraint;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080084import org.onlab.onos.net.intent.constraint.LinkTypeConstraint;
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -080085import org.onlab.onos.net.intent.constraint.ObstacleConstraint;
86import org.onlab.onos.net.intent.constraint.WaypointConstraint;
Madan Jampani2ff05592014-10-10 15:42:47 -070087import org.onlab.onos.net.link.DefaultLinkDescription;
Jonathan Hart4f60f982014-10-27 08:11:17 -070088import org.onlab.onos.net.packet.DefaultOutboundPacket;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070089import org.onlab.onos.net.provider.ProviderId;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080090import org.onlab.onos.net.resource.Bandwidth;
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -080091import org.onlab.onos.net.resource.BandwidthResourceAllocation;
92import org.onlab.onos.net.resource.BandwidthResourceRequest;
93import org.onlab.onos.net.resource.DefaultLinkResourceAllocations;
94import org.onlab.onos.net.resource.DefaultLinkResourceRequest;
Thomas Vachuska7d0032b2014-11-04 17:39:57 -080095import org.onlab.onos.net.resource.Lambda;
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -080096import org.onlab.onos.net.resource.LambdaResourceAllocation;
97import org.onlab.onos.net.resource.LambdaResourceRequest;
Brian O'Connor41718fc2014-10-30 16:57:21 -070098import org.onlab.onos.net.resource.LinkResourceRequest;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070099import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -0700100import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700101import org.onlab.packet.IpAddress;
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800102import org.onlab.packet.Ip4Address;
103import org.onlab.packet.Ip6Address;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700104import org.onlab.packet.IpPrefix;
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800105import org.onlab.packet.Ip4Prefix;
106import org.onlab.packet.Ip6Prefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700107import org.onlab.packet.MacAddress;
108import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700109import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700110
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700111import com.google.common.collect.ImmutableList;
112import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700113import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700114
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700115public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700116
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800117 public static final KryoNamespace BASIC = KryoNamespace.newBuilder()
118 .register(ImmutableMap.class, new ImmutableMapSerializer())
119 .register(ImmutableList.class, new ImmutableListSerializer())
120 .register(ImmutableSet.class, new ImmutableSetSerializer())
121 .register(
122 ArrayList.class,
123 Arrays.asList().getClass(),
124 HashMap.class,
125 HashSet.class,
126 LinkedList.class,
Sho SHIMIZU977cb602014-11-13 08:40:50 -0800127 byte[].class,
128 Duration.class
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800129 )
130 .build();
131
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700132 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700133 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700134 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700135 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700136 .register(IpPrefix.class, new IpPrefixSerializer())
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800137 .register(Ip4Prefix.class, new Ip4PrefixSerializer())
138 .register(Ip6Prefix.class, new Ip6PrefixSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700139 .register(IpAddress.class, new IpAddressSerializer())
Pavlin Radoslavov17378ef2014-11-05 16:13:47 -0800140 .register(Ip4Address.class, new Ip4AddressSerializer())
141 .register(Ip6Address.class, new Ip6AddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700142 .register(MacAddress.class, new MacAddressSerializer())
143 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700144 .build();
145
146 // TODO: Populate other classes
147 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700148 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700149 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700150 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700151 .register(MISC)
Yuta HIGUCHI1aa249c2014-11-05 17:40:28 -0800152 .register(BASIC)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700153 .register(
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700154 ControllerNode.State.class,
155 Device.Type.class,
Thomas Vachuskad16ce182014-10-29 17:25:29 -0700156 Port.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700157 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700158 DefaultAnnotations.class,
159 DefaultControllerNode.class,
160 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700161 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700162 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700163 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700164 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700165 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700166 Link.Type.class,
Thomas Vachuska57126fe2014-11-11 17:13:24 -0800167 Link.State.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700168 Timestamp.class,
169 HostId.class,
170 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700171 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700172 DefaultFlowEntry.class,
173 StoredFlowEntry.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700174 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700175 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700176 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700177 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700178 DefaultTrafficSelector.class,
179 Criteria.PortCriterion.class,
180 Criteria.EthCriterion.class,
181 Criteria.EthTypeCriterion.class,
182 Criteria.IPCriterion.class,
183 Criteria.IPProtocolCriterion.class,
184 Criteria.VlanIdCriterion.class,
185 Criteria.VlanPcpCriterion.class,
186 Criteria.TcpPortCriterion.class,
187 Criterion.class,
188 Criterion.Type.class,
189 DefaultTrafficTreatment.class,
190 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700191 Instructions.OutputInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700192 L0ModificationInstruction.class,
193 L0ModificationInstruction.L0SubType.class,
194 L0ModificationInstruction.ModLambdaInstruction.class,
195 L2ModificationInstruction.class,
196 L2ModificationInstruction.L2SubType.class,
197 L2ModificationInstruction.ModEtherInstruction.class,
198 L2ModificationInstruction.ModVlanIdInstruction.class,
199 L2ModificationInstruction.ModVlanPcpInstruction.class,
200 L3ModificationInstruction.class,
201 L3ModificationInstruction.L3SubType.class,
202 L3ModificationInstruction.ModIPInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700203 RoleInfo.class,
204 FlowRuleBatchOperation.class,
205 CompletedBatchOperation.class,
206 FlowRuleBatchEntry.class,
Yuta HIGUCHI087019b2014-10-28 21:07:56 -0700207 FlowRuleBatchEntry.FlowRuleOperation.class,
208 IntentId.class,
209 IntentState.class,
210 Intent.class,
211 ConnectivityIntent.class,
212 PathIntent.class,
213 DefaultPath.class,
214 DefaultEdgeLink.class,
215 HostToHostIntent.class,
216 PointToPointIntent.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700217 MultiPointToSinglePointIntent.class,
Brian O'Connor41718fc2014-10-30 16:57:21 -0700218 LinkCollectionIntent.class,
219 OpticalConnectivityIntent.class,
220 OpticalPathIntent.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800221 LinkResourceRequest.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800222 DefaultLinkResourceRequest.class,
223 BandwidthResourceRequest.class,
224 LambdaResourceRequest.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800225 Lambda.class,
226 Bandwidth.class,
Yuta HIGUCHIadac04a2014-11-13 00:02:45 -0800227 DefaultLinkResourceAllocations.class,
228 BandwidthResourceAllocation.class,
229 LambdaResourceAllocation.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800230 // Constraints
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800231 LambdaConstraint.class,
232 BandwidthConstraint.class,
233 LinkTypeConstraint.class,
Sho SHIMIZUcd4bac82014-11-11 17:07:25 -0800234 LatencyConstraint.class,
235 WaypointConstraint.class,
236 ObstacleConstraint.class,
237 AnnotationConstraint.class,
Thomas Vachuska7d0032b2014-11-04 17:39:57 -0800238 BooleanConstraint.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700239 )
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700240 .register(DefaultApplicationId.class, new DefaultApplicationIdSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700241 .register(URI.class, new URISerializer())
242 .register(NodeId.class, new NodeIdSerializer())
243 .register(ProviderId.class, new ProviderIdSerializer())
244 .register(DeviceId.class, new DeviceIdSerializer())
245 .register(PortNumber.class, new PortNumberSerializer())
246 .register(DefaultPort.class, new DefaultPortSerializer())
247 .register(LinkKey.class, new LinkKeySerializer())
248 .register(ConnectPoint.class, new ConnectPointSerializer())
249 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700250 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700251 .register(HostLocation.class, new HostLocationSerializer())
Jonathan Hart4f60f982014-10-27 08:11:17 -0700252 .register(DefaultOutboundPacket.class, new DefaultOutboundPacketSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700253
254 .build();
255
256
257 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700258 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700259}