/
Create an HL7 File Feeder

Create an HL7 File Feeder

Say you have a text file with a bunch of HL7 messages. Each segment ends with \r. And each message ends with \n. Here’s a sample file:

You could use the simulator component and feed it in via an HL7 Server - but honestly it’s probably easier to write you own simple component and feed the data directly into the component you are testing.

Here we use ~/test.txt for the default location of the input file. Take a look at Custom Fieldsif you haven’t already.

You access the field with:

local F = component.fields()

The FIL Library makes it really easy to inhale the file:

local Content = FILread(F)

We can easily see this by looking at the contents of the file using escaped mode of:

The string viewing window

See String:split(). The List contains a Lua table as list with the messages.

local List = Content:split("\n") trace(#List)

See Lua table as list

for i=1, #List do queue.push{data=List[i]} end

And now we have a working test component!

See Edit Connections if you need a refresher.

Now for a little extra flourish:

Let’s add some Custom Logging

Just added lines 7 and 11 to the script:

function main(Data) local F = component.fields().InputFile trace(F) local Content = FILread(F) local List = Content:split("\n") trace(#List) iguana.logInfo("#start About to queue "..#List.." messages"); for i=1, #List do queue.push{data=List[i]} end iguana.logInfo("#end Finished queueing "..#List.." messages"); end

See Concatenating strings for more on the “..“ notation to join strings together.

See Custom Status

require "FIL.FILreadWrite" function Status(N, Total) component.setStatus{data="Sending "..N.." of "..Total} end function StatusDone(Total) component.setStatus{data="Completed sending "..Total.." messages."} end function main(Data) local F = component.fields().InputFile trace(F) local Content = FILread(F) local List = Content:split("\n") trace(#List) iguana.logInfo("#start About to queue "..#List.." messages"); for i=1, #List do Status(i, #List) queue.push{data=List[i]} end StatusDone(#List) iguana.logInfo("#end Finished queueing "..#List.." messages"); end

The repository is here:

https://bitbucket.org/interfaceware/feeder/src/main/ - Git URL is git@bitbucket.org:interfaceware/feeder.git

See From URL

This shows using the component and the internals:

And this one shows using the logs from the component:

 

And now we have a simple tool that makes it easy to test our HL7 interfaces. But more importantly this exercise puts together a set of little concepts that once you grasp you can solve not only simple problems, but you can build up the skills to be able solve complex ones as well. There are no bottlenecks you cannot remove.