-/**
+/*
* Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
import com.google.common.annotations.VisibleForTesting;
import com.google.common.base.Preconditions;
-import java.util.ArrayList;
+import com.google.common.collect.ImmutableSet;
import java.util.List;
+import java.util.Set;
import java.util.concurrent.atomic.AtomicLong;
import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
import org.opendaylight.openflowplugin.api.openflow.device.Xid;
import org.opendaylight.openflowplugin.impl.services.util.RequestInputUtils;
-import org.opendaylight.openflowplugin.impl.services.util.ServiceException;
import org.opendaylight.openflowplugin.impl.statistics.services.compatibility.AbstractCompatibleStatService;
import org.opendaylight.openflowplugin.impl.util.GroupUtil;
import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.transaction.rev150304.TransactionId;
private static final MultipartRequestGroupFeaturesCase GROUP_FEAT_CASE =
new MultipartRequestGroupFeaturesCaseBuilder().build();
- public GroupFeaturesService(RequestContextStack requestContextStack, DeviceContext deviceContext, AtomicLong compatibilityXidSeed) {
+ GroupFeaturesService(final RequestContextStack requestContextStack,
+ final DeviceContext deviceContext,
+ final AtomicLong compatibilityXidSeed) {
super(requestContextStack, deviceContext, compatibilityXidSeed);
}
@Override
- protected OfHeader buildRequest(final Xid xid, final GetGroupFeaturesInput input) throws ServiceException {
+ protected OfHeader buildRequest(final Xid xid, final GetGroupFeaturesInput input) {
final MultipartRequestInputBuilder mprInput = RequestInputUtils.createMultipartHeader(
MultipartType.OFPMPGROUPFEATURES, xid.getValue(), getVersion());
mprInput.setMultipartRequestBody(GROUP_FEAT_CASE);
}
@Override
- public GetGroupFeaturesOutput buildTxCapableResult(TransactionId emulatedTxId) {
+ public GetGroupFeaturesOutput buildTxCapableResult(final TransactionId emulatedTxId) {
return new GetGroupFeaturesOutputBuilder().setTransactionId(emulatedTxId).build();
}
@Override
- public GroupFeaturesUpdated transformToNotification(List<MultipartReply> result, TransactionId emulatedTxId) {
+ public GroupFeaturesUpdated transformToNotification(final List<MultipartReply> result,
+ final TransactionId emulatedTxId) {
final int mpSize = result.size();
Preconditions.checkArgument(mpSize == 1, "unexpected (!=1) mp-reply size received: {}", mpSize);
notification.setMoreReplies(Boolean.FALSE);
notification.setTransactionId(emulatedTxId);
- MultipartReplyGroupFeaturesCase caseBody = (MultipartReplyGroupFeaturesCase) result.get(0).getMultipartReplyBody();
+ MultipartReplyGroupFeaturesCase caseBody =
+ (MultipartReplyGroupFeaturesCase) result.get(0).getMultipartReplyBody();
MultipartReplyGroupFeatures replyBody = caseBody.getMultipartReplyGroupFeatures();
notification.setGroupTypesSupported(extractSupportedGroupTypes(replyBody.getTypes()));
}
@VisibleForTesting
- static List<Class<? extends GroupCapability>> extractSupportedCapabilities(GroupCapabilities capabilities) {
- List<Class<? extends GroupCapability>> supportedCapabilities = new ArrayList<>();
-
- if (capabilities.isOFPGFCCHAINING()) {
- supportedCapabilities.add(Chaining.class);
+ static Set<Class<? extends GroupCapability>> extractSupportedCapabilities(final GroupCapabilities capabilities) {
+ final var builder = ImmutableSet.<Class<? extends GroupCapability>>builder();
+ if (capabilities.getOFPGFCCHAINING()) {
+ builder.add(Chaining.class);
}
- if (capabilities.isOFPGFCCHAININGCHECKS()) {
- supportedCapabilities.add(ChainingChecks.class);
+ if (capabilities.getOFPGFCCHAININGCHECKS()) {
+ builder.add(ChainingChecks.class);
}
- if (capabilities.isOFPGFCSELECTLIVENESS()) {
- supportedCapabilities.add(SelectLiveness.class);
+ if (capabilities.getOFPGFCSELECTLIVENESS()) {
+ builder.add(SelectLiveness.class);
}
- if (capabilities.isOFPGFCSELECTWEIGHT()) {
- supportedCapabilities.add(SelectWeight.class);
+ if (capabilities.getOFPGFCSELECTWEIGHT()) {
+ builder.add(SelectWeight.class);
}
- return supportedCapabilities;
+ return builder.build();
}
@VisibleForTesting
- static List<Class<? extends GroupType>> extractSupportedGroupTypes(GroupTypes types) {
- List<Class<? extends GroupType>> supportedGroups = new ArrayList<>();
-
- if (types.isOFPGTALL()) {
- supportedGroups.add(GroupAll.class);
+ static Set<Class<? extends GroupType>> extractSupportedGroupTypes(final GroupTypes types) {
+ final var builder = ImmutableSet.<Class<? extends GroupType>>builder();
+ if (types.getOFPGTALL()) {
+ builder.add(GroupAll.class);
}
- if (types.isOFPGTSELECT()) {
- supportedGroups.add(GroupSelect.class);
+ if (types.getOFPGTSELECT()) {
+ builder.add(GroupSelect.class);
}
- if (types.isOFPGTINDIRECT()) {
- supportedGroups.add(GroupIndirect.class);
+ if (types.getOFPGTINDIRECT()) {
+ builder.add(GroupIndirect.class);
}
- if (types.isOFPGTFF()) {
- supportedGroups.add(GroupFf.class);
+ if (types.getOFPGTFF()) {
+ builder.add(GroupFf.class);
}
- return supportedGroups;
+ return builder.build();
}
}