[pdm-devel] [PATCH datacenter-manager v2 08/12] api: resources: status: add support for view-filter parameter

Dominik Csapak d.csapak at proxmox.com
Wed Nov 5 11:08:10 CET 2025


Reviewed-by: Dominik Csapak <d.csapak at proxmox.com>

On 11/3/25 1:35 PM, Lukas Wagner wrote:
> A view filter allows one to get filtered subset of all resources, based
> on filter rules defined in a config file. View filters integrate with
> the permission system - if a user has permissions on
> /view/{view-filter-id}, then these privileges are transitively applied
> to all resources which are matched by the rules. All other permission
> checks are replaced if requesting data through a view filter.
> 
> Signed-off-by: Lukas Wagner <l.wagner at proxmox.com>
> ---
>   server/src/api/resources.rs | 7 ++++++-
>   1 file changed, 6 insertions(+), 1 deletion(-)
> 
> diff --git a/server/src/api/resources.rs b/server/src/api/resources.rs
> index ea76d81b..f718ce3e 100644
> --- a/server/src/api/resources.rs
> +++ b/server/src/api/resources.rs
> @@ -429,6 +429,10 @@ pub(crate) async fn get_resources_impl(
>                   default: 30,
>                   optional: true,
>               },
> +            "view-filter": {
> +                schema: VIEW_FILTER_ID_SCHEMA,
> +                optional: true,
> +            },
>           }
>       },
>       returns: {
> @@ -442,10 +446,11 @@ pub(crate) async fn get_resources_impl(
>   /// Return the amount of configured/seen resources by type
>   pub async fn get_status(
>       max_age: u64,
> +    view_filter: Option<String>,
>       rpcenv: &mut dyn RpcEnvironment,
>   ) -> Result<ResourcesStatus, Error> {
>       let remotes_with_resources =
> -        get_resources_impl(max_age, None, None, None, Some(rpcenv)).await?;
> +        get_resources_impl(max_age, None, None, view_filter.as_deref(), Some(rpcenv)).await?;
>       let mut counts = ResourcesStatus::default();
>       for remote_with_resources in remotes_with_resources {
>           if let Some(err) = remote_with_resources.error {





More information about the pdm-devel mailing list