blob: 9341cba72b1881bdb4b6f65e0abd69ce7c9ec4ef [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;
74import org.onlab.onos.net.intent.PathIntent;
75import org.onlab.onos.net.intent.PointToPointIntent;
Madan Jampani2ff05592014-10-10 15:42:47 -070076import org.onlab.onos.net.link.DefaultLinkDescription;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070077import org.onlab.onos.net.provider.ProviderId;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070078import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070079import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070080import org.onlab.packet.IpAddress;
81import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070082import org.onlab.packet.MacAddress;
83import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070084import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070085
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070086import com.google.common.collect.ImmutableList;
87import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070088import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070089
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070090public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070091
92 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070093 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070094 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070095 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070096 .register(IpPrefix.class, new IpPrefixSerializer())
97 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070098 .register(MacAddress.class, new MacAddressSerializer())
99 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700100 .build();
101
102 // TODO: Populate other classes
103 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700104 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700105 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700106 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700107 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700108 .register(ImmutableMap.class, new ImmutableMapSerializer())
109 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700110 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700111 .register(
112 //
113 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700114 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700115 HashMap.class,
alshabib3d643ec2014-10-22 18:33:00 -0700116 HashSet.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700117 LinkedList.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700118 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700119 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700120 ControllerNode.State.class,
121 Device.Type.class,
Thomas Vachuskad16ce182014-10-29 17:25:29 -0700122 Port.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700123 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700124 DefaultAnnotations.class,
125 DefaultControllerNode.class,
126 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700127 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700128 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700129 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700130 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700131 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700132 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700133 Timestamp.class,
134 HostId.class,
135 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700136 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700137 DefaultFlowEntry.class,
138 StoredFlowEntry.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700139 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700140 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700141 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700142 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700143 DefaultTrafficSelector.class,
144 Criteria.PortCriterion.class,
145 Criteria.EthCriterion.class,
146 Criteria.EthTypeCriterion.class,
147 Criteria.IPCriterion.class,
148 Criteria.IPProtocolCriterion.class,
149 Criteria.VlanIdCriterion.class,
150 Criteria.VlanPcpCriterion.class,
151 Criteria.TcpPortCriterion.class,
152 Criterion.class,
153 Criterion.Type.class,
154 DefaultTrafficTreatment.class,
155 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700156 Instructions.OutputInstruction.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700157 L0ModificationInstruction.class,
158 L0ModificationInstruction.L0SubType.class,
159 L0ModificationInstruction.ModLambdaInstruction.class,
160 L2ModificationInstruction.class,
161 L2ModificationInstruction.L2SubType.class,
162 L2ModificationInstruction.ModEtherInstruction.class,
163 L2ModificationInstruction.ModVlanIdInstruction.class,
164 L2ModificationInstruction.ModVlanPcpInstruction.class,
165 L3ModificationInstruction.class,
166 L3ModificationInstruction.L3SubType.class,
167 L3ModificationInstruction.ModIPInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700168 RoleInfo.class,
169 FlowRuleBatchOperation.class,
170 CompletedBatchOperation.class,
171 FlowRuleBatchEntry.class,
Yuta HIGUCHI087019b2014-10-28 21:07:56 -0700172 FlowRuleBatchEntry.FlowRuleOperation.class,
173 IntentId.class,
174 IntentState.class,
175 Intent.class,
176 ConnectivityIntent.class,
177 PathIntent.class,
178 DefaultPath.class,
179 DefaultEdgeLink.class,
180 HostToHostIntent.class,
181 PointToPointIntent.class,
Jonathan Hart68fef9d2014-10-29 17:30:03 -0700182 MultiPointToSinglePointIntent.class,
183 LinkCollectionIntent.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700184 )
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700185 .register(DefaultApplicationId.class, new DefaultApplicationIdSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700186 .register(URI.class, new URISerializer())
187 .register(NodeId.class, new NodeIdSerializer())
188 .register(ProviderId.class, new ProviderIdSerializer())
189 .register(DeviceId.class, new DeviceIdSerializer())
190 .register(PortNumber.class, new PortNumberSerializer())
191 .register(DefaultPort.class, new DefaultPortSerializer())
192 .register(LinkKey.class, new LinkKeySerializer())
193 .register(ConnectPoint.class, new ConnectPointSerializer())
194 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700195 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700196 .register(HostLocation.class, new HostLocationSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700197
198 .build();
199
200
201 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700202 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700203}