go to post Scott Roth · 2 hr ago 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.
go to post Scott Roth · May 28 Hello Community, My name is Scott Roth I am from the United States, and currently live in Columbus, Ohio. I am a Sr Application Development Analyst for the The Ohio State University Wexner Medical Center I have been in Health Care Integration for 21 years and have been using InterSystems HealthShare Health Connect since 2015. I became a Developer Community Moderator in 2016/2017 I’m a Health Care Integration Developer with hands-on experience in HL7. Beyond standard interface development, I focus on enhancing our integration capabilities by exploring new tools, technologies, and architectural approaches to improve interoperability and streamline workflows. Currently working with and on developing the Health Share Provider Directory with Managed Services to hopefully one day replace our homegrown built Provider Master Solution. I can be found on Linked In I will be presenting at InterSystems Ready 2025 on Tuesday afternoon at 2:30
go to post Scott Roth · May 28 Thanks responseData.items.%Get(0).titles.%Get(0).value.%Get("en_US") did the trick
go to post Scott Roth · May 14 After talking with the vendor, they mentioned they had a .wsdl that could be used to send the HL7 message via a SOAP connection. I took the wsdl and ran it through the SOAP wizard to create the basic classes. Now we are waiting on a firewall request to allow us to communicate with the vendor over port 443.
go to post Scott Roth · May 7 If the Response you get from a REST call is a %DynamicAbstractObject, how do you know how many levels to go through? I tried using JSON2Persistant however the naming convention of the tree that it is building it too long for me to upload it into github, so since I have two values that I need to only retrieve I am attempting to iterate through the JSON and just extract those two values for example, if I only want to pull the pureId and the portalURL from the response object, how can I iterate through the JSON response to get those values only? { "count": 0, "pageInformation": { "offset": 0, "size": 0 }, "items": [ { "pureId": 0, "uuid": "196ab1c9-6e60-4000-88cb-4b1795761180", "createdBy": "string", "createdDate": "1970-01-01T00:00:00.000Z", "modifiedBy": "string", "modifiedDate": "1970-01-01T00:00:00.000Z", "portalUrl": "string", "prettyUrlIdentifiers": [ "string" ], "previousUuids": [ "string" ], "version": "string", "startDateAsResearcher": "1970-01-01", "affiliationNote": "string", "dateOfBirth": "1970-01-01", "employeeStartDate": "1970-01-01", "employeeEndDate": "1970-01-01", "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 } }, "externalOrganization": { "uuid": "196ab1c9-6e60-4000-8b89-29269178a480", "systemName": "string" } } ], when I attempted set itr = responseData.%GetIterator() while itr.%GetNext(.key, .value) { if key = "pureID"{ set pResponse.pureID = value } elseif key = "portalURL" { set pResponse.portalURL = value } } both the pureID and portalURL came back blank.
go to post Scott Roth · May 6 Typically, it would only be one message schema, but I understand what you mean by creating a copy of the EnsLib.HL7.Operation.TCPOperation. I'll keep that in mind if I want to explore this further.
go to post Scott Roth · May 6 How do we take the JSON response, iterate through it to put it into a data class structure that could be used? Using JSON2Persistent, I took a JSON response and converted it into a Data Class Structure.
go to post Scott Roth · May 5 Adding a Pre-Processing Router on top seems like it would work, but it's not really efficient when you are struggling with processing, cpu, memory etc... it adds another process on top of everything else.
go to post Scott Roth · May 5 My task class is calling another Method in another class file that is set to write, but when the Task ran, I got was a blank Output File.
go to post Scott Roth · May 1 I just had a similar issue, where there were 25 sessions open with my name. We hit our limit of licenses, so I ended up killing what I was not using so it did not interrupt my team. I did not capture the Timeout (UTC) before I did it, but should of. After I freed up sessions, I did notice that if I opened VSCode that /api/atelier sessions still opened after I had closed out VS Code. We have the CSP Inactivity Timeout on the Web Gateway to 24 hrs, so I don't know if those sessions were over that timeframe or not.
go to post Scott Roth · Apr 28 I have an Identifier that I receive in an HL7 MFN message, I need to take this Identifier and find the Locations that the Identifier is associated with, so I can set the Sending Facility value within the HL7 message to help filter out specific locations from being sent to the Health Share Provider Directory.for example... ID1 might be associated with Site 1, Site 3. IF site 1 is valued and equals xxx, then send on else do not send on.
go to post Scott Roth · Apr 22 I was able to get it to work. I found that in Cache I need to call %Get("<column>") name vs what I am doing in a BPL. s Loc = "" s tStatement = ##class(%SQL.Statement).%New() s execall= "CALL osuwmc_Utils_EnterpriseDirDb.InterfaceCheckConnectMedCtrID(?)" s qStatus = tStatement.%Prepare(execall) if $$$ISERR(qStatus) {write "%Prepare failed:" do $SYSTEM.Status.DisplayError(qStatus) quit} set rset = tStatement.%Execute(pInput) while rset.%Next() { set Loc = rset.%Get("OSUguestRoleDTL") } if $Length(Loc) = 0 { set Loc = "OSUWMC" }
go to post Scott Roth · Apr 14 The Class name is osuwmc.Epic.Clarity.DepartmentMaster and it is storing data in Data - ^E2C8.D9IS.1 BitmapExtent Index - ^E2C8.D9IS.2 IDIndex Index - ^E2C8.D9IS.3 IDKey Index - ^E2C8.D9IS.1 Indexes - ^E2C8.D9IS.I Stream - ^E2C8.D9IS.S I am not sure what to put in as the Global Name, would that be E2C8? and then the subscript to be mapped would be D9IS.*?
go to post Scott Roth · Apr 14 I am also trying to map a Database table from one namespace to another. When I enter the following into the %ALL namespace as the global map, when I select from that table in the second namespace I get no results.
go to post Scott Roth · Apr 3 The rule was just routing the message through a DTL and sending it to two places in the same line. The message size was 12661. My team member just ended up splitting up the send line into multiple send lines instead of a single send line with two destinations.
go to post Scott Roth · Apr 2 interesting theory to try, someone on my team changed it to cover it to stream, and put it back into the message before this answer. the Physician memory usage went down, the virtual memory usage went up. However, the error seemed more at the Routing than the DTL. It may have something to do with Locking and trying to send to multiple locations in a single send.
go to post Scott Roth · Apr 1 With the way that we built our namespaces, I had to create a smaller namespace that included all of our nuances that we do like... BPL making JDBC MS SQL Stored Procedure calls, making internal cache calls, making linked table/store procedure calls. Larger namespaces will cause the comparison run to take longer to run. So, my mini namespace is used to test new versions of HealthShare Health Connect.
go to post Scott Roth · Mar 17 I ended up doing a BS for each query that I was pulling into an Internal Cache Table. Adding a Service and BP would cause more overhead system resource wise.
go to post Scott Roth · Mar 13 The issue was with the query I was using. Those that wrote the query were renaming columns with ' ' but putting spaces in the new names. SELECT A AS 'ABC CDE' FROM TableName I think there was the Typo in my service code, because I never use spaces and assumed that the column names did not have spaces.
go to post Scott Roth · Mar 13 I am connecting to a MS SQL Server Database using JDBC. These columns can be up to 255 characters.