blob: b2b4380f21b36ef47e9ef8eb8eed6d3acbfd2825 [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
Thomas Vachuskae0f804a2014-10-27 23:40:48 -070025import org.onlab.onos.core.DefaultApplicationId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070026import 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;
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;
34import org.onlab.onos.net.DefaultLink;
35import org.onlab.onos.net.DefaultPort;
36import org.onlab.onos.net.Device;
37import org.onlab.onos.net.DeviceId;
38import org.onlab.onos.net.Element;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070039import org.onlab.onos.net.HostId;
40import org.onlab.onos.net.HostLocation;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070041import org.onlab.onos.net.Link;
42import org.onlab.onos.net.LinkKey;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070043import org.onlab.onos.net.Port;
44import org.onlab.onos.net.PortNumber;
Madan Jampani53e44e62014-10-07 12:39:51 -070045import org.onlab.onos.net.device.DefaultDeviceDescription;
46import org.onlab.onos.net.device.DefaultPortDescription;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070047import org.onlab.onos.net.flow.CompletedBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070048import org.onlab.onos.net.flow.DefaultFlowEntry;
Madan Jampani38b250d2014-10-17 11:02:38 -070049import org.onlab.onos.net.flow.DefaultFlowRule;
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -070050import org.onlab.onos.net.flow.DefaultTrafficSelector;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070051import org.onlab.onos.net.flow.DefaultTrafficTreatment;
alshabibf6c2ede2014-10-22 23:31:50 -070052import org.onlab.onos.net.flow.FlowEntry;
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -070053import org.onlab.onos.net.flow.FlowId;
Yuta HIGUCHI9def0472014-10-23 15:51:10 -070054import org.onlab.onos.net.flow.FlowRuleBatchEntry;
55import org.onlab.onos.net.flow.FlowRuleBatchOperation;
Madan Jampani117aaae2014-10-23 10:04:05 -070056import org.onlab.onos.net.flow.StoredFlowEntry;
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -070057import org.onlab.onos.net.flow.criteria.Criteria;
58import org.onlab.onos.net.flow.criteria.Criterion;
59import org.onlab.onos.net.flow.instructions.Instructions;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070060import org.onlab.onos.net.host.DefaultHostDescription;
61import org.onlab.onos.net.host.HostDescription;
Madan Jampani2ff05592014-10-10 15:42:47 -070062import org.onlab.onos.net.link.DefaultLinkDescription;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070063import org.onlab.onos.net.provider.ProviderId;
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -070064import org.onlab.onos.store.Timestamp;
alshabib7911a052014-10-16 17:49:37 -070065import org.onlab.packet.ChassisId;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070066import org.onlab.packet.IpAddress;
67import org.onlab.packet.IpPrefix;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070068import org.onlab.packet.MacAddress;
69import org.onlab.packet.VlanId;
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070070import org.onlab.util.KryoNamespace;
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070071
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070072import com.google.common.collect.ImmutableList;
73import com.google.common.collect.ImmutableMap;
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070074import com.google.common.collect.ImmutableSet;
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070075
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070076public final class KryoNamespaces {
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070077
78 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070079 * KryoNamespace which can serialize ON.lab misc classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070080 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070081 public static final KryoNamespace MISC = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070082 .register(IpPrefix.class, new IpPrefixSerializer())
83 .register(IpAddress.class, new IpAddressSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070084 .register(MacAddress.class, new MacAddressSerializer())
85 .register(VlanId.class)
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070086 .build();
87
88 // TODO: Populate other classes
89 /**
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070090 * KryoNamespace which can serialize API bundle classes.
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070091 */
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -070092 public static final KryoNamespace API = KryoNamespace.newBuilder()
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070093 .register(MISC)
Yuta HIGUCHI47c40882014-10-10 18:44:37 -070094 .register(ImmutableMap.class, new ImmutableMapSerializer())
95 .register(ImmutableList.class, new ImmutableListSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -070096 .register(ImmutableSet.class, new ImmutableSetSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -070097 .register(
98 //
99 ArrayList.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700100 Arrays.asList().getClass(),
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700101 HashMap.class,
alshabib3d643ec2014-10-22 18:33:00 -0700102 HashSet.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700103 LinkedList.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700104 //
Yuta HIGUCHI47c40882014-10-10 18:44:37 -0700105 //
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700106 ControllerNode.State.class,
107 Device.Type.class,
alshabib7911a052014-10-16 17:49:37 -0700108 ChassisId.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700109 DefaultAnnotations.class,
110 DefaultControllerNode.class,
111 DefaultDevice.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700112 DefaultDeviceDescription.class,
Madan Jampani2ff05592014-10-10 15:42:47 -0700113 DefaultLinkDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700114 Port.class,
Madan Jampani53e44e62014-10-07 12:39:51 -0700115 DefaultPortDescription.class,
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700116 Element.class,
Yuta HIGUCHI9ee60f62014-10-09 10:00:01 -0700117 Link.Type.class,
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700118 Timestamp.class,
119 HostId.class,
120 HostDescription.class,
Madan Jampani38b250d2014-10-17 11:02:38 -0700121 DefaultHostDescription.class,
Madan Jampani117aaae2014-10-23 10:04:05 -0700122 DefaultFlowEntry.class,
123 StoredFlowEntry.class,
Yuta HIGUCHI2fcfde92014-10-20 18:37:14 -0700124 DefaultFlowRule.class,
alshabib3d643ec2014-10-22 18:33:00 -0700125 DefaultFlowEntry.class,
alshabibf6c2ede2014-10-22 23:31:50 -0700126 FlowEntry.FlowEntryState.class,
Yuta HIGUCHI2809bf32014-10-20 22:44:12 -0700127 FlowId.class,
Yuta HIGUCHI85d58d12014-10-20 23:59:44 -0700128 DefaultTrafficSelector.class,
129 Criteria.PortCriterion.class,
130 Criteria.EthCriterion.class,
131 Criteria.EthTypeCriterion.class,
132 Criteria.IPCriterion.class,
133 Criteria.IPProtocolCriterion.class,
134 Criteria.VlanIdCriterion.class,
135 Criteria.VlanPcpCriterion.class,
136 Criteria.TcpPortCriterion.class,
137 Criterion.class,
138 Criterion.Type.class,
139 DefaultTrafficTreatment.class,
140 Instructions.DropInstruction.class,
Yuta HIGUCHI40d01772014-10-21 00:08:44 -0700141 Instructions.OutputInstruction.class,
Yuta HIGUCHI9def0472014-10-23 15:51:10 -0700142 RoleInfo.class,
143 FlowRuleBatchOperation.class,
144 CompletedBatchOperation.class,
145 FlowRuleBatchEntry.class,
146 FlowRuleBatchEntry.FlowRuleOperation.class
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700147 )
Thomas Vachuskae0f804a2014-10-27 23:40:48 -0700148 .register(DefaultApplicationId.class, new DefaultApplicationIdSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700149 .register(URI.class, new URISerializer())
150 .register(NodeId.class, new NodeIdSerializer())
151 .register(ProviderId.class, new ProviderIdSerializer())
152 .register(DeviceId.class, new DeviceIdSerializer())
153 .register(PortNumber.class, new PortNumberSerializer())
154 .register(DefaultPort.class, new DefaultPortSerializer())
155 .register(LinkKey.class, new LinkKeySerializer())
156 .register(ConnectPoint.class, new ConnectPointSerializer())
157 .register(DefaultLink.class, new DefaultLinkSerializer())
Yuta HIGUCHIfa891c92014-10-09 15:21:40 -0700158 .register(MastershipTerm.class, new MastershipTermSerializer())
Yuta HIGUCHI5fa3dc02014-10-15 17:08:13 -0700159 .register(HostLocation.class, new HostLocationSerializer())
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700160
161 .build();
162
163
164 // not to be instantiated
Yuta HIGUCHI8d143d22014-10-19 23:15:09 -0700165 private KryoNamespaces() {}
Yuta HIGUCHI03fec1f2014-10-03 09:13:50 -0700166}