[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