Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FM2-130:Adding support for the FHIR Media resource #328

Draft
wants to merge 31 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
d785e97
FM2-130:Adding support for the FHIR Media resource
tendomart Feb 15, 2021
68e5bd4
Refining Media Complex Obs Handler
tendomart Feb 16, 2021
d508846
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Feb 16, 2021
39be2b1
Adding Search params , Service and Translator Layers
tendomart Feb 16, 2021
0aca54d
Doing more refining
tendomart Feb 18, 2021
b28be07
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Feb 18, 2021
53d8ff7
Implementing fhir media translator
tendomart Mar 30, 2021
ba5c351
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Mar 30, 2021
027f483
Doing cleaning
tendomart Mar 30, 2021
9fda48d
Removing duplicate code
tendomart Mar 30, 2021
5041fa2
Doing more refactorings and adding unit tests for Tranlator , service…
tendomart Mar 31, 2021
f4a4bed
Fine tuning Media search params doing other changes
tendomart Apr 1, 2021
1ba904b
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Apr 1, 2021
dd4b80e
Doing more refactoring
tendomart Apr 6, 2021
da7d841
Removing commented out lines
tendomart Apr 6, 2021
aea79f8
Doing more rectifications
tendomart Apr 7, 2021
b26adb3
Adding search params and FhirMediaDaoImplTest
tendomart Apr 12, 2021
d2625e6
Adding Media element translators
tendomart Apr 14, 2021
74103bc
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Apr 14, 2021
119fb76
Deleting unnecessary Media Translators
tendomart Apr 15, 2021
619d08b
Refining Translators
tendomart Apr 28, 2021
ee13f88
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Apr 28, 2021
86e2ca9
Refining MediaContentTranslator and Accompanying tests
tendomart Apr 30, 2021
a8c2605
Refactoring translators
tendomart May 5, 2021
3933575
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart May 5, 2021
93f2f45
Rectifying project build failure
tendomart May 7, 2021
9c843e8
Doing more fixes
tendomart May 27, 2021
bb9dbdf
Dealing with FhirMediaDaoImplTest failing tests
tendomart Jun 4, 2021
b6888be
Making FhirMediaDaoImpl CRUD methods work
tendomart Jun 7, 2021
6d2e407
Merge branch 'master' of https://github.com/openmrs/openmrs-module-fh…
tendomart Jun 7, 2021
5c79a15
Removing redundant code
tendomart Jun 7, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 23 additions & 0 deletions api/src/main/java/org/openmrs/module/fhir2/FhirConstants.java
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ public class FhirConstants {

public static final String ENCOUNTER_CLASS_VALUE_SET_URI = HL7_FHIR_CODE_SYSTEM_PREFIX + "/v3-ActCode";

public static final String MEDIA_CREATED_DATE_TIME = "media.created.date.time";

@Value("${project.version}")
public static String OPENMRS_FHIR_SERVER_VERSION;

Expand Down Expand Up @@ -296,4 +298,25 @@ public class FhirConstants {
public static final String REVERSE_INCLUDE_SEARCH_HANDLER = "_revinclude.search.handler";

public static final String CONDITION_OBSERVATION_CONCEPT_UUID = "1284AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA";

public static final String FHIR_MEDIA = "media";

public static final String MEDIA_STATUS = "media.status";

public static final String MEDIA_TYPE = "media.type";

public static final String MEDIA_SUBJECT = "media.subject";

public static final String MEDIA_ENCOUNTER_REFERENCE = "media.encounter.reference";

public static final String MEDIA_CREATED_ON = "media.created.on";

public static final String MEDIA_CONTENT_TYPE = "media.content.type";

public static final String CONTENT_DATA = "content.data";

public static final String CONTENT_TITLE = "content.title";

public static final String CONTENT_DATE_OF_CREATION = "content.creation";

tendomart marked this conversation as resolved.
Show resolved Hide resolved
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.module.fhir2.api;

import javax.annotation.Nonnull;

import java.util.HashSet;

import ca.uhn.fhir.model.api.Include;
import ca.uhn.fhir.rest.api.SortSpec;
import ca.uhn.fhir.rest.api.server.IBundleProvider;
import ca.uhn.fhir.rest.param.DateRangeParam;
import ca.uhn.fhir.rest.param.ReferenceAndListParam;
import ca.uhn.fhir.rest.param.StringAndListParam;
import ca.uhn.fhir.rest.param.TokenAndListParam;
import org.hl7.fhir.r4.model.Observation;

public interface FhirMediaService extends FhirService<Observation> {

IBundleProvider searchForMedia(TokenAndListParam status, TokenAndListParam type, ReferenceAndListParam subject,
ReferenceAndListParam encounterReference, DateRangeParam createdDateTime, TokenAndListParam contentType,
StringAndListParam contentDataType, StringAndListParam contentTitle, DateRangeParam contentCreated,
DateRangeParam lastUpdated, HashSet<Include> includes, HashSet<Include> revIncludes, SortSpec sort);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
/*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.module.fhir2.api.dao;

import javax.annotation.Nonnull;

import java.util.List;

import org.openmrs.Obs;
import org.openmrs.annotation.Authorized;
import org.openmrs.module.fhir2.api.search.param.SearchParameterMap;
import org.openmrs.util.PrivilegeConstants;

public interface FhirMediaDao extends FhirDao<Obs> {

@Override
@Authorized(PrivilegeConstants.GET_OBS)
Obs get(@Nonnull String uuid);

@Override
@Authorized(PrivilegeConstants.ADD_OBS)
Obs createOrUpdate(@Nonnull Obs newEntry);

@Override
@Authorized(PrivilegeConstants.DELETE_OBS)
Obs delete(@Nonnull String uuid);

@Override
@Authorized(PrivilegeConstants.GET_OBS)
List<String> getSearchResultUuids(@Nonnull SearchParameterMap theParams);

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
/*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.module.fhir2.api.dao.impl;

import ca.uhn.fhir.rest.param.DateRangeParam;
import ca.uhn.fhir.rest.param.ReferenceAndListParam;
import ca.uhn.fhir.rest.param.StringAndListParam;
import ca.uhn.fhir.rest.param.TokenAndListParam;
import lombok.AccessLevel;
import lombok.Setter;
import org.hibernate.Criteria;
import org.openmrs.Obs;
import org.openmrs.module.fhir2.FhirConstants;
import org.openmrs.module.fhir2.api.dao.FhirMediaDao;
import org.openmrs.module.fhir2.api.search.param.SearchParameterMap;
import org.springframework.stereotype.Component;

@Component
@Setter(AccessLevel.PACKAGE)
public class FhirMediaDaoImpl extends BaseFhirDao<Obs> implements FhirMediaDao {

@Override
protected void setupSearchParams(Criteria criteria, SearchParameterMap theParams) {
theParams.getParameters().forEach(entry -> {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here, we'll want to ensure that we're only searching ComplexObs and not just any Obs. This looks like it could be done as something like:

if (lacksAlias(criteria, "c")) {
	criteria.createAlias("concept", "c");
}

if (lacksAlias(criteria, "cdt")) {
    criteria.createAlias("c.datatype", "cdt");
}

criteria.add(eq("cdt.hl7_abbreviation", "ED"));

switch (entry.getKey()) {
case FhirConstants.MEDIA_STATUS:
entry.getValue().forEach(status -> handleStatus(criteria, (TokenAndListParam) status.getParam()));
break;
case FhirConstants.MEDIA_TYPE:
entry.getValue().forEach(type -> handleMediaType(criteria, (TokenAndListParam) type.getParam()));
break;
case FhirConstants.MEDIA_SUBJECT:
entry.getValue().forEach(subject -> handleMediaSubject(criteria, (ReferenceAndListParam) subject.getParam()));
break;
case FhirConstants.MEDIA_ENCOUNTER_REFERENCE:
entry.getValue().forEach(encounter -> handleMediaEncounterReference(criteria, (ReferenceAndListParam) encounter.getParam()));
break;
case FhirConstants.MEDIA_CREATED_DATE_TIME:
entry.getValue().forEach(createdDateTime -> handleMediaCreatedDate(criteria, (DateRangeParam) createdDateTime.getParam()));
break;
case FhirConstants.MEDIA_CONTENT_TYPE:
entry.getValue().forEach(contentType -> handleMediaContentType(criteria, (TokenAndListParam) contentType.getParam()));
break;
case FhirConstants.CONTENT_DATA:
entry.getValue().forEach(contentData -> handleContentData(criteria, (StringAndListParam) contentData.getParam()));
break;
case FhirConstants.CONTENT_TITLE:
entry.getValue().forEach(contentTitle -> handleContentTitle(criteria, (StringAndListParam) contentTitle.getParam()));
break;
case FhirConstants.CONTENT_DATE_OF_CREATION:
entry.getValue().forEach(contentDateOfCreation -> handleContentDateOfCreation(criteria, (DateRangeParam) contentDateOfCreation.getParam()));
break;

}
});
}

private void handleContentDateOfCreation(Criteria criteria, DateRangeParam contentDateOfCreation) {

}

private void handleContentTitle(Criteria criteria, StringAndListParam contentTitle) {
}

private void handleContentData(Criteria criteria, StringAndListParam contentData) {
}

private void handleMediaContentType(Criteria criteria, TokenAndListParam mediaContentType) {
}

private void handleMediaCreatedDate(Criteria criteria, DateRangeParam mediaCreatedDate) {
}

private void handleMediaEncounterReference(Criteria criteria, ReferenceAndListParam encounterReference) {
}

private void handleMediaSubject(Criteria criteria, ReferenceAndListParam mediaSubject) {
}

private void handleMediaType(Criteria criteria, TokenAndListParam mediaType) {
}

private void handleStatus(Criteria criteria, TokenAndListParam status) {
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
/*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.module.fhir2.api.impl;

import javax.annotation.Nonnull;
import java.util.HashSet;

import ca.uhn.fhir.model.api.Include;
import ca.uhn.fhir.rest.api.SortSpec;
import ca.uhn.fhir.rest.api.server.IBundleProvider;
import ca.uhn.fhir.rest.param.DateRangeParam;
import ca.uhn.fhir.rest.param.ReferenceAndListParam;
import ca.uhn.fhir.rest.param.StringAndListParam;
import ca.uhn.fhir.rest.param.TokenAndListParam;
import lombok.AccessLevel;
import lombok.Getter;
import lombok.Setter;
import org.hl7.fhir.r4.model.Observation;
import org.openmrs.Obs;
import org.openmrs.module.fhir2.FhirConstants;
import org.openmrs.module.fhir2.api.FhirMediaService;
import org.openmrs.module.fhir2.api.dao.FhirMediaDao;
import org.openmrs.module.fhir2.api.search.SearchQuery;
import org.openmrs.module.fhir2.api.search.SearchQueryInclude;
import org.openmrs.module.fhir2.api.search.param.SearchParameterMap;
import org.openmrs.module.fhir2.api.translators.MediaTranslator;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;

@Component
@Transactional
@Setter(AccessLevel.PACKAGE)
@Getter(AccessLevel.PROTECTED)
public class FhirMediaServiceImpl extends BaseFhirService<Observation, Obs> implements FhirMediaService {
tendomart marked this conversation as resolved.
Show resolved Hide resolved

@Autowired
private FhirMediaDao dao;

@Autowired
private MediaTranslator translator;

@Autowired
private SearchQuery<org.openmrs.Obs, Observation, FhirMediaDao, MediaTranslator, SearchQueryInclude<Observation>> searchQuery;

@Autowired
private SearchQueryInclude<Observation> searchQueryInclude;

@Override
public Observation get(@Nonnull String uuid) {
return null;
}

@Override
public IBundleProvider searchForMedia(TokenAndListParam status, TokenAndListParam type, ReferenceAndListParam subject,
ReferenceAndListParam encounterReference, DateRangeParam createdDateTime, TokenAndListParam contentType,
StringAndListParam contentDataType, StringAndListParam contentTitle, DateRangeParam contentCreated,
DateRangeParam lastUpdated, HashSet<Include> includes, HashSet<Include> revIncludes, SortSpec sort) {

SearchParameterMap theParams = new SearchParameterMap().addParameter(FhirConstants.MEDIA_STATUS, status)
.addParameter(FhirConstants.MEDIA_TYPE, type).addParameter(FhirConstants.MEDIA_SUBJECT, subject)
.addParameter(FhirConstants.MEDIA_ENCOUNTER_REFERENCE, encounterReference)
.addParameter(FhirConstants.MEDIA_CREATED_DATE_TIME, createdDateTime)
.addParameter(FhirConstants.MEDIA_CONTENT_TYPE, contentType)
.addParameter(FhirConstants.CONTENT_DATA, contentDataType)
.addParameter(FhirConstants.CONTENT_TITLE, contentTitle)
.addParameter(FhirConstants.CONTENT_DATE_OF_CREATION, contentCreated)
.addParameter(FhirConstants.COMMON_SEARCH_HANDLER, FhirConstants.ID_PROPERTY, id)
tendomart marked this conversation as resolved.
Show resolved Hide resolved
.addParameter(FhirConstants.COMMON_SEARCH_HANDLER, FhirConstants.LAST_UPDATED_PROPERTY, lastUpdated)
.addParameter(FhirConstants.COMMON_SEARCH_HANDLER, includes)
.addParameter(FhirConstants.COMMON_SEARCH_HANDLER, revIncludes).setSortSpec(sort);

return searchQuery.getQueryResults(theParams, dao, translator, searchQueryInclude);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.module.fhir2.api.translators;

import javax.annotation.Nonnull;

import org.hl7.fhir.r4.model.Media;
import org.openmrs.Obs;

public interface MediaTranslator extends ToFhirTranslator<Obs, Media>, OpenmrsFhirUpdatableTranslator<Obs, Media> {

/**
* Maps an {@link org.openmrs.Obs} to a {@link org.hl7.fhir.r4.model.Media}
*
* @param data the FHIR Media to translate
* @return the corresponding FHIR media resource
*/
@Override
Media toFhirResource(@Nonnull Obs data);

/**
* Maps a {@link org.hl7.fhir.r4.model.Media} to an {@link org.openmrs.Obs}
*
* @param resource the FHIR Media resource to translate
* @return the corresponding OpenMRS observation resource
*/
@Override
Obs toOpenmrsType(@Nonnull Media resource);

/**
* Maps a {@link Media} to an existing {@link org.openmrs.Obs}
*
* @param existingObject the observation to update
* @param resource the FHIR complex object to map
* @return the updated OpenMRS observation
*/
@Override
Obs toOpenmrsType(@Nonnull Obs existingObject, @Nonnull Media resource);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
/*
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/. OpenMRS is also distributed under
* the terms of the Healthcare Disclaimer located at http://openmrs.org/license.
*
* Copyright (C) OpenMRS Inc. OpenMRS is a registered trademark and the OpenMRS
* graphic logo is a trademark of OpenMRS Inc.
*/
package org.openmrs.module.fhir2.api.translators.impl;

import lombok.AccessLevel;
import lombok.Setter;
import org.hl7.fhir.r4.model.Media;
import org.hl7.fhir.r4.model.Observation;
import org.openmrs.Obs;
import org.openmrs.module.fhir2.api.translators.MediaTranslator;
import org.openmrs.module.fhir2.api.translators.ObservationStatusTranslator;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import javax.annotation.Nonnull;

import static org.apache.commons.lang.Validate.notNull;

@Component
@Setter(AccessLevel.PACKAGE)
public class MediaTranslatorImpl implements MediaTranslator {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For the mappings to be added here, look at the ticket and the way we generally map those properties. Most of them have overlap with Obs, so the ObservationTranslatorImpl class would be a good place to start.



@Autowired
private ObservationStatusTranslator observationStatusTranslator;

@Override
public Media toFhirResource(@Nonnull Obs data) {
notNull(data, "The Openmrs Complex obs object should not be null");

Observation obs = new Observation();
obs.setId(data.getUuid());
obs.setStatus(observationStatusTranslator.toFhirResource(data));
Media media = new Media();
return media;
}

@Override
public Obs toOpenmrsType(@Nonnull Media resource) {
notNull(resource, "The media resource should not be null");
return toOpenmrsType(new Obs(), resource);
}

@Override
public Obs toOpenmrsType(@Nonnull Obs existingObject, @Nonnull Media resource) {
notNull(existingObject, "The existing object should not be null");
notNull(resource, "The observation object should not be null");
return existingObject;
}
}
Loading