<channel version="3.2.1">
  <id>53423725-c96e-4b21-b9c4-5d422674df1c</id>
  <nextMetaDataId>5</nextMetaDataId>
  <name>SCH_RAD_ADT</name>
  <description></description>
  <enabled>true</enabled>
  <lastModified>
    <time>1442535649135</time>
    <timezone>America/Los_Angeles</timezone>
  </lastModified>
  <revision>30</revision>
  <sourceConnector version="3.2.1">
    <metaDataId>0</metaDataId>
    <name>sourceConnector</name>
    <properties class="com.mirth.connect.connectors.file.FileReceiverProperties" version="3.2.1">
      <pluginProperties/>
      <pollConnectorProperties version="3.2.1">
        <pollingType>interval</pollingType>
        <pollingHour>0</pollingHour>
        <pollingMinute>0</pollingMinute>
        <pollingFrequency>15000</pollingFrequency>
      </pollConnectorProperties>
      <sourceConnectorProperties version="3.2.1">
        <responseVariable>None</responseVariable>
        <respondAfterProcessing>true</respondAfterProcessing>
        <processBatch>true</processBatch>
        <firstResponse>true</firstResponse>
        <resourceIds class="linked-hash-set">
          <string>Default Resource</string>
        </resourceIds>
      </sourceConnectorProperties>
      <scheme>FILE</scheme>
      <host>D:/HealthLevel Data/sch/listener-hl7-adt/source/</host>
      <fileFilter>*.hl7</fileFilter>
      <regex>false</regex>
      <directoryRecursion>true</directoryRecursion>
      <ignoreDot>true</ignoreDot>
      <anonymous>true</anonymous>
      <username>anonymous</username>
      <password>anonymous</password>
      <timeout>10000</timeout>
      <secure>true</secure>
      <passive>true</passive>
      <validateConnection>true</validateConnection>
      <afterProcessingAction>MOVE</afterProcessingAction>
      <moveToDirectory>D:/HealthLevel Data/sch/listener-hl7-adt/done/${date.get(&apos;yyyy-MM-dd&apos;)}/</moveToDirectory>
      <moveToFileName>${originalFilename}</moveToFileName>
      <errorReadingAction>MOVE</errorReadingAction>
      <errorResponseAction>MOVE</errorResponseAction>
      <errorMoveToDirectory>D:/HealthLevel Data/sch/listener-hl7-adt/error/${date.get(&apos;yyyy-MM-dd&apos;)}/</errorMoveToDirectory>
      <errorMoveToFileName>${originalFilename}</errorMoveToFileName>
      <checkFileAge>false</checkFileAge>
      <fileAge>1000</fileAge>
      <fileSizeMinimum>0</fileSizeMinimum>
      <fileSizeMaximum></fileSizeMaximum>
      <ignoreFileSizeMaximum>true</ignoreFileSizeMaximum>
      <sortBy>date</sortBy>
      <binary>false</binary>
      <charsetEncoding>DEFAULT_ENCODING</charsetEncoding>
    </properties>
    <transformer version="3.2.1">
      <steps>
        <step>
          <sequenceNumber>0</sequenceNumber>
          <name>Variable Declaration</name>
          <script>var errorDir = &quot;D:/HealthLevel Data/sch/listener-hl7-adt/error/&quot;;
var fileDir = &quot;D:/HealthLevel Data/sch/listener-psv/process/unprocessed/&quot;;
var fileName = &quot;ADT_sch_&quot;;




var newFileName=&quot;&quot;;
var MIN = 15;
var pipeBatch=&quot;&quot;;
// import java sql package to use prepared statements
importPackage(java.sql);
importPackage(java.io);

// Get Message ChildIndex
function getCI(seg)
{
	return seg.childIndex();
}

// Get Segment Name
function getSN(index)
{
	return (msg.children()[index]).name();
}

// Check source segement is same as the target Segment
function isSeg(src,tgt)
{
	return src == tgt ;
}

function getVal(index,sub,ssub, sssub)
{
	var segName = getSN(index);

	if (sssub)
	{
		if (sssub == 0)
			return msg.children()[index][segName+&apos;.&apos;+sub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub].toString();
		else
			return msg.children()[index][segName+&apos;.&apos;+sub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub+&apos;.&apos;+sssub].toString();	
	}
	else
	if(ssub == 0)
	{
//		logger.info(index+&quot;,&quot;+sub+&quot;,&quot;+ssub);
		var fieldLen = (msg.children()[index][segName+&apos;.&apos;+sub]).children().length();
		var res=&quot;&quot;;
		if(fieldLen &gt;= 1)
			res = (SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML((msg.children()[index][segName+&apos;.&apos;+sub])));
		return res;
	}
	else
		return msg.children()[index][segName+&apos;.&apos;+sub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub].toString();

	return &apos;&apos;;	
}


function converttoformattedtimestamp (tmpts2)
{
		return tmpts2;
		
	var retval = &apos;&apos; ;
	var tmpts = tmpts2.toString() ;
	var slen = tmpts.length();

	//logger.info(&apos;len:&apos;+slen.toString());


	if (slen &lt; 4)
		return &apos;&apos;;
		
	var yyyy = tmpts.toString().substr(0,4) ;
	var month = tmpts.substr(4,2);
	var day = tmpts.substr(6,2);

	retval = yyyy.toString() + &apos;-&apos; + month.toString() + &apos;-&apos; + day.toString();
	//logger.info(&apos;tretval :&apos;+retval);

	var hh = &apos;&apos; ;
	var minutes = &apos;&apos; ;
	var ss = &apos;&apos; ;
	
	if (slen &gt;= 12)
	{
		hh = tmpts.substr(8, 2);
		minutes= tmpts.substr(10,2) ;
		retval = retval + &apos; &apos; + hh.toString() + &apos;:&apos; + minutes.toString();
	}
		
	if (slen &gt;= 14)
	{
		ss= tmpts.substr(12,2) 
		retval = retval + &apos;:&apos; + ss.toString() ;
	}

	//logger.info(&apos;returning retval :&apos;+retval.toString());
	return retval.toString() ;
}

function handler_msh(rec, msg)
{
	rec.msgsendingapp = msg[&apos;MSH&apos;][&apos;MSH.3&apos;][&apos;MSH.3.1&apos;].toString();
	rec.msgsendingfacility = msg[&apos;MSH&apos;][&apos;MSH.4&apos;][&apos;MSH.4.1&apos;].toString();
	rec.msgtype = msg[&apos;MSH&apos;][&apos;MSH.9&apos;][&apos;MSH.9.1&apos;].toString();
	rec.msgtrigger = msg[&apos;MSH&apos;][&apos;MSH.9&apos;][&apos;MSH.9.2&apos;].toString();
	rec.ts_msg = converttoformattedtimestamp (msg[&apos;MSH&apos;][&apos;MSH.7&apos;][&apos;MSH.7.1&apos;].toString());

	rec.security = msg[&apos;MSH&apos;][&apos;MSH.8&apos;][&apos;MSH.8.1&apos;].toString();
	
}

function handler_pid(rec, msg)
{
	// PID Segment Entries
	var numofempis = msg[&apos;PID&apos;][&apos;PID.2&apos;].length();
	if (numofempis &gt;= 1)
		rec.empi = msg[&apos;PID&apos;][&apos;PID.2&apos;][numofempis-1][&apos;PID.2.1&apos;].toString();
	var numofMRNs = msg[&apos;PID&apos;][&apos;PID.3&apos;].length();
	rec.mrn = msg[&apos;PID&apos;][&apos;PID.3&apos;][numofMRNs-1][&apos;PID.3.1&apos;].toString();
	
	rec.dob = msg[&apos;PID&apos;][&apos;PID.7&apos;][&apos;PID.7.1&apos;].toString();
	rec.sex = msg[&apos;PID&apos;][&apos;PID.8&apos;][&apos;PID.8.1&apos;].toString();
	
	var numrace = msg[&apos;PID&apos;][&apos;PID.10&apos;].length();
	if (numrace &gt;= 1)
	{
		rec.race = msg[&apos;PID&apos;][&apos;PID.10&apos;][numrace-1][&apos;PID.10.1&apos;].toString();
	}
	var numaddresses = msg[&apos;PID&apos;][&apos;PID.11&apos;].length();
	if (numaddresses &gt;= 1)
	{
		rec.city = msg[&apos;PID&apos;][&apos;PID.11&apos;][numaddresses-1][&apos;PID.11.3&apos;].toString();
		rec.zip = msg[&apos;PID&apos;][&apos;PID.11&apos;][numaddresses-1][&apos;PID.11.5&apos;].toString();	
		rec.county = msg[&apos;PID&apos;][&apos;PID.11&apos;][numaddresses-1][&apos;PID.11.9&apos;].toString();
	}

	rec.language = msg[&apos;PID&apos;][&apos;PID.15&apos;][&apos;PID.15.1&apos;].toString();
	rec.ms = msg[&apos;PID&apos;][&apos;PID.16&apos;][&apos;PID.16.1&apos;].toString();
	rec.religion = msg[&apos;PID&apos;][&apos;PID.17&apos;][&apos;PID.17.1&apos;].toString();
	rec.ethnicgroup = msg[&apos;PID&apos;][&apos;PID.22&apos;][&apos;PID.22.1&apos;].toString();
	rec.birthorder = msg[&apos;PID&apos;][&apos;PID.25&apos;][&apos;PID.25.1&apos;].toString();
	rec.death = msg[&apos;PID&apos;][&apos;PID.30&apos;][&apos;PID.30.1&apos;].toString();

	if (rec.msgtype &amp;&amp; rec.msgtype == &apos;ADT&apos;)
		rec.har = msg[&apos;PID&apos;][&apos;PID.18&apos;][&apos;PID.18.1&apos;].toString();
	else
	{
		var numvisits = msg[&apos;PID&apos;][&apos;PID.18&apos;].length();
		if (numvisits &gt;= 1)
			rec.visitnumber = msg[&apos;PID&apos;][&apos;PID.18&apos;][numvisits-1][&apos;PID.18.1&apos;].toString();
	}	
	rec.info = &apos;PATIENT_DEM&apos;;
	
	AddToBuffer(rec);
	//clean all, EXCEPT identifiers.
	rec.info = &apos;&apos;;
	rec.dob = &apos;&apos;;
	rec.sex = &apos;&apos;;
	rec.race = &apos;&apos;;	
	rec.language = &apos;&apos;;
     rec.ms = &apos;&apos;;
     rec.religion = &apos;&apos;;
	rec.city = &apos;&apos;;
	rec.zip = &apos;&apos;;
	rec.county = &apos;&apos;;
	rec.ethnicgroup = &apos;&apos;;
	rec.birthorder = &apos;&apos;;
	rec.death = &apos;&apos;;
		
	// check if the above list cleanup matches setup
}


function handler_pd1(rec, msg)
{
	// PID Segment Entries
	var PCPcount = msg[&apos;PD1&apos;][&apos;PD1.4&apos;].length();
	if (PCPcount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PD1&apos;][&apos;PD1.4&apos;][PCPcount-1][&apos;PD1.4.3&apos;].toString();
		rec.staff_last = msg[&apos;PD1&apos;][&apos;PD1.4&apos;][PCPcount-1][&apos;PD1.4.2&apos;].toString();
		rec.staff_middle = msg[&apos;PD1&apos;][&apos;PD1.4&apos;][PCPcount-1][&apos;PD1.4.4&apos;].toString();
		rec.info = &apos;STAFF&apos;;
		rec.staff_role = &apos;PCP&apos;;

		AddToBuffer(rec);

		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;
	}
		
	// check if the above list cleanup matches setup
}

function handler_pv1(rec, msg)
{
	var len = parseInt(msg[&apos;PV1&apos;].length());
	if (len &lt;= 0)
	{
		return;
	}
	rec.patientclass = msg[&apos;PV1&apos;][&apos;PV1.2&apos;][0][&apos;PV1.2.1&apos;].toString();
	rec.patientlocation = msg[&apos;PV1&apos;][&apos;PV1.3&apos;][0][&apos;PV1.3.1&apos;].toString();
	rec.patientroom = msg[&apos;PV1&apos;][&apos;PV1.3&apos;][0][&apos;PV1.3.2&apos;].toString();
	rec.admittype = msg[&apos;PV1&apos;][&apos;PV1.4&apos;][0][&apos;PV1.4.1&apos;].toString();
	rec.patienttype = msg[&apos;PV1&apos;][&apos;PV1.18&apos;][0][&apos;PV1.18.1&apos;].toString();
	rec.hospitalservice = msg[&apos;PV1&apos;][&apos;PV1.10&apos;][0][&apos;PV1.10.1&apos;].toString();
	rec.servicingfacility = msg[&apos;PV1&apos;][&apos;PV1.39&apos;][0][&apos;PV1.39.1&apos;].toString();
	rec.vip = msg[&apos;PV1&apos;][&apos;PV1.16&apos;][0][&apos;PV1.16.1&apos;].toString();
	rec.pendinglocation = msg[&apos;PV1&apos;][&apos;PV1.42&apos;][0][&apos;PV1.42.1&apos;].toString();
	rec.pendingroom = msg[&apos;PV1&apos;][&apos;PV1.42&apos;][0][&apos;PV1.42.2&apos;].toString();

	var visitnum = msg[&apos;PV1&apos;][&apos;PV1.19&apos;][0][&apos;PV1.19.1&apos;].toString();
	if (visitnum != &apos;&apos;) // if visit is present, then use, otherwise, ignore
		rec.visitnumber = visitnum;
		
	rec.info = &apos;PATIENT_VISIT&apos;;
	
	AddToBuffer(rec);

	rec.patientclass = &apos;&apos; ;
	rec.patientlocation = &apos;&apos; ;
	rec.admittype = &apos;&apos; ;
	rec.patienttype = &apos;&apos; ;
	rec.hospitalservice = &apos;&apos; ;
	rec.servicingfacility = &apos;&apos; ;
	rec.vip = &apos;&apos; ;
	rec.info = &apos;&apos;;
	
	var AdmitMDCount = msg[&apos;PV1&apos;][&apos;PV1.17&apos;].length();
	if (AdmitMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.17&apos;][AdmitMDCount-1][&apos;PV1.17.3&apos;].toString();
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.17&apos;][AdmitMDCount-1][&apos;PV1.17.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.17&apos;][AdmitMDCount-1][&apos;PV1.17.4&apos;].toString();
			rec.staff_role = &apos;Admitting MD&apos;;
			rec.info = &apos;STAFF&apos;;
	
			AddToBuffer(rec);
		}
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}

	var attMDCount = msg[&apos;PV1&apos;][&apos;PV1.7&apos;].length();
	if (attMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.7&apos;][attMDCount-1][&apos;PV1.7.3&apos;].toString();
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.7&apos;][attMDCount-1][&apos;PV1.7.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.7&apos;][attMDCount-1][&apos;PV1.7.4&apos;].toString();
			rec.staff_role = &apos;Attending MD&apos;;
			rec.info = &apos;STAFF&apos;;
	
			AddToBuffer(rec);
		}
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}


	var RefMDCount = msg[&apos;PV1&apos;][&apos;PV1.8&apos;].length();
	if (RefMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.8&apos;][RefMDCount-1][&apos;PV1.8.3&apos;].toString();
		if (rec.staff_first)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.8&apos;][RefMDCount-1][&apos;PV1.8.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.8&apos;][RefMDCount-1][&apos;PV1.8.4&apos;].toString();
			rec.info = &apos;STAFF&apos;;
			rec.staff_role = &apos;Referring MD&apos;;
	
			AddToBuffer(rec);
		}
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}

	var ConsultingMDCount = msg[&apos;PV1&apos;][&apos;PV1.9&apos;].length();
	if (ConsultingMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.9&apos;][ConsultingMDCount-1][&apos;PV1.9.3&apos;].toString();
		if (rec.staff_first)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.9&apos;][ConsultingMDCount-1][&apos;PV1.9.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.9&apos;][ConsultingMDCount-1][&apos;PV1.9.4&apos;].toString();
			rec.info = &apos;STAFF&apos;;
			rec.staff_role = &apos;Consulting MD&apos;;	
			AddToBuffer(rec);
		}

		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}	
	
	rec.ts_when = converttoformattedtimestamp(msg[&apos;PV1&apos;][&apos;PV1.44&apos;][0][&apos;PV1.44.1&apos;].toString() )  ;
	if (rec.ts_when != &apos;&apos;)
	{
		rec.workflow_state = &apos;ts_admit&apos;;
		rec.info = &apos;WORKFLOWSTATE&apos;;
		AddToBuffer (rec);
		rec.info = &apos;&apos; ;
		rec.workflow_state = &apos;&apos;;
	}

	rec.ts_when = converttoformattedtimestamp(msg[&apos;PV1&apos;][&apos;PV1.45&apos;][0][&apos;PV1.45.1&apos;].toString() )  ;
	if (rec.ts_when != &apos;&apos;)
	{
		rec.workflow_state = &apos;ts_discharge&apos;;
		rec.info = &apos;WORKFLOWSTATE&apos;;
		AddToBuffer (rec);
		rec.info = &apos;&apos; ;
		rec.workflow_state = &apos;&apos;;
	}
	
	
}

function handler_pv2(rec, msg)
{
	var len = parseInt(msg[&apos;PV2&apos;].length());
	if (len &lt;= 0)
	{
		return;
	}
	rec.hospitalservice = msg[&apos;PV2&apos;][&apos;PV2.12&apos;][0][&apos;PV2.12.1&apos;].toString();
	rec.ts_when = converttoformattedtimestamp(msg[&apos;PV2&apos;][&apos;PV2.8&apos;][0][&apos;PV2.8.1&apos;].toString() )  ;
	if (rec.ts_when != &apos;&apos;)
	{
		rec.workflow_state = &apos;ts_scheduledfor&apos;;
		rec.info = &apos;WORKFLOWSTATE&apos;;
		AddToBuffer (rec);
		rec.info = &apos;&apos; ;
		rec.workflow_state = &apos;&apos;;
	}

}

function handler_DG1(rec, msg)
{
	var len = parseInt(msg[&apos;DGI1&apos;].length());
	rec.info = &apos;CONDITIONS&apos;;
	for (i=0; i&lt; len;i++)
	{
		rec.attribute_name =  &apos;DIAGNOSIS&apos; ;
		rec.attribute_id =  msg[&apos;DG1&apos;][i][&apos;DG1.3&apos;][&apos;DG1.3.1&apos;].toString() ;
		rec.attribute_value =  msg[&apos;DG1&apos;][i][&apos;DG1.3&apos;][&apos;DG1.3.2&apos;].toString() ;
		rec.coding_system =  msg[&apos;DG1&apos;][i][&apos;DG1.3&apos;][&apos;DG1.3.3&apos;].toString() ;
		rec.ts_when =  msg.ts_msg ;
		AddToBuffer (rec);
	}
	rec.info = &apos;&apos;;
	rec.attribute_name  = &apos;&apos;;
	rec.attribute_id  = &apos;&apos;;
	rec.attribute_value =  &apos;&apos;;
	rec.coding_system = &apos;&apos;;
	rec.ts_when =  &apos;&apos;;
}


function handler_in1(rec, msg)
{
	var len = parseInt(msg[&apos;IN1&apos;].length());
	rec.info = &apos;PAYER&apos;;
	for (i=0; i&lt; len;i++)
	{
		rec.attribute_value =  msg[&apos;IN1&apos;][i][&apos;IN1.4&apos;][&apos;IN1.4.1&apos;].toString() ;
		rec.value_status =  msg[&apos;IN1&apos;][i][&apos;IN1.22&apos;][&apos;IN1.22.1&apos;].toString() ;
		rec.ts_when =  converttoformattedtimestamp(msg[&apos;IN1&apos;][i][&apos;IN1.29&apos;][&apos;IN1.29.1&apos;].toString()) ;
		AddToBuffer (rec);
	}
	rec.info = &apos;&apos;;
	rec.attribute_value =  &apos;&apos;;
	rec.value_status =  &apos;&apos;;
	rec.ts_when =  &apos;&apos;;
}

function handler_al1(rec, msg)
{
	var len = parseInt(msg[&apos;AL1&apos;].length());
	for (i=0; i&lt; len;i++)
	{
		rec.info = &apos;CONDITION&apos;;
		rec.attribute_name = &apos;ALLERGY&apos;;
		rec.value_status =msg[&apos;AL1&apos;][i] ? msg[&apos;AL1&apos;][i][&apos;AL1.2&apos;][&apos;AL1.2.1&apos;].toString() : &apos;&apos;;
		rec.attribute_id = msg[&apos;AL1&apos;][i] ? msg[&apos;AL1&apos;][i][&apos;AL1.3&apos;][&apos;AL1.3.1&apos;].toString(): &apos;&apos;;
		rec.attribute_value = msg[&apos;AL1&apos;][i] ? msg[&apos;AL1&apos;][i][&apos;AL1.3&apos;][&apos;AL1.3.2&apos;].toString(): &apos;&apos;;
		AddToBuffer (rec);
	}
	rec.value_status = &apos;&apos;;
	rec.attribute_id = &apos;&apos;;
	rec.attribute_value = &apos;&apos;;
	rec.info = &apos;&apos;;
	rec.attribute_name = &apos;&apos;;
}

function handler_obr_rad (rec, msg)
{
	var obrlen = parseInt(msg[&apos;OBR&apos;].length());
	for (var i=0;i&lt;obrlen;i++)
	{
		var workflowstatus_assembler = &apos;&apos;;
		var obrIndex = getCI(msg[&apos;OBR&apos;][i]);
		//logger.info(segIndex);
		// Parsing ORC Segment
		var orcIndex = obrIndex - 1;
		var orcAvailable = isSeg(getSN(orcIndex),&apos;ORC&apos;);
		if (orcAvailable == true)
		{
			rec.orccontrol = orcAvailable ? getVal(orcIndex,1,1):&apos;&apos;;
			rec.orcstatus = orcAvailable ? getVal(orcIndex,5,1):&apos;&apos;;
			workflowstatus_assembler += rec.orccontrol + &apos;-&apos; + rec.orcstatus;
			
			rec.orcfiller = orcAvailable ? getVal(orcIndex,3,1):&apos;&apos;;
			rec.orderstatus = orcAvailable ? getVal(orcIndex,5,1):&apos;&apos;;
			rec.priority = orcAvailable ? getVal(orcIndex,7,6):&apos;&apos;;		
			rec.enteringorganization = orcAvailable ? getVal(orcIndex,17,1):&apos;&apos;;			
		}
		//logger.info(rec.orc91+&quot;,&quot;+rec.orc101+&quot;,&quot;+rec.orc113);

		// Parsing OBR Segment

		var numofobr201repeats = msg[&apos;OBR&apos;][i][&apos;OBR.20&apos;].length();
		//logger.info(&apos;numfoobr201repeats:&apos;+numofobr201repeats.toString());
		if (numofobr201repeats &gt; 0)
		{
			//logger.info(msg[&apos;OBR&apos;][&apos;OBR.20&apos;][0][&apos;OBR.20.2&apos;].toString());
			if (msg[&apos;OBR&apos;][i][&apos;OBR.20&apos;][0][&apos;OBR.20.2&apos;].toString() == &apos;HNA_ACCN&apos;)
			{
				var tmpstr = msg[&apos;OBR&apos;][i][&apos;OBR.20&apos;][0][&apos;OBR.20.1&apos;].toString();
				var part1 = tmpstr.substr(5,2);
				var part2 = tmpstr.substr(9,2);
				var part3 = tmpstr.substr(tmpstr.length-5,5);
				//logger.info(&apos;wholefield:&apos;+tmpstr);
				//logger.info(&apos;part1:&apos;+part1);
				//logger.info(&apos;part2:&apos;+part2);
				//logger.info(&apos;part3:&apos;+part3);
				rec.placerorder = part1+part2+part3;
				//logger.info(&apos;accn#:&apos; + rec.placerorder);
			}	
		}
		
		rec.fillerorder = getVal(obrIndex,3,1);

		if (rec.msgtype = &apos;ORU&apos;)
		{
			rec.cptcode = getVal(obrIndex,4,1);
			rec.cptname = getVal(obrIndex,4,2);
		}
		else
		{
			rec.ordercode = getVal(obrIndex,4,1);
			rec.ordername = getVal(obrIndex,4,2);
		}
		rec.reasonforstudy = getVal(obrIndex,31,2);
		rec.relevantclinicalinfo = getVal(obrIndex,13,1);
		rec.performingresource = getVal(obrIndex,21,1);
		rec.department = getVal(obrIndex,24,1);
		rec.info = &apos;CaseInfo&apos;;

		AddToBuffer (rec);	 // basic case info

		rec.cptcode = &apos;&apos;;
		rec.cptname = &apos;&apos;;
		rec.ordercode = &apos;&apos;;
		rec.ordername = &apos;&apos;;
		rec.reasonforstudy = &apos;&apos;;
		rec.relevantclinicalinfo = &apos;&apos;;
		rec.performingresource = &apos;&apos;;
		rec.department = &apos;&apos;;
		
		rec.staff_first = getVal(obrIndex, 16, 3);
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last = getVal(obrIndex, 16, 2);
			rec.staff_middle = getVal(obrIndex, 16, 4);
			rec.staff_role = &apos;Ordering MD&apos; ;
			rec.info = &apos;STAFF&apos;;
			AddToBuffer (rec);	 // basic info
		}
		
		rec.staff_first  =  getVal(obrIndex, 32, 1, 3);// msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.3&apos;].toString()   ;//     getVal(obrIndex, 16, 3);
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last   =  getVal(obrIndex, 32, 1, 2);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.2&apos;].toString()   ;
			rec.staff_middle =  getVal(obrIndex, 32, 1, 4);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.4&apos;].toString()  ;
			rec.staff_role = &apos;Attending Radiologist&apos; ;
			rec.info = &apos;STAFF&apos;;
			//logger.info (&apos;staff:&apos;+rec.staff_first+&apos; &apos; + rec.staff_last + &apos; &apos; + rec.staff_middle);
			AddToBuffer (rec);	 // basic info
		}		

		rec.staff_first =   getVal(obrIndex, 35, 1, 3); // msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.3&apos;].toString()   ;//     getVal(obrIndex, 16, 3);
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last =  getVal(obrIndex, 35, 1, 2);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.2&apos;].toString()   ;
			rec.staff_middle = getVal(obrIndex, 35, 1, 4);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.4&apos;].toString()  ;
			rec.info = &apos;STAFF&apos;;
			rec.staff_role = &apos;Resident&apos; ;
			AddToBuffer (rec);	 // basic info
		}

		if (orcAvailable)
		{
			if (rec.orcstatus == &apos;RADSTART&apos; || rec.orcstatus == &apos;RADCOMP&apos;)
			{
				rec.staff_first = getVal(orcIndex,19,3);
				if (rec.staff_first != &apos;&apos;)
				{
					rec.staff_last = getVal(orcIndex,19,2);
					rec.staff_middle = getVal(orcIndex,19,4);
					rec.info = &apos;STAFF&apos;;
					rec.staff_role = &apos;Technologist&apos;;
					AddToBuffer (rec);	 // basic info		
					//logger.info(rec.staff_first+&apos;-&apos;+rec.staff_last);
				}
			}
		}

		rec.staff_role = &apos;&apos; ;
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_mnemonic = &apos;&apos;;
		rec.info = &apos;&apos;;

		rec.info = &apos;WORKFLOWSTATE&apos;;
		
		rec.workflow_state = &apos;ts_start&apos; ;
		rec.ts_when = getVal(obrIndex, 7, 1);
		AddToBuffer (rec);	 // basic info

		rec.workflow_state = &apos;ts_stop&apos; ;
		rec.ts_when = getVal(obrIndex, 8, 1);
		AddToBuffer (rec);	 // basic info

		if (rec.msgtype = &apos;ORU&apos;)
		{
			rec.workflow_state = workflowstatus_assembler + &apos;-&apos; + getVal(obrIndex, 25, 1);
			rec.ts_when = rec.ts_msg;
			AddToBuffer (rec);	 // basic info	
		}
		else // ORM
		{
			rec.workflow_state = workflowstatus_assembler ; //: &apos;ts_unknown&apos;;
			rec.ts_when = converttoformattedtimestamp(getVal(obrIndex, 22, 1)); //msg[&apos;OBR&apos;][&apos;OBR.22&apos;][&apos;OBR.22.1&apos;].toString() )  ;
			AddToBuffer (rec);	 // basic info
		}

		rec.workflow_state = &apos;&apos;;
		rec.ts_when = &apos;&apos;;
		rec.info = &apos;&apos;;

	}//end of obr loop for n obr segments...
	
}



function handler_obx_rad(rec, msg)
{
	var len = parseInt(msg[&apos;OBX&apos;].length());
//logger.info(&apos;obx len:&apos;+len.toString());
	for (i=0; i&lt; len;i++)
	{
//logger.info(&apos;in obx:&apos;+i.toString());
		//rec.info = &apos;CONDITION&apos;;
		//rec.local_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.1&apos;].toString() : &apos;&apos;;
		//rec.local_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.2&apos;].toString() : &apos;&apos;;
		//rec.local_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.3&apos;].toString() : &apos;&apos;;

		//rec.attribute_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.4&apos;].toString() : &apos;&apos;;
		//rec.attribute_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.5&apos;].toString() : &apos;&apos;;
		//rec.coding_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.6&apos;].toString() : &apos;&apos;;

				// dont get report text at this time contains the huge text
		//rec.attribute_value = &apos;report text&apos;; //msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.5&apos;][&apos;OBX.5.1&apos;].toString() : &apos;&apos;;
		//rec.attribute_units = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.6&apos;][&apos;OBX.6.1&apos;].toString() : &apos;&apos;;
		//rec.reference_range = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.7&apos;][&apos;OBX.7.1&apos;].toString() : &apos;&apos;;
		//rec.abnormal_flag =  msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.10&apos;][&apos;OBX.11.1&apos;].toString() : &apos;&apos;;

		if (rec.msgtype = &apos;ORU&apos;)
		{
			rec.info = &apos;WORKFLOWSTATE&apos;;
			rec.workflow_state =  msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.11&apos;][&apos;OBX.11.1&apos;].toString() : &apos;&apos;;
			rec.ts_when =  converttoformattedtimestamp(msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.14&apos;][&apos;OBX.14.1&apos;].toString() : &apos;&apos;) ; 
			if (rec.ts_when == &apos;&apos;) // use message time stamp if the actual observation ts is empty.
				rec.ts_when = rec.ts_msg;
				
			AddToBuffer (rec);
			rec.info = &apos;&apos; ;
			rec.workflow_state = &apos;&apos;;
			rec.ts_when = &apos;&apos;;
		}
		else
		{
			//rec.info = &apos;CONDITION&apos;;
			//rec.local_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.1&apos;].toString() : &apos;&apos;;
			//rec.local_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.2&apos;].toString() : &apos;&apos;;
			//rec.local_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.3&apos;].toString() : &apos;&apos;;
	
			//rec.attribute_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.4&apos;].toString() : &apos;&apos;;
			//rec.attribute_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.5&apos;].toString() : &apos;&apos;;
			//rec.coding_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.6&apos;].toString() : &apos;&apos;;

					// dont get report text at this time contains the huge text
			//rec.attribute_value = &apos;report text&apos;; //msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.5&apos;][&apos;OBX.5.1&apos;].toString() : &apos;&apos;;
			//rec.attribute_units = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.6&apos;][&apos;OBX.6.1&apos;].toString() : &apos;&apos;;
			//rec.reference_range = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.7&apos;][&apos;OBX.7.1&apos;].toString() : &apos;&apos;;
			//rec.abnormal_flag =  msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.10&apos;][&apos;OBX.11.1&apos;].toString() : &apos;&apos;;
		}
	}
	rec.infotype = &apos;&apos;;
	rec.local_id = &apos;&apos; ;
	rec.local_name = &apos;&apos;;
	rec.local_system = &apos;&apos;;
	rec.attribute_id = &apos;&apos;;
	rec.attribute_name = &apos;&apos;;
	rec.coding_system = &apos;&apos;;
	rec.attribute_value = &apos;&apos;;
	rec.attribute_units = &apos;&apos;;
	rec.value_status = &apos;&apos;;

}

try
{
	var rec = {};

	handler_msh (rec, msg);
	//handler_evn (rec, msg);
	handler_pid (rec, msg);
	handler_pd1 (rec, msg);
	
	handler_pv1 (rec, msg);
	handler_pv2 (rec, msg);
	
	//handler_obr_rad (rec, msg);
	//handler_obx_rad (rec, msg);
	
	handler_al1(rec, msg);
	handler_in1(rec, msg);

	// get the maximum cardinality of IN1, FT1, AL1, OBR Segments	
	writeContent();		
}
catch(exception)
{
	var dateString = DateUtil.getCurrentDate(&apos;yyyyMMddHHmmss&apos;);
	var hl7 = SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML(msg);
	FileUtil.write(errorDir+&apos;Error_&apos;+dateString+&apos;.hl7&apos;, false, hl7);
	throw(exception);
}</script>
          <type>JavaScript</type>
          <data>
            <entry>
              <string>Script</string>
              <string>var errorDir = &quot;D:/HealthLevel Data/sch/listener-hl7-adt/error/&quot;;
var fileDir = &quot;D:/HealthLevel Data/sch/listener-psv/process/unprocessed/&quot;;
var fileName = &quot;ADT_sch_&quot;;




var newFileName=&quot;&quot;;
var MIN = 15;
var pipeBatch=&quot;&quot;;
// import java sql package to use prepared statements
importPackage(java.sql);
importPackage(java.io);

// Get Message ChildIndex
function getCI(seg)
{
	return seg.childIndex();
}

// Get Segment Name
function getSN(index)
{
	return (msg.children()[index]).name();
}

// Check source segement is same as the target Segment
function isSeg(src,tgt)
{
	return src == tgt ;
}

function getVal(index,sub,ssub, sssub)
{
	var segName = getSN(index);

	if (sssub)
	{
		if (sssub == 0)
			return msg.children()[index][segName+&apos;.&apos;+sub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub].toString();
		else
			return msg.children()[index][segName+&apos;.&apos;+sub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub+&apos;.&apos;+sssub].toString();	
	}
	else
	if(ssub == 0)
	{
//		logger.info(index+&quot;,&quot;+sub+&quot;,&quot;+ssub);
		var fieldLen = (msg.children()[index][segName+&apos;.&apos;+sub]).children().length();
		var res=&quot;&quot;;
		if(fieldLen &gt;= 1)
			res = (SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML((msg.children()[index][segName+&apos;.&apos;+sub])));
		return res;
	}
	else
		return msg.children()[index][segName+&apos;.&apos;+sub][segName+&apos;.&apos;+sub+&apos;.&apos;+ssub].toString();

	return &apos;&apos;;	
}


function converttoformattedtimestamp (tmpts2)
{
		return tmpts2;
		
	var retval = &apos;&apos; ;
	var tmpts = tmpts2.toString() ;
	var slen = tmpts.length();

	//logger.info(&apos;len:&apos;+slen.toString());


	if (slen &lt; 4)
		return &apos;&apos;;
		
	var yyyy = tmpts.toString().substr(0,4) ;
	var month = tmpts.substr(4,2);
	var day = tmpts.substr(6,2);

	retval = yyyy.toString() + &apos;-&apos; + month.toString() + &apos;-&apos; + day.toString();
	//logger.info(&apos;tretval :&apos;+retval);

	var hh = &apos;&apos; ;
	var minutes = &apos;&apos; ;
	var ss = &apos;&apos; ;
	
	if (slen &gt;= 12)
	{
		hh = tmpts.substr(8, 2);
		minutes= tmpts.substr(10,2) ;
		retval = retval + &apos; &apos; + hh.toString() + &apos;:&apos; + minutes.toString();
	}
		
	if (slen &gt;= 14)
	{
		ss= tmpts.substr(12,2) 
		retval = retval + &apos;:&apos; + ss.toString() ;
	}

	//logger.info(&apos;returning retval :&apos;+retval.toString());
	return retval.toString() ;
}

function handler_msh(rec, msg)
{
	rec.msgsendingapp = msg[&apos;MSH&apos;][&apos;MSH.3&apos;][&apos;MSH.3.1&apos;].toString();
	rec.msgsendingfacility = msg[&apos;MSH&apos;][&apos;MSH.4&apos;][&apos;MSH.4.1&apos;].toString();
	rec.msgtype = msg[&apos;MSH&apos;][&apos;MSH.9&apos;][&apos;MSH.9.1&apos;].toString();
	rec.msgtrigger = msg[&apos;MSH&apos;][&apos;MSH.9&apos;][&apos;MSH.9.2&apos;].toString();
	rec.ts_msg = converttoformattedtimestamp (msg[&apos;MSH&apos;][&apos;MSH.7&apos;][&apos;MSH.7.1&apos;].toString());

	rec.security = msg[&apos;MSH&apos;][&apos;MSH.8&apos;][&apos;MSH.8.1&apos;].toString();
	
}

function handler_pid(rec, msg)
{
	// PID Segment Entries
	var numofempis = msg[&apos;PID&apos;][&apos;PID.2&apos;].length();
	if (numofempis &gt;= 1)
		rec.empi = msg[&apos;PID&apos;][&apos;PID.2&apos;][numofempis-1][&apos;PID.2.1&apos;].toString();
	var numofMRNs = msg[&apos;PID&apos;][&apos;PID.3&apos;].length();
	rec.mrn = msg[&apos;PID&apos;][&apos;PID.3&apos;][numofMRNs-1][&apos;PID.3.1&apos;].toString();
	
	rec.dob = msg[&apos;PID&apos;][&apos;PID.7&apos;][&apos;PID.7.1&apos;].toString();
	rec.sex = msg[&apos;PID&apos;][&apos;PID.8&apos;][&apos;PID.8.1&apos;].toString();
	
	var numrace = msg[&apos;PID&apos;][&apos;PID.10&apos;].length();
	if (numrace &gt;= 1)
	{
		rec.race = msg[&apos;PID&apos;][&apos;PID.10&apos;][numrace-1][&apos;PID.10.1&apos;].toString();
	}
	var numaddresses = msg[&apos;PID&apos;][&apos;PID.11&apos;].length();
	if (numaddresses &gt;= 1)
	{
		rec.city = msg[&apos;PID&apos;][&apos;PID.11&apos;][numaddresses-1][&apos;PID.11.3&apos;].toString();
		rec.zip = msg[&apos;PID&apos;][&apos;PID.11&apos;][numaddresses-1][&apos;PID.11.5&apos;].toString();	
		rec.county = msg[&apos;PID&apos;][&apos;PID.11&apos;][numaddresses-1][&apos;PID.11.9&apos;].toString();
	}

	rec.language = msg[&apos;PID&apos;][&apos;PID.15&apos;][&apos;PID.15.1&apos;].toString();
	rec.ms = msg[&apos;PID&apos;][&apos;PID.16&apos;][&apos;PID.16.1&apos;].toString();
	rec.religion = msg[&apos;PID&apos;][&apos;PID.17&apos;][&apos;PID.17.1&apos;].toString();
	rec.ethnicgroup = msg[&apos;PID&apos;][&apos;PID.22&apos;][&apos;PID.22.1&apos;].toString();
	rec.birthorder = msg[&apos;PID&apos;][&apos;PID.25&apos;][&apos;PID.25.1&apos;].toString();
	rec.death = msg[&apos;PID&apos;][&apos;PID.30&apos;][&apos;PID.30.1&apos;].toString();

	if (rec.msgtype &amp;&amp; rec.msgtype == &apos;ADT&apos;)
		rec.har = msg[&apos;PID&apos;][&apos;PID.18&apos;][&apos;PID.18.1&apos;].toString();
	else
	{
		var numvisits = msg[&apos;PID&apos;][&apos;PID.18&apos;].length();
		if (numvisits &gt;= 1)
			rec.visitnumber = msg[&apos;PID&apos;][&apos;PID.18&apos;][numvisits-1][&apos;PID.18.1&apos;].toString();
	}	
	rec.info = &apos;PATIENT_DEM&apos;;
	
	AddToBuffer(rec);
	//clean all, EXCEPT identifiers.
	rec.info = &apos;&apos;;
	rec.dob = &apos;&apos;;
	rec.sex = &apos;&apos;;
	rec.race = &apos;&apos;;	
	rec.language = &apos;&apos;;
     rec.ms = &apos;&apos;;
     rec.religion = &apos;&apos;;
	rec.city = &apos;&apos;;
	rec.zip = &apos;&apos;;
	rec.county = &apos;&apos;;
	rec.ethnicgroup = &apos;&apos;;
	rec.birthorder = &apos;&apos;;
	rec.death = &apos;&apos;;
		
	// check if the above list cleanup matches setup
}


function handler_pd1(rec, msg)
{
	// PID Segment Entries
	var PCPcount = msg[&apos;PD1&apos;][&apos;PD1.4&apos;].length();
	if (PCPcount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PD1&apos;][&apos;PD1.4&apos;][PCPcount-1][&apos;PD1.4.3&apos;].toString();
		rec.staff_last = msg[&apos;PD1&apos;][&apos;PD1.4&apos;][PCPcount-1][&apos;PD1.4.2&apos;].toString();
		rec.staff_middle = msg[&apos;PD1&apos;][&apos;PD1.4&apos;][PCPcount-1][&apos;PD1.4.4&apos;].toString();
		rec.info = &apos;STAFF&apos;;
		rec.staff_role = &apos;PCP&apos;;

		AddToBuffer(rec);

		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;
	}
		
	// check if the above list cleanup matches setup
}

function handler_pv1(rec, msg)
{
	var len = parseInt(msg[&apos;PV1&apos;].length());
	if (len &lt;= 0)
	{
		return;
	}
	rec.patientclass = msg[&apos;PV1&apos;][&apos;PV1.2&apos;][0][&apos;PV1.2.1&apos;].toString();
	rec.patientlocation = msg[&apos;PV1&apos;][&apos;PV1.3&apos;][0][&apos;PV1.3.1&apos;].toString();
	rec.patientroom = msg[&apos;PV1&apos;][&apos;PV1.3&apos;][0][&apos;PV1.3.2&apos;].toString();
	rec.admittype = msg[&apos;PV1&apos;][&apos;PV1.4&apos;][0][&apos;PV1.4.1&apos;].toString();
	rec.patienttype = msg[&apos;PV1&apos;][&apos;PV1.18&apos;][0][&apos;PV1.18.1&apos;].toString();
	rec.hospitalservice = msg[&apos;PV1&apos;][&apos;PV1.10&apos;][0][&apos;PV1.10.1&apos;].toString();
	rec.servicingfacility = msg[&apos;PV1&apos;][&apos;PV1.39&apos;][0][&apos;PV1.39.1&apos;].toString();
	rec.vip = msg[&apos;PV1&apos;][&apos;PV1.16&apos;][0][&apos;PV1.16.1&apos;].toString();
	rec.pendinglocation = msg[&apos;PV1&apos;][&apos;PV1.42&apos;][0][&apos;PV1.42.1&apos;].toString();
	rec.pendingroom = msg[&apos;PV1&apos;][&apos;PV1.42&apos;][0][&apos;PV1.42.2&apos;].toString();

	var visitnum = msg[&apos;PV1&apos;][&apos;PV1.19&apos;][0][&apos;PV1.19.1&apos;].toString();
	if (visitnum != &apos;&apos;) // if visit is present, then use, otherwise, ignore
		rec.visitnumber = visitnum;
		
	rec.info = &apos;PATIENT_VISIT&apos;;
	
	AddToBuffer(rec);

	rec.patientclass = &apos;&apos; ;
	rec.patientlocation = &apos;&apos; ;
	rec.admittype = &apos;&apos; ;
	rec.patienttype = &apos;&apos; ;
	rec.hospitalservice = &apos;&apos; ;
	rec.servicingfacility = &apos;&apos; ;
	rec.vip = &apos;&apos; ;
	rec.info = &apos;&apos;;
	
	var AdmitMDCount = msg[&apos;PV1&apos;][&apos;PV1.17&apos;].length();
	if (AdmitMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.17&apos;][AdmitMDCount-1][&apos;PV1.17.3&apos;].toString();
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.17&apos;][AdmitMDCount-1][&apos;PV1.17.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.17&apos;][AdmitMDCount-1][&apos;PV1.17.4&apos;].toString();
			rec.staff_role = &apos;Admitting MD&apos;;
			rec.info = &apos;STAFF&apos;;
	
			AddToBuffer(rec);
		}
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}

	var attMDCount = msg[&apos;PV1&apos;][&apos;PV1.7&apos;].length();
	if (attMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.7&apos;][attMDCount-1][&apos;PV1.7.3&apos;].toString();
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.7&apos;][attMDCount-1][&apos;PV1.7.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.7&apos;][attMDCount-1][&apos;PV1.7.4&apos;].toString();
			rec.staff_role = &apos;Attending MD&apos;;
			rec.info = &apos;STAFF&apos;;
	
			AddToBuffer(rec);
		}
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}


	var RefMDCount = msg[&apos;PV1&apos;][&apos;PV1.8&apos;].length();
	if (RefMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.8&apos;][RefMDCount-1][&apos;PV1.8.3&apos;].toString();
		if (rec.staff_first)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.8&apos;][RefMDCount-1][&apos;PV1.8.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.8&apos;][RefMDCount-1][&apos;PV1.8.4&apos;].toString();
			rec.info = &apos;STAFF&apos;;
			rec.staff_role = &apos;Referring MD&apos;;
	
			AddToBuffer(rec);
		}
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}

	var ConsultingMDCount = msg[&apos;PV1&apos;][&apos;PV1.9&apos;].length();
	if (ConsultingMDCount &gt;= 1)
	{
		rec.staff_first = msg[&apos;PV1&apos;][&apos;PV1.9&apos;][ConsultingMDCount-1][&apos;PV1.9.3&apos;].toString();
		if (rec.staff_first)
		{
			rec.staff_last = msg[&apos;PV1&apos;][&apos;PV1.9&apos;][ConsultingMDCount-1][&apos;PV1.9.2&apos;].toString();
			rec.staff_middle = msg[&apos;PV1&apos;][&apos;PV1.9&apos;][ConsultingMDCount-1][&apos;PV1.9.4&apos;].toString();
			rec.info = &apos;STAFF&apos;;
			rec.staff_role = &apos;Consulting MD&apos;;	
			AddToBuffer(rec);
		}

		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_role = &apos;&apos;;
		rec.info = &apos;&apos; ;		
	}	
	
	rec.ts_when = converttoformattedtimestamp(msg[&apos;PV1&apos;][&apos;PV1.44&apos;][0][&apos;PV1.44.1&apos;].toString() )  ;
	if (rec.ts_when != &apos;&apos;)
	{
		rec.workflow_state = &apos;ts_admit&apos;;
		rec.info = &apos;WORKFLOWSTATE&apos;;
		AddToBuffer (rec);
		rec.info = &apos;&apos; ;
		rec.workflow_state = &apos;&apos;;
	}

	rec.ts_when = converttoformattedtimestamp(msg[&apos;PV1&apos;][&apos;PV1.45&apos;][0][&apos;PV1.45.1&apos;].toString() )  ;
	if (rec.ts_when != &apos;&apos;)
	{
		rec.workflow_state = &apos;ts_discharge&apos;;
		rec.info = &apos;WORKFLOWSTATE&apos;;
		AddToBuffer (rec);
		rec.info = &apos;&apos; ;
		rec.workflow_state = &apos;&apos;;
	}
	
	
}

function handler_pv2(rec, msg)
{
	var len = parseInt(msg[&apos;PV2&apos;].length());
	if (len &lt;= 0)
	{
		return;
	}
	rec.hospitalservice = msg[&apos;PV2&apos;][&apos;PV2.12&apos;][0][&apos;PV2.12.1&apos;].toString();
	rec.ts_when = converttoformattedtimestamp(msg[&apos;PV2&apos;][&apos;PV2.8&apos;][0][&apos;PV2.8.1&apos;].toString() )  ;
	if (rec.ts_when != &apos;&apos;)
	{
		rec.workflow_state = &apos;ts_scheduledfor&apos;;
		rec.info = &apos;WORKFLOWSTATE&apos;;
		AddToBuffer (rec);
		rec.info = &apos;&apos; ;
		rec.workflow_state = &apos;&apos;;
	}

}

function handler_DG1(rec, msg)
{
	var len = parseInt(msg[&apos;DGI1&apos;].length());
	rec.info = &apos;CONDITIONS&apos;;
	for (i=0; i&lt; len;i++)
	{
		rec.attribute_name =  &apos;DIAGNOSIS&apos; ;
		rec.attribute_id =  msg[&apos;DG1&apos;][i][&apos;DG1.3&apos;][&apos;DG1.3.1&apos;].toString() ;
		rec.attribute_value =  msg[&apos;DG1&apos;][i][&apos;DG1.3&apos;][&apos;DG1.3.2&apos;].toString() ;
		rec.coding_system =  msg[&apos;DG1&apos;][i][&apos;DG1.3&apos;][&apos;DG1.3.3&apos;].toString() ;
		rec.ts_when =  msg.ts_msg ;
		AddToBuffer (rec);
	}
	rec.info = &apos;&apos;;
	rec.attribute_name  = &apos;&apos;;
	rec.attribute_id  = &apos;&apos;;
	rec.attribute_value =  &apos;&apos;;
	rec.coding_system = &apos;&apos;;
	rec.ts_when =  &apos;&apos;;
}


function handler_in1(rec, msg)
{
	var len = parseInt(msg[&apos;IN1&apos;].length());
	rec.info = &apos;PAYER&apos;;
	for (i=0; i&lt; len;i++)
	{
		rec.attribute_value =  msg[&apos;IN1&apos;][i][&apos;IN1.4&apos;][&apos;IN1.4.1&apos;].toString() ;
		rec.value_status =  msg[&apos;IN1&apos;][i][&apos;IN1.22&apos;][&apos;IN1.22.1&apos;].toString() ;
		rec.ts_when =  converttoformattedtimestamp(msg[&apos;IN1&apos;][i][&apos;IN1.29&apos;][&apos;IN1.29.1&apos;].toString()) ;
		AddToBuffer (rec);
	}
	rec.info = &apos;&apos;;
	rec.attribute_value =  &apos;&apos;;
	rec.value_status =  &apos;&apos;;
	rec.ts_when =  &apos;&apos;;
}

function handler_al1(rec, msg)
{
	var len = parseInt(msg[&apos;AL1&apos;].length());
	for (i=0; i&lt; len;i++)
	{
		rec.info = &apos;CONDITION&apos;;
		rec.attribute_name = &apos;ALLERGY&apos;;
		rec.value_status =msg[&apos;AL1&apos;][i] ? msg[&apos;AL1&apos;][i][&apos;AL1.2&apos;][&apos;AL1.2.1&apos;].toString() : &apos;&apos;;
		rec.attribute_id = msg[&apos;AL1&apos;][i] ? msg[&apos;AL1&apos;][i][&apos;AL1.3&apos;][&apos;AL1.3.1&apos;].toString(): &apos;&apos;;
		rec.attribute_value = msg[&apos;AL1&apos;][i] ? msg[&apos;AL1&apos;][i][&apos;AL1.3&apos;][&apos;AL1.3.2&apos;].toString(): &apos;&apos;;
		AddToBuffer (rec);
	}
	rec.value_status = &apos;&apos;;
	rec.attribute_id = &apos;&apos;;
	rec.attribute_value = &apos;&apos;;
	rec.info = &apos;&apos;;
	rec.attribute_name = &apos;&apos;;
}

function handler_obr_rad (rec, msg)
{
	var obrlen = parseInt(msg[&apos;OBR&apos;].length());
	for (var i=0;i&lt;obrlen;i++)
	{
		var workflowstatus_assembler = &apos;&apos;;
		var obrIndex = getCI(msg[&apos;OBR&apos;][i]);
		//logger.info(segIndex);
		// Parsing ORC Segment
		var orcIndex = obrIndex - 1;
		var orcAvailable = isSeg(getSN(orcIndex),&apos;ORC&apos;);
		if (orcAvailable == true)
		{
			rec.orccontrol = orcAvailable ? getVal(orcIndex,1,1):&apos;&apos;;
			rec.orcstatus = orcAvailable ? getVal(orcIndex,5,1):&apos;&apos;;
			workflowstatus_assembler += rec.orccontrol + &apos;-&apos; + rec.orcstatus;
			
			rec.orcfiller = orcAvailable ? getVal(orcIndex,3,1):&apos;&apos;;
			rec.orderstatus = orcAvailable ? getVal(orcIndex,5,1):&apos;&apos;;
			rec.priority = orcAvailable ? getVal(orcIndex,7,6):&apos;&apos;;		
			rec.enteringorganization = orcAvailable ? getVal(orcIndex,17,1):&apos;&apos;;			
		}
		//logger.info(rec.orc91+&quot;,&quot;+rec.orc101+&quot;,&quot;+rec.orc113);

		// Parsing OBR Segment

		var numofobr201repeats = msg[&apos;OBR&apos;][i][&apos;OBR.20&apos;].length();
		//logger.info(&apos;numfoobr201repeats:&apos;+numofobr201repeats.toString());
		if (numofobr201repeats &gt; 0)
		{
			//logger.info(msg[&apos;OBR&apos;][&apos;OBR.20&apos;][0][&apos;OBR.20.2&apos;].toString());
			if (msg[&apos;OBR&apos;][i][&apos;OBR.20&apos;][0][&apos;OBR.20.2&apos;].toString() == &apos;HNA_ACCN&apos;)
			{
				var tmpstr = msg[&apos;OBR&apos;][i][&apos;OBR.20&apos;][0][&apos;OBR.20.1&apos;].toString();
				var part1 = tmpstr.substr(5,2);
				var part2 = tmpstr.substr(9,2);
				var part3 = tmpstr.substr(tmpstr.length-5,5);
				//logger.info(&apos;wholefield:&apos;+tmpstr);
				//logger.info(&apos;part1:&apos;+part1);
				//logger.info(&apos;part2:&apos;+part2);
				//logger.info(&apos;part3:&apos;+part3);
				rec.placerorder = part1+part2+part3;
				//logger.info(&apos;accn#:&apos; + rec.placerorder);
			}	
		}
		
		rec.fillerorder = getVal(obrIndex,3,1);

		if (rec.msgtype = &apos;ORU&apos;)
		{
			rec.cptcode = getVal(obrIndex,4,1);
			rec.cptname = getVal(obrIndex,4,2);
		}
		else
		{
			rec.ordercode = getVal(obrIndex,4,1);
			rec.ordername = getVal(obrIndex,4,2);
		}
		rec.reasonforstudy = getVal(obrIndex,31,2);
		rec.relevantclinicalinfo = getVal(obrIndex,13,1);
		rec.performingresource = getVal(obrIndex,21,1);
		rec.department = getVal(obrIndex,24,1);
		rec.info = &apos;CaseInfo&apos;;

		AddToBuffer (rec);	 // basic case info

		rec.cptcode = &apos;&apos;;
		rec.cptname = &apos;&apos;;
		rec.ordercode = &apos;&apos;;
		rec.ordername = &apos;&apos;;
		rec.reasonforstudy = &apos;&apos;;
		rec.relevantclinicalinfo = &apos;&apos;;
		rec.performingresource = &apos;&apos;;
		rec.department = &apos;&apos;;
		
		rec.staff_first = getVal(obrIndex, 16, 3);
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last = getVal(obrIndex, 16, 2);
			rec.staff_middle = getVal(obrIndex, 16, 4);
			rec.staff_role = &apos;Ordering MD&apos; ;
			rec.info = &apos;STAFF&apos;;
			AddToBuffer (rec);	 // basic info
		}
		
		rec.staff_first  =  getVal(obrIndex, 32, 1, 3);// msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.3&apos;].toString()   ;//     getVal(obrIndex, 16, 3);
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last   =  getVal(obrIndex, 32, 1, 2);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.2&apos;].toString()   ;
			rec.staff_middle =  getVal(obrIndex, 32, 1, 4);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.4&apos;].toString()  ;
			rec.staff_role = &apos;Attending Radiologist&apos; ;
			rec.info = &apos;STAFF&apos;;
			//logger.info (&apos;staff:&apos;+rec.staff_first+&apos; &apos; + rec.staff_last + &apos; &apos; + rec.staff_middle);
			AddToBuffer (rec);	 // basic info
		}		

		rec.staff_first =   getVal(obrIndex, 35, 1, 3); // msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.3&apos;].toString()   ;//     getVal(obrIndex, 16, 3);
		if (rec.staff_first != &apos;&apos;)
		{
			rec.staff_last =  getVal(obrIndex, 35, 1, 2);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.2&apos;].toString()   ;
			rec.staff_middle = getVal(obrIndex, 35, 1, 4);//msg[&apos;OBR&apos;][&apos;OBR.32&apos;][&apos;OBR.32.1&apos;][&apos;OBR.32.1.4&apos;].toString()  ;
			rec.info = &apos;STAFF&apos;;
			rec.staff_role = &apos;Resident&apos; ;
			AddToBuffer (rec);	 // basic info
		}

		if (orcAvailable)
		{
			if (rec.orcstatus == &apos;RADSTART&apos; || rec.orcstatus == &apos;RADCOMP&apos;)
			{
				rec.staff_first = getVal(orcIndex,19,3);
				if (rec.staff_first != &apos;&apos;)
				{
					rec.staff_last = getVal(orcIndex,19,2);
					rec.staff_middle = getVal(orcIndex,19,4);
					rec.info = &apos;STAFF&apos;;
					rec.staff_role = &apos;Technologist&apos;;
					AddToBuffer (rec);	 // basic info		
					//logger.info(rec.staff_first+&apos;-&apos;+rec.staff_last);
				}
			}
		}

		rec.staff_role = &apos;&apos; ;
		rec.staff_first = &apos;&apos;;
		rec.staff_last = &apos;&apos;;
		rec.staff_middle = &apos;&apos;;
		rec.staff_mnemonic = &apos;&apos;;
		rec.info = &apos;&apos;;

		rec.info = &apos;WORKFLOWSTATE&apos;;
		
		rec.workflow_state = &apos;ts_start&apos; ;
		rec.ts_when = getVal(obrIndex, 7, 1);
		AddToBuffer (rec);	 // basic info

		rec.workflow_state = &apos;ts_stop&apos; ;
		rec.ts_when = getVal(obrIndex, 8, 1);
		AddToBuffer (rec);	 // basic info

		if (rec.msgtype = &apos;ORU&apos;)
		{
			rec.workflow_state = workflowstatus_assembler + &apos;-&apos; + getVal(obrIndex, 25, 1);
			rec.ts_when = rec.ts_msg;
			AddToBuffer (rec);	 // basic info	
		}
		else // ORM
		{
			rec.workflow_state = workflowstatus_assembler ; //: &apos;ts_unknown&apos;;
			rec.ts_when = converttoformattedtimestamp(getVal(obrIndex, 22, 1)); //msg[&apos;OBR&apos;][&apos;OBR.22&apos;][&apos;OBR.22.1&apos;].toString() )  ;
			AddToBuffer (rec);	 // basic info
		}

		rec.workflow_state = &apos;&apos;;
		rec.ts_when = &apos;&apos;;
		rec.info = &apos;&apos;;

	}//end of obr loop for n obr segments...
	
}



function handler_obx_rad(rec, msg)
{
	var len = parseInt(msg[&apos;OBX&apos;].length());
//logger.info(&apos;obx len:&apos;+len.toString());
	for (i=0; i&lt; len;i++)
	{
//logger.info(&apos;in obx:&apos;+i.toString());
		//rec.info = &apos;CONDITION&apos;;
		//rec.local_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.1&apos;].toString() : &apos;&apos;;
		//rec.local_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.2&apos;].toString() : &apos;&apos;;
		//rec.local_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.3&apos;].toString() : &apos;&apos;;

		//rec.attribute_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.4&apos;].toString() : &apos;&apos;;
		//rec.attribute_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.5&apos;].toString() : &apos;&apos;;
		//rec.coding_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.6&apos;].toString() : &apos;&apos;;

				// dont get report text at this time contains the huge text
		//rec.attribute_value = &apos;report text&apos;; //msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.5&apos;][&apos;OBX.5.1&apos;].toString() : &apos;&apos;;
		//rec.attribute_units = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.6&apos;][&apos;OBX.6.1&apos;].toString() : &apos;&apos;;
		//rec.reference_range = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.7&apos;][&apos;OBX.7.1&apos;].toString() : &apos;&apos;;
		//rec.abnormal_flag =  msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.10&apos;][&apos;OBX.11.1&apos;].toString() : &apos;&apos;;

		if (rec.msgtype = &apos;ORU&apos;)
		{
			rec.info = &apos;WORKFLOWSTATE&apos;;
			rec.workflow_state =  msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.11&apos;][&apos;OBX.11.1&apos;].toString() : &apos;&apos;;
			rec.ts_when =  converttoformattedtimestamp(msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.14&apos;][&apos;OBX.14.1&apos;].toString() : &apos;&apos;) ; 
			if (rec.ts_when == &apos;&apos;) // use message time stamp if the actual observation ts is empty.
				rec.ts_when = rec.ts_msg;
				
			AddToBuffer (rec);
			rec.info = &apos;&apos; ;
			rec.workflow_state = &apos;&apos;;
			rec.ts_when = &apos;&apos;;
		}
		else
		{
			//rec.info = &apos;CONDITION&apos;;
			//rec.local_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.1&apos;].toString() : &apos;&apos;;
			//rec.local_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.2&apos;].toString() : &apos;&apos;;
			//rec.local_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.3&apos;].toString() : &apos;&apos;;
	
			//rec.attribute_id = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.4&apos;].toString() : &apos;&apos;;
			//rec.attribute_name = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.5&apos;].toString() : &apos;&apos;;
			//rec.coding_system = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.3&apos;][&apos;OBX.3.6&apos;].toString() : &apos;&apos;;

					// dont get report text at this time contains the huge text
			//rec.attribute_value = &apos;report text&apos;; //msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.5&apos;][&apos;OBX.5.1&apos;].toString() : &apos;&apos;;
			//rec.attribute_units = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.6&apos;][&apos;OBX.6.1&apos;].toString() : &apos;&apos;;
			//rec.reference_range = msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.7&apos;][&apos;OBX.7.1&apos;].toString() : &apos;&apos;;
			//rec.abnormal_flag =  msg[&apos;OBX&apos;][i] ? msg[&apos;OBX&apos;][i][&apos;OBX.10&apos;][&apos;OBX.11.1&apos;].toString() : &apos;&apos;;
		}
	}
	rec.infotype = &apos;&apos;;
	rec.local_id = &apos;&apos; ;
	rec.local_name = &apos;&apos;;
	rec.local_system = &apos;&apos;;
	rec.attribute_id = &apos;&apos;;
	rec.attribute_name = &apos;&apos;;
	rec.coding_system = &apos;&apos;;
	rec.attribute_value = &apos;&apos;;
	rec.attribute_units = &apos;&apos;;
	rec.value_status = &apos;&apos;;

}

try
{
	var rec = {};

	handler_msh (rec, msg);
	//handler_evn (rec, msg);
	handler_pid (rec, msg);
	handler_pd1 (rec, msg);
	
	handler_pv1 (rec, msg);
	handler_pv2 (rec, msg);
	
	//handler_obr_rad (rec, msg);
	//handler_obx_rad (rec, msg);
	
	handler_al1(rec, msg);
	handler_in1(rec, msg);

	// get the maximum cardinality of IN1, FT1, AL1, OBR Segments	
	writeContent();		
}
catch(exception)
{
	var dateString = DateUtil.getCurrentDate(&apos;yyyyMMddHHmmss&apos;);
	var hl7 = SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML(msg);
	FileUtil.write(errorDir+&apos;Error_&apos;+dateString+&apos;.hl7&apos;, false, hl7);
	throw(exception);
}</string>
            </entry>
          </data>
        </step>
        <step>
          <sequenceNumber>1</sequenceNumber>
          <name>File Scripts</name>
          <script>//Insert record into the file
function AddToBuffer(rec)
{
	var body = getRecord(rec);
	pipeBatch += body;
}

// Check Whether File Exists or not.
function fileDoesNotExist()
{
	var f = new File(fileDir+newFileName);
	return !f.exists();
}


// Write the record to the file
function writeContent()
{
	 var loopcount = 0
	 for (loopcount = 5; loopcount &gt;0; loopcount--)
	 {
		// Writing the pipe delimted file to the file directory
		var newdate = DateUtil.getCurrentDate(&apos;yyyy/MM/dd HH:mm&apos;);
		var oldConf = globalChannelMap.get(&quot;old&quot;);
		var olddate = oldConf.date;
		newFileName= fileName+DateUtil.convertDate(&apos;yyyy/MM/dd HH:mm&apos;, &apos;yyyyMMddHHmm&apos;, olddate)+&quot;.psv&quot;;
		// If file is a new one after deployment or execeeds certian minutes create new file
		if(fileDoesNotExist() || ((new Date(newdate).getTime() - new Date(olddate).getTime())/60000 &gt; MIN) )
		{
			logger.info(&quot;Creating New File&quot;);
			newFileName= fileName + DateUtil.convertDate(&apos;yyyy/MM/dd HH:mm&apos;, &apos;yyyyMMddHHmm&apos;, newdate)+&quot;.psv&quot;;
			var header= getHeader();
			// Write header to file
			pipeBatch = header+pipeBatch;
			// Change Config Data
			oldConf.date = newdate;
			globalChannelMap.put(&quot;old&quot;,oldConf);
		}
		try
		{
			FileUtil.write(fileDir+newFileName,true,pipeBatch);
			loopcount = 0;
		}
		catch (exception)
		{
			loopcount--;
		}
	
	 }
}


// Convert the record into a valid Pipe Delimited Record
function getPipeData(rec)
{
	return (SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML(rec)).replace(&quot;REC|&quot;,&quot;&quot;)+&quot;\r\n&quot;;
}


// Create Header
function getHeader()
{
	//var incMsg = SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML(&quot;|||||||||||||||insurancename|insurance_type|IN1segmentsequence#&quot;);
	var header = new XML(&quot;&lt;REC/&gt;&quot;);

	header[&apos;REC&apos;][&apos;REC.1&apos;] = &quot;msgsendingapp&quot;;
	header[&apos;REC&apos;][&apos;REC.2&apos;] = &quot;msgsendingfacility&quot;;
	header[&apos;REC&apos;][&apos;REC.3&apos;] = &quot;msgtype&quot;;
	header[&apos;REC&apos;][&apos;REC.4&apos;] = &quot;msgtrigger&quot;;
	header[&apos;REC&apos;][&apos;REC.5&apos;] = &quot;ts_msg&quot;;
	header[&apos;REC&apos;][&apos;REC.6&apos;] = &quot;security&quot;;

	header[&apos;REC&apos;][&apos;REC.7&apos;] = &quot;EMPI&quot;;
	header[&apos;REC&apos;][&apos;REC.8&apos;] = &quot;Patient_Id&quot;;
	header[&apos;REC&apos;][&apos;REC.9&apos;] = &quot;dob&quot;;
	header[&apos;REC&apos;][&apos;REC.10&apos;] = &quot;sex&quot;;
	header[&apos;REC&apos;][&apos;REC.11&apos;] = &quot;race&quot;;
	header[&apos;REC&apos;][&apos;REC.12&apos;] = &quot;city&quot;;
	header[&apos;REC&apos;][&apos;REC.13&apos;] = &quot;zip&quot;;
	header[&apos;REC&apos;][&apos;REC.14&apos;] = &quot;county&quot;;
	header[&apos;REC&apos;][&apos;REC.15&apos;] = &quot;language&quot;;
	header[&apos;REC&apos;][&apos;REC.16&apos;] = &quot;marital_status&quot;;
	header[&apos;REC&apos;][&apos;REC.17&apos;] = &quot;religion&quot;;
	header[&apos;REC&apos;][&apos;REC.18&apos;] = &quot;ethnicgroup&quot;;
	header[&apos;REC&apos;][&apos;REC.19&apos;] = &quot;birthorder&quot;;
	header[&apos;REC&apos;][&apos;REC.20&apos;] = &quot;death&quot;;
	
	header[&apos;REC&apos;][&apos;REC.21&apos;] = &quot;har&quot;;
	header[&apos;REC&apos;][&apos;REC.22&apos;] = &quot;visitnumber&quot;;

	header[&apos;REC&apos;][&apos;REC.23&apos;] = &quot;info&quot;;
	
	header[&apos;REC&apos;][&apos;REC.24&apos;] = &quot;patientclass&quot;;
	header[&apos;REC&apos;][&apos;REC.25&apos;] = &quot;patientlocation&quot;;
	header[&apos;REC&apos;][&apos;REC.26&apos;] = &quot;patientroom&quot;;
	header[&apos;REC&apos;][&apos;REC.27&apos;] = &quot;admittype&quot;;
	header[&apos;REC&apos;][&apos;REC.28&apos;] = &quot;patienttype&quot;;
	header[&apos;REC&apos;][&apos;REC.29&apos;] = &quot;hospitalservice&quot;;
	header[&apos;REC&apos;][&apos;REC.30&apos;] = &quot;servicingfacility&quot;;
	header[&apos;REC&apos;][&apos;REC.31&apos;] = &quot;vip&quot;;
	
	header[&apos;REC&apos;][&apos;REC.32&apos;] = &quot;staff_role&quot;;
	header[&apos;REC&apos;][&apos;REC.33&apos;] = &quot;staff_first&quot;;
	header[&apos;REC&apos;][&apos;REC.34&apos;] = &quot;staff_middle&quot;;
	header[&apos;REC&apos;][&apos;REC.35&apos;] = &quot;staff_last&quot;;

	header[&apos;REC&apos;][&apos;REC.36&apos;] = &quot;workflow_state&quot;;
	header[&apos;REC&apos;][&apos;REC.37&apos;] = &quot;ts_when&quot;;   

	header[&apos;REC&apos;][&apos;REC.38&apos;] = &quot;orccontrol&quot;;
	header[&apos;REC&apos;][&apos;REC.39&apos;] = &quot;orcstatus&quot;;
	header[&apos;REC&apos;][&apos;REC.40&apos;] = &quot;priority&quot;;
	header[&apos;REC&apos;][&apos;REC.41&apos;] = &quot;enteringorganization&quot;;
	
	header[&apos;REC&apos;][&apos;REC.42&apos;] = &quot;placerorder&quot;;
	header[&apos;REC&apos;][&apos;REC.43&apos;] = &quot;fillerorder&quot;;
	header[&apos;REC&apos;][&apos;REC.44&apos;] = &quot;fillerissuer&quot;;

	header[&apos;REC&apos;][&apos;REC.45&apos;] = &quot;cptcode&quot;; 
	header[&apos;REC&apos;][&apos;REC.46&apos;] = &quot;cptname&quot;; 
	header[&apos;REC&apos;][&apos;REC.47&apos;] = &quot;ordercode&quot;; 
	header[&apos;REC&apos;][&apos;REC.48&apos;] = &quot;ordertext&quot;; 
	header[&apos;REC&apos;][&apos;REC.49&apos;] = &quot;ordercodingsystem&quot;; 
	header[&apos;REC&apos;][&apos;REC.50&apos;] = &quot;reasonforstudy&quot;; 
	header[&apos;REC&apos;][&apos;REC.51&apos;] = &quot;relevantclinicalinfo&quot;; 
	header[&apos;REC&apos;][&apos;REC.52&apos;] = &quot;performingresource&quot;; 
	header[&apos;REC&apos;][&apos;REC.53&apos;] = &quot;department&quot;; 
	

	header[&apos;REC&apos;][&apos;REC.54&apos;] = &quot;local_id&quot;; 
	header[&apos;REC&apos;][&apos;REC.55&apos;] = &quot;local_name&quot;; 
	header[&apos;REC&apos;][&apos;REC.56&apos;] = &quot;local_system&quot;; 

	header[&apos;REC&apos;][&apos;REC.57&apos;] = &quot;attribute_id&quot;; 
	header[&apos;REC&apos;][&apos;REC.58&apos;] = &quot;attribute_name&quot;; 
	header[&apos;REC&apos;][&apos;REC.59&apos;] = &quot;coding_system&quot;; 

	header[&apos;REC&apos;][&apos;REC.60&apos;] = &quot;attribute_value&quot;;
	header[&apos;REC&apos;][&apos;REC.61&apos;] = &quot;attribute_units&quot;;
	header[&apos;REC&apos;][&apos;REC.62&apos;] = &quot;reference_range&quot;; 
	header[&apos;REC&apos;][&apos;REC.63&apos;] = &quot;abnormal_flag&quot;;
	header[&apos;REC&apos;][&apos;REC.64&apos;] = &quot;value_status&quot;;

	header[&apos;REC&apos;][&apos;REC.65&apos;] = &quot;pendinglocation&quot;;
	header[&apos;REC&apos;][&apos;REC.66&apos;] = &quot;pendingroom&quot;;


	return getPipeData(header);
}


// Create Record
function getRecord(record)
{
	// Create Record to be inserted in the File
	var rec = new XML(&quot;&lt;REC/&gt;&quot;);
	rec[&apos;REC&apos;][&apos;record.1&apos;] = record.msgsendingapp ? record.msgsendingapp : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.2&apos;] = record.msgsendingfacility ? record.msgsendingfacility : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.3&apos;] = record.msgtype ? record.msgtype : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.4&apos;] = record.msgtrigger ? record.msgtrigger : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.5&apos;] = record.ts_msg ? record.ts_msg : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.6&apos;] = record.security ? record.security : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.7&apos;] = record.empi ? record.empi : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.8&apos;] = record.mrn ? record.mrn : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.9&apos;] = record.dob ? record.dob : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.10&apos;] = record.sex ? record.sex : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.11&apos;] = record.race ? record.race : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.12&apos;] = record.city ? record.city : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.13&apos;] = record.zip ? record.zip : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.14&apos;] = record.county ? record.county : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.15&apos;] = record.language ? record.language : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.16&apos;] = record.ms ? record.ms : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.17&apos;] = record.religion ? record.religion : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.18&apos;] = record.ethnicgroup ? record.ethnicgroup : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.19&apos;] = record.birthorder ? record.birthorder : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.20&apos;] = record.death ? record.death : &apos;&apos;;
	
	rec[&apos;REC&apos;][&apos;record.21&apos;] = record.har ? record.har : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.22&apos;] = record.visitnumber ? record.visitnumber : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.23&apos;] = record.info ? record.info : &apos;&apos;;
	
	rec[&apos;REC&apos;][&apos;record.24&apos;] = record.patientclass ? record.patientclass : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.25&apos;] = record.patientlocation ? record.patientlocation : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.26&apos;] = record.patientroom ? record.patientroom : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.27&apos;] = record.admittype ? record.admittype : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.28&apos;] = record.patienttype ? record.patienttype : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.29&apos;] = record.hospitalservice ? record.hospitalservice : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.30&apos;] = record.servicingfacility ? record.servicingfacility : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.31&apos;] = record.vip ? record.vip : &apos;&apos;;
		
	rec[&apos;REC&apos;][&apos;record.32&apos;] = record.staff_role ? record.staff_role : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.33&apos;] = record.staff_first ? record.staff_first : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.34&apos;] = record.staff_middle ? record.staff_middle : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.35&apos;] = record.staff_last ? record.staff_last : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.36&apos;] = record.workflow_state ? record.workflow_state : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.37&apos;] = record.ts_when ? record.ts_when : &apos;&apos;;   

	rec[&apos;REC&apos;][&apos;record.38&apos;] = record.orccontrol ? record.orccontrol : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.39&apos;] = record.orcstatus ? record.orcstatus : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.40&apos;] = record.priority ? record.priority : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.41&apos;] = record.enteringorganization ? record.enteringorganization : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.42&apos;] = record.placerorder ? record.placerorder : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.43&apos;] = record.fillerorder ? record.fillerorder : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.44&apos;] = record.fillerissuer ? record.fillerissuer : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.45&apos;] = record.cptcode ? record.cptcode : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.46&apos;] = record.cptname ? record.cptname : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.47&apos;] = record.ordercode ? record.ordercode : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.48&apos;] = record.ordertext ? record.ordertext : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.49&apos;] = record.ordercodingsystem ? record.ordercodingsystem : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.50&apos;] = record.reasonforstudy ? record.reasonforstudy : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.51&apos;] = record.relevantclinicalinfo ? record.relevantclinicalinfo : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.52&apos;] = record.performingresource ? record.performingresource : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.53&apos;] = record.department ? record.department : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.54&apos;] = record.local_id ? record.local_id : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.55&apos;] = record.local_name ? record.local_name : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.56&apos;] = record.local_system ? record.local_system : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.57&apos;] = record.attribute_id ? record.attribute_id : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.58&apos;] = record.attribute_name ? record.attribute_name : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.59&apos;] = record.coding_system ? record.coding_system : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.60&apos;] = record.attribute_value ? record.attribute_value : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.61&apos;] = record.attribute_units ? record.attribute_units : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.62&apos;] = record.reference_range ? record.reference_range : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.63&apos;] = record.abnormal_flag ? record.abnormal_flag : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.64&apos;] = record.value_status ? record.value_status : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.65&apos;] = record.pendinglocation ? record.pendinglocation : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.66&apos;] = record.pendingroom ? record.pendingroom : &apos;&apos;;

	//logger.info(rec);
	return getPipeData(rec);
}</script>
          <type>JavaScript</type>
          <data>
            <entry>
              <string>Script</string>
              <string>//Insert record into the file
function AddToBuffer(rec)
{
	var body = getRecord(rec);
	pipeBatch += body;
}

// Check Whether File Exists or not.
function fileDoesNotExist()
{
	var f = new File(fileDir+newFileName);
	return !f.exists();
}


// Write the record to the file
function writeContent()
{
	 var loopcount = 0
	 for (loopcount = 5; loopcount &gt;0; loopcount--)
	 {
		// Writing the pipe delimted file to the file directory
		var newdate = DateUtil.getCurrentDate(&apos;yyyy/MM/dd HH:mm&apos;);
		var oldConf = globalChannelMap.get(&quot;old&quot;);
		var olddate = oldConf.date;
		newFileName= fileName+DateUtil.convertDate(&apos;yyyy/MM/dd HH:mm&apos;, &apos;yyyyMMddHHmm&apos;, olddate)+&quot;.psv&quot;;
		// If file is a new one after deployment or execeeds certian minutes create new file
		if(fileDoesNotExist() || ((new Date(newdate).getTime() - new Date(olddate).getTime())/60000 &gt; MIN) )
		{
			logger.info(&quot;Creating New File&quot;);
			newFileName= fileName + DateUtil.convertDate(&apos;yyyy/MM/dd HH:mm&apos;, &apos;yyyyMMddHHmm&apos;, newdate)+&quot;.psv&quot;;
			var header= getHeader();
			// Write header to file
			pipeBatch = header+pipeBatch;
			// Change Config Data
			oldConf.date = newdate;
			globalChannelMap.put(&quot;old&quot;,oldConf);
		}
		try
		{
			FileUtil.write(fileDir+newFileName,true,pipeBatch);
			loopcount = 0;
		}
		catch (exception)
		{
			loopcount--;
		}
	
	 }
}


// Convert the record into a valid Pipe Delimited Record
function getPipeData(rec)
{
	return (SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML(rec)).replace(&quot;REC|&quot;,&quot;&quot;)+&quot;\r\n&quot;;
}


// Create Header
function getHeader()
{
	//var incMsg = SerializerFactory.getSerializer(&apos;HL7V2&apos;).fromXML(&quot;|||||||||||||||insurancename|insurance_type|IN1segmentsequence#&quot;);
	var header = new XML(&quot;&lt;REC/&gt;&quot;);

	header[&apos;REC&apos;][&apos;REC.1&apos;] = &quot;msgsendingapp&quot;;
	header[&apos;REC&apos;][&apos;REC.2&apos;] = &quot;msgsendingfacility&quot;;
	header[&apos;REC&apos;][&apos;REC.3&apos;] = &quot;msgtype&quot;;
	header[&apos;REC&apos;][&apos;REC.4&apos;] = &quot;msgtrigger&quot;;
	header[&apos;REC&apos;][&apos;REC.5&apos;] = &quot;ts_msg&quot;;
	header[&apos;REC&apos;][&apos;REC.6&apos;] = &quot;security&quot;;

	header[&apos;REC&apos;][&apos;REC.7&apos;] = &quot;EMPI&quot;;
	header[&apos;REC&apos;][&apos;REC.8&apos;] = &quot;Patient_Id&quot;;
	header[&apos;REC&apos;][&apos;REC.9&apos;] = &quot;dob&quot;;
	header[&apos;REC&apos;][&apos;REC.10&apos;] = &quot;sex&quot;;
	header[&apos;REC&apos;][&apos;REC.11&apos;] = &quot;race&quot;;
	header[&apos;REC&apos;][&apos;REC.12&apos;] = &quot;city&quot;;
	header[&apos;REC&apos;][&apos;REC.13&apos;] = &quot;zip&quot;;
	header[&apos;REC&apos;][&apos;REC.14&apos;] = &quot;county&quot;;
	header[&apos;REC&apos;][&apos;REC.15&apos;] = &quot;language&quot;;
	header[&apos;REC&apos;][&apos;REC.16&apos;] = &quot;marital_status&quot;;
	header[&apos;REC&apos;][&apos;REC.17&apos;] = &quot;religion&quot;;
	header[&apos;REC&apos;][&apos;REC.18&apos;] = &quot;ethnicgroup&quot;;
	header[&apos;REC&apos;][&apos;REC.19&apos;] = &quot;birthorder&quot;;
	header[&apos;REC&apos;][&apos;REC.20&apos;] = &quot;death&quot;;
	
	header[&apos;REC&apos;][&apos;REC.21&apos;] = &quot;har&quot;;
	header[&apos;REC&apos;][&apos;REC.22&apos;] = &quot;visitnumber&quot;;

	header[&apos;REC&apos;][&apos;REC.23&apos;] = &quot;info&quot;;
	
	header[&apos;REC&apos;][&apos;REC.24&apos;] = &quot;patientclass&quot;;
	header[&apos;REC&apos;][&apos;REC.25&apos;] = &quot;patientlocation&quot;;
	header[&apos;REC&apos;][&apos;REC.26&apos;] = &quot;patientroom&quot;;
	header[&apos;REC&apos;][&apos;REC.27&apos;] = &quot;admittype&quot;;
	header[&apos;REC&apos;][&apos;REC.28&apos;] = &quot;patienttype&quot;;
	header[&apos;REC&apos;][&apos;REC.29&apos;] = &quot;hospitalservice&quot;;
	header[&apos;REC&apos;][&apos;REC.30&apos;] = &quot;servicingfacility&quot;;
	header[&apos;REC&apos;][&apos;REC.31&apos;] = &quot;vip&quot;;
	
	header[&apos;REC&apos;][&apos;REC.32&apos;] = &quot;staff_role&quot;;
	header[&apos;REC&apos;][&apos;REC.33&apos;] = &quot;staff_first&quot;;
	header[&apos;REC&apos;][&apos;REC.34&apos;] = &quot;staff_middle&quot;;
	header[&apos;REC&apos;][&apos;REC.35&apos;] = &quot;staff_last&quot;;

	header[&apos;REC&apos;][&apos;REC.36&apos;] = &quot;workflow_state&quot;;
	header[&apos;REC&apos;][&apos;REC.37&apos;] = &quot;ts_when&quot;;   

	header[&apos;REC&apos;][&apos;REC.38&apos;] = &quot;orccontrol&quot;;
	header[&apos;REC&apos;][&apos;REC.39&apos;] = &quot;orcstatus&quot;;
	header[&apos;REC&apos;][&apos;REC.40&apos;] = &quot;priority&quot;;
	header[&apos;REC&apos;][&apos;REC.41&apos;] = &quot;enteringorganization&quot;;
	
	header[&apos;REC&apos;][&apos;REC.42&apos;] = &quot;placerorder&quot;;
	header[&apos;REC&apos;][&apos;REC.43&apos;] = &quot;fillerorder&quot;;
	header[&apos;REC&apos;][&apos;REC.44&apos;] = &quot;fillerissuer&quot;;

	header[&apos;REC&apos;][&apos;REC.45&apos;] = &quot;cptcode&quot;; 
	header[&apos;REC&apos;][&apos;REC.46&apos;] = &quot;cptname&quot;; 
	header[&apos;REC&apos;][&apos;REC.47&apos;] = &quot;ordercode&quot;; 
	header[&apos;REC&apos;][&apos;REC.48&apos;] = &quot;ordertext&quot;; 
	header[&apos;REC&apos;][&apos;REC.49&apos;] = &quot;ordercodingsystem&quot;; 
	header[&apos;REC&apos;][&apos;REC.50&apos;] = &quot;reasonforstudy&quot;; 
	header[&apos;REC&apos;][&apos;REC.51&apos;] = &quot;relevantclinicalinfo&quot;; 
	header[&apos;REC&apos;][&apos;REC.52&apos;] = &quot;performingresource&quot;; 
	header[&apos;REC&apos;][&apos;REC.53&apos;] = &quot;department&quot;; 
	

	header[&apos;REC&apos;][&apos;REC.54&apos;] = &quot;local_id&quot;; 
	header[&apos;REC&apos;][&apos;REC.55&apos;] = &quot;local_name&quot;; 
	header[&apos;REC&apos;][&apos;REC.56&apos;] = &quot;local_system&quot;; 

	header[&apos;REC&apos;][&apos;REC.57&apos;] = &quot;attribute_id&quot;; 
	header[&apos;REC&apos;][&apos;REC.58&apos;] = &quot;attribute_name&quot;; 
	header[&apos;REC&apos;][&apos;REC.59&apos;] = &quot;coding_system&quot;; 

	header[&apos;REC&apos;][&apos;REC.60&apos;] = &quot;attribute_value&quot;;
	header[&apos;REC&apos;][&apos;REC.61&apos;] = &quot;attribute_units&quot;;
	header[&apos;REC&apos;][&apos;REC.62&apos;] = &quot;reference_range&quot;; 
	header[&apos;REC&apos;][&apos;REC.63&apos;] = &quot;abnormal_flag&quot;;
	header[&apos;REC&apos;][&apos;REC.64&apos;] = &quot;value_status&quot;;

	header[&apos;REC&apos;][&apos;REC.65&apos;] = &quot;pendinglocation&quot;;
	header[&apos;REC&apos;][&apos;REC.66&apos;] = &quot;pendingroom&quot;;


	return getPipeData(header);
}


// Create Record
function getRecord(record)
{
	// Create Record to be inserted in the File
	var rec = new XML(&quot;&lt;REC/&gt;&quot;);
	rec[&apos;REC&apos;][&apos;record.1&apos;] = record.msgsendingapp ? record.msgsendingapp : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.2&apos;] = record.msgsendingfacility ? record.msgsendingfacility : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.3&apos;] = record.msgtype ? record.msgtype : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.4&apos;] = record.msgtrigger ? record.msgtrigger : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.5&apos;] = record.ts_msg ? record.ts_msg : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.6&apos;] = record.security ? record.security : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.7&apos;] = record.empi ? record.empi : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.8&apos;] = record.mrn ? record.mrn : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.9&apos;] = record.dob ? record.dob : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.10&apos;] = record.sex ? record.sex : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.11&apos;] = record.race ? record.race : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.12&apos;] = record.city ? record.city : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.13&apos;] = record.zip ? record.zip : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.14&apos;] = record.county ? record.county : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.15&apos;] = record.language ? record.language : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.16&apos;] = record.ms ? record.ms : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.17&apos;] = record.religion ? record.religion : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.18&apos;] = record.ethnicgroup ? record.ethnicgroup : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.19&apos;] = record.birthorder ? record.birthorder : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.20&apos;] = record.death ? record.death : &apos;&apos;;
	
	rec[&apos;REC&apos;][&apos;record.21&apos;] = record.har ? record.har : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.22&apos;] = record.visitnumber ? record.visitnumber : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.23&apos;] = record.info ? record.info : &apos;&apos;;
	
	rec[&apos;REC&apos;][&apos;record.24&apos;] = record.patientclass ? record.patientclass : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.25&apos;] = record.patientlocation ? record.patientlocation : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.26&apos;] = record.patientroom ? record.patientroom : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.27&apos;] = record.admittype ? record.admittype : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.28&apos;] = record.patienttype ? record.patienttype : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.29&apos;] = record.hospitalservice ? record.hospitalservice : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.30&apos;] = record.servicingfacility ? record.servicingfacility : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.31&apos;] = record.vip ? record.vip : &apos;&apos;;
		
	rec[&apos;REC&apos;][&apos;record.32&apos;] = record.staff_role ? record.staff_role : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.33&apos;] = record.staff_first ? record.staff_first : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.34&apos;] = record.staff_middle ? record.staff_middle : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.35&apos;] = record.staff_last ? record.staff_last : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.36&apos;] = record.workflow_state ? record.workflow_state : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.37&apos;] = record.ts_when ? record.ts_when : &apos;&apos;;   

	rec[&apos;REC&apos;][&apos;record.38&apos;] = record.orccontrol ? record.orccontrol : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.39&apos;] = record.orcstatus ? record.orcstatus : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.40&apos;] = record.priority ? record.priority : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.41&apos;] = record.enteringorganization ? record.enteringorganization : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.42&apos;] = record.placerorder ? record.placerorder : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.43&apos;] = record.fillerorder ? record.fillerorder : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.44&apos;] = record.fillerissuer ? record.fillerissuer : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.45&apos;] = record.cptcode ? record.cptcode : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.46&apos;] = record.cptname ? record.cptname : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.47&apos;] = record.ordercode ? record.ordercode : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.48&apos;] = record.ordertext ? record.ordertext : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.49&apos;] = record.ordercodingsystem ? record.ordercodingsystem : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.50&apos;] = record.reasonforstudy ? record.reasonforstudy : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.51&apos;] = record.relevantclinicalinfo ? record.relevantclinicalinfo : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.52&apos;] = record.performingresource ? record.performingresource : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.53&apos;] = record.department ? record.department : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.54&apos;] = record.local_id ? record.local_id : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.55&apos;] = record.local_name ? record.local_name : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.56&apos;] = record.local_system ? record.local_system : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.57&apos;] = record.attribute_id ? record.attribute_id : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.58&apos;] = record.attribute_name ? record.attribute_name : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.59&apos;] = record.coding_system ? record.coding_system : &apos;&apos;; 

	rec[&apos;REC&apos;][&apos;record.60&apos;] = record.attribute_value ? record.attribute_value : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.61&apos;] = record.attribute_units ? record.attribute_units : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.62&apos;] = record.reference_range ? record.reference_range : &apos;&apos;; 
	rec[&apos;REC&apos;][&apos;record.63&apos;] = record.abnormal_flag ? record.abnormal_flag : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.64&apos;] = record.value_status ? record.value_status : &apos;&apos;;

	rec[&apos;REC&apos;][&apos;record.65&apos;] = record.pendinglocation ? record.pendinglocation : &apos;&apos;;
	rec[&apos;REC&apos;][&apos;record.66&apos;] = record.pendingroom ? record.pendingroom : &apos;&apos;;

	//logger.info(rec);
	return getPipeData(rec);
}</string>
            </entry>
          </data>
        </step>
      </steps>
      <inboundTemplate encoding="base64"></inboundTemplate>
      <outboundTemplate encoding="base64"></outboundTemplate>
      <inboundDataType>HL7V2</inboundDataType>
      <outboundDataType>HL7V2</outboundDataType>
      <inboundProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DataTypeProperties" version="3.2.1">
        <serializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2SerializationProperties" version="3.2.1">
          <handleRepetitions>true</handleRepetitions>
          <handleSubcomponents>true</handleSubcomponents>
          <useStrictParser>false</useStrictParser>
          <useStrictValidation>false</useStrictValidation>
          <stripNamespaces>true</stripNamespaces>
          <segmentDelimiter>\r</segmentDelimiter>
          <convertLineBreaks>true</convertLineBreaks>
        </serializationProperties>
        <deserializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DeserializationProperties" version="3.2.1">
          <useStrictParser>false</useStrictParser>
          <useStrictValidation>false</useStrictValidation>
          <segmentDelimiter>\r</segmentDelimiter>
        </deserializationProperties>
        <batchProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2BatchProperties" version="3.2.1">
          <splitType>MSH_Segment</splitType>
          <batchScript></batchScript>
        </batchProperties>
        <responseGenerationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseGenerationProperties" version="3.2.1">
          <segmentDelimiter>\r</segmentDelimiter>
          <successfulACKCode>AA</successfulACKCode>
          <successfulACKMessage></successfulACKMessage>
          <errorACKCode>AE</errorACKCode>
          <errorACKMessage>An Error Occurred Processing Message.</errorACKMessage>
          <rejectedACKCode>AR</rejectedACKCode>
          <rejectedACKMessage>Message Rejected.</rejectedACKMessage>
          <msh15ACKAccept>false</msh15ACKAccept>
          <dateFormat>yyyyMMddHHmmss</dateFormat>
        </responseGenerationProperties>
        <responseValidationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseValidationProperties" version="3.2.1">
          <successfulACKCode>AA,CA</successfulACKCode>
          <errorACKCode>AE,CE</errorACKCode>
          <rejectedACKCode>AR,CR</rejectedACKCode>
          <validateMessageControlId>false</validateMessageControlId>
          <originalMessageControlId>Destination_Encoded</originalMessageControlId>
          <originalIdMapVariable></originalIdMapVariable>
        </responseValidationProperties>
      </inboundProperties>
      <outboundProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DataTypeProperties" version="3.2.1">
        <serializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2SerializationProperties" version="3.2.1">
          <handleRepetitions>true</handleRepetitions>
          <handleSubcomponents>true</handleSubcomponents>
          <useStrictParser>false</useStrictParser>
          <useStrictValidation>false</useStrictValidation>
          <stripNamespaces>true</stripNamespaces>
          <segmentDelimiter>\r</segmentDelimiter>
          <convertLineBreaks>true</convertLineBreaks>
        </serializationProperties>
        <deserializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DeserializationProperties" version="3.2.1">
          <useStrictParser>false</useStrictParser>
          <useStrictValidation>false</useStrictValidation>
          <segmentDelimiter>\r</segmentDelimiter>
        </deserializationProperties>
        <batchProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2BatchProperties" version="3.2.1">
          <splitType>MSH_Segment</splitType>
          <batchScript></batchScript>
        </batchProperties>
        <responseGenerationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseGenerationProperties" version="3.2.1">
          <segmentDelimiter>\r</segmentDelimiter>
          <successfulACKCode>AA</successfulACKCode>
          <successfulACKMessage></successfulACKMessage>
          <errorACKCode>AE</errorACKCode>
          <errorACKMessage>An Error Occurred Processing Message.</errorACKMessage>
          <rejectedACKCode>AR</rejectedACKCode>
          <rejectedACKMessage>Message Rejected.</rejectedACKMessage>
          <msh15ACKAccept>false</msh15ACKAccept>
          <dateFormat>yyyyMMddHHmmss</dateFormat>
        </responseGenerationProperties>
        <responseValidationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseValidationProperties" version="3.2.1">
          <successfulACKCode>AA,CA</successfulACKCode>
          <errorACKCode>AE,CE</errorACKCode>
          <rejectedACKCode>AR,CR</rejectedACKCode>
          <validateMessageControlId>false</validateMessageControlId>
          <originalMessageControlId>Destination_Encoded</originalMessageControlId>
          <originalIdMapVariable></originalIdMapVariable>
        </responseValidationProperties>
      </outboundProperties>
    </transformer>
    <filter version="3.2.1">
      <rules>
        <rule>
          <sequenceNumber>0</sequenceNumber>
          <name>Accept message if &quot;msg[&apos;MSH&apos;].toString()&quot; exists</name>
          <data>
            <entry>
              <string>Field</string>
              <string>msg[&apos;MSH&apos;].toString()</string>
            </entry>
            <entry>
              <string>Name</string>
              <string></string>
            </entry>
            <entry>
              <string>OriginalField</string>
              <string></string>
            </entry>
            <entry>
              <string>Equals</string>
              <string>2</string>
            </entry>
            <entry>
              <string>Values</string>
              <list/>
            </entry>
          </data>
          <type>Rule Builder</type>
          <script>if(msg[&apos;MSH&apos;].toString().length &gt; 0) {
	return true;
}
return false;</script>
          <operator>NONE</operator>
        </rule>
        <rule>
          <sequenceNumber>1</sequenceNumber>
          <name>Accept message if &quot;msg[&apos;PID&apos;].toString()&quot; exists</name>
          <data>
            <entry>
              <string>Field</string>
              <string>msg[&apos;PID&apos;].toString()</string>
            </entry>
            <entry>
              <string>Name</string>
              <string></string>
            </entry>
            <entry>
              <string>OriginalField</string>
              <string></string>
            </entry>
            <entry>
              <string>Equals</string>
              <string>2</string>
            </entry>
            <entry>
              <string>Values</string>
              <list/>
            </entry>
          </data>
          <type>Rule Builder</type>
          <script>if(msg[&apos;PID&apos;].toString().length &gt; 0) {
	return true;
}
return false;</script>
          <operator>AND</operator>
        </rule>
        <rule>
          <sequenceNumber>2</sequenceNumber>
          <name>Accept message if &quot;msg[&apos;MSH&apos;][&apos;MSH.8&apos;][&apos;MSH.8.1&apos;].toString()&quot; does not equal &apos;REG_UPDATE&apos;</name>
          <data>
            <entry>
              <string>Field</string>
              <string>msg[&apos;MSH&apos;][&apos;MSH.8&apos;][&apos;MSH.8.1&apos;].toString()</string>
            </entry>
            <entry>
              <string>Name</string>
              <string></string>
            </entry>
            <entry>
              <string>OriginalField</string>
              <string></string>
            </entry>
            <entry>
              <string>Equals</string>
              <string>0</string>
            </entry>
            <entry>
              <string>Values</string>
              <list>
                <string>&apos;REG_UPDATE&apos;</string>
              </list>
            </entry>
          </data>
          <type>Rule Builder</type>
          <script>if(msg[&apos;MSH&apos;][&apos;MSH.8&apos;][&apos;MSH.8.1&apos;].toString() != &apos;REG_UPDATE&apos;) {
	return true;
}
return false;</script>
          <operator>AND</operator>
        </rule>
      </rules>
    </filter>
    <transportName>File Reader</transportName>
    <mode>SOURCE</mode>
    <enabled>true</enabled>
    <waitForPrevious>true</waitForPrevious>
  </sourceConnector>
  <destinationConnectors>
    <connector version="3.2.1">
      <metaDataId>1</metaDataId>
      <name>Destination 1</name>
      <properties class="com.mirth.connect.connectors.js.JavaScriptDispatcherProperties" version="3.2.1">
        <pluginProperties/>
        <destinationConnectorProperties version="3.2.1">
          <queueEnabled>false</queueEnabled>
          <sendFirst>false</sendFirst>
          <retryIntervalMillis>10000</retryIntervalMillis>
          <regenerateTemplate>false</regenerateTemplate>
          <retryCount>0</retryCount>
          <rotate>false</rotate>
          <includeFilterTransformer>false</includeFilterTransformer>
          <threadCount>1</threadCount>
          <validateResponse>false</validateResponse>
          <resourceIds class="linked-hash-set">
            <string>Default Resource</string>
          </resourceIds>
        </destinationConnectorProperties>
        <script>//logger.info(&quot;Completed the Transaction&quot;);</script>
      </properties>
      <transformer version="3.2.1">
        <steps/>
        <inboundTemplate encoding="base64"></inboundTemplate>
        <outboundTemplate encoding="base64"></outboundTemplate>
        <inboundDataType>HL7V2</inboundDataType>
        <outboundDataType>DELIMITED</outboundDataType>
        <inboundProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DataTypeProperties" version="3.2.1">
          <serializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2SerializationProperties" version="3.2.1">
            <handleRepetitions>true</handleRepetitions>
            <handleSubcomponents>true</handleSubcomponents>
            <useStrictParser>false</useStrictParser>
            <useStrictValidation>false</useStrictValidation>
            <stripNamespaces>true</stripNamespaces>
            <segmentDelimiter>\r</segmentDelimiter>
            <convertLineBreaks>true</convertLineBreaks>
          </serializationProperties>
          <deserializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DeserializationProperties" version="3.2.1">
            <useStrictParser>false</useStrictParser>
            <useStrictValidation>false</useStrictValidation>
            <segmentDelimiter>\r</segmentDelimiter>
          </deserializationProperties>
          <batchProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2BatchProperties" version="3.2.1">
            <splitType>MSH_Segment</splitType>
            <batchScript></batchScript>
          </batchProperties>
          <responseGenerationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseGenerationProperties" version="3.2.1">
            <segmentDelimiter>\r</segmentDelimiter>
            <successfulACKCode>AA</successfulACKCode>
            <successfulACKMessage></successfulACKMessage>
            <errorACKCode>AE</errorACKCode>
            <errorACKMessage>An Error Occurred Processing Message.</errorACKMessage>
            <rejectedACKCode>AR</rejectedACKCode>
            <rejectedACKMessage>Message Rejected.</rejectedACKMessage>
            <msh15ACKAccept>false</msh15ACKAccept>
            <dateFormat>yyyyMMddHHmmss</dateFormat>
          </responseGenerationProperties>
          <responseValidationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseValidationProperties" version="3.2.1">
            <successfulACKCode>AA,CA</successfulACKCode>
            <errorACKCode>AE,CE</errorACKCode>
            <rejectedACKCode>AR,CR</rejectedACKCode>
            <validateMessageControlId>false</validateMessageControlId>
            <originalMessageControlId>Destination_Encoded</originalMessageControlId>
            <originalIdMapVariable></originalIdMapVariable>
          </responseValidationProperties>
        </inboundProperties>
        <outboundProperties class="com.mirth.connect.plugins.datatypes.delimited.DelimitedDataTypeProperties" version="3.2.1">
          <serializationProperties class="com.mirth.connect.plugins.datatypes.delimited.DelimitedSerializationProperties" version="3.2.1">
            <columnDelimiter>|</columnDelimiter>
            <recordDelimiter>\n</recordDelimiter>
            <quoteChar>&quot;</quoteChar>
            <escapeWithDoubleQuote>true</escapeWithDoubleQuote>
            <quoteEscapeChar>\</quoteEscapeChar>
            <numberedRows>false</numberedRows>
            <ignoreCR>true</ignoreCR>
          </serializationProperties>
          <deserializationProperties class="com.mirth.connect.plugins.datatypes.delimited.DelimitedDeserializationProperties" version="3.2.1">
            <columnDelimiter>|</columnDelimiter>
            <recordDelimiter>\n</recordDelimiter>
            <quoteChar>&quot;</quoteChar>
            <escapeWithDoubleQuote>true</escapeWithDoubleQuote>
            <quoteEscapeChar>\</quoteEscapeChar>
          </deserializationProperties>
          <batchProperties class="com.mirth.connect.plugins.datatypes.delimited.DelimitedBatchProperties" version="3.2.1">
            <splitType>Record</splitType>
            <batchSkipRecords>0</batchSkipRecords>
            <batchMessageDelimiter></batchMessageDelimiter>
            <batchMessageDelimiterIncluded>false</batchMessageDelimiterIncluded>
            <batchGroupingColumn></batchGroupingColumn>
            <batchScript></batchScript>
          </batchProperties>
        </outboundProperties>
      </transformer>
      <responseTransformer version="3.2.1">
        <steps/>
        <inboundDataType>HL7V2</inboundDataType>
        <outboundDataType>HL7V2</outboundDataType>
        <inboundProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DataTypeProperties" version="3.2.1">
          <serializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2SerializationProperties" version="3.2.1">
            <handleRepetitions>true</handleRepetitions>
            <handleSubcomponents>true</handleSubcomponents>
            <useStrictParser>false</useStrictParser>
            <useStrictValidation>false</useStrictValidation>
            <stripNamespaces>true</stripNamespaces>
            <segmentDelimiter>\r</segmentDelimiter>
            <convertLineBreaks>true</convertLineBreaks>
          </serializationProperties>
          <deserializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DeserializationProperties" version="3.2.1">
            <useStrictParser>false</useStrictParser>
            <useStrictValidation>false</useStrictValidation>
            <segmentDelimiter>\r</segmentDelimiter>
          </deserializationProperties>
          <batchProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2BatchProperties" version="3.2.1">
            <splitType>MSH_Segment</splitType>
            <batchScript></batchScript>
          </batchProperties>
          <responseGenerationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseGenerationProperties" version="3.2.1">
            <segmentDelimiter>\r</segmentDelimiter>
            <successfulACKCode>AA</successfulACKCode>
            <successfulACKMessage></successfulACKMessage>
            <errorACKCode>AE</errorACKCode>
            <errorACKMessage>An Error Occurred Processing Message.</errorACKMessage>
            <rejectedACKCode>AR</rejectedACKCode>
            <rejectedACKMessage>Message Rejected.</rejectedACKMessage>
            <msh15ACKAccept>false</msh15ACKAccept>
            <dateFormat>yyyyMMddHHmmss</dateFormat>
          </responseGenerationProperties>
          <responseValidationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseValidationProperties" version="3.2.1">
            <successfulACKCode>AA,CA</successfulACKCode>
            <errorACKCode>AE,CE</errorACKCode>
            <rejectedACKCode>AR,CR</rejectedACKCode>
            <validateMessageControlId>false</validateMessageControlId>
            <originalMessageControlId>Destination_Encoded</originalMessageControlId>
            <originalIdMapVariable></originalIdMapVariable>
          </responseValidationProperties>
        </inboundProperties>
        <outboundProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DataTypeProperties" version="3.2.1">
          <serializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2SerializationProperties" version="3.2.1">
            <handleRepetitions>true</handleRepetitions>
            <handleSubcomponents>true</handleSubcomponents>
            <useStrictParser>false</useStrictParser>
            <useStrictValidation>false</useStrictValidation>
            <stripNamespaces>true</stripNamespaces>
            <segmentDelimiter>\r</segmentDelimiter>
            <convertLineBreaks>true</convertLineBreaks>
          </serializationProperties>
          <deserializationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2DeserializationProperties" version="3.2.1">
            <useStrictParser>false</useStrictParser>
            <useStrictValidation>false</useStrictValidation>
            <segmentDelimiter>\r</segmentDelimiter>
          </deserializationProperties>
          <batchProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2BatchProperties" version="3.2.1">
            <splitType>MSH_Segment</splitType>
            <batchScript></batchScript>
          </batchProperties>
          <responseGenerationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseGenerationProperties" version="3.2.1">
            <segmentDelimiter>\r</segmentDelimiter>
            <successfulACKCode>AA</successfulACKCode>
            <successfulACKMessage></successfulACKMessage>
            <errorACKCode>AE</errorACKCode>
            <errorACKMessage>An Error Occurred Processing Message.</errorACKMessage>
            <rejectedACKCode>AR</rejectedACKCode>
            <rejectedACKMessage>Message Rejected.</rejectedACKMessage>
            <msh15ACKAccept>false</msh15ACKAccept>
            <dateFormat>yyyyMMddHHmmss</dateFormat>
          </responseGenerationProperties>
          <responseValidationProperties class="com.mirth.connect.plugins.datatypes.hl7v2.HL7v2ResponseValidationProperties" version="3.2.1">
            <successfulACKCode>AA,CA</successfulACKCode>
            <errorACKCode>AE,CE</errorACKCode>
            <rejectedACKCode>AR,CR</rejectedACKCode>
            <validateMessageControlId>false</validateMessageControlId>
            <originalMessageControlId>Destination_Encoded</originalMessageControlId>
            <originalIdMapVariable></originalIdMapVariable>
          </responseValidationProperties>
        </outboundProperties>
      </responseTransformer>
      <filter version="3.2.1">
        <rules/>
      </filter>
      <transportName>JavaScript Writer</transportName>
      <mode>DESTINATION</mode>
      <enabled>true</enabled>
      <waitForPrevious>true</waitForPrevious>
    </connector>
  </destinationConnectors>
  <preprocessingScript>// Modify the message variable below to pre process data

//var fname = &quot;C://a-xfer//monfepic//testadt-output//&quot; + originalFilename + &quot;.psv&quot; ;
//var columnsout = &quot;A|B|C|D|E&quot; ;

//FileUtil.write( fname, false, columnsout);
//FileUtil.write(&quot;c:\\workspace\\mirth-test\\fixed.txt&quot;, true, &quot;Patient ID,First Name,Last Name\r\n&quot;);
return message;</preprocessingScript>
  <postprocessingScript>// This script executes once after a message has been processed
// Responses returned from here will be stored as &quot;Postprocessor&quot; in the response map
return;</postprocessingScript>
  <deployScript>// This script executes once when the channel is deployed
// You only have access to the globalMap and globalChannelMap here to persist data
logger.info(&quot;Deploying the Channel&quot;);
var conf = {};
var dateString = DateUtil.getCurrentDate(&apos;yyyy/MM/dd HH:mm&apos;);
conf.date = dateString;
globalChannelMap.put(&apos;old&apos;,conf);
return;</deployScript>
  <undeployScript>// This script executes once when the channel is undeployed
// You only have access to the globalMap and globalChannelMap here to persist data
return;</undeployScript>
  <properties version="3.2.1">
    <clearGlobalChannelMap>true</clearGlobalChannelMap>
    <messageStorageMode>DISABLED</messageStorageMode>
    <encryptData>false</encryptData>
    <removeContentOnCompletion>false</removeContentOnCompletion>
    <removeAttachmentsOnCompletion>false</removeAttachmentsOnCompletion>
    <initialState>STARTED</initialState>
    <storeAttachments>false</storeAttachments>
    <tags class="linked-hash-set"/>
    <metaDataColumns>
      <metaDataColumn>
        <name>SOURCE</name>
        <type>STRING</type>
        <mappingName>mirth_source</mappingName>
      </metaDataColumn>
      <metaDataColumn>
        <name>TYPE</name>
        <type>STRING</type>
        <mappingName>mirth_type</mappingName>
      </metaDataColumn>
    </metaDataColumns>
    <attachmentProperties>
      <type>None</type>
      <properties/>
    </attachmentProperties>
    <pruneMetaDataDays>1</pruneMetaDataDays>
    <pruneContentDays>1</pruneContentDays>
    <archiveEnabled>false</archiveEnabled>
    <resourceIds class="linked-hash-set">
      <string>Default Resource</string>
    </resourceIds>
  </properties>
</channel>