2023-07-08 08:43:30 -06:00
// THIS FILE IS GENERATED BY https://github.com/fastenhealth/fasten-onprem/blob/main/backend/pkg/models/database/generate.go
// PLEASE DO NOT EDIT BY HAND
package database
import (
"encoding/json"
"fmt"
goja "github.com/dop251/goja"
2023-08-27 18:09:46 -06:00
models "github.com/fastenhealth/fasten-onprem/backend/pkg/models"
2023-07-08 08:43:30 -06:00
datatypes "gorm.io/datatypes"
"time"
)
type FhirProcedure struct {
models . ResourceBase
// A request for this procedure
// https://hl7.org/fhir/r4/search.html#reference
BasedOn datatypes . JSON ` gorm:"column:basedOn;type:text;serializer:json" json:"basedOn,omitempty" `
// Classification of the procedure
// https://hl7.org/fhir/r4/search.html#token
Category datatypes . JSON ` gorm:"column:category;type:text;serializer:json" json:"category,omitempty" `
/ *
Multiple Resources :
* [ AllergyIntolerance ] ( allergyintolerance . html ) : Code that identifies the allergy or intolerance
* [ Condition ] ( condition . html ) : Code for the condition
* [ DeviceRequest ] ( devicerequest . html ) : Code for what is being requested / ordered
* [ DiagnosticReport ] ( diagnosticreport . html ) : The code for the report , as opposed to codes for the atomic results , which are the names on the observation resource referred to from the result
* [ FamilyMemberHistory ] ( familymemberhistory . html ) : A search by a condition code
* [ List ] ( list . html ) : What the purpose of this list is
* [ Medication ] ( medication . html ) : Returns medications for a specific code
* [ MedicationAdministration ] ( medicationadministration . html ) : Return administrations of this medication code
* [ MedicationDispense ] ( medicationdispense . html ) : Returns dispenses of this medicine code
* [ MedicationRequest ] ( medicationrequest . html ) : Return prescriptions of this medication code
* [ MedicationStatement ] ( medicationstatement . html ) : Return statements of this medication code
* [ Observation ] ( observation . html ) : The code of the observation type
* [ Procedure ] ( procedure . html ) : A code to identify a procedure
* [ ServiceRequest ] ( servicerequest . html ) : What is being requested / ordered
* /
// https://hl7.org/fhir/r4/search.html#token
Code datatypes . JSON ` gorm:"column:code;type:text;serializer:json" json:"code,omitempty" `
/ *
Multiple Resources :
* [ AllergyIntolerance ] ( allergyintolerance . html ) : Date first version of the resource instance was recorded
* [ CarePlan ] ( careplan . html ) : Time period plan covers
* [ CareTeam ] ( careteam . html ) : Time period team covers
* [ ClinicalImpression ] ( clinicalimpression . html ) : When the assessment was documented
* [ Composition ] ( composition . html ) : Composition editing time
* [ Consent ] ( consent . html ) : When this Consent was created or indexed
* [ DiagnosticReport ] ( diagnosticreport . html ) : The clinically relevant time of the report
* [ Encounter ] ( encounter . html ) : A date within the period the Encounter lasted
* [ EpisodeOfCare ] ( episodeofcare . html ) : The provided date search value falls within the episode of care ' s period
* [ FamilyMemberHistory ] ( familymemberhistory . html ) : When history was recorded or last updated
* [ Flag ] ( flag . html ) : Time period when flag is active
* [ Immunization ] ( immunization . html ) : Vaccination ( non ) - Administration Date
* [ List ] ( list . html ) : When the list was prepared
* [ Observation ] ( observation . html ) : Obtained date / time . If the obtained element is a period , a date that falls in the period
* [ Procedure ] ( procedure . html ) : When the procedure was performed
* [ RiskAssessment ] ( riskassessment . html ) : When was assessment made ?
* [ SupplyRequest ] ( supplyrequest . html ) : When the request was made
* /
// https://hl7.org/fhir/r4/search.html#date
2023-08-01 21:29:35 -06:00
Date * time . Time ` gorm:"column:date;type:datetime" json:"date,omitempty" `
2023-07-08 08:43:30 -06:00
/ *
Multiple Resources :
* [ Composition ] ( composition . html ) : Context of the Composition
* [ DeviceRequest ] ( devicerequest . html ) : Encounter during which request was created
* [ DiagnosticReport ] ( diagnosticreport . html ) : The Encounter when the order was made
* [ DocumentReference ] ( documentreference . html ) : Context of the document content
* [ Flag ] ( flag . html ) : Alert relevant during encounter
* [ List ] ( list . html ) : Context in which list created
* [ NutritionOrder ] ( nutritionorder . html ) : Return nutrition orders with this encounter identifier
* [ Observation ] ( observation . html ) : Encounter related to the observation
* [ Procedure ] ( procedure . html ) : Encounter created as part of
* [ RiskAssessment ] ( riskassessment . html ) : Where was assessment performed ?
* [ ServiceRequest ] ( servicerequest . html ) : An encounter in which this request is made
* [ VisionPrescription ] ( visionprescription . html ) : Return prescriptions with this encounter identifier
* /
// https://hl7.org/fhir/r4/search.html#reference
Encounter datatypes . JSON ` gorm:"column:encounter;type:text;serializer:json" json:"encounter,omitempty" `
/ *
Multiple Resources :
* [ AllergyIntolerance ] ( allergyintolerance . html ) : External ids for this item
* [ CarePlan ] ( careplan . html ) : External Ids for this plan
* [ CareTeam ] ( careteam . html ) : External Ids for this team
* [ Composition ] ( composition . html ) : Version - independent identifier for the Composition
* [ Condition ] ( condition . html ) : A unique identifier of the condition record
* [ Consent ] ( consent . html ) : Identifier for this record ( external references )
* [ DetectedIssue ] ( detectedissue . html ) : Unique id for the detected issue
* [ DeviceRequest ] ( devicerequest . html ) : Business identifier for request / order
* [ DiagnosticReport ] ( diagnosticreport . html ) : An identifier for the report
* [ DocumentManifest ] ( documentmanifest . html ) : Unique Identifier for the set of documents
* [ DocumentReference ] ( documentreference . html ) : Master Version Specific Identifier
* [ Encounter ] ( encounter . html ) : Identifier ( s ) by which this encounter is known
* [ EpisodeOfCare ] ( episodeofcare . html ) : Business Identifier ( s ) relevant for this EpisodeOfCare
* [ FamilyMemberHistory ] ( familymemberhistory . html ) : A search by a record identifier
* [ Goal ] ( goal . html ) : External Ids for this goal
* [ ImagingStudy ] ( imagingstudy . html ) : Identifiers for the Study , such as DICOM Study Instance UID and Accession number
* [ Immunization ] ( immunization . html ) : Business identifier
* [ List ] ( list . html ) : Business identifier
* [ MedicationAdministration ] ( medicationadministration . html ) : Return administrations with this external identifier
* [ MedicationDispense ] ( medicationdispense . html ) : Returns dispenses with this external identifier
* [ MedicationRequest ] ( medicationrequest . html ) : Return prescriptions with this external identifier
* [ MedicationStatement ] ( medicationstatement . html ) : Return statements with this external identifier
* [ NutritionOrder ] ( nutritionorder . html ) : Return nutrition orders with this external identifier
* [ Observation ] ( observation . html ) : The unique id for a particular observation
* [ Procedure ] ( procedure . html ) : A unique identifier for a procedure
* [ RiskAssessment ] ( riskassessment . html ) : Unique identifier for the assessment
* [ ServiceRequest ] ( servicerequest . html ) : Identifiers assigned to this order
* [ SupplyDelivery ] ( supplydelivery . html ) : External identifier
* [ SupplyRequest ] ( supplyrequest . html ) : Business Identifier for SupplyRequest
* [ VisionPrescription ] ( visionprescription . html ) : Return prescriptions with this external identifier
* /
// https://hl7.org/fhir/r4/search.html#token
Identifier datatypes . JSON ` gorm:"column:identifier;type:text;serializer:json" json:"identifier,omitempty" `
// Instantiates FHIR protocol or definition
// https://hl7.org/fhir/r4/search.html#reference
InstantiatesCanonical datatypes . JSON ` gorm:"column:instantiatesCanonical;type:text;serializer:json" json:"instantiatesCanonical,omitempty" `
// Instantiates external protocol or definition
// https://hl7.org/fhir/r4/search.html#uri
InstantiatesUri string ` gorm:"column:instantiatesUri;type:text" json:"instantiatesUri,omitempty" `
// Language of the resource content
// https://hl7.org/fhir/r4/search.html#token
Language datatypes . JSON ` gorm:"column:language;type:text;serializer:json" json:"language,omitempty" `
// Where the procedure happened
// https://hl7.org/fhir/r4/search.html#reference
Location datatypes . JSON ` gorm:"column:location;type:text;serializer:json" json:"location,omitempty" `
2023-11-19 12:09:23 -07:00
// When the resource version last changed
// https://hl7.org/fhir/r4/search.html#date
MetaLastUpdated * time . Time ` gorm:"column:metaLastUpdated;type:datetime" json:"metaLastUpdated,omitempty" `
// Profiles this resource claims to conform to
// https://hl7.org/fhir/r4/search.html#reference
MetaProfile datatypes . JSON ` gorm:"column:metaProfile;type:text;serializer:json" json:"metaProfile,omitempty" `
// Tags applied to this resource
// https://hl7.org/fhir/r4/search.html#token
MetaTag datatypes . JSON ` gorm:"column:metaTag;type:text;serializer:json" json:"metaTag,omitempty" `
// Tags applied to this resource
// This is a primitive string literal (`keyword` type). It is not a recognized SearchParameter type from https://hl7.org/fhir/r4/search.html, it's Fasten Health-specific
MetaVersionId string ` gorm:"column:metaVersionId;type:text" json:"metaVersionId,omitempty" `
2023-07-08 08:43:30 -06:00
// Part of referenced event
// https://hl7.org/fhir/r4/search.html#reference
PartOf datatypes . JSON ` gorm:"column:partOf;type:text;serializer:json" json:"partOf,omitempty" `
// The reference to the practitioner
// https://hl7.org/fhir/r4/search.html#reference
Performer datatypes . JSON ` gorm:"column:performer;type:text;serializer:json" json:"performer,omitempty" `
// Coded reason procedure performed
// https://hl7.org/fhir/r4/search.html#token
ReasonCode datatypes . JSON ` gorm:"column:reasonCode;type:text;serializer:json" json:"reasonCode,omitempty" `
// The justification that the procedure was performed
// https://hl7.org/fhir/r4/search.html#reference
ReasonReference datatypes . JSON ` gorm:"column:reasonReference;type:text;serializer:json" json:"reasonReference,omitempty" `
// preparation | in-progress | not-done | on-hold | stopped | completed | entered-in-error | unknown
// https://hl7.org/fhir/r4/search.html#token
Status datatypes . JSON ` gorm:"column:status;type:text;serializer:json" json:"status,omitempty" `
// Search by subject
// https://hl7.org/fhir/r4/search.html#reference
Subject datatypes . JSON ` gorm:"column:subject;type:text;serializer:json" json:"subject,omitempty" `
// Text search against the narrative
2023-11-19 12:09:23 -07:00
// This is a primitive string literal (`keyword` type). It is not a recognized SearchParameter type from https://hl7.org/fhir/r4/search.html, it's Fasten Health-specific
Text string ` gorm:"column:text;type:text" json:"text,omitempty" `
2023-07-08 08:43:30 -06:00
// A resource type filter
// https://hl7.org/fhir/r4/search.html#special
Type datatypes . JSON ` gorm:"column:type;type:text;serializer:json" json:"type,omitempty" `
}
func ( s * FhirProcedure ) GetSearchParameters ( ) map [ string ] string {
searchParameters := map [ string ] string {
"basedOn" : "reference" ,
"category" : "token" ,
"code" : "token" ,
"date" : "date" ,
"encounter" : "reference" ,
2023-08-23 13:24:08 -06:00
"id" : "keyword" ,
2023-07-08 08:43:30 -06:00
"identifier" : "token" ,
"instantiatesCanonical" : "reference" ,
"instantiatesUri" : "uri" ,
"language" : "token" ,
"location" : "reference" ,
2023-11-19 12:09:23 -07:00
"metaLastUpdated" : "date" ,
"metaProfile" : "reference" ,
"metaTag" : "token" ,
"metaVersionId" : "keyword" ,
2023-07-08 08:43:30 -06:00
"partOf" : "reference" ,
"performer" : "reference" ,
"reasonCode" : "token" ,
"reasonReference" : "reference" ,
2023-10-01 20:15:24 -06:00
"sort_date" : "date" ,
2023-08-23 13:24:08 -06:00
"source_id" : "keyword" ,
"source_resource_id" : "keyword" ,
"source_resource_type" : "keyword" ,
"source_uri" : "keyword" ,
2023-07-08 08:43:30 -06:00
"status" : "token" ,
"subject" : "reference" ,
2023-11-19 12:09:23 -07:00
"text" : "keyword" ,
2023-07-08 08:43:30 -06:00
"type" : "special" ,
}
return searchParameters
}
func ( s * FhirProcedure ) PopulateAndExtractSearchParameters ( resourceRaw json . RawMessage ) error {
s . ResourceRaw = datatypes . JSON ( resourceRaw )
// unmarshal the raw resource (bytes) into a map
var resourceRawMap map [ string ] interface { }
err := json . Unmarshal ( resourceRaw , & resourceRawMap )
if err != nil {
return err
}
if len ( fhirPathJs ) == 0 {
return fmt . Errorf ( "fhirPathJs script is empty" )
}
vm := goja . New ( )
// setup the global window object
vm . Set ( "window" , vm . NewObject ( ) )
// set the global FHIR Resource object
vm . Set ( "fhirResource" , resourceRawMap )
// compile the fhirpath library
fhirPathJsProgram , err := goja . Compile ( "fhirpath.min.js" , fhirPathJs , true )
if err != nil {
return err
}
2023-11-19 12:09:23 -07:00
// compile the searchParametersExtractor library
searchParametersExtractorJsProgram , err := goja . Compile ( "searchParameterExtractor.js" , searchParameterExtractorJs , true )
if err != nil {
return err
}
2023-07-08 08:43:30 -06:00
// add the fhirpath library in the goja vm
_ , err = vm . RunProgram ( fhirPathJsProgram )
if err != nil {
return err
}
2023-11-19 12:09:23 -07:00
// add the searchParametersExtractor library in the goja vm
_ , err = vm . RunProgram ( searchParametersExtractorJsProgram )
if err != nil {
return err
}
2023-07-08 08:43:30 -06:00
// execute the fhirpath expression for each search parameter
// extracting BasedOn
2023-11-19 12:09:23 -07:00
basedOnResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.basedOn')" )
2023-07-08 08:43:30 -06:00
if err == nil && basedOnResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . BasedOn = [ ] byte ( basedOnResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
// extracting Category
2023-11-19 12:09:23 -07:00
categoryResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'Procedure.category')" )
2023-07-08 08:43:30 -06:00
if err == nil && categoryResult . String ( ) != "undefined" {
s . Category = [ ] byte ( categoryResult . String ( ) )
}
// extracting Code
2023-11-19 12:09:23 -07:00
codeResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'AllergyIntolerance.code | AllergyIntolerance.reaction.substance | Condition.code | (DeviceRequest.codeCodeableConcept) | DiagnosticReport.code | FamilyMemberHistory.condition.code | List.code | Medication.code | (MedicationAdministration.medicationCodeableConcept) | (MedicationDispense.medicationCodeableConcept) | (MedicationRequest.medicationCodeableConcept) | (MedicationStatement.medicationCodeableConcept) | Observation.code | Procedure.code | ServiceRequest.code')" )
2023-07-08 08:43:30 -06:00
if err == nil && codeResult . String ( ) != "undefined" {
s . Code = [ ] byte ( codeResult . String ( ) )
}
// extracting Date
2023-11-19 12:09:23 -07:00
dateResult , err := vm . RunString ( "extractDateSearchParameters(fhirResource, 'AllergyIntolerance.recordedDate | CarePlan.period | CareTeam.period | ClinicalImpression.date | Composition.date | Consent.dateTime | DiagnosticReport.effectiveDateTime | DiagnosticReport.effectivePeriod | Encounter.period | EpisodeOfCare.period | FamilyMemberHistory.date | Flag.period | (Immunization.occurrenceDateTime) | List.date | Observation.effectiveDateTime | Observation.effectivePeriod | Observation.effectiveTiming | Observation.effectiveInstant | Procedure.performedDateTime | Procedure.performedPeriod | Procedure.performedString | Procedure.performedAge | Procedure.performedRange | (RiskAssessment.occurrenceDateTime) | SupplyRequest.authoredOn')" )
2023-07-08 08:43:30 -06:00
if err == nil && dateResult . String ( ) != "undefined" {
t , err := time . Parse ( time . RFC3339 , dateResult . String ( ) )
if err == nil {
2023-08-01 21:29:35 -06:00
s . Date = & t
} else if err != nil {
d , err := time . Parse ( "2006-01-02" , dateResult . String ( ) )
if err == nil {
s . Date = & d
}
2023-07-08 08:43:30 -06:00
}
}
// extracting Encounter
2023-11-19 12:09:23 -07:00
encounterResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Composition.encounter | DeviceRequest.encounter | DiagnosticReport.encounter | DocumentReference.context.encounter.where(resolve() is Encounter) | Flag.encounter | List.encounter | NutritionOrder.encounter | Observation.encounter | Procedure.encounter | RiskAssessment.encounter | ServiceRequest.encounter | VisionPrescription.encounter')" )
2023-07-08 08:43:30 -06:00
if err == nil && encounterResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . Encounter = [ ] byte ( encounterResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
// extracting Identifier
2023-11-19 12:09:23 -07:00
identifierResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'AllergyIntolerance.identifier | CarePlan.identifier | CareTeam.identifier | Composition.identifier | Condition.identifier | Consent.identifier | DetectedIssue.identifier | DeviceRequest.identifier | DiagnosticReport.identifier | DocumentManifest.masterIdentifier | DocumentManifest.identifier | DocumentReference.masterIdentifier | DocumentReference.identifier | Encounter.identifier | EpisodeOfCare.identifier | FamilyMemberHistory.identifier | Goal.identifier | ImagingStudy.identifier | Immunization.identifier | List.identifier | MedicationAdministration.identifier | MedicationDispense.identifier | MedicationRequest.identifier | MedicationStatement.identifier | NutritionOrder.identifier | Observation.identifier | Procedure.identifier | RiskAssessment.identifier | ServiceRequest.identifier | SupplyDelivery.identifier | SupplyRequest.identifier | VisionPrescription.identifier')" )
2023-07-08 08:43:30 -06:00
if err == nil && identifierResult . String ( ) != "undefined" {
s . Identifier = [ ] byte ( identifierResult . String ( ) )
}
// extracting InstantiatesCanonical
2023-11-19 12:09:23 -07:00
instantiatesCanonicalResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.instantiatesCanonical')" )
2023-07-08 08:43:30 -06:00
if err == nil && instantiatesCanonicalResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . InstantiatesCanonical = [ ] byte ( instantiatesCanonicalResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
// extracting InstantiatesUri
2023-11-19 12:09:23 -07:00
instantiatesUriResult , err := vm . RunString ( "extractSimpleSearchParameters(fhirResource, 'Procedure.instantiatesUri')" )
2023-07-08 08:43:30 -06:00
if err == nil && instantiatesUriResult . String ( ) != "undefined" {
s . InstantiatesUri = instantiatesUriResult . String ( )
}
// extracting Language
2023-11-19 12:09:23 -07:00
languageResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'language')" )
2023-07-08 08:43:30 -06:00
if err == nil && languageResult . String ( ) != "undefined" {
s . Language = [ ] byte ( languageResult . String ( ) )
}
2023-11-19 12:09:23 -07:00
// extracting Location
locationResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.location')" )
if err == nil && locationResult . String ( ) != "undefined" {
s . Location = [ ] byte ( locationResult . String ( ) )
}
// extracting MetaLastUpdated
metaLastUpdatedResult , err := vm . RunString ( "extractDateSearchParameters(fhirResource, 'meta.lastUpdated')" )
if err == nil && metaLastUpdatedResult . String ( ) != "undefined" {
t , err := time . Parse ( time . RFC3339 , metaLastUpdatedResult . String ( ) )
2023-07-08 08:43:30 -06:00
if err == nil {
2023-11-19 12:09:23 -07:00
s . MetaLastUpdated = & t
2023-08-01 21:29:35 -06:00
} else if err != nil {
2023-11-19 12:09:23 -07:00
d , err := time . Parse ( "2006-01-02" , metaLastUpdatedResult . String ( ) )
2023-08-01 21:29:35 -06:00
if err == nil {
2023-11-19 12:09:23 -07:00
s . MetaLastUpdated = & d
2023-08-01 21:29:35 -06:00
}
2023-07-08 08:43:30 -06:00
}
}
2023-11-19 12:09:23 -07:00
// extracting MetaProfile
metaProfileResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'meta.profile')" )
if err == nil && metaProfileResult . String ( ) != "undefined" {
s . MetaProfile = [ ] byte ( metaProfileResult . String ( ) )
}
// extracting MetaTag
metaTagResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'meta.tag')" )
if err == nil && metaTagResult . String ( ) != "undefined" {
s . MetaTag = [ ] byte ( metaTagResult . String ( ) )
}
// extracting MetaVersionId
metaVersionIdResult , err := vm . RunString ( "extractSimpleSearchParameters(fhirResource, 'meta.versionId')" )
if err == nil && metaVersionIdResult . String ( ) != "undefined" {
s . MetaVersionId = metaVersionIdResult . String ( )
2023-07-08 08:43:30 -06:00
}
// extracting PartOf
2023-11-19 12:09:23 -07:00
partOfResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.partOf')" )
2023-07-08 08:43:30 -06:00
if err == nil && partOfResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . PartOf = [ ] byte ( partOfResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
// extracting Performer
2023-11-19 12:09:23 -07:00
performerResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.performer.actor')" )
2023-07-08 08:43:30 -06:00
if err == nil && performerResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . Performer = [ ] byte ( performerResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
// extracting ReasonCode
2023-11-19 12:09:23 -07:00
reasonCodeResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'Procedure.reasonCode')" )
2023-07-08 08:43:30 -06:00
if err == nil && reasonCodeResult . String ( ) != "undefined" {
s . ReasonCode = [ ] byte ( reasonCodeResult . String ( ) )
}
// extracting ReasonReference
2023-11-19 12:09:23 -07:00
reasonReferenceResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.reasonReference')" )
2023-07-08 08:43:30 -06:00
if err == nil && reasonReferenceResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . ReasonReference = [ ] byte ( reasonReferenceResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
// extracting Status
2023-11-19 12:09:23 -07:00
statusResult , err := vm . RunString ( "extractTokenSearchParameters(fhirResource, 'Procedure.status')" )
2023-07-08 08:43:30 -06:00
if err == nil && statusResult . String ( ) != "undefined" {
s . Status = [ ] byte ( statusResult . String ( ) )
}
// extracting Subject
2023-11-19 12:09:23 -07:00
subjectResult , err := vm . RunString ( "extractReferenceSearchParameters(fhirResource, 'Procedure.subject')" )
2023-07-08 08:43:30 -06:00
if err == nil && subjectResult . String ( ) != "undefined" {
2023-08-13 15:28:03 -06:00
s . Subject = [ ] byte ( subjectResult . String ( ) )
2023-07-08 08:43:30 -06:00
}
2023-11-19 12:09:23 -07:00
// extracting Text
textResult , err := vm . RunString ( "extractSimpleSearchParameters(fhirResource, 'text')" )
if err == nil && textResult . String ( ) != "undefined" {
s . Text = textResult . String ( )
2023-07-08 08:43:30 -06:00
}
return nil
}
// TableName overrides the table name from fhir_observations (pluralized) to `fhir_observation`. https://gorm.io/docs/conventions.html#TableName
func ( s * FhirProcedure ) TableName ( ) string {
return "fhir_procedure"
}