go to post Jeffrey Drumm · Jul 4 Set From = "2024-07-04 13:21:16.477" Set To = $ZSTRIP($PIECE(From,".",1),"*P")
go to post Jeffrey Drumm · Jul 4 @Enrico Parisi's observation is the most likely reason for the failure. You can obtain the credentials (assuming you've set them up in Interoperability | Configure | Credentials) with Set tCreds = ##class(Ens.Config.Credentials).%OpenId(..Adapter.Credentials,,.tSC) Return:$$$ISERR(tSC) tSC The tCreds.Username and tCreds.Password properties are available on success.
go to post Jeffrey Drumm · Jul 4 The Connect() method returns a %Boolean, not an %Status. You should check the ReturnCode and ReturnMessage properties to determine why it's failing.
go to post Jeffrey Drumm · Jul 3 The new editor doesn't support that, at least yet. If you'd prefer to have the original rule editor launch when editing a rule, you can disable the new editor's web application /ui/interop/rule-editor through the Management Console via System Administration | Security | Applications | Web Applications.
go to post Jeffrey Drumm · Jun 12 Odd. I just ran your exact query on IRIS for Health 2023.3 and it executed successfully. The error message suggests that a macro isn't defined, specifically $$$vaDataSegName, which is found in EnsHL7.inc (among others). Since you're working specifically with HL7 messages I suspect that include file is not available to the namespace in which you're running the query.
go to post Jeffrey Drumm · May 26 Looking through the HL7 2.5 OML_O21 structure as supplied by InterSystems, you'll find that there's a nested PIDgrpgrp() under ORCgrp().OBRgrp() that has a subordinate ORCgrp(). It looks like the parse is attempting to match on the required OBR segment in the nested PIDgrpgrp().ORCgrp(). You have a couple of options ... both of which require a custom schema to match your message. The first is to make the OBR segment in the PIDGrpgrp().ORCgrp() optional; the second is to remove the PIDgrpgrp() grouping entirely in the custom schema. EDIT: The first option doesn't work since the ORC matches on the optional ORC segment in the nested PIDgrpgrp.ORCgrp(), which makes it attempt to match on the required PIDgrpgrp.ORCgrp().OBXgrp().
go to post Jeffrey Drumm · May 20 This is what DTLs are for. The example below shows a scenario using HL7 2.5.1's ORU_R01 message structure, where each OBX segment may be followed by one or more NTE segments. The OBX Set ID, Value Type and Observation Value fields are populated; the first by the value of tObxCounter, the second by the string "TX" and the third by the contents of the Note field. The highlighted area demonstrates the updating of newly added OBX segments with the contents of corresponding NTE segments.
go to post Jeffrey Drumm · Apr 18 The ISCAgent is available through the online distribution link at the WRC site, in the "InterSystems Components" category. The oldest version available is 2018.1, but it may work for you.
go to post Jeffrey Drumm · Mar 12 OnGetConnections() should return an array in the first (Output) argument, indexed by the names of the target process(es) and/or operation(s). The second argument is the production item object passed by the invocation of the method from the web ui. Here's an example that scans the business process settings for any setting that ends with "ConfigName" or "ConfigNames" and sets the pArray argument appropriately: ClassMethod OnGetConnections(Output pArray As %String, pItem As Ens.Config.Item) { #dim tSetting As Ens.Config.Setting Do ##super(.pArray,pItem) For l=1:1:pItem.Settings.Count() { Set tSetting = pItem.Settings.GetAt(l) If ($LOCATE(tSetting.Name,"ConfigNames?$") && pItem.GetModifiedSetting(tSetting.Name,.tValue)) { For i=1:1:$L(tValue,",") { Set tOne=$ZStrip($P(tValue,",",i),"<>W") Continue:""=tOne Set pArray(tOne)="" } } } } Adjust the match string in the $LOCATE() function if you're using custom setting name(s) for the target(s).
go to post Jeffrey Drumm · Jan 30 I'd suggest using some other directory than /tmp as the root of the source path. And I would also recommend installing it as root rather than a user with some elevated privileges. You'll be specifying the account under which it will actually run later, during the install.
go to post Jeffrey Drumm · Jan 19 As mentioned by @Alexander Pettitt, xfs is recommended, but ext4 is supported as well. I've used both for LVM2 LVs on RedHat at multiple high-volume customers without issue. For my personal development environments I use Ubuntu 22.04 with LVM2 and ext4 LVs.
go to post Jeffrey Drumm · Jan 16 It's defined in Ensemble.inc ... but I'm not sure that's what you're looking for. The output should show in the Event log. #define sysTRACE(%arg) $$$catTRACE("system",%arg) #define catTRACE(%cat,%arg) Do:$$$DoTrace ##class(Ens.Util.Trace).WriteTrace(%cat,$$$CurrentClass,$$$CurrentMethod,%arg)
go to post Jeffrey Drumm · Jan 16 Add a code rule at the end of the DTL that contains: Write "<pre>"_target.RawContent_"</pre><hr>" Run the DTL Test and the raw message output will show above the HTML-formatted message. Disable the rule when you're satisfied with what you're getting.
go to post Jeffrey Drumm · Jan 16 Please note the caveat for using RawContent. You may get truncated messages ...
go to post Jeffrey Drumm · Jan 4 The executable should be here: C:\Program Files (x86)\Common Files\InterSystems\Agent\ISCAgent.exe Its properties (via Windows Explorer) show the version:
go to post Jeffrey Drumm · Dec 15, 2023 IRIS For Health includes ASTM E1394-97 / LIS02-A2 structures for mapping to many formats using a DTL, including HL7v2.5.1. It also includes a service class for handling ASTM files (EnsLib.EDI.ASTM.FileService).
go to post Jeffrey Drumm · Dec 10, 2023 Double check the <install-dir>/mgr/cacheodbc.ini file. I don't think changing the shared object file should have any effect on the visibility of the DSN in the Management Console, but I could be wrong.
go to post Jeffrey Drumm · Dec 10, 2023 I experienced a similar issue when configuring the MSSQL ODBC driver for IRIS. It appears as though the default odbcgateway.so is 32 bit, and I was able to get it working through the following steps: Change the working directory to Caché's /<install-dir>/bin Copy odbcgateway.so to odbcgateway32.so Copy odbcgatewayur64.so to odbcgateway.so