2 * Copyright (c) 2015 Cisco Systems, Inc. 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
8 package org.opendaylight.netconf.sal.connect.netconf.listener;
10 import static java.util.Objects.requireNonNull;
12 import com.google.common.collect.ImmutableMap;
13 import com.google.common.collect.ImmutableSet;
14 import org.eclipse.jdt.annotation.NonNull;
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.connection.oper.available.capabilities.AvailableCapability;
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.connection.oper.unavailable.capabilities.UnavailableCapability.FailureReason;
17 import org.opendaylight.yangtools.yang.common.QName;
19 public record NetconfDeviceCapabilities(
20 @NonNull ImmutableMap<QName, FailureReason> unresolvedCapabilites,
21 @NonNull ImmutableSet<AvailableCapability> resolvedCapabilities,
22 @NonNull ImmutableSet<AvailableCapability> nonModuleBasedCapabilities) {
23 private static final @NonNull NetconfDeviceCapabilities EMPTY =
24 new NetconfDeviceCapabilities(ImmutableMap.of(), ImmutableSet.of(), ImmutableSet.of());
26 public NetconfDeviceCapabilities {
27 requireNonNull(unresolvedCapabilites);
28 requireNonNull(resolvedCapabilities);
29 requireNonNull(nonModuleBasedCapabilities);
32 public static @NonNull NetconfDeviceCapabilities empty() {