From 312499e751e57cd426e3078d7d823e55958c69c2 Mon Sep 17 00:00:00 2001 From: Alexey Kirichun Date: Tue, 7 Jan 2025 17:44:28 +0000 Subject: [PATCH] Org-wide and filtered access to cloud integrations (#831) --- encord/orm/cloud_integration.py | 8 +++++++- encord/user_client.py | 30 +++++++++++++++++++++++++++--- 2 files changed, 34 insertions(+), 4 deletions(-) diff --git a/encord/orm/cloud_integration.py b/encord/orm/cloud_integration.py index b2510390a..05eb4c4ff 100644 --- a/encord/orm/cloud_integration.py +++ b/encord/orm/cloud_integration.py @@ -1,4 +1,4 @@ -from typing import List +from typing import List, Optional from uuid import UUID from encord.orm.base_dto import BaseDTO @@ -16,3 +16,9 @@ class CloudIntegrationV2(BaseDTO): class GetCloudIntegrationsResponse(BaseDTO): result: List[CloudIntegrationV2] + + +class GetCloudIntegrationsParams(BaseDTO): + filter_integration_uuids: Optional[List[UUID]] = None + filter_integration_titles: Optional[List[str]] = None + include_org_access: bool = False diff --git a/encord/user_client.py b/encord/user_client.py index 6b20b11da..878af7e63 100644 --- a/encord/user_client.py +++ b/encord/user_client.py @@ -52,7 +52,7 @@ ) from encord.ontology import Ontology from encord.orm.client_metadata_schema import ClientMetadataSchemaTypes -from encord.orm.cloud_integration import CloudIntegration, GetCloudIntegrationsResponse +from encord.orm.cloud_integration import CloudIntegration, GetCloudIntegrationsParams, GetCloudIntegrationsResponse from encord.orm.dataset import ( DEFAULT_DATASET_ACCESS_SETTINGS, CreateDatasetPayload, @@ -865,7 +865,27 @@ def __upload_cvat_images( return dataset_hash, image_title_to_image - def get_cloud_integrations(self) -> List[CloudIntegration]: + def get_cloud_integrations( + self, + filter_integration_uuids: Optional[Union[List[UUID], List[str], List[Union[UUID, str]]]] = None, + filter_integration_titles: Optional[List[str]] = None, + include_org_access: bool = False, + ) -> List[CloudIntegration]: + """ + List either all (if called with no arguments) or matching cloud integrations the user has access to. + + Args: + filter_integration_uuids: optional list of integration UUIDs to include. + filter_integration_titles: optional list of integration titles to include (exact match). + include_org_access: if set to true and the calling user is the organization admin, the + method will return all cloud integrations in the organization. + + If `filter_integration_uuids` and `filter_integration_titles` are both provided, the method will return + the integrations that match both of the filters. + """ + + if filter_integration_uuids is not None: + filter_integration_uuids = [UUID(x) if isinstance(x, str) else x for x in filter_integration_uuids] return [ CloudIntegration( id=str(x.integration_uuid), @@ -873,7 +893,11 @@ def get_cloud_integrations(self) -> List[CloudIntegration]: ) for x in self._api_client.get( "cloud-integrations", - params=None, + params=GetCloudIntegrationsParams( + filter_integration_uuids=filter_integration_uuids, + filter_integration_titles=filter_integration_titles, + include_org_access=include_org_access, + ), result_type=GetCloudIntegrationsResponse, ).result ]