[pve-devel] [PATCH v6 proxmox-backup 5/6] add upgrade_repositories call
Fabian Grünbichler
f.gruenbichler at proxmox.com
Fri Jun 18 10:21:02 CEST 2021
On June 11, 2021 1:44 pm, Fabian Ebner wrote:
> Signed-off-by: Fabian Ebner <f.ebner at proxmox.com>
> ---
>
> Note that the release_upgrade function is available with proxmox-apt 0.1.1
> (but disabled) so this can be applied to the master branch as well.
>
> Changes from v5:
> * limit to Superuser instead of SYS_MODIFY
> * use new/renamed release_upgrade function from library.
> * error if not all files could be parsed
not that important for the current use case, but.. we might want to add
a lockfile for reading/writing the repo files? if we ever add
full-fledged editing capabilities.. it's also reading/parsing multiple
files, so a write might intermingle with that and cause inconsistent
reads (first few files old, latter files updated)..
>
> src/api2/node/apt.rs | 53 ++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 53 insertions(+)
>
> diff --git a/src/api2/node/apt.rs b/src/api2/node/apt.rs
> index deb481a7..861bc32b 100644
> --- a/src/api2/node/apt.rs
> +++ b/src/api2/node/apt.rs
> @@ -509,6 +509,58 @@ pub fn get_repositories() -> Result<Value, Error> {
> }))
> }
>
> +#[api(
> + input: {
> + properties: {
> + node: {
> + schema: NODE_SCHEMA,
> + },
> + digest: {
> + schema: PROXMOX_CONFIG_DIGEST_SCHEMA,
> + optional: true,
> + },
> + },
> + },
> + protected: true,
> + access: {
> + permission: &Permission::Superuser,
> + },
> +)]
> +/// Upgrade the repository configuration for the next major release.
> +pub fn upgrade_repositories(digest: Option<String>) -> Result<(), Error> {
> + let (mut files, errors) = proxmox_apt::repositories::repositories()?;
> +
> + if files.len() == 0 {
> + bail!("no APT repository files could be parsed!");
> + }
> +
> + if errors.len() > 0 {
> + let message = errors.iter().fold(
> + "Problem parsing file(s):".to_string(),
> + |message, error| format!("{}\n{}", message, error),
> + );
> + bail!(message);
> + }
> +
> + if let Some(digest) = digest {
> + let expected_digest = proxmox::tools::hex_to_digest(&digest)?;
> + let current_digest = proxmox_apt::repositories::common_digest(&files);
> + crate::tools::detect_modified_configuration_file(¤t_digest, &expected_digest)?;
> + }
> +
> + proxmox_apt::repositories::release_upgrade(&mut files)?;
> +
> + if let Err(errors) = proxmox_apt::repositories::write_repositories(&files) {
> + let message = errors.iter().fold(
> + "Problem writing file(s):".to_string(),
> + |message, error| format!("{}\n{}", message, error),
> + );
> + bail!(message);
> + }
> +
> + Ok(())
> +}
> +
> const SUBDIRS: SubdirMap = &[
> ("changelog", &Router::new().get(&API_METHOD_APT_GET_CHANGELOG)),
> ("checkrepositories", &Router::new().get(&API_METHOD_CHECK_REPOSITORIES)),
> @@ -517,6 +569,7 @@ const SUBDIRS: SubdirMap = &[
> .get(&API_METHOD_APT_UPDATE_AVAILABLE)
> .post(&API_METHOD_APT_UPDATE_DATABASE)
> ),
> + ("upgraderepositories", &Router::new().put(&API_METHOD_UPGRADE_REPOSITORIES)),
> ("versions", &Router::new().get(&API_METHOD_GET_VERSIONS)),
> ];
>
> --
> 2.20.1
>
>
>
> _______________________________________________
> pve-devel mailing list
> pve-devel at lists.proxmox.com
> https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel
>
>
>
More information about the pve-devel
mailing list