mirror of
git://git.proxmox.com/git/proxmox-backup.git
synced 2025-01-18 06:03:59 +03:00
6771869cc1
Instead of using the plain String or slices of it for archive names, use the dedicated api type and its methods to parse and check for archive type based on archive filename extension. Thereby, keeping the checks and mappings in the api type and resticting function parameters by the narrower wrapper type to reduce potential misuse. Further, instead of declaring and using the archive name constants throughout the codebase, use the `BackupArchiveName` helpers to generate the archive names for manifest, client logs and encryption keys. This allows for easy archive name comparisons using the same `BackupArchiveName` type, at the cost of some extra allocations and avoids the currently present double constant declaration of `CATALOG_NAME`. A positive ergonomic side effect of this is that commands now also accept the archive type extension optionally, when passing the archive name. E.g. ``` proxmox-backup-client restore <snapshot> <name>.pxar.didx <target> ``` is equal to ``` proxmox-backup-client restore <snapshot> <name>.pxar <target> ``` The previously default mapping of any archive name extension to a blob has been dropped in favor of consistent mapping by the api type helpers. Signed-off-by: Christian Ebner <c.ebner@proxmox.com> FG: use LazyLock for constant archive names FG: add missing import Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>