go to post Scott Roth · Jul 1 I was a part of a presentation at #Ready2025 very similar to what you are looking for. At Ready 2025, I worked with @John Goodgame , @Justin Owens, @Julio Rodriguez to present a Change Control Audit (Stealth Control) in which a task queries for changes and inserts the data into SQL tables that could be alerted or queried on. When it is posted look for a session named...Partnering for Success Collaborative Innovations in Interoperability @John Goodgame is talking with Product to see if this could be included, or might be publishing the code somewhere for others to use.
go to post Scott Roth · Jun 18 This is how i solved the issue Set tSC = pRequest.NewResponse(.tResponse) Quit:$$$ISERR(tSC) tSC Set tResponse.encodedMessage = $get(encodedMessage) set dMsg = $SYSTEM.Encryption.Base64Decode(tResponse.encodedMessage) set pResponse = ##class(EnsLib.HL7.Message).%New() set pResponse = ##class(EnsLib.HL7.Message).ImportFromString($Get(dMsg)) set pResponse.DocType = ##class(EnsLib.HL7.Schema).ResolveSchemaTypeToDocType(pResponse.TypeVersion,pResponse.Name)
go to post Scott Roth · Jun 18 This is how I solved the issue... Set tSC = pRequest.NewResponse(.tResponse) Quit:$$$ISERR(tSC) tSC Set tResponse.encodedMessage = $get(encodedMessage) set dMsg = $SYSTEM.Encryption.Base64Decode(tResponse.encodedMessage) set pResponse = ##class(EnsLib.HL7.Message).%New() set pResponse = ##class(EnsLib.HL7.Message).ImportFromString($Get(dMsg)) set pResponse.DocType = ##class(EnsLib.HL7.Schema).ResolveSchemaTypeToDocType(pResponse.TypeVersion,pResponse.Name)
go to post Scott Roth · Jun 17 How would I do nested iterations if I need to get something from say example "external Positions" "externalPositions": [ { "pureId": 0, "appointment": { "uri": "string", "term": { "en_GB": "Some text" } }, "appointmentString": { "en_GB": "Some text" }, "period": { "startDate": { "year": 0, "month": 1, "day": 1 }, "endDate": { "year": 0, "month": 1, "day": 1 } },
go to post Scott Roth · Jun 12 Not sure I am following, the idea was to take the HL7 message, encode it, and put it into the osuwmc.Nutrition.OSU.CBOARDNetMenuRequest.SendMessageRequest as the encodedMessage. Using the osuwmc.Nutrition.OSU.CBOARDNetMenuRequest.SendMessageRequest to pass to the Web Service Class to send outbound to the vendor. The two Parenthesis was a typo, and I was using the $Get(a) to dereference the %Stream to a string for the osuwmc.Nutrition.OSU.CBOARDNetMenuRequest.SendMessageRequest. The Soap wizard created the osuwmc.Nutrition.OSU.CBOARDNetMenuRequest.SendMessageRequest as the vendor requires a key value and encoded message in the body of the soap request.
go to post Scott Roth · Jun 11 [HealthConnect:3.5.0-1.m1] it was a group permission issue with the directory. However, once I created the DB, added it to the mirror on the Primary, I cannot get it to Sync with the others in the mirror. I removed it from the mirror for now till I have time to look at it again.
go to post Scott Roth · Jun 11 While I have applauded the updates, I have given feedback to the UX design team, as at times it seems clunky if we have big namespaces.
go to post Scott Roth · Jun 10 I need to take the Encoded Stream and send it as an Encoded String. How would I take a Stream and send it as a String?
go to post Scott Roth · Jun 6 I dismounted, secure copied the IRIS.dat to my backup/DR and mount the Database, but when I attempt to Activate Mirror Database on the backup, I am getting the following error... sc="0 "_$lb($lb(2073,"/ensemble/TEST/DB/TESTING/",,,,,,,,$lb(,"%SYS",$lb("e^ActivateMirroredDatabase+3^SYS.Mirror.1^2","e^^^0"))))/* ERROR #2073: Mirrored Database '/ensemble/TEST/DB/TESTING/' is not found on this system */ but it shows that the database has been mounted in the Terminal.
go to post Scott Roth · Jun 5 @Evgeny Shvarov, it makes sense I just haven't had the time to investigate.
go to post Scott Roth · Jun 2 Still not working right.. Class osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port Extends Ens.BusinessOperation [ ProcedureBlock ] { Parameter ADAPTER = "EnsLib.SOAP.OutboundAdapter"; Property LocalInterface As %String(MAXLEN = 255); Parameter SETTINGS = "LocalInterface:Connection:selector?context={Ens.ContextSearch/TCPLocalInterfaces}"; Method OnInit() As %Status { If 'IsObject(..Adapter.%Client.HttpRequest) { Set ..Adapter.%Client.HttpRequest=##class(%Net.HttpRequest).%New() } Set ..Adapter.%Client.HttpRequest.LocalInterface=$ZStrip($P(..LocalInterface,"("),"*W") } Terminating Job 819984 / 'NutritionCBOARDNetMenuSOAP' with Status = ERROR <Ens>ErrException: <SUBSCRIPT>OnInit+1^osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port.1 *IsObject("") -- logged as '-' number - @' If 'IsObject(..Adapter.%Client.HttpRequest) {', %QuitTask=
go to post Scott Roth · Jun 2 Class osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port Extends (Ens.BusinessOperation, EnsLib.SOAP.GenericOperation) [ ProcedureBlock ] { Parameter ADAPTER = "EnsLib.SOAP.OutboundAdapter"; Property LocalInterface As %String(MAXLEN = 255); Parameter SETTINGS = "LocalInterface:Connection:selector?context={Ens.ContextSearch/TCPLocalInterfaces}"; Method OnInit() As %Status { set interface = $ZStrip($P(..LocalInterface,"("),"*W") Set ..%Client.HttpRequest=##class(%Net.HttpRequest).%New() set ..%Client.HttpRequest.LocalInterface = interface QUIT $$$OK } I tried using ..%Client but got.. ERROR: osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port.cls ERROR: osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port.1(4) : MPP5376 : Method or Property '%Client' does not exist in this class. TEXT: Set ..%Client.HttpRequest=##class(%Net.HttpRequest).%New() ERROR: osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port.1(5) : MPP5376 : Method or Property '%Client' does not exist in this class. TEXT: set ..%Client.HttpRequest.LocalInterface = interface When I tried to compile.
go to post Scott Roth · Jun 2 I ended up doing.. Class osuwmc.Nutrition.OSU.CBOARDNetMenuOperation.CBORDHL7Port Extends (Ens.BusinessOperation, EnsLib.SOAP.GenericOperation) [ ProcedureBlock ] { Parameter ADAPTER = "EnsLib.SOAP.OutboundAdapter"; Property LocalInterface As %String(MAXLEN = 255); Parameter SETTINGS = "LocalInterface:Connection:selector?context={Ens.ContextSearch/TCPLocalInterfaces}"; Method OnInit() As %Status { set interface = $ZStrip($P(..LocalInterface,"("),"*W") set HttpRequest = ##class(%Net.HttpRequest).%New() set HttpRequest.LocalInterface = interface $$$LOGINFO("CBORDHL7Port OnInit: LocalInterface="_interface) QUIT $$$OK } The $$$LOGINFO is showing the correct address, but I am still having issues connecting. But thanks
go to post Scott Roth · Jun 2 This has been presented in each of the previous Global Summit's conferences. We will be reviewing it again at this years InterSystems READY 2025. Orlando Health has been the mainstay in the Development work of this tool. Please see previous session recordings via You Tube. Integration Production Tools: HealthShare Health Connect & InterSystems IRIS Healthhttps://www.youtube.com/watch?v=61Nduu5UyS0&ntb=1&msockid=232752513fc511f08781af03632c4a64
go to post Scott Roth · May 30 I am not sure I quite understand the question, but I just recently wrote EnsLib.SQL.InboundAdapters that will query MS SQL Server and write the data directly to IRIS Cache Tables I built, so in that sense it is possible. But if you have a service that is listening for a connection to query IRIS Tables, then I think you would want to build like an API listener that then queries the tables.