From 31f9aa13d7ec901e594b20be4c431ba8ec511c90 Mon Sep 17 00:00:00 2001 From: dlpzx Date: Wed, 4 Dec 2024 09:58:26 +0100 Subject: [PATCH] Implemented restricted information for Dashboards. Fix FE visisbility and tests --- backend/dataall/modules/dashboards/api/resolvers.py | 6 ++++++ backend/dataall/modules/dashboards/api/types.py | 13 +++++++++++-- .../dashboards/services/dashboard_service.py | 8 ++++++-- .../Dashboards/components/DashboardListItem.js | 4 ++-- .../Dashboards/components/DashboardOverview.js | 2 +- .../Dashboards/components/DashboardViewer.js | 8 +++++++- .../src/modules/Dashboards/services/getDashboard.js | 5 ++++- .../modules/Dashboards/services/searchDashboards.js | 6 ++++-- .../src/modules/Dashboards/views/DashboardView.js | 4 ++-- tests/modules/dashboards/test_dashboards.py | 1 - .../integration_tests/modules/dashboards/queries.py | 11 ++++++++--- 11 files changed, 51 insertions(+), 17 deletions(-) diff --git a/backend/dataall/modules/dashboards/api/resolvers.py b/backend/dataall/modules/dashboards/api/resolvers.py index 7a9bbe133..8f703419d 100644 --- a/backend/dataall/modules/dashboards/api/resolvers.py +++ b/backend/dataall/modules/dashboards/api/resolvers.py @@ -48,6 +48,12 @@ def get_dashboard(context: Context, source, dashboardUri: str = None): return DashboardService.get_dashboard(uri=dashboardUri) +def get_dashboard_restricted_information(context: Context, source: Dashboard): + if not source: + return None + return DashboardService.get_dashboard_restricted_information(uri=source.dashboardUri, dashboard=source) + + def resolve_user_role(context: Context, source: Dashboard): if context.username and source.owner == context.username: return DashboardRole.Creator.value diff --git a/backend/dataall/modules/dashboards/api/types.py b/backend/dataall/modules/dashboards/api/types.py index 857cf9333..9e5405891 100644 --- a/backend/dataall/modules/dashboards/api/types.py +++ b/backend/dataall/modules/dashboards/api/types.py @@ -1,7 +1,7 @@ from dataall.base.api import gql from dataall.modules.dashboards.api.resolvers import ( DashboardRole, - get_dashboard_organization, + get_dashboard_restricted_information, resolve_glossary_terms, resolve_upvotes, resolve_user_role, @@ -9,6 +9,11 @@ from dataall.core.environment.api.resolvers import resolve_environment +DashboardRestrictedInformation = gql.ObjectType( + name='DashboardRestrictedInformation', + fields=[gql.Field('AwsAccountId', type=gql.String), gql.Field('region', type=gql.String)], +) + Dashboard = gql.ObjectType( name='Dashboard', fields=[ @@ -19,10 +24,14 @@ gql.Field('DashboardId', type=gql.String), gql.Field('tags', type=gql.ArrayType(gql.String)), gql.Field('created', type=gql.String), - gql.Field('AwsAccountId', type=gql.String), gql.Field('updated', type=gql.String), gql.Field('owner', type=gql.String), gql.Field('SamlGroupName', type=gql.String), + gql.Field( + 'restricted', + type=DashboardRestrictedInformation, + resolver=get_dashboard_restricted_information, + ), gql.Field( 'environment', type=gql.Ref('EnvironmentSimplified'), diff --git a/backend/dataall/modules/dashboards/services/dashboard_service.py b/backend/dataall/modules/dashboards/services/dashboard_service.py index 34d6c3a34..a70a40fc5 100644 --- a/backend/dataall/modules/dashboards/services/dashboard_service.py +++ b/backend/dataall/modules/dashboards/services/dashboard_service.py @@ -6,7 +6,7 @@ from dataall.core.permissions.services.tenant_policy_service import TenantPolicyService from dataall.modules.catalog.db.glossary_repositories import GlossaryRepository from dataall.modules.vote.db.vote_repositories import VoteRepository -from dataall.base.db.exceptions import UnauthorizedOperation +from dataall.base.db.exceptions import UnauthorizedOperation, ResourceUnauthorized from dataall.modules.dashboards.db.dashboard_repositories import DashboardRepository from dataall.modules.dashboards.db.dashboard_models import Dashboard from dataall.modules.dashboards.aws.dashboard_quicksight_client import DashboardQuicksightClient @@ -25,11 +25,15 @@ class DashboardService: """Service that serves request related to dashboard""" @staticmethod - @ResourcePolicyService.has_resource_permission(GET_DASHBOARD) def get_dashboard(uri: str) -> Dashboard: with get_context().db_engine.scoped_session() as session: return DashboardRepository.get_dashboard_by_uri(session, uri) + @staticmethod + @ResourcePolicyService.has_resource_permission(GET_DASHBOARD) + def get_dashboard_restricted_information(uri: str, dashboard: Dashboard): + return dashboard + @staticmethod @TenantPolicyService.has_tenant_permission(MANAGE_DASHBOARDS) @ResourcePolicyService.has_resource_permission(CREATE_DASHBOARD) diff --git a/frontend/src/modules/Dashboards/components/DashboardListItem.js b/frontend/src/modules/Dashboards/components/DashboardListItem.js index 17f40b9bd..810e642d9 100644 --- a/frontend/src/modules/Dashboards/components/DashboardListItem.js +++ b/frontend/src/modules/Dashboards/components/DashboardListItem.js @@ -159,7 +159,7 @@ export const DashboardListItem = (props) => { - {dashboard.AwsAccountId} + {dashboard.restricted?.AwsAccountId || 'UNAUTHORIZED_INFO'} @@ -178,7 +178,7 @@ export const DashboardListItem = (props) => { - {dashboard.environment.region} + {dashboard.restricted?.region || 'UNAUTHORIZED_INFO'} diff --git a/frontend/src/modules/Dashboards/components/DashboardOverview.js b/frontend/src/modules/Dashboards/components/DashboardOverview.js index 74953923e..bec9448fc 100644 --- a/frontend/src/modules/Dashboards/components/DashboardOverview.js +++ b/frontend/src/modules/Dashboards/components/DashboardOverview.js @@ -30,7 +30,7 @@ export const DashboardOverview = (props) => { { const client = useClient(); const [dashboardRef] = useState(createRef()); const [sessionUrl, setSessionUrl] = useState(null); + const [loading, setLoading] = useState(false); const fetchReaderSessionUrl = useCallback(async () => { + setLoading(true); const response = await client.query( getReaderSession(dashboard.dashboardUri) ); @@ -40,6 +42,7 @@ export const DashboardViewer = ({ dashboard }) => { } else { dispatch({ type: SET_ERROR, error: response.errors[0].message }); } + setLoading(false); }, [client, dispatch, dashboard, dashboardRef]); useEffect(() => { @@ -50,7 +53,10 @@ export const DashboardViewer = ({ dashboard }) => { } }, [client, dispatch, fetchReaderSessionUrl, sessionUrl]); - if (!sessionUrl) { + if (!sessionUrl && !loading) { + return null; + } + if (loading) { return ; } return ( diff --git a/frontend/src/modules/Dashboards/services/getDashboard.js b/frontend/src/modules/Dashboards/services/getDashboard.js index 2c1148d85..5a17d6f64 100644 --- a/frontend/src/modules/Dashboards/services/getDashboard.js +++ b/frontend/src/modules/Dashboards/services/getDashboard.js @@ -18,10 +18,13 @@ export const getDashboard = (dashboardUri) => ({ userRoleForDashboard DashboardId upvotes + restricted { + region + AwsAccountId + } environment { environmentUri label - region organization { organizationUri label diff --git a/frontend/src/modules/Dashboards/services/searchDashboards.js b/frontend/src/modules/Dashboards/services/searchDashboards.js index c3741f5d5..b149237a8 100644 --- a/frontend/src/modules/Dashboards/services/searchDashboards.js +++ b/frontend/src/modules/Dashboards/services/searchDashboards.js @@ -17,7 +17,10 @@ export const searchDashboards = (filter) => ({ name owner SamlGroupName - AwsAccountId + restricted { + region + AwsAccountId + } description label created @@ -27,7 +30,6 @@ export const searchDashboards = (filter) => ({ environment { environmentUri label - region } } } diff --git a/frontend/src/modules/Dashboards/views/DashboardView.js b/frontend/src/modules/Dashboards/views/DashboardView.js index d093546e7..0ebf5f742 100644 --- a/frontend/src/modules/Dashboards/views/DashboardView.js +++ b/frontend/src/modules/Dashboards/views/DashboardView.js @@ -47,7 +47,7 @@ const DashboardView = () => { const client = useClient(); const { enqueueSnackbar } = useSnackbar(); const navigate = useNavigate(); - const [currentTab, setCurrentTab] = useState('viewer'); + const [currentTab, setCurrentTab] = useState('overview'); const [loading, setLoading] = useState(true); const [isUpVoted, setIsUpVoted] = useState(false); const [upVotes, setUpvotes] = useState(null); @@ -119,7 +119,7 @@ const DashboardView = () => { const fetchItem = useCallback(async () => { setLoading(true); const response = await client.query(getDashboard(params.uri)); - if (!response.errors) { + if (response.data.getDashboard !== null) { setDashboard(response.data.getDashboard); setUpvotes(response.data.getDashboard.upvotes); setIsAdmin( diff --git a/tests/modules/dashboards/test_dashboards.py b/tests/modules/dashboards/test_dashboards.py index fe1f1054a..9b66acdfe 100644 --- a/tests/modules/dashboards/test_dashboards.py +++ b/tests/modules/dashboards/test_dashboards.py @@ -82,7 +82,6 @@ def test_get_dashboard(client, env_fixture, db, dashboard, group): environment { environmentUri label - region organization { organizationUri label diff --git a/tests_new/integration_tests/modules/dashboards/queries.py b/tests_new/integration_tests/modules/dashboards/queries.py index 047fb7de3..4d167a920 100644 --- a/tests_new/integration_tests/modules/dashboards/queries.py +++ b/tests_new/integration_tests/modules/dashboards/queries.py @@ -25,16 +25,18 @@ def search_dashboards(client, filter): owner SamlGroupName description - AwsAccountId label created tags userRoleForDashboard upvotes + restricted { + region + AwsAccountId + } environment { environmentUri label - region organization { organizationUri label @@ -65,10 +67,13 @@ def get_dashboard(client, dashboardUri): created tags userRoleForDashboard + restricted { + region + AwsAccountId + } environment { environmentUri label - region organization { organizationUri label