2 * Copyright (c) 2016 Pantheon Technologies s.r.o. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.openflowplugin.impl.protocol.serialization;
11 import com.google.common.annotations.VisibleForTesting;
12 import java.util.function.Consumer;
13 import java.util.function.Function;
14 import org.opendaylight.openflowjava.protocol.api.extensibility.OFSerializer;
15 import org.opendaylight.openflowjava.protocol.api.extensibility.SerializerExtensionProvider;
16 import org.opendaylight.openflowjava.protocol.api.keys.MessageTypeKey;
17 import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
18 import org.opendaylight.openflowplugin.impl.protocol.serialization.messages.FlowMessageSerializer;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.FlowMessage;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader;
21 import org.opendaylight.openflowplugin.impl.protocol.serialization.messages.MeterMessageSerializer;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.meter.types.rev130918.MeterMessage;
25 * Util class for injecting new message serializers into OpenflowJava
27 class MessageSerializerInjector {
30 * Injects message serializers into provided {@link org.opendaylight.openflowjava.protocol.api.extensibility.SerializerExtensionProvider}
31 * @param provider OpenflowJava serializer extension provider
33 static void injectSerializers(final SerializerExtensionProvider provider) {
34 // Inject new message serializers here using injector created by createInjector method
35 final Function<Class<?>, Consumer<OFSerializer<? extends OfHeader>>> injector =
36 createInjector(provider, EncodeConstants.OF13_VERSION_ID);
38 injector.apply(FlowMessage.class).accept(new FlowMessageSerializer());
39 injector.apply(MeterMessage.class).accept(new MeterMessageSerializer());
43 * Create injector that will inject new serializers into #{@link org.opendaylight.openflowjava.protocol.api.extensibility.SerializerExtensionProvider}
44 * @param provider OpenflowJava serializer extension provider
45 * @param version Openflow version
49 static Function<Class<?>, Consumer<OFSerializer<? extends OfHeader>>> createInjector(final SerializerExtensionProvider provider,
51 return type -> serializer ->
52 provider.registerSerializer(
53 new MessageTypeKey<>(version, type),