Thomas Vachuska | 4f1a60c | 2014-10-28 13:39:07 -0700 | [diff] [blame] | 1 | /* |
| 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 HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 16 | package org.onlab.onos.store.serializers; |
| 17 | |
| 18 | import java.net.URI; |
| 19 | import java.util.ArrayList; |
Madan Jampani | 53e44e6 | 2014-10-07 12:39:51 -0700 | [diff] [blame] | 20 | import java.util.Arrays; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 21 | import java.util.HashMap; |
alshabib | 3d643ec | 2014-10-22 18:33:00 -0700 | [diff] [blame] | 22 | import java.util.HashSet; |
Yuta HIGUCHI | 9def047 | 2014-10-23 15:51:10 -0700 | [diff] [blame] | 23 | import java.util.LinkedList; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 24 | |
Thomas Vachuska | e0f804a | 2014-10-27 23:40:48 -0700 | [diff] [blame] | 25 | import org.onlab.onos.core.DefaultApplicationId; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 26 | import org.onlab.onos.cluster.ControllerNode; |
| 27 | import org.onlab.onos.cluster.DefaultControllerNode; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 28 | import org.onlab.onos.cluster.NodeId; |
Yuta HIGUCHI | 40d0177 | 2014-10-21 00:08:44 -0700 | [diff] [blame] | 29 | import org.onlab.onos.cluster.RoleInfo; |
Yuta HIGUCHI | 80912e6 | 2014-10-12 00:15:47 -0700 | [diff] [blame] | 30 | import org.onlab.onos.mastership.MastershipTerm; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 31 | import org.onlab.onos.net.ConnectPoint; |
| 32 | import org.onlab.onos.net.DefaultAnnotations; |
| 33 | import org.onlab.onos.net.DefaultDevice; |
Yuta HIGUCHI | 087019b | 2014-10-28 21:07:56 -0700 | [diff] [blame] | 34 | import org.onlab.onos.net.DefaultEdgeLink; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 35 | import org.onlab.onos.net.DefaultLink; |
Yuta HIGUCHI | 087019b | 2014-10-28 21:07:56 -0700 | [diff] [blame] | 36 | import org.onlab.onos.net.DefaultPath; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 37 | import org.onlab.onos.net.DefaultPort; |
| 38 | import org.onlab.onos.net.Device; |
| 39 | import org.onlab.onos.net.DeviceId; |
| 40 | import org.onlab.onos.net.Element; |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 41 | import org.onlab.onos.net.HostId; |
| 42 | import org.onlab.onos.net.HostLocation; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 43 | import org.onlab.onos.net.Link; |
| 44 | import org.onlab.onos.net.LinkKey; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 45 | import org.onlab.onos.net.Port; |
| 46 | import org.onlab.onos.net.PortNumber; |
Madan Jampani | 53e44e6 | 2014-10-07 12:39:51 -0700 | [diff] [blame] | 47 | import org.onlab.onos.net.device.DefaultDeviceDescription; |
| 48 | import org.onlab.onos.net.device.DefaultPortDescription; |
Yuta HIGUCHI | 9def047 | 2014-10-23 15:51:10 -0700 | [diff] [blame] | 49 | import org.onlab.onos.net.flow.CompletedBatchOperation; |
Madan Jampani | 117aaae | 2014-10-23 10:04:05 -0700 | [diff] [blame] | 50 | import org.onlab.onos.net.flow.DefaultFlowEntry; |
Madan Jampani | 38b250d | 2014-10-17 11:02:38 -0700 | [diff] [blame] | 51 | import org.onlab.onos.net.flow.DefaultFlowRule; |
Yuta HIGUCHI | 2809bf3 | 2014-10-20 22:44:12 -0700 | [diff] [blame] | 52 | import org.onlab.onos.net.flow.DefaultTrafficSelector; |
Yuta HIGUCHI | 85d58d1 | 2014-10-20 23:59:44 -0700 | [diff] [blame] | 53 | import org.onlab.onos.net.flow.DefaultTrafficTreatment; |
alshabib | f6c2ede | 2014-10-22 23:31:50 -0700 | [diff] [blame] | 54 | import org.onlab.onos.net.flow.FlowEntry; |
Yuta HIGUCHI | 2fcfde9 | 2014-10-20 18:37:14 -0700 | [diff] [blame] | 55 | import org.onlab.onos.net.flow.FlowId; |
Yuta HIGUCHI | 9def047 | 2014-10-23 15:51:10 -0700 | [diff] [blame] | 56 | import org.onlab.onos.net.flow.FlowRuleBatchEntry; |
| 57 | import org.onlab.onos.net.flow.FlowRuleBatchOperation; |
Madan Jampani | 117aaae | 2014-10-23 10:04:05 -0700 | [diff] [blame] | 58 | import org.onlab.onos.net.flow.StoredFlowEntry; |
Yuta HIGUCHI | 85d58d1 | 2014-10-20 23:59:44 -0700 | [diff] [blame] | 59 | import org.onlab.onos.net.flow.criteria.Criteria; |
| 60 | import org.onlab.onos.net.flow.criteria.Criterion; |
| 61 | import org.onlab.onos.net.flow.instructions.Instructions; |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 62 | import org.onlab.onos.net.host.DefaultHostDescription; |
| 63 | import org.onlab.onos.net.host.HostDescription; |
Yuta HIGUCHI | 087019b | 2014-10-28 21:07:56 -0700 | [diff] [blame] | 64 | import org.onlab.onos.net.intent.ConnectivityIntent; |
| 65 | import org.onlab.onos.net.intent.HostToHostIntent; |
| 66 | import org.onlab.onos.net.intent.Intent; |
| 67 | import org.onlab.onos.net.intent.IntentId; |
| 68 | import org.onlab.onos.net.intent.IntentState; |
| 69 | import org.onlab.onos.net.intent.MultiPointToSinglePointIntent; |
| 70 | import org.onlab.onos.net.intent.PathIntent; |
| 71 | import org.onlab.onos.net.intent.PointToPointIntent; |
Madan Jampani | 2ff0559 | 2014-10-10 15:42:47 -0700 | [diff] [blame] | 72 | import org.onlab.onos.net.link.DefaultLinkDescription; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 73 | import org.onlab.onos.net.provider.ProviderId; |
Yuta HIGUCHI | 9ee60f6 | 2014-10-09 10:00:01 -0700 | [diff] [blame] | 74 | import org.onlab.onos.store.Timestamp; |
alshabib | 7911a05 | 2014-10-16 17:49:37 -0700 | [diff] [blame] | 75 | import org.onlab.packet.ChassisId; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 76 | import org.onlab.packet.IpAddress; |
| 77 | import org.onlab.packet.IpPrefix; |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 78 | import org.onlab.packet.MacAddress; |
| 79 | import org.onlab.packet.VlanId; |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 80 | import org.onlab.util.KryoNamespace; |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 81 | |
Yuta HIGUCHI | 47c4088 | 2014-10-10 18:44:37 -0700 | [diff] [blame] | 82 | import com.google.common.collect.ImmutableList; |
| 83 | import com.google.common.collect.ImmutableMap; |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 84 | import com.google.common.collect.ImmutableSet; |
Yuta HIGUCHI | 47c4088 | 2014-10-10 18:44:37 -0700 | [diff] [blame] | 85 | |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 86 | public final class KryoNamespaces { |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 87 | |
| 88 | /** |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 89 | * KryoNamespace which can serialize ON.lab misc classes. |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 90 | */ |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 91 | public static final KryoNamespace MISC = KryoNamespace.newBuilder() |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 92 | .register(IpPrefix.class, new IpPrefixSerializer()) |
| 93 | .register(IpAddress.class, new IpAddressSerializer()) |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 94 | .register(MacAddress.class, new MacAddressSerializer()) |
| 95 | .register(VlanId.class) |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 96 | .build(); |
| 97 | |
| 98 | // TODO: Populate other classes |
| 99 | /** |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 100 | * KryoNamespace which can serialize API bundle classes. |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 101 | */ |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 102 | public static final KryoNamespace API = KryoNamespace.newBuilder() |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 103 | .register(MISC) |
Yuta HIGUCHI | 47c4088 | 2014-10-10 18:44:37 -0700 | [diff] [blame] | 104 | .register(ImmutableMap.class, new ImmutableMapSerializer()) |
| 105 | .register(ImmutableList.class, new ImmutableListSerializer()) |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 106 | .register(ImmutableSet.class, new ImmutableSetSerializer()) |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 107 | .register( |
| 108 | // |
| 109 | ArrayList.class, |
Madan Jampani | 53e44e6 | 2014-10-07 12:39:51 -0700 | [diff] [blame] | 110 | Arrays.asList().getClass(), |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 111 | HashMap.class, |
alshabib | 3d643ec | 2014-10-22 18:33:00 -0700 | [diff] [blame] | 112 | HashSet.class, |
Yuta HIGUCHI | 9def047 | 2014-10-23 15:51:10 -0700 | [diff] [blame] | 113 | LinkedList.class, |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 114 | // |
Yuta HIGUCHI | 47c4088 | 2014-10-10 18:44:37 -0700 | [diff] [blame] | 115 | // |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 116 | ControllerNode.State.class, |
| 117 | Device.Type.class, |
alshabib | 7911a05 | 2014-10-16 17:49:37 -0700 | [diff] [blame] | 118 | ChassisId.class, |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 119 | DefaultAnnotations.class, |
| 120 | DefaultControllerNode.class, |
| 121 | DefaultDevice.class, |
Madan Jampani | 53e44e6 | 2014-10-07 12:39:51 -0700 | [diff] [blame] | 122 | DefaultDeviceDescription.class, |
Madan Jampani | 2ff0559 | 2014-10-10 15:42:47 -0700 | [diff] [blame] | 123 | DefaultLinkDescription.class, |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 124 | Port.class, |
Madan Jampani | 53e44e6 | 2014-10-07 12:39:51 -0700 | [diff] [blame] | 125 | DefaultPortDescription.class, |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 126 | Element.class, |
Yuta HIGUCHI | 9ee60f6 | 2014-10-09 10:00:01 -0700 | [diff] [blame] | 127 | Link.Type.class, |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 128 | Timestamp.class, |
| 129 | HostId.class, |
| 130 | HostDescription.class, |
Madan Jampani | 38b250d | 2014-10-17 11:02:38 -0700 | [diff] [blame] | 131 | DefaultHostDescription.class, |
Madan Jampani | 117aaae | 2014-10-23 10:04:05 -0700 | [diff] [blame] | 132 | DefaultFlowEntry.class, |
| 133 | StoredFlowEntry.class, |
Yuta HIGUCHI | 2fcfde9 | 2014-10-20 18:37:14 -0700 | [diff] [blame] | 134 | DefaultFlowRule.class, |
alshabib | 3d643ec | 2014-10-22 18:33:00 -0700 | [diff] [blame] | 135 | DefaultFlowEntry.class, |
alshabib | f6c2ede | 2014-10-22 23:31:50 -0700 | [diff] [blame] | 136 | FlowEntry.FlowEntryState.class, |
Yuta HIGUCHI | 2809bf3 | 2014-10-20 22:44:12 -0700 | [diff] [blame] | 137 | FlowId.class, |
Yuta HIGUCHI | 85d58d1 | 2014-10-20 23:59:44 -0700 | [diff] [blame] | 138 | DefaultTrafficSelector.class, |
| 139 | Criteria.PortCriterion.class, |
| 140 | Criteria.EthCriterion.class, |
| 141 | Criteria.EthTypeCriterion.class, |
| 142 | Criteria.IPCriterion.class, |
| 143 | Criteria.IPProtocolCriterion.class, |
| 144 | Criteria.VlanIdCriterion.class, |
| 145 | Criteria.VlanPcpCriterion.class, |
| 146 | Criteria.TcpPortCriterion.class, |
| 147 | Criterion.class, |
| 148 | Criterion.Type.class, |
| 149 | DefaultTrafficTreatment.class, |
| 150 | Instructions.DropInstruction.class, |
Yuta HIGUCHI | 40d0177 | 2014-10-21 00:08:44 -0700 | [diff] [blame] | 151 | Instructions.OutputInstruction.class, |
Yuta HIGUCHI | 9def047 | 2014-10-23 15:51:10 -0700 | [diff] [blame] | 152 | RoleInfo.class, |
| 153 | FlowRuleBatchOperation.class, |
| 154 | CompletedBatchOperation.class, |
| 155 | FlowRuleBatchEntry.class, |
Yuta HIGUCHI | 087019b | 2014-10-28 21:07:56 -0700 | [diff] [blame] | 156 | FlowRuleBatchEntry.FlowRuleOperation.class, |
| 157 | IntentId.class, |
| 158 | IntentState.class, |
| 159 | Intent.class, |
| 160 | ConnectivityIntent.class, |
| 161 | PathIntent.class, |
| 162 | DefaultPath.class, |
| 163 | DefaultEdgeLink.class, |
| 164 | HostToHostIntent.class, |
| 165 | PointToPointIntent.class, |
| 166 | MultiPointToSinglePointIntent.class |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 167 | ) |
Thomas Vachuska | e0f804a | 2014-10-27 23:40:48 -0700 | [diff] [blame] | 168 | .register(DefaultApplicationId.class, new DefaultApplicationIdSerializer()) |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 169 | .register(URI.class, new URISerializer()) |
| 170 | .register(NodeId.class, new NodeIdSerializer()) |
| 171 | .register(ProviderId.class, new ProviderIdSerializer()) |
| 172 | .register(DeviceId.class, new DeviceIdSerializer()) |
| 173 | .register(PortNumber.class, new PortNumberSerializer()) |
| 174 | .register(DefaultPort.class, new DefaultPortSerializer()) |
| 175 | .register(LinkKey.class, new LinkKeySerializer()) |
| 176 | .register(ConnectPoint.class, new ConnectPointSerializer()) |
| 177 | .register(DefaultLink.class, new DefaultLinkSerializer()) |
Yuta HIGUCHI | fa891c9 | 2014-10-09 15:21:40 -0700 | [diff] [blame] | 178 | .register(MastershipTerm.class, new MastershipTermSerializer()) |
Yuta HIGUCHI | 5fa3dc0 | 2014-10-15 17:08:13 -0700 | [diff] [blame] | 179 | .register(HostLocation.class, new HostLocationSerializer()) |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 180 | |
| 181 | .build(); |
| 182 | |
| 183 | |
| 184 | // not to be instantiated |
Yuta HIGUCHI | 8d143d2 | 2014-10-19 23:15:09 -0700 | [diff] [blame] | 185 | private KryoNamespaces() {} |
Yuta HIGUCHI | 03fec1f | 2014-10-03 09:13:50 -0700 | [diff] [blame] | 186 | } |