From 31763fbc3dba2ace9dd74bd3ed9ef6acb04fec11 Mon Sep 17 00:00:00 2001 From: Brendan Schell Date: Wed, 24 Jul 2024 15:06:44 -0400 Subject: [PATCH 1/3] add private data method and update asset html repr to show private access message instead of error --- .../syft/src/syft/service/dataset/dataset.py | 47 ++++++++++++------- 1 file changed, 29 insertions(+), 18 deletions(-) diff --git a/packages/syft/src/syft/service/dataset/dataset.py b/packages/syft/src/syft/service/dataset/dataset.py index 10b5be04ca9..97dcfa4f306 100644 --- a/packages/syft/src/syft/service/dataset/dataset.py +++ b/packages/syft/src/syft/service/dataset/dataset.py @@ -144,14 +144,21 @@ def _repr_html_(self) -> Any: else "" ) - if isinstance(self.data, ActionObject): - data_table_line = itables.to_html_datatable( - df=self.data.syft_action_data, css=itables_css - ) - elif isinstance(self.data, pd.DataFrame): - data_table_line = itables.to_html_datatable(df=self.data, css=itables_css) + private_data_res = self._private_data() + if private_data_res.is_err(): + data_table_line = private_data_res.err_value else: - data_table_line = self.data + private_data_obj = private_data_res.ok_value + if isinstance(private_data_obj, ActionObject): + data_table_line = itables.to_html_datatable( + df=self.data.syft_action_data, css=itables_css + ) + elif isinstance(private_data_obj, pd.DataFrame): + data_table_line = itables.to_html_datatable( + df=private_data_obj, css=itables_css + ) + else: + data_table_line = private_data_res.ok_value if isinstance(self.mock, ActionObject): mock_table_line = itables.to_html_datatable( @@ -176,7 +183,7 @@ def _repr_html_(self) -> Any:

{self.name}

-

{self.description}

+

{self.description or ""}

Asset ID: {self.id}

Action Object ID: {self.action_id}

{uploaded_by_line} @@ -278,25 +285,29 @@ def has_permission(self, data_result: Any) -> bool: and data_result.endswith("denied") ) - @property - def data(self) -> Any: - # relative - + def _private_data(self) -> Result[Any, str]: api = APIRegistry.api_for( server_uid=self.server_uid, user_verify_key=self.syft_client_verify_key, ) if api is None or api.services is None: - return None + return Ok(None) res = api.services.action.get(self.action_id) if self.has_permission(res): - return res.syft_action_data + return Ok(res.syft_action_data) else: - warning = SyftError( - message="You do not have permission to access private data." - ) - display(warning, clear=True) + return Err("You do not have permission to access private data.") + + @property + def data(self) -> Any: + # relative + private_data_or_error = self._private_data() + + if private_data_or_error.is_err(): + display(SyftError(message=private_data_or_error.err_value), clear=True) return None + else: + return private_data_or_error.ok_value def _is_action_data_empty(obj: Any) -> bool: From 3a823c5dd1b378870a49d689c3e20cadd36984c7 Mon Sep 17 00:00:00 2001 From: Brendan Schell Date: Wed, 24 Jul 2024 15:13:09 -0400 Subject: [PATCH 2/3] add docstring --- packages/syft/src/syft/service/dataset/dataset.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/packages/syft/src/syft/service/dataset/dataset.py b/packages/syft/src/syft/service/dataset/dataset.py index 97dcfa4f306..279347d6390 100644 --- a/packages/syft/src/syft/service/dataset/dataset.py +++ b/packages/syft/src/syft/service/dataset/dataset.py @@ -286,6 +286,13 @@ def has_permission(self, data_result: Any) -> bool: ) def _private_data(self) -> Result[Any, str]: + """ + Retrieves the private data associated with this asset. + + Returns: + Result[Any, str]: A Result object containing the private data if the user has permission (or None if no API is registered), + otherwise an Err object with the message "You do not have permission to access private data." + """ api = APIRegistry.api_for( server_uid=self.server_uid, user_verify_key=self.syft_client_verify_key, From a98af5ffb24e60c5cf5e22d3dfefc93e0811298e Mon Sep 17 00:00:00 2001 From: Brendan Schell Date: Wed, 24 Jul 2024 15:38:57 -0400 Subject: [PATCH 3/3] shorten docstring for linter --- packages/syft/src/syft/service/dataset/dataset.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/syft/src/syft/service/dataset/dataset.py b/packages/syft/src/syft/service/dataset/dataset.py index 279347d6390..5b13e108435 100644 --- a/packages/syft/src/syft/service/dataset/dataset.py +++ b/packages/syft/src/syft/service/dataset/dataset.py @@ -290,7 +290,7 @@ def _private_data(self) -> Result[Any, str]: Retrieves the private data associated with this asset. Returns: - Result[Any, str]: A Result object containing the private data if the user has permission (or None if no API is registered), + Result[Any, str]: A Result object containing the private data if the user has permission otherwise an Err object with the message "You do not have permission to access private data." """ api = APIRegistry.api_for(