Skip to content

Commit

Permalink
fix(cohort-rights): use new rights system when fetching in background (
Browse files Browse the repository at this point in the history
  • Loading branch information
pl-buiquang authored Jul 17, 2023
2 parents 8993293 + b22fbbd commit dd5af9e
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 89 deletions.
2 changes: 2 additions & 0 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ build-job:
- develop
- /^feat_deploy_(\w*|\d*)/
- /^release_(\w*|\d*|-*|_*|\.*)+$/
- /^hotfix_(\w*|\d*|-*|_*|\.*)+$/

cache:
key: cohort360_nodemodules_cache
Expand Down Expand Up @@ -58,3 +59,4 @@ deploy-job:
- develop
- /^feat_deploy_(\w*|\d*)/
- /^release_(\w*|\d*|-*|_*|\.*)+$/
- /^hotfix_(\w*|\d*|-*|_*|\.*)+$/
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "cohort360_react",
"version": "2.22.0",
"version": "2.22.1",
"private": true,
"dependencies": {
"@apollo/client": "^3.7.10",
Expand Down
111 changes: 25 additions & 86 deletions src/state/exploredCohort.ts
Original file line number Diff line number Diff line change
Expand Up @@ -103,83 +103,11 @@ const fetchExploredCohort = createAsyncThunk<
default:
break
}
let cohort
const fetchCohortAction = dispatch(fetchExploredCohortInBackground({ context, id }))
if (shouldRefreshData || forceReload) {
switch (context) {
case 'cohort': {
if (id) {
cohort = (await services.cohorts.fetchCohort(id)) as ExploredCohortState
if (cohort) {
cohort.cohortId = id
const cohortRights = await services.cohorts.fetchCohortsRights([{ fhir_group_id: id }])
if (cohortRights?.[0].rights) {
if (
cohortRights?.[0]?.rights?.read_patient_pseudo === false &&
cohortRights?.[0]?.rights?.read_patient_nomi === false
) {
throw new Error("You don't have any rights on this cohort")
} else {
cohort.canMakeExport = !!ODD_EXPORT ? cohortRights?.[0]?.rights?.export_csv_nomi : false

cohort.deidentifiedBoolean = cohortRights?.[0]?.rights?.read_patient_pseudo
? cohortRights?.[0]?.rights?.read_patient_nomi
? false
: true
: false
}
} else {
throw new Error("You don't have any rights on this cohort")
}
}
}
break
}
case 'patients': {
cohort = (await services.patients.fetchMyPatients()) as ExploredCohortState
const perimeters = await services.perimeters.getPerimeters()
if (cohort) {
cohort.name = '-'
cohort.description = ''
cohort.requestId = ''
cohort.favorite = false
cohort.uuid = ''
cohort.canMakeExport = false
cohort.deidentifiedBoolean = perimeters.some(
(perimeter) => servicesPerimeters.getAccessFromScope(perimeter) === 'Pseudonymisé'
)
}
break
}
case 'perimeters': {
if (id) {
cohort = (await services.perimeters.fetchPerimetersInfos(id)) as ExploredCohortState
if (cohort) {
cohort.name = '-'
cohort.description = ''
cohort.requestId = ''
cohort.favorite = false
cohort.uuid = ''
cohort.canMakeExport = false
cohort.deidentifiedBoolean =
cohort.cohort && cohort.cohort && Array.isArray(cohort.cohort)
? cohort.cohort.some((cohort) =>
cohort.extension?.some(
({ url, valueString }) => url === 'READ_ACCESS' && valueString === 'DATA_PSEUDOANONYMISED'
)
) ?? true
: true
}
}
break
}

default:
break
}
} else {
dispatch(fetchExploredCohortInBackground({ context, id }))
return await fetchCohortAction.unwrap()
}
return cohort ?? state.exploredCohort
return state.exploredCohort
})

const fetchExploredCohortInBackground = createAsyncThunk<
Expand All @@ -195,18 +123,26 @@ const fetchExploredCohortInBackground = createAsyncThunk<
if (id) {
cohort = (await services.cohorts.fetchCohort(id)) as ExploredCohortState
if (cohort) {
cohort.cohortId = id
const cohortRights = await services.cohorts.fetchCohortsRights([{ fhir_group_id: id }])
const cohortRight = cohortRights && cohortRights[0]
cohort.canMakeExport =
(!!ODD_EXPORT &&
cohortRight?.extension?.some(
({ url, valueString }) => url === 'EXPORT_ACCESS' && valueString === 'DATA_NOMINATIVE'
)) ??
false
cohort.deidentifiedBoolean =
cohortRight?.extension?.some(
({ url, valueString }) => url === 'READ_ACCESS' && valueString === 'DATA_PSEUDOANONYMISED'
) ?? true
if (cohortRights?.[0].rights) {
if (
cohortRights?.[0]?.rights?.read_patient_pseudo === false &&
cohortRights?.[0]?.rights?.read_patient_nomi === false
) {
throw new Error("You don't have any rights on this cohort")
} else {
cohort.canMakeExport = !!ODD_EXPORT ? cohortRights?.[0]?.rights?.export_csv_nomi : false

cohort.deidentifiedBoolean = cohortRights?.[0]?.rights?.read_patient_pseudo
? cohortRights?.[0]?.rights?.read_patient_nomi
? false
: true
: false
}
} else {
throw new Error("You don't have any rights on this cohort")
}
}
}
break
Expand Down Expand Up @@ -249,6 +185,9 @@ const fetchExploredCohortInBackground = createAsyncThunk<
}
break
}

default:
break
}
return cohort ?? state.exploredCohort
})
Expand Down

0 comments on commit dd5af9e

Please sign in to comment.