public inbox for pve-devel@lists.proxmox.com
 help / color / mirror / Atom feed
From: Wolfgang Bumiller <w.bumiller@proxmox.com>
To: "Max R. Carrara" <m.carrara@proxmox.com>
Cc: pve-devel@lists.proxmox.com
Subject: Re: [PATCH pve-storage v1 09/54] plugin: adapt get_subdir_files helper of list_volumes API method
Date: Tue, 28 Apr 2026 17:07:19 +0200	[thread overview]
Message-ID: <ex6gdtlicrwrxpw6bmz5awhw5bnnt4g5uokuajq4fn3b2kkkd6@mjkvz3oppvzi> (raw)
In-Reply-To: <20260422111322.257380-10-m.carrara@proxmox.com>

Mostly fine.

On Wed, Apr 22, 2026 at 01:12:35PM +0200, Max R. Carrara wrote:
> Pull the body of the loop inside `get_subdir_files()` out into a
> closure and break up the if-elsif chain into more readable if-clauses.
> 
> Strip the vtype subdirectory from the beginning of the file paths
> being worked on inside that closure. This does not have an effect on
> how any of the subsequent regexes match on the path / file name,
> because they match at the end of a given path.
> 
> Additionally, take take the storage config hash `$scfg` instead of the
> volume type subdir `$path` as parameter. Passing `$scfg` along
> makes it possible to obtain the subdir for the given `$vtype` inside
> the helper directly instead of passing both the vtype and its
> associated subdirectory along.
> 
> All of these things make future changes easier to manage.
> 
> Signed-off-by: Max R. Carrara <m.carrara@proxmox.com>
> ---
>  src/PVE/Storage/Plugin.pm | 95 ++++++++++++++++++++++++++-------------
>  1 file changed, 64 insertions(+), 31 deletions(-)
> 
> diff --git a/src/PVE/Storage/Plugin.pm b/src/PVE/Storage/Plugin.pm
> index 2d76f452..c4eb6f18 100644
> --- a/src/PVE/Storage/Plugin.pm
> +++ b/src/PVE/Storage/Plugin.pm
> @@ -1673,37 +1673,54 @@ sub list_images {
> 
>  # $vtype = <iso|vztmpl|backup|snippets|import>
>  my sub get_subdir_files {
> -    my ($storeid, $path, $vtype, $vmid) = @_;
> +    my ($storeid, $scfg, $vtype, $vmid) = @_;
> +
> +    my $vtype_subdir = plugin_get_vtype_subdir($scfg, $vtype);
> 
>      my $res = [];
> 
> -    for my $filename (<$path/*>) {
> -        my $st = File::stat::stat($filename);
> +    my $get_subdir_file_info = sub {
> +        my ($path, $st) = @_;
> 
> -        next if (!$st || S_ISDIR($st->mode));
> -
> -        my $info;
> +        # Strip the vtype subdir from beginning of the current path
> +        # so that we don't have to take it into account when parsing the file name
> +        my $filename = $path;
> +        if ($filename !~ s!^\Q$vtype_subdir\E!!) {

It might be good to also look-ahead for a slash here. That is, add a
`(?=/)` after the `\E`. (Alternatively just do `\E/!/!` (to re-insert the
slash after the removal))

This won't change the result, but if custom subdirs match by prefix we
won't do unnecessary work. (eg. if we have `foo` for one vtype and
`foobar` for the other, `foo` will match the `foobar/...` paths)

(I know this later gets changed by the `Parse` module, but something
similar probably applies there.)

> +            return;
> +        }
> 
>          if ($vtype eq 'iso') {
> -            next if $filename !~ m!/([^/]+$PVE::Storage::ISO_EXT_RE_0)$!i;
> +            return if $filename !~ m!/([^/]+$PVE::Storage::ISO_EXT_RE_0)$!i;
> 
> -            $info = { volid => "$storeid:iso/$1", format => 'iso' };
> +            return {
> +                volid => "$storeid:iso/$1",
> +                format => 'iso',
> +            };
> +        }
> 
> -        } elsif ($vtype eq 'vztmpl') {
> -            next if $filename !~ m!/([^/]+$PVE::Storage::VZTMPL_EXT_RE_1)$!;
> +        if ($vtype eq 'vztmpl') {
> +            return if $filename !~ m!/([^/]+$PVE::Storage::VZTMPL_EXT_RE_1)$!;
> 
> -            $info = { volid => "$storeid:vztmpl/$1", format => $2 eq 'tar' ? $2 : "t$2" };
> +            return {
> +                volid => "$storeid:vztmpl/$1",
> +                format => $2 eq 'tar' ? $2 : "t$2",
> +            };
> +        }
> 
> -        } elsif ($vtype eq 'backup') {
> -            next if $filename !~ m!/([^/]+$PVE::Storage::BACKUP_EXT_RE_2)$!;
> -            my $original = $filename;
> +        if ($vtype eq 'backup') {
> +            return if $filename !~ m!/([^/]+$PVE::Storage::BACKUP_EXT_RE_2)$!;
> +
> +            my $original = $path;
>              my $format = $2;
>              $filename = $1;
> 
>              # only match for VMID now, to avoid false positives (VMID in parent directory name)
> -            next if defined($vmid) && $filename !~ m/\S+-$vmid-\S+/;
> +            return if defined($vmid) && $filename !~ m/\S+-$vmid-\S+/;
> 
> -            $info = { volid => "$storeid:backup/$filename", format => $format };
> +            my $info = {
> +                volid => "$storeid:backup/$filename",
> +                format => $format,
> +            };
> 
>              my $archive_info = eval { PVE::Storage::archive_info($filename) } // {};
> 
> @@ -1722,24 +1739,42 @@ my sub get_subdir_files {
>              }
> 
>              $info->{protected} = 1 if -e PVE::Storage::protection_file_path($original);
> -        } elsif ($vtype eq 'snippets') {
> 
> -            $info = {
> +            return $info;
> +        }
> +
> +        if ($vtype eq 'snippets') {
> +            return {
>                  volid => "$storeid:snippets/" . basename($filename),
>                  format => 'snippet',
>              };
> -        } elsif ($vtype eq 'import') {
> -            next
> +        }
> +
> +        if ($vtype eq 'import') {
> +            return
>                  if $filename !~
>                  m!/(${PVE::Storage::SAFE_CHAR_CLASS_RE}+$PVE::Storage::IMPORT_EXT_RE_1)$!i;
> 
> -            $info = { volid => "$storeid:import/$1", format => "$2" };
> +            return {
> +                volid => "$storeid:import/$1",
> +                format => "$2",
> +            };
>          }
> 
> -        $info->{size} = $st->size;
> -        $info->{ctime} //= $st->ctime;
> +        return;
> +    };
> 
> -        push @$res, $info;
> +    for my $path (<$vtype_subdir/*>) {
> +        my $st = File::stat::stat($path);
> +
> +        next if (!$st || S_ISDIR($st->mode));
> +
> +        if (defined(my $info = $get_subdir_file_info->($path, $st))) {
> +            $info->{size} = $st->size;
> +            $info->{ctime} //= $st->ctime;
> +
> +            push $res->@*, $info;
> +        }
>      }
> 
>      return $res;
> @@ -1758,18 +1793,16 @@ sub list_volumes {
>          if ($type eq 'images' || $type eq 'rootdir') {
>              $data = $class->list_images($storeid, $scfg, $vmid);
>          } elsif ($scfg->{path}) {
> -            my $path = plugin_get_vtype_subdir($scfg, $type);
> -
>              if ($type eq 'iso' && !defined($vmid)) {
> -                $data = get_subdir_files($storeid, $path, 'iso');
> +                $data = get_subdir_files($storeid, $scfg, 'iso', undef);
>              } elsif ($type eq 'vztmpl' && !defined($vmid)) {
> -                $data = get_subdir_files($storeid, $path, 'vztmpl');
> +                $data = get_subdir_files($storeid, $scfg, 'vztmpl', undef);
>              } elsif ($type eq 'backup') {
> -                $data = get_subdir_files($storeid, $path, 'backup', $vmid);
> +                $data = get_subdir_files($storeid, $scfg, 'backup', $vmid);
>              } elsif ($type eq 'snippets') {
> -                $data = get_subdir_files($storeid, $path, 'snippets');
> +                $data = get_subdir_files($storeid, $scfg, 'snippets', undef);
>              } elsif ($type eq 'import') {
> -                $data = get_subdir_files($storeid, $path, 'import');
> +                $data = get_subdir_files($storeid, $scfg, 'import', undef);
>              }
>          }
> 
> --
> 2.47.3
> 
> 
> 
> 
> 

-- 




  reply	other threads:[~2026-04-28 15:07 UTC|newest]

Thread overview: 63+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-04-22 11:12 [PATCH pve-storage, pve-manager v1 00/54] Fix #2884: Implement Subdirectory Scanning for Dir-Based Storage Types Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 01/54] test: plugin tests: run tests with at most 4 jobs Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 02/54] plugin, common: remove superfluous use of =pod command paragraph Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 03/54] common: add POD headings for groups of helpers Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 04/54] common: use Exporter module for PVE::Storage::Common Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 05/54] plugin: make get_subdir_files a proper subroutine and update style Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 06/54] plugin api: replace helpers w/ standalone subs, bump API version & age Max R. Carrara
2026-04-28 15:01   ` Wolfgang Bumiller
2026-04-22 11:12 ` [PATCH pve-storage v1 07/54] common: prevent autovivification in plugin_get_vtype_subdir helper Max R. Carrara
2026-04-28 15:02   ` Wolfgang Bumiller
2026-04-22 11:12 ` [PATCH pve-storage v1 08/54] plugin: break up needless if-elsif chain into separate if-blocks Max R. Carrara
2026-04-28 15:04   ` Wolfgang Bumiller
2026-04-22 11:12 ` [PATCH pve-storage v1 09/54] plugin: adapt get_subdir_files helper of list_volumes API method Max R. Carrara
2026-04-28 15:07   ` Wolfgang Bumiller [this message]
2026-04-22 11:12 ` [PATCH pve-storage v1 10/54] plugin: update code style of list_volumes plugin " Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 11/54] plugin: use closure for obtaining raw volume data in list_volumes Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 12/54] plugin: use closure for inner loop logic " Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 13/54] storage: update code style in function path_to_volume_id Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 14/54] storage: break up needless if-elsif chain in path_to_volume_id Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 15/54] storage: heave vtype file path parsing logic inside loop into helper Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 16/54] storage: clean up code that was moved into helper in path_to_volume_id Max R. Carrara
2026-04-28 15:08   ` Wolfgang Bumiller
2026-04-22 11:12 ` [PATCH pve-storage v1 17/54] api: status: move content type assert for up-/downloads into helper Max R. Carrara
2026-04-28 15:10   ` Wolfgang Bumiller
2026-04-22 11:12 ` [PATCH pve-storage v1 18/54] api: status: use helper from common module to get content directory Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 19/54] api: status: move up-/download file path parsing code into helper Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 20/54] api: status: simplify file content assertion logic for up-/download Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 21/54] test: guest import: add tests for PVE::GuestImport Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 22/54] tree-wide: introduce parsing module and replace usages of ISO_EXT_RE_0 Max R. Carrara
2026-04-28 15:20   ` Wolfgang Bumiller
2026-04-22 11:12 ` [PATCH pve-storage v1 23/54] common: test: set up parser testing code, add tests for 'iso' vtype Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 24/54] tree-wide: replace usages of VZTMPL_EXT_RE_1 with parsing functions Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 25/54] tree-wide: replace usages of BACKUP_EXT_RE_2 " Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 26/54] tree-wide: replace usages of inline regexes for snippets with parsers Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 27/54] tree-wide: partially replace usages of regexes for 'import' vtype Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 28/54] tree-wide: replace remaining " Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 29/54] plugin: simplify recently refactored logic in parse_volname method Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 30/54] plugin: simplify recently refactored logic in get_subdir_files helper Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 31/54] storage: simplify recently refactored logic in path_to_volume_id sub Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 32/54] api: status: simplify recently added parsing helper for file transfers Max R. Carrara
2026-04-22 11:12 ` [PATCH pve-storage v1 33/54] plugin: use parsing helper in parse_volume_id sub Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 34/54] test: list volumes: reorganize and modernize test running code Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 35/54] test: list volumes: fix broken test checking for vmlist modifications Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 36/54] test: list volumes: introduce new format for test cases Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 37/54] test: list volumes: remove legacy code and migrate cases to new format Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 38/54] test: list volumes: document behavior wrt. undeclared content types Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 39/54] plugin: correct comment in get_subdir_files helper Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 40/54] test: parse volname: modernize code Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 41/54] test: parse volname: adapt tests regarding 'import' volume type Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 42/54] test: parse volname: move VM disk test creation into separate block Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 43/54] test: parse volname: move backup file test creation into sep. block Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 44/54] test: parse volname: parameterize test case creation for some vtypes Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 45/54] test: volume id: modernize code Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 46/54] test: volume id: rename 'volname' test case parameter to 'file' Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 47/54] test: filesystem path: modernize code Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 48/54] fix #2884: implement nested subdir scanning and support 'iso' vtype Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 49/54] fix #2884: support nested subdir scanning for 'vztmpl' volume type Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 50/54] fix #2884: support nested subdir scanning for 'snippets' vtype Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 51/54] test: add more tests for 'import' vtype & guard against nested subdirs Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 52/54] test: add tests guarding against subdir scanning for vtypes Max R. Carrara
2026-04-22 11:13 ` [PATCH pve-storage v1 53/54] storage api: mark old public regexes for removal, bump APIVER & APIAGE Max R. Carrara
2026-04-28 15:22   ` Wolfgang Bumiller
2026-04-22 11:13 ` [PATCH pve-manager v1 54/54] fix #2884: ui: storage: add field for 'max-scan-depth' property Max R. Carrara

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=ex6gdtlicrwrxpw6bmz5awhw5bnnt4g5uokuajq4fn3b2kkkd6@mjkvz3oppvzi \
    --to=w.bumiller@proxmox.com \
    --cc=m.carrara@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