[pve-devel] [PATCH pve-network 5/9] api: nodes: fabrics: add endpoint for querying neighbor information
Hannes Laimer
h.laimer at proxmox.com
Mon Nov 3 15:22:45 CET 2025
On 10/30/25 16:51, Stefan Hanreich wrote:
> From: Gabriel Goller <g.goller at proxmox.com>
>
> This endpoint returns all neighbors for a given fabric and their
> current status. For more information about the return value, consult
> the respective proxmox-perl-rs commit. It is used by the
> NetworkBrowser panel.
>
> Co-authored-by: Stefan Hanreich <s.hanreich at proxmox.com>
> Signed-off-by: Gabriel Goller <g.goller at proxmox.com>
> Signed-off-by: Stefan Hanreich <s.hanreich at proxmox.com>
> ---
> src/PVE/API2/Network/SDN/Nodes/Fabric.pm | 48 +++++++++++++++++++++++-
> 1 file changed, 47 insertions(+), 1 deletion(-)
>
> diff --git a/src/PVE/API2/Network/SDN/Nodes/Fabric.pm b/src/PVE/API2/Network/SDN/Nodes/Fabric.pm
> index c1886b7..b5971c7 100644
> --- a/src/PVE/API2/Network/SDN/Nodes/Fabric.pm
> +++ b/src/PVE/API2/Network/SDN/Nodes/Fabric.pm
> @@ -40,7 +40,7 @@ __PACKAGE__->register_method({
> code => sub {
> my ($param) = @_;
> my $res = [
> - { subdir => 'routes' },
> + { subdir => 'neighbors' }, { subdir => 'routes' },
> ];
>
> return $res;
> @@ -92,3 +92,49 @@ __PACKAGE__->register_method({
> },
> });
>
> +__PACKAGE__->register_method({
> + name => 'neighbors',
> + path => 'neighbors',
> + method => 'GET',
> + description => "Get neighbors of all fabrics.",
> + permissions => {
> + check => ['perm', '/sdn/fabrics/{fabric}', ['SDN.Audit']],
> + },
> + protected => 1,
> + proxyto => 'node',
> + parameters => {
> + additionalProperties => 0,
> + properties => {
> + node => get_standard_option('pve-node'),
> + fabric => get_standard_option('pve-sdn-fabric-id'),
> + },
> + },
> + returns => {
> + type => 'array',
> + items => {
> + type => "object",
> + properties => {
> + neighbor => {
> + description => "The IP of the neighbor.",
> + type => 'string',
I think we have an IP format, but also fine as is
> + },
> + status => {
> + description => "The status of the neighbor, as returned by FRR.",
> + type => 'string',
> + },
> + uptime => {
> + description =>
> + "The uptime of this neighbor, as returned by FRR (e.g. 8h24m12s).",
> + type => 'string',
> + },
> + },
> + },
> + },
> + code => sub {
> + my ($param) = @_;
> +
> + my $fabric_id = extract_param($param, 'fabric');
> + return PVE::RS::SDN::Fabrics::neighbors($fabric_id);
> + },
> +});
> +
More information about the pve-devel
mailing list