public inbox for pve-devel@lists.proxmox.com
 help / color / mirror / Atom feed
From: Mira Limbeck <m.limbeck@proxmox.com>
To: pve-devel@lists.proxmox.com
Subject: [PATCH v2 storage 13/15] api: add non-persistent iscsi discovery option
Date: Thu, 30 Apr 2026 19:27:11 +0200	[thread overview]
Message-ID: <20260430173220.441001-14-m.limbeck@proxmox.com> (raw)
In-Reply-To: <20260430173220.441001-1-m.limbeck@proxmox.com>

and return new portals list with reachability information for each
portal

Signed-off-by: Mira Limbeck <m.limbeck@proxmox.com>
---


 src/PVE/API2/Storage/Scan.pm   | 32 ++++++++++++++++++++++++++++++--
 src/PVE/CLI/pvesm.pm           |  3 ++-
 src/PVE/Storage.pm             |  2 +-
 src/PVE/Storage/ISCSIPlugin.pm | 15 +++++++++++----
 4 files changed, 44 insertions(+), 8 deletions(-)

diff --git a/src/PVE/API2/Storage/Scan.pm b/src/PVE/API2/Storage/Scan.pm
index a58bdd8..f272e3b 100644
--- a/src/PVE/API2/Storage/Scan.pm
+++ b/src/PVE/API2/Storage/Scan.pm
@@ -265,6 +265,12 @@ __PACKAGE__->register_method({
                 type => 'string',
                 format => 'pve-storage-portal-dns',
             },
+            persist => {
+                description => 'Persist discovery results to discovery db.',
+                type => 'boolean',
+                optional => 1,
+                default => 1,
+            },
         },
     },
     returns => {
@@ -280,17 +286,39 @@ __PACKAGE__->register_method({
                     description => "The iSCSI portal name.",
                     type => 'string',
                 },
+                portals => {
+                    description => 'The iSCSI portals discovered, includes reachability.',
+                    type => 'string',
+                },
             },
         },
     },
     code => sub {
         my ($param) = @_;
 
-        my $res = PVE::Storage::scan_iscsi($param->{portal});
+        my $persist = $param->{persist} // 1;
+        my $res = PVE::Storage::scan_iscsi($param->{portal}, $persist);
 
         my $data = [];
         foreach my $k (sort keys %$res) {
-            push @$data, { target => $k, portal => join(',', @{ $res->{$k} }) };
+            my $portals = [];
+            my $portals_reachability = [];
+            for my $entry ($res->{$k}->@*) {
+                my $portal = $entry->{portal};
+                my $reachability = $entry->{reachable} ? '1' : '0';
+                push $portals->@*, $portal;
+                push $portals_reachability->@*, $portal . ':' . $reachability;
+            }
+            #my $portals = [ map { $_->{portal} } $res->{$k}->@* ];
+            #my $portals_reachability = [ map { $_->{portal} . ':' . ($_->{reachable} ? '1' : '0') } $res->{$k}->@* ];
+            my $entry = {
+                target => $k,
+                portal => join(',', $portals->@*),
+                portals => join(',', $portals_reachability->@*),
+                #portals => join(',', map { $_->{portal}.':'.($_->{reachable} // '0') } $res->{$k}->@*),
+            };
+            #push @$data, { target => $k, portal => join(',', $portals->@*) };
+            push $data->@*, $entry;
         }
 
         return $data;
diff --git a/src/PVE/CLI/pvesm.pm b/src/PVE/CLI/pvesm.pm
index 06bc4c9..6e88123 100755
--- a/src/PVE/CLI/pvesm.pm
+++ b/src/PVE/CLI/pvesm.pm
@@ -688,7 +688,8 @@ our $cmddef = {
                     $maxlen = $len if $len > $maxlen;
                 }
                 foreach my $rec (@$res) {
-                    printf "%-${maxlen}s %s\n", $rec->{target}, $rec->{portal};
+                    printf "%-${maxlen}s %s %s\n", $rec->{target}, $rec->{portal},
+                        $rec->{portals};
                 }
             },
         ],
diff --git a/src/PVE/Storage.pm b/src/PVE/Storage.pm
index d783788..73546d2 100755
--- a/src/PVE/Storage.pm
+++ b/src/PVE/Storage.pm
@@ -1658,7 +1658,7 @@ sub scan_iscsi {
         die "unable to parse/resolve portal address '${portal_in}'\n";
     }
 
-    return PVE::Storage::ISCSIPlugin::iscsi_discovery(undef, [$portal]);
+    return PVE::Storage::ISCSIPlugin::iscsi_discovery(undef, [$portal], undef, 0);
 }
 
 sub storage_default_format {
diff --git a/src/PVE/Storage/ISCSIPlugin.pm b/src/PVE/Storage/ISCSIPlugin.pm
index a95edf4..066d1ed 100644
--- a/src/PVE/Storage/ISCSIPlugin.pm
+++ b/src/PVE/Storage/ISCSIPlugin.pm
@@ -200,7 +200,7 @@ sub iscsi_portals {
 }
 
 sub iscsi_discovery {
-    my ($target_in, $portals, $cache, $update_db) = @_;
+    my ($target_in, $portals, $cache, $persist) = @_;
 
     assert_iscsi_support();
 
@@ -208,8 +208,9 @@ sub iscsi_discovery {
     for my $portal ($portals->@*) {
         next if !iscsi_test_portal($target_in, $portal, $cache); # fixme: raise exception here?
 
+        my $target_found = 0;
         my $cmd = [$ISCSIADM, '--mode', 'discovery', '--type', 'sendtargets', '--portal', $portal];
-        push $cmd->@*, '-o', 'nonpersistent' if !$update_db;
+        push $cmd->@*, '-o', 'nonpersistent' if !$persist;
         eval {
             run_command(
                 $cmd,
@@ -220,14 +221,20 @@ sub iscsi_discovery {
                         my ($portal, $target) = ($1, $2);
                         # one target can have more than one portal (multipath)
                         # and sendtargets should return all of them in single call
-                        push @{ $res->{$target} }, $portal;
+                        my $entry = {
+                            portal => $portal,
+                            reachable => !!iscsi_test_portal($target, $portal, $cache),
+                        };
+                        push @{ $res->{$target} }, $entry;
+
+                        $target_found = 1 if defined($target_in) && $target_in eq $target;
                     }
                 },
             );
         };
 
         # In case of multipath we can stop after receiving targets from any available portal
-        last if defined($target) && scalar(keys %$res) > 0;
+        last if $target_found && scalar(keys %$res) > 0;
     }
 
     return $res;
-- 
2.47.3




  parent reply	other threads:[~2026-04-30 17:33 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-04-30 17:26 [PATCH v2 cluster/storage/manager 00/15] storage mapping Mira Limbeck
2026-04-30 17:26 ` [PATCH v2 cluster 01/15] mapping: add storage.cfg Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 02/15] mapping: add base plugin Mira Limbeck
2026-04-30 17:35   ` Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 03/15] mapping: add iSCSI plugin Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 04/15] iscsi: introduce mapping support Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 05/15] iscsi: add helper to get local config Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 06/15] iscsi: change functions to handle mappings Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 07/15] iscsi: introduce helper to update discovery db Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 08/15] iscsi: rework to update discovery db and simplify login Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 09/15] iscsi: remove stale sessions in non-mapping case Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 10/15] api: add mapping support Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 11/15] mapping: iscsi: add discovery-portal config option Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 storage 12/15] iscsi: add support for non-persistent discovery Mira Limbeck
2026-04-30 17:38   ` Mira Limbeck
2026-04-30 17:27 ` Mira Limbeck [this message]
2026-04-30 17:27 ` [POC v2 storage 14/15] mapping: add zfspool plugin Mira Limbeck
2026-04-30 17:27 ` [PATCH v2 manager 15/15] api: mapping: add storage mapping path Mira Limbeck

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20260430173220.441001-14-m.limbeck@proxmox.com \
    --to=m.limbeck@proxmox.com \
    --cc=pve-devel@lists.proxmox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox
Service provided by Proxmox Server Solutions GmbH | Privacy | Legal