blob: 2a4c10c89a33768976e4a30a86d3e01d879cdcb8 [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;
19import java.util.ArrayList;
Madan Jampani53e44e62014-10-07 12:39:51 -070020import java.util.Arrays;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070021import java.util.HashMap;
alshabib3d643ec2014-10-22 18:33:00 -070022import java.util.HashSet;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070023import java.util.LinkedList;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070024
25import org.onlab.onos.cluster.ControllerNode;
26import org.onlab.onos.cluster.DefaultControllerNode;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070027import org.onlab.onos.cluster.NodeId;
Yuta HIGUCHI40d01772014-10-21 00:08:44 -070028import org.onlab.onos.cluster.RoleInfo;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070029import org.onlab.onos.core.DefaultApplicationId;
Yuta HIGUCHI80912e62014-10-12 00:15:47 -070030import org.onlab.onos.mastership.MastershipTerm;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070031import org.onlab.onos.net.ConnectPoint;
32import org.onlab.onos.net.DefaultAnnotations;
33import org.onlab.onos.net.DefaultDevice;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070034import org.onlab.onos.net.DefaultEdgeLink;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070035import org.onlab.onos.net.DefaultLink;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070036import org.onlab.onos.net.DefaultPath;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070037import org.onlab.onos.net.DefaultPort;
38import org.onlab.onos.net.Device;
39import org.onlab.onos.net.DeviceId;
40import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070041import org.onlab.onos.net.HostId;
42import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070043import org.onlab.onos.net.Link;
44import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070045import org.onlab.onos.net.Port;
46import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070047import org.onlab.onos.net.device.DefaultDeviceDescription;
48import org.onlab.onos.net.device.DefaultPortDescription;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070049import org.onlab.onos.net.flow.CompletedBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070050import org.onlab.onos.net.flow.DefaultFlowEntry;
Madan Jampani38b250d2014-10-17 11:02:38 -070051import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070052import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070053import org.onlab.onos.net.flow.DefaultTrafficTreatment;
alshabibf6c2ede2014-10-22 23:31:50 -070054import org.onlab.onos.net.flow.FlowEntry;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070055import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070056import org.onlab.onos.net.flow.FlowRuleBatchEntry;
57import org.onlab.onos.net.flow.FlowRuleBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070058import org.onlab.onos.net.flow.StoredFlowEntry;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070059import org.onlab.onos.net.flow.criteria.Criteria;
60import org.onlab.onos.net.flow.criteria.Criterion;
61import org.onlab.onos.net.flow.instructions.Instructions;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070062import org.onlab.onos.net.flow.instructions.L0ModificationInstruction;
63import org.onlab.onos.net.flow.instructions.L2ModificationInstruction;
64import org.onlab.onos.net.flow.instructions.L3ModificationInstruction;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070065import org.onlab.onos.net.host.DefaultHostDescription;
66import org.onlab.onos.net.host.HostDescription;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070067import org.onlab.onos.net.intent.ConnectivityIntent;
68import org.onlab.onos.net.intent.HostToHostIntent;
69import org.onlab.onos.net.intent.Intent;
70import org.onlab.onos.net.intent.IntentId;
71import org.onlab.onos.net.intent.IntentState;
Jonathan Hart68fef9d2014-10-29 17:30:03 -070072import org.onlab.onos.net.intent.LinkCollectionIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070073import org.onlab.onos.net.intent.MultiPointToSinglePointIntent;
Brian O'Connor41718fc2014-10-30 16:57:21 -070074import org.onlab.onos.net.intent.OpticalConnectivityIntent;
75import org.onlab.onos.net.intent.OpticalPathIntent;
Yuta HIGUCHI087019b2014-10-28 21:07:56 -070076import org.onlab.onos.net.intent.PathIntent;
77import org.onlab.onos.net.intent.PointToPointIntent;
Madan Jampani2ff05592014-10-10 15:42:47 -070078import org.onlab.onos.net.link.DefaultLinkDescription;
Jonathan Hart4f60f982014-10-27 08:11:17 -070079import org.onlab.onos.net.packet.DefaultOutboundPacket;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070080import org.onlab.onos.net.provider.ProviderId;
Brian O'Connor41718fc2014-10-30 16:57:21 -070081import org.onlab.onos.net.resource.LinkResourceRequest;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070082import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070083import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070084import org.onlab.packet.IpAddress;
85import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070086import org.onlab.packet.MacAddress;
87import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070088import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070089
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070090import com.google.common.collect.ImmutableList;
91import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070092import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070093
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070094public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070095
96 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070097 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070098 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070099 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700100 .register(IpPrefix.class, new IpPrefixSerializer())
101 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700102 .register(MacAddress.class, new MacAddressSerializer())
103 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700104 .build();
105
106 // TODO: Populate other classes
107 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700108 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700109 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700110 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700111 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700112 .register(ImmutableMap.class, new ImmutableMapSerializer())
113 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700114 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700115 .register(
116 //
117 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700118 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700119 HashMap.class,
alshabib3d643ec2014-10-22 18:33:00 -0700120 HashSet.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700121 LinkedList.class,
Jonathan Hart4f60f982014-10-27 08:11:17 -0700122 byte[].class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700123 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700124 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700125 ControllerNode.State.class,
126 Device.Type.class,
Thomas Vachuskad16ce182014-10-29 17:25:29 -0700127 Port.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700128 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700129 DefaultAnnotations.class,
130 DefaultControllerNode.class,
131 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700132 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700133 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700134 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700135 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700136 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700137 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700138 Timestamp.class,
139 HostId.class,
140 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700141 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700142 DefaultFlowEntry.class,
143 StoredFlowEntry.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700144 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700145 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700146 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700147 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700148 DefaultTrafficSelector.class,
149 Criteria.PortCriterion.class,
150 Criteria.EthCriterion.class,
151 Criteria.EthTypeCriterion.class,
152 Criteria.IPCriterion.class,
153 Criteria.IPProtocolCriterion.class,
154 Criteria.VlanIdCriterion.class,
155 Criteria.VlanPcpCriterion.class,
156 Criteria.TcpPortCriterion.class,
157 Criterion.class,
158 Criterion.Type.class,
159 DefaultTrafficTreatment.class,
160 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700161 Instructions.OutputInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700162 L0ModificationInstruction.class,
163 L0ModificationInstruction.L0SubType.class,
164 L0ModificationInstruction.ModLambdaInstruction.class,
165 L2ModificationInstruction.class,
166 L2ModificationInstruction.L2SubType.class,
167 L2ModificationInstruction.ModEtherInstruction.class,
168 L2ModificationInstruction.ModVlanIdInstruction.class,
169 L2ModificationInstruction.ModVlanPcpInstruction.class,
170 L3ModificationInstruction.class,
171 L3ModificationInstruction.L3SubType.class,
172 L3ModificationInstruction.ModIPInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700173 RoleInfo.class,
174 FlowRuleBatchOperation.class,
175 CompletedBatchOperation.class,
176 FlowRuleBatchEntry.class,
Yuta HIGUCHI087019b2014-10-28 21:07:56 -0700177 FlowRuleBatchEntry.FlowRuleOperation.class,
178 IntentId.class,
179 IntentState.class,
180 Intent.class,
181 ConnectivityIntent.class,
182 PathIntent.class,
183 DefaultPath.class,
184 DefaultEdgeLink.class,
185 HostToHostIntent.class,
186 PointToPointIntent.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700187 MultiPointToSinglePointIntent.class,
Brian O'Connor41718fc2014-10-30 16:57:21 -0700188 LinkCollectionIntent.class,
189 OpticalConnectivityIntent.class,
190 OpticalPathIntent.class,
191 LinkResourceRequest.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700192 )
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700193 .register(DefaultApplicationId.class, new DefaultApplicationIdSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700194 .register(URI.class, new URISerializer())
195 .register(NodeId.class, new NodeIdSerializer())
196 .register(ProviderId.class, new ProviderIdSerializer())
197 .register(DeviceId.class, new DeviceIdSerializer())
198 .register(PortNumber.class, new PortNumberSerializer())
199 .register(DefaultPort.class, new DefaultPortSerializer())
200 .register(LinkKey.class, new LinkKeySerializer())
201 .register(ConnectPoint.class, new ConnectPointSerializer())
202 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700203 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700204 .register(HostLocation.class, new HostLocationSerializer())
Jonathan Hart4f60f982014-10-27 08:11:17 -0700205 .register(DefaultOutboundPacket.class, new DefaultOutboundPacketSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700206
207 .build();
208
209
210 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700211 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700212}