Revert "agent: use rtnetlink's neighbours API to add neighbors"

This reverts commit 845c1c03cf.

Fixes: #5126
This commit is contained in:
Archana Shinde 2022-09-06 14:30:45 -07:00
parent 188d37badc
commit d340564d61
3 changed files with 90 additions and 42 deletions

70
src/agent/Cargo.lock generated
View File

@ -654,8 +654,8 @@ dependencies = [
"libc", "libc",
"log", "log",
"logging", "logging",
"netlink-packet-utils 0.4.1", "netlink-packet-utils",
"netlink-sys 0.7.0", "netlink-sys",
"nix 0.24.2", "nix 0.24.2",
"oci", "oci",
"opentelemetry", "opentelemetry",
@ -841,28 +841,28 @@ checksum = "e5ce46fe64a9d73be07dcbe690a38ce1b293be448fd8ce1e6c1b8062c9f72c6a"
[[package]] [[package]]
name = "netlink-packet-core" name = "netlink-packet-core"
version = "0.4.2" version = "0.2.4"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "345b8ab5bd4e71a2986663e88c56856699d060e78e152e6e9d7966fcd5491297" checksum = "ac48279d5062bdf175bdbcb6b58ff1d6b0ecd54b951f7a0ff4bc0550fe903ccb"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"byteorder", "byteorder",
"libc", "libc",
"netlink-packet-utils 0.5.1", "netlink-packet-utils",
] ]
[[package]] [[package]]
name = "netlink-packet-route" name = "netlink-packet-route"
version = "0.13.0" version = "0.8.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "f5dee5ed749373c298237fe694eb0a51887f4cc1a27370c8464bac4382348f1a" checksum = "76aed5d3b6e3929713bf1e1334a11fd65180b6d9f5d7c8572664c48b122604f8"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"bitflags", "bitflags",
"byteorder", "byteorder",
"libc", "libc",
"netlink-packet-core", "netlink-packet-core",
"netlink-packet-utils 0.5.1", "netlink-packet-utils",
] ]
[[package]] [[package]]
@ -877,31 +877,19 @@ dependencies = [
"thiserror", "thiserror",
] ]
[[package]]
name = "netlink-packet-utils"
version = "0.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "25af9cf0dc55498b7bd94a1508af7a78706aa0ab715a73c5169273e03c84845e"
dependencies = [
"anyhow",
"byteorder",
"paste",
"thiserror",
]
[[package]] [[package]]
name = "netlink-proto" name = "netlink-proto"
version = "0.10.0" version = "0.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "65b4b14489ab424703c092062176d52ba55485a89c076b4f9db05092b7223aa6" checksum = "ddd06e90449ae973fe3888c1ff85949604ef5189b4ac9a2ae39518da1e00762d"
dependencies = [ dependencies = [
"bytes 1.1.0", "bytes 1.1.0",
"futures", "futures",
"log", "log",
"netlink-packet-core", "netlink-packet-core",
"netlink-sys 0.8.3", "netlink-sys",
"thiserror",
"tokio", "tokio",
"tokio-util",
] ]
[[package]] [[package]]
@ -917,16 +905,16 @@ dependencies = [
] ]
[[package]] [[package]]
name = "netlink-sys" name = "nix"
version = "0.8.3" version = "0.22.3"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "92b654097027250401127914afb37cb1f311df6610a9891ff07a757e94199027" checksum = "e4916f159ed8e5de0082076562152a76b7a1f64a01fd9d1e0fea002c37624faf"
dependencies = [ dependencies = [
"bytes 1.1.0", "bitflags",
"futures", "cc",
"cfg-if 1.0.0",
"libc", "libc",
"log", "memoffset",
"tokio",
] ]
[[package]] [[package]]
@ -1491,15 +1479,15 @@ dependencies = [
[[package]] [[package]]
name = "rtnetlink" name = "rtnetlink"
version = "0.11.0" version = "0.8.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "46f1cfa18f8cebe685373a2697915d7e0db3b4554918bba118385e0f71f258a7" checksum = "7c9a6200d18ec1acfc218ce71363dcc9b6075f399220f903fdfeacd476a876ef"
dependencies = [ dependencies = [
"futures", "futures",
"log", "log",
"netlink-packet-route", "netlink-packet-route",
"netlink-proto", "netlink-proto",
"nix 0.24.2", "nix 0.22.3",
"thiserror", "thiserror",
"tokio", "tokio",
] ]
@ -1888,6 +1876,20 @@ dependencies = [
"tokio", "tokio",
] ]
[[package]]
name = "tokio-util"
version = "0.6.10"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "36943ee01a6d67977dd3f84a5a1d2efeb4ada3a1ae771cadfaa535d9d9fc6507"
dependencies = [
"bytes 1.1.0",
"futures-core",
"futures-sink",
"log",
"pin-project-lite",
"tokio",
]
[[package]] [[package]]
name = "tokio-vsock" name = "tokio-vsock"
version = "0.3.1" version = "0.3.1"

View File

@ -35,7 +35,7 @@ tokio = { version = "1.14.0", features = ["full"] }
tokio-vsock = "0.3.1" tokio-vsock = "0.3.1"
netlink-sys = { version = "0.7.0", features = ["tokio_socket",]} netlink-sys = { version = "0.7.0", features = ["tokio_socket",]}
rtnetlink = "0.11.0" rtnetlink = "0.8.0"
netlink-packet-utils = "0.4.1" netlink-packet-utils = "0.4.1"
ipnetwork = "0.17.0" ipnetwork = "0.17.0"

View File

@ -4,7 +4,7 @@
// //
use anyhow::{anyhow, Context, Result}; use anyhow::{anyhow, Context, Result};
use futures::{future, TryStreamExt}; use futures::{future, StreamExt, TryStreamExt};
use ipnetwork::{IpNetwork, Ipv4Network, Ipv6Network}; use ipnetwork::{IpNetwork, Ipv4Network, Ipv6Network};
use nix::errno::Errno; use nix::errno::Errno;
use protobuf::RepeatedField; use protobuf::RepeatedField;
@ -164,7 +164,7 @@ impl Handle {
let request = self.handle.link().get(); let request = self.handle.link().get();
let filtered = match filter { let filtered = match filter {
LinkFilter::Name(name) => request.match_name(name.to_owned()), LinkFilter::Name(name) => request.set_name_filter(name.to_owned()),
LinkFilter::Index(index) => request.match_index(index), LinkFilter::Index(index) => request.match_index(index),
_ => request, // Post filters _ => request, // Post filters
}; };
@ -516,6 +516,7 @@ impl Handle {
} }
/// Adds an ARP neighbor. /// Adds an ARP neighbor.
/// TODO: `rtnetlink` has no neighbours API, remove this after https://github.com/little-dude/netlink/pull/135
async fn add_arp_neighbor(&mut self, neigh: &ARPNeighbor) -> Result<()> { async fn add_arp_neighbor(&mut self, neigh: &ARPNeighbor) -> Result<()> {
let ip_address = neigh let ip_address = neigh
.toIPAddress .toIPAddress
@ -527,13 +528,58 @@ impl Handle {
let ip = IpAddr::from_str(ip_address) let ip = IpAddr::from_str(ip_address)
.map_err(|e| anyhow!("Failed to parse IP {}: {:?}", ip_address, e))?; .map_err(|e| anyhow!("Failed to parse IP {}: {:?}", ip_address, e))?;
// Import rtnetlink objects that make sense only for this function
use packet::constants::{NDA_UNSPEC, NLM_F_ACK, NLM_F_CREATE, NLM_F_EXCL, NLM_F_REQUEST};
use packet::neighbour::{NeighbourHeader, NeighbourMessage};
use packet::nlas::neighbour::Nla;
use packet::{NetlinkMessage, NetlinkPayload, RtnlMessage};
use rtnetlink::Error;
const IFA_F_PERMANENT: u16 = 0x80; // See https://github.com/little-dude/netlink/blob/0185b2952505e271805902bf175fee6ea86c42b8/netlink-packet-route/src/rtnl/constants.rs#L770
let link = self.find_link(LinkFilter::Name(&neigh.device)).await?; let link = self.find_link(LinkFilter::Name(&neigh.device)).await?;
self.handle let message = NeighbourMessage {
.neighbours() header: NeighbourHeader {
.add(link.index(), ip) family: match ip {
.execute() IpAddr::V4(_) => packet::AF_INET,
.await?; IpAddr::V6(_) => packet::AF_INET6,
} as u8,
ifindex: link.index(),
state: if neigh.state != 0 {
neigh.state as u16
} else {
IFA_F_PERMANENT
},
flags: neigh.flags as u8,
ntype: NDA_UNSPEC as u8,
},
nlas: {
let mut nlas = vec![Nla::Destination(match ip {
IpAddr::V4(v4) => v4.octets().to_vec(),
IpAddr::V6(v6) => v6.octets().to_vec(),
})];
if !neigh.lladdr.is_empty() {
nlas.push(Nla::LinkLocalAddress(
parse_mac_address(&neigh.lladdr)?.to_vec(),
));
}
nlas
},
};
// Send request and ACK
let mut req = NetlinkMessage::from(RtnlMessage::NewNeighbour(message));
req.header.flags = NLM_F_REQUEST | NLM_F_ACK | NLM_F_EXCL | NLM_F_CREATE;
let mut response = self.handle.request(req)?;
while let Some(message) = response.next().await {
if let NetlinkPayload::Error(err) = message.payload {
return Err(anyhow!(Error::NetlinkError(err)));
}
}
Ok(()) Ok(())
} }