Ejemplo n.º 1
0
        public async Task <IActionResult> Post([FromBody] AddRegistrationPatientCommand registerpatientcommand)
        {
            var response = await _mediator.Send(registerpatientcommand, Request.HttpContext.RequestAborted);

            if (response.IsValid)
            {
                return(Ok(response.Value));
            }
            return(BadRequest(response));
        }
Ejemplo n.º 2
0
        public async Task <Result <AddRegistrationPatientResponse> > Handle(AddRegistrationPatientCommand request, CancellationToken cancellationToken)
        {
            try
            {
                using (_unitOfWork)
                {
                    //var sqlPatient = "exec pr_OpenDecryptedSession;" +
                    //                 "Insert Into  Patient(ptn_pk,PersonId,PatientIndex,PatientType,FacilityId,Active,DateOfBirth,NationalId,DeleteFlag,CreatedBy,CreateDate,AuditData,DobPrecision)" +
                    //                 $"Values(0, {request.PersonId}, {DateTime.Now.Year + '-' + request.PersonId}, 258, 13028, 1," +
                    //                 $"'{request.DateOfBirth.ToString("yyyy-MM-dd")}', ENCRYPTBYKEY(KEY_GUID('Key_CTC'), '99999999'), 0, 1, GETDATE()," +
                    //                 $"NULL, 1);" +
                    //                 $"SELECT [Id],[ptn_pk],[PersonId],[PatientIndex],[PatientType],[FacilityId],[Active],[DateOfBirth]," +
                    //                 $"[DobPrecision],CAST(DECRYPTBYKEY(NationalId) AS VARCHAR(50)) [NationalId],[DeleteFlag],[CreatedBy]," +
                    //                 $"[CreateDate],[AuditData],[RegistrationDate] FROM [dbo].[Patient] WHERE Id = SCOPE_IDENTITY();" +
                    //                 $"exec [dbo].[pr_CloseDecryptedSession];";

                    //var patientInsert = await _unitOfWork.Repository<Patient>().FromSql(sqlPatient);

                    RegisterPersonService registerPersonService = new RegisterPersonService(_unitOfWork);
                    if (request.PersonId > 0)
                    {
                        var patient = await registerPersonService.GetPatientByPersonId(request.PersonId);

                        if (patient != null)
                        {
                            var pat = await registerPersonService.UpdateRegistrationPatient(request.PersonId, request.RegistrationDate, request.NationalId, request.DateOfBirth, request.UserId);

                            patientid = pat.Id;
                        }
                        else
                        {
                            var patadd = await registerPersonService.AddRegistrationPatient(request.PersonId, request.RegistrationDate, request.NationalId, request.DateOfBirth, request.UserId);

                            patientid = patadd.Id;
                        }
                    }
                    else
                    {
                        var patient = await registerPersonService.AddRegistrationPatient(request.PersonId, request.RegistrationDate, request.NationalId, request.DateOfBirth, request.UserId);

                        patientid = patient.Id;
                    }
                    _unitOfWork.Dispose();

                    return(Result <AddRegistrationPatientResponse> .Valid(new AddRegistrationPatientResponse()
                    {
                        PatientId = patientid
                    }));
                }
            }
            catch (Exception e)
            {
                return(Result <AddRegistrationPatientResponse> .Invalid(e.Message));
            }
        }