An Nhax file is a file format that is used to export/import data from Noah.
The Nhax format is a mix of binary data and XML formatted data the so called sections. As the Nhax format is complex and hard to implement HIMSA has developed a standalone library that can be used by business system developers that must support the Nhax format.
Extension to Old Nhax Format
In order to increase the quality of the data the data in Nhax sections is defined using XSD files. All data must validate with respect to the XSD when reading/writing Nhax files.
Furthermore the Misc section is now used and is defined in and XSD file.
Link to binary Nhax format: Noah 4 Extended Native Format (Nhax and Enhax)
Link to XML Sections in Nhax Files: XML Sections in Nhax Files
Error Handling
In general Nhaxlib functions returns a ValidateResult class:
public class ValidateResult
{
/// <summary>
/// Set to false if an error occurs
/// </summary>
public bool Validated { get; private set; }
// Error code
public ErrorCode ErrorCode { get; private set; }
/// <summary>
/// Textual description of the failing entity
/// </summary>
public string ErrorEntity { get; private set; }
/// <summary>
/// Textual description of the error
/// </summary>
public string ErrorDescription { get; private set; }
}
Furthermore functions may throw exceptions.
Nhax Writer
The Nhax writer writes Noah data to an Nhax file or a stream. The behavior of the NhaxWrites is define of the constructor called to make an instance of the writer. It may either produce a number of files of a given max size, one file that contains all data or all data written to a stream.
/// <summary>
/// Write all data to one Nhax file.
/// </summary>
/// <param name="fullPath">Full path to Nhax file</param>
/// <param name="password">Password to access the file</param>
/// <param name="nhaxFileCreatedCallback">Function called when Nhax file is written. The function is called with the name of the file that is written. Can be set to null.</param>
/// <param name="overwriteExistingFiles">True existing files will be overwritten. If false an error will be reported if file exists.</param>
/// <param name="compressData">If true data are compressed</param>
public NhaxWriter(string fullPath, string password, NhaxFileCreatedCallback nhaxFileCreatedCallback = null, bool overwriteExistingFiles = false, bool compressData = true)
/// <summary>
/// NhaxWriter constructor that writes data to one or more Nhax files.
/// If more than one Nhax file are created the file will contain a Misc section containing al Misc data provided. The user section will only contain users that are referenced by patients or actions.
/// </summary>
/// <param name="path">Path where the files is stored</param>
/// <param name="filePrefix">The prefix of the Nhax file. The file name is "filePrefix-dddddd" where d is digit e.g. "file-000001", "file-000002"</param>
/// <param name="password">Password to access the file</param>
/// <param name="nhaxFileCreatedCallback">Function called when Nhax file is written. The is called with the name of the file that is written. Can be set to null.</param>
/// <param name="overwriteExistingFiles">True existing files will be overwritten. If false an error will be reported if file exists.</param>
/// <param name="compressData">If true data are compressed</param>
/// <param name="maxFileSize">Max size of created file. When this size is reached a new Nhax file is created and data written to this file.</param>
public NhaxWriter(string path, string filePrefix, string password, NhaxFileCreatedCallback nhaxFileCreatedCallback = null, bool overwriteExistingFiles = false, bool compressData = true, long maxFileSize = ConstMaxFileSize)
When the NhaxWriter instance has been created WriteUsers and WriteMiscData must be called in order to add users and add Misc data to the Nhax file. These functions must be called before the WritePatient is called. Each call of WritePatient will add a patient to the Nhax file.
If using the constructor that takes maxFileSize argument a new Nhax file is created when the file size exceeds the maxFileSize after a patient is written. When changing to new Nhax file the nhaxFileCreatedCallback is called whith name of created Nhax file. The default size of maxFileSize is the advised size when generating Nhax file that is used when migrating to NoahES.
It is possible to call the writeUsers multiple times but when writing patient data. The users referred from a patient object must be knowm when WritePatient is called.
IMPORTANT: Be aware that the Nhax Writer implements the idisposable interface. It is important that dispose in order to update the binary part of the Nhax file correctly.
Nhax Reader
The Nhax reader reads data from an Nhax file or a stream that contains an Nhax file. The Nhax reader can be initialized with file or a stream.
/// <summary>
/// Initializing Nhax file reader
/// </summary>
/// <param name="password">Password if Nhax file is encrypted</param>
public ValidateResult Initialize(string filePath, string password)
/// <summary>
/// Initializing Nhax stream reader
/// </summary>
/// <param name="inStream">Stream that contains Nhax formatted data</param>
/// <param name="password">Password if Nhax data is encrypted</param>
/// <returns></returns>
public ValidateResult Initialize(Stream inStream, string password)
Be aware that the Nhax reader implements the idisposable interface. It is important to called the dispose function.
When reading large Nhax files it is recommended to read a moderate number of patients.
Nhax Logger Interface
Logging in NhaxLib can be enable either by implementing the Nhax logger interface INhaxLogger or create and use the simple logger that NhaxLib implements. The logger must be added using NhaxLogger.AddLogger.
Using the NhaxLib logger:
string logPath = @"c:\..."
INhaxLogger Logger = NhaxLogger.CreateLogger(logPath, true, 10 * 1024 * 1024);
NhaxLogger.AddLogger(Logger, NhaxLogLevel.Debug);
Sample