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

Convert ABDM into Plug - Part 2/3 #2313

Merged
merged 89 commits into from
Oct 18, 2024
Merged
Show file tree
Hide file tree
Changes from 79 commits
Commits
Show all changes
89 commits
Select commit Hold shift + click to select a range
9ec18a3
added consent flows in abdm
khavinshankar Aug 30, 2023
87cbc4b
Merge branch 'master' into abdm-m3
khavinshankar Aug 30, 2023
515f38a
made patient_abha as a foriegn key field in consent
khavinshankar Aug 30, 2023
5f8ec34
renamed patient_health_id to patient_abha
khavinshankar Aug 30, 2023
761e725
renamed patient_health_id to patient_abha
khavinshankar Aug 30, 2023
021f0a0
added filterset class to consent
khavinshankar Aug 31, 2023
0eb7f64
send external_id as id in consent serializer
khavinshankar Aug 31, 2023
eae6342
Merge branch 'master' into abdm-m3
khavinshankar Sep 13, 2023
89577c4
resolved migration conflicts
khavinshankar Sep 26, 2023
eb4b495
seperated out consent request and consent artefact
khavinshankar Oct 1, 2023
a3138f0
get health information from hip
khavinshankar Oct 1, 2023
9220755
decrypt data from abdm
khavinshankar Oct 1, 2023
57a946f
store health information in s3
khavinshankar Oct 1, 2023
49ae5ee
moved status from consent request to consent artefact
khavinshankar Oct 1, 2023
cd2d20c
display health information
khavinshankar Oct 2, 2023
fa37907
added patients find apis
khavinshankar Oct 10, 2023
87a8a71
added consents__hiu__notify
khavinshankar Oct 10, 2023
6c8f2a0
send push notification in patients/on-find
khavinshankar Oct 17, 2023
5e063bd
fixed gateway api calls
khavinshankar Oct 17, 2023
f284f62
remove date range from health-information/cm/request
khavinshankar Oct 17, 2023
da35803
added ratelimits to abdm m3 apis
khavinshankar Nov 2, 2023
89522ca
added status in consent request
khavinshankar Dec 4, 2023
159c4bc
fix consent denied logic
khavinshankar Dec 5, 2023
c56f67b
added facility filter to consent requests
khavinshankar Dec 18, 2023
32a9247
fixed a typo
khavinshankar Dec 18, 2023
f57ceff
added patient_abha_object in consent request serializer
khavinshankar Dec 18, 2023
7986c78
fixed consent status update logic
khavinshankar Dec 18, 2023
0684c45
support retrieve hi docs by consent id
khavinshankar Dec 19, 2023
2233f36
Merge branch 'master' of github.com:coronasafe/care into abdm-m3
khavinshankar Jan 20, 2024
3df5835
Merge branch 'abdm-m3' of github.com:coronasafe/care into abdm-m3
khavinshankar Jan 20, 2024
00624b9
added all the suggestions from review
khavinshankar Jan 20, 2024
079f0a3
Merge branch 'master' into abdm-m3
khavinshankar Feb 6, 2024
ac41a56
Merge branch 'master' of github.com:coronasafe/care into abdm-m3
khavinshankar Mar 7, 2024
e0692f0
Merge remote-tracking branch 'origin/master' into abdm-m3
sainak Mar 8, 2024
cb841d3
update migrations
sainak Mar 8, 2024
06cd7f4
added date range to health_information__cm__request
khavinshankar Apr 12, 2024
68be86b
fixed reverse mapping of an enum REVERSE_CONDITION_VERIFICATION_STATUSES
khavinshankar Apr 12, 2024
0f5f4f4
fix a type in health_id
khavinshankar Apr 12, 2024
3c81813
Merge branch 'develop' into abdm-m3
sainak Apr 12, 2024
ca2c7e1
fix migration
khavinshankar Apr 12, 2024
41ae638
fix linting error
khavinshankar Apr 12, 2024
ea9ff1b
added backend domain env
khavinshankar Apr 12, 2024
24cfd21
removed https prefix while using BACKEND_DOMAIN
khavinshankar Apr 12, 2024
a44d1f0
removed duplicate conditional logic
khavinshankar Apr 12, 2024
6056e3b
fix linting issues
khavinshankar Apr 12, 2024
0e99c97
Merge branch 'develop' into abdm-m3
khavinshankar Apr 13, 2024
685c62c
added patient field to abdm.abhanumber model
khavinshankar Apr 21, 2024
2c0d4fb
remove abha_number field from facility.patientregistration model
khavinshankar Apr 21, 2024
bae0b03
remove abdm references in the patient serializer
khavinshankar Apr 21, 2024
027a0d9
remove abdm references (auto add care context on consultation create)…
khavinshankar Apr 21, 2024
561b638
removed an unused abdm import
khavinshankar Apr 21, 2024
8c05d01
added related_name to patient field in abdm.abhanumber model
khavinshankar Apr 21, 2024
e242628
add hasattr check while patient.abha_number and revert patient.abha_n…
khavinshankar Apr 22, 2024
49f42bf
added consultation receiver to auto add care context on create
khavinshankar Apr 22, 2024
0042cec
added abha_number viewset and serializer
khavinshankar May 6, 2024
c114997
remove abha number from patient model in dummy data
khavinshankar May 14, 2024
f613fc9
Merge branch 'develop' into pre-abdm-plug
khavinshankar May 14, 2024
004d52d
resolve migration conflicts
khavinshankar May 14, 2024
6d7fcef
fix linting errors
khavinshankar May 14, 2024
73baf5e
fixed migration reference
khavinshankar May 14, 2024
82bbfdb
Merge branch 'develop' into pre-abdm-plug
sainak May 14, 2024
10a8a14
Apply suggestions from code review
sainak May 14, 2024
16fb40c
Merge branch 'develop' into pre-abdm-plug
May 20, 2024
da2dbad
resolve migration conflict
May 20, 2024
3aa812e
use bulk update in reverse_patient_abhanumber_relation
May 20, 2024
e6c3143
Merge branch 'develop' into pre-abdm-plug
khavinshankar May 28, 2024
8f690f8
resolve migration conflict
khavinshankar May 28, 2024
e9dc343
fix the migration logic abha_number not found on patient
khavinshankar May 28, 2024
3b6f2ca
added validation errors
khavinshankar May 29, 2024
9471e48
replaced general exceptions with validation error
khavinshankar May 29, 2024
c49ff4d
fixed consent filters
khavinshankar Jul 3, 2024
27c4009
Merge branch 'develop' into pre-abdm-plug
khavinshankar Jul 3, 2024
ca79856
fix migration conflict
khavinshankar Jul 3, 2024
e9e91e3
fix dummy data
khavinshankar Jul 3, 2024
c88f1a8
revert dummy data changes
sainak Jul 3, 2024
7a1b161
remove abha_number field
sainak Jul 3, 2024
bcee797
handle json decode errors for abdm responses
khavinshankar Jul 4, 2024
a9d1e17
use correct json exception
sainak Jul 4, 2024
9d83712
added replace migrations for migrations with abdm dependencies
khavinshankar Jul 20, 2024
dc2c302
Merge branch 'develop' into pre-abdm-plug
khavinshankar Aug 23, 2024
7fc24bd
fixed migration conflict
khavinshankar Aug 23, 2024
6cee939
Merge branch 'pre-abdm-plug' into pre-abdm-plug-2
khavinshankar Aug 23, 2024
9b7b86f
fixed squash migration conflicts
khavinshankar Aug 23, 2024
c0d52e0
Merge branch 'develop' into pre-abdm-plug-2
khavinshankar Sep 10, 2024
077a7ec
renamed migration
khavinshankar Sep 10, 2024
f551992
Merge branch 'develop' into pre-abdm-plug-2
khavinshankar Oct 18, 2024
9059474
fixed migration conflicts
khavinshankar Oct 18, 2024
1ceac69
fixed migration issues
khavinshankar Oct 18, 2024
befc660
fix migrations
sainak Oct 18, 2024
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
9 changes: 0 additions & 9 deletions care/abdm/api/serializers/abha.py

This file was deleted.

20 changes: 20 additions & 0 deletions care/abdm/api/serializers/abha_number.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# ModelSerializer
from rest_framework import serializers

from care.abdm.models import AbhaNumber
from care.facility.api.serializers.patient import PatientDetailSerializer
from care.facility.models import PatientRegistration
from care.utils.serializer.external_id_field import ExternalIdSerializerField


class AbhaNumberSerializer(serializers.ModelSerializer):
id = serializers.CharField(source="external_id", read_only=True)
patient = ExternalIdSerializerField(
queryset=PatientRegistration.objects.all(), required=False, allow_null=True
)
patient_object = PatientDetailSerializer(source="patient", read_only=True)
new = serializers.BooleanField(read_only=True)

class Meta:
model = AbhaNumber
exclude = ("deleted", "access_token", "refresh_token", "txn_id")
10 changes: 0 additions & 10 deletions care/abdm/api/serializers/abhanumber.py

This file was deleted.

2 changes: 1 addition & 1 deletion care/abdm/api/serializers/consent.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from rest_framework import serializers

from care.abdm.api.serializers.abhanumber import AbhaNumberSerializer
from care.abdm.api.serializers.abha_number import AbhaNumberSerializer
from care.abdm.models.consent import ConsentArtefact, ConsentRequest
from care.users.api.serializers.user import UserBaseMinimumSerializer

Expand Down
38 changes: 0 additions & 38 deletions care/abdm/api/viewsets/abha.py

This file was deleted.

56 changes: 56 additions & 0 deletions care/abdm/api/viewsets/abha_number.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
from django.db.models import Q
from django.http import Http404
from rest_framework.decorators import action
from rest_framework.mixins import RetrieveModelMixin
from rest_framework.permissions import IsAuthenticated
from rest_framework.response import Response
from rest_framework.viewsets import GenericViewSet

from care.abdm.api.serializers.abha_number import AbhaNumberSerializer
from care.abdm.models import AbhaNumber
from care.abdm.utils.api_call import HealthIdGateway
from care.utils.queryset.patient import get_patient_queryset


class AbhaNumberViewSet(
GenericViewSet,
RetrieveModelMixin,
):
serializer_class = AbhaNumberSerializer
model = AbhaNumber
queryset = AbhaNumber.objects.all()
permission_classes = (IsAuthenticated,)

def get_queryset(self):
queryset = self.queryset
patients = get_patient_queryset(self.request.user)
return queryset.filter(patient__in=patients, deleted=False)

Check warning on line 27 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L25-L27

Added lines #L25 - L27 were not covered by tests

def get_object(self):
queryset = self.get_queryset()
id = self.kwargs.get("pk")

Check warning on line 31 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L30-L31

Added lines #L30 - L31 were not covered by tests

instance = queryset.filter(

Check warning on line 33 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L33

Added line #L33 was not covered by tests
Q(abha_number=id) | Q(health_id=id) | Q(patient__external_id=id)
).first()

if not instance:
raise Http404

Check warning on line 38 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L38

Added line #L38 was not covered by tests

self.check_object_permissions(self.request, instance)

Check warning on line 40 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L40

Added line #L40 was not covered by tests

return instance

Check warning on line 42 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L42

Added line #L42 was not covered by tests

@action(detail=True, methods=["GET"])
def qr_code(self, request, *args, **kwargs):
obj = self.get_object()
serializer = self.get_serializer(obj)
response = HealthIdGateway().get_qr_code(serializer.data)
return Response(response)

Check warning on line 49 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L46-L49

Added lines #L46 - L49 were not covered by tests

@action(detail=True, methods=["GET"])
def profile(self, request, *args, **kwargs):
obj = self.get_object()
serializer = self.get_serializer(obj)
response = HealthIdGateway().get_profile(serializer.data)
return Response(response)

Check warning on line 56 in care/abdm/api/viewsets/abha_number.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/abha_number.py#L53-L56

Added lines #L53 - L56 were not covered by tests
62 changes: 20 additions & 42 deletions care/abdm/api/viewsets/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,17 +25,7 @@
def post(self, request, *args, **kwargs):
data = request.data

try:
AbdmGateway().init(data["resp"]["requestId"])
except Exception as e:
logger.warning(
f"Error: OnFetchView::post failed while initialising ABDM Gateway, Reason: {e}",
exc_info=True,
)
return Response(
{"detail": "Error: Initialising ABDM Gateway failed."},
status=status.HTTP_400_BAD_REQUEST,
)
AbdmGateway().init(data["resp"]["requestId"])

Check warning on line 28 in care/abdm/api/viewsets/auth.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/auth.py#L28

Added line #L28 was not covered by tests

return Response({}, status=status.HTTP_202_ACCEPTED)

Expand Down Expand Up @@ -337,38 +327,26 @@
}
)

try:
AbdmGateway().data_notify(
{
"health_id": consent["notification"]["consentDetail"]["patient"][
"id"
],
"consent_id": data["hiRequest"]["consent"]["id"],
"transaction_id": data["transactionId"],
"session_status": "TRANSFERRED"
AbdmGateway().data_notify(
{
"health_id": consent["notification"]["consentDetail"]["patient"]["id"],
"consent_id": data["hiRequest"]["consent"]["id"],
"transaction_id": data["transactionId"],
"session_status": (
"TRANSFERRED"
if data_transfer_response
and data_transfer_response.status_code == 202
else "FAILED",
"care_contexts": list(
map(
lambda context: {"id": context["careContextReference"]},
consent["notification"]["consentDetail"]["careContexts"][
:-2:-1
],
)
),
}
)
except Exception as e:
logger.warning(
f"Error: RequestDataView::post failed to notify (health-information/notify). Reason: {e}",
exc_info=True,
)
return Response(
{
"detail": "Failed to notify (health-information/notify)",
},
status=status.HTTP_400_BAD_REQUEST,
)
else "FAILED"
),
"care_contexts": list(
map(
lambda context: {"id": context["careContextReference"]},
consent["notification"]["consentDetail"]["careContexts"][
:-2:-1
],
)
),
}
)

return Response({}, status=status.HTTP_202_ACCEPTED)
22 changes: 5 additions & 17 deletions care/abdm/api/viewsets/consent.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,7 @@


class ConsentRequestFilter(filters.FilterSet):
patient = filters.UUIDFilter(
field_name="patient_abha__patientregistration__external_id"
)
patient = filters.UUIDFilter(field_name="patient_abha__patient__external_id")
health_id = filters.CharFilter(field_name="patient_abha__health_id")
ordering = filters.OrderingFilter(
fields=(
Expand All @@ -33,7 +31,7 @@
)
)
facility = filters.UUIDFilter(
field_name="patient_abha__patientregistration__facility__external_id"
field_name="patient_abha__patient__facility__external_id"
)

class Meta:
Expand Down Expand Up @@ -71,19 +69,9 @@

consent = ConsentRequest(**serializer.validated_data, requester=request.user)

try:
response = Gateway().consent_requests__init(consent)
if response.status_code != 202:
return Response(response.json(), status=response.status_code)
except Exception as e:
logger.warning(
f"Error: ConsentViewSet::create failed to notify (consent_requests__init). Reason: {e}",
exc_info=True,
)
return Response(
{"detail": "Failed to initialize consent request"},
status=status.HTTP_400_BAD_REQUEST,
)
response = Gateway().consent_requests__init(consent)

Check warning on line 72 in care/abdm/api/viewsets/consent.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/consent.py#L72

Added line #L72 was not covered by tests
if response.status_code != 202:
return Response(response.json(), status=response.status_code)

Check warning on line 74 in care/abdm/api/viewsets/consent.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/consent.py#L74

Added line #L74 was not covered by tests

consent.save()
return Response(
Expand Down
12 changes: 1 addition & 11 deletions care/abdm/api/viewsets/health_information.py
Original file line number Diff line number Diff line change
Expand Up @@ -142,16 +142,6 @@
file.upload_completed = True
file.save()

try:
Gateway().health_information__notify(artefact)
except Exception as e:
logger.warning(
f"Error: health_information__transfer::post failed to notify (health-information/notify). Reason: {e}",
exc_info=True,
)
return Response(
{"detail": "Failed to notify (health-information/notify)"},
status=status.HTTP_400_BAD_REQUEST,
)
Gateway().health_information__notify(artefact)

Check warning on line 145 in care/abdm/api/viewsets/health_information.py

View check run for this annotation

Codecov / codecov/patch

care/abdm/api/viewsets/health_information.py#L145

Added line #L145 was not covered by tests

return Response(status=status.HTTP_202_ACCEPTED)
Loading