go to post Ashok Kumar · Apr 1 Hello @Phillip Wu The "status" is set to 1 for tasks that are either currently suspended ("Suspended Reschedule") or encounter an error during execution. If the "Suspend task on error?" option is set to "no" when scheduling the task, the error message is stored in the status column. However, the task status is not suspended. From documentation If not defined by the task default success will be 1If the job is currently running (JobRunning) Status will be -1If there was an untrapped error (JobUntrappedError) Status will be -2If there was an error before execution (JobSetupError) Status will be -3If the task timed out trying to job (JobTimeout) Status will be -4If there was an error after execution (JobPostProcessError) Status will be -5The text of the status code will be in the property Error. SQL Query select Name,displaystatus,Error,Suspended,%ID from %SYS.Task Where Suspended=1 or Suspended=2 Query method set tResult = ##class(%SYS.Task).TaskListFilterFunc("Suspend") do tResult.%Display()
go to post Ashok Kumar · Mar 31 Hello @Nezla, The %SYS.Task class has the task details which includes the status of the task. The "Suspended" column has value if incase the task is errored out while running ("Suspend Leave" ) or the task is suspended ("Suspend Reschedule"). Based on this column you can find out the suspended /errored task. Use the below query for the TaskName and additional details. select Name,Status,TaskClass,Suspended from %SYS.Task
go to post Ashok Kumar · Mar 31 You can use the $STACK to get the previous stack call information by using the level and code string. Try the below code in your method "B". it returns the previous call stack information. $STACK($STACK(-1)-1,"PLACE")
go to post Ashok Kumar · Mar 28 You can use $$$CurrentMethod from Ensemble.inc used to get the current classmethod in your methods.
go to post Ashok Kumar · Mar 27 Hello @Michael Wood, here are several approaches you can take to handle this. One option is to create a file service that reads the file as a stream and sends it to a custom business process. You can then convert that stream into a JSON object and iterate through each DynamicObject entry. Alternatively, you could send the stream to BPL and process the JSON there Simplified sample of process the JSON. Class Samples.Introp.JSONFileService Extends Ens.BusinessService { Parameter ADAPTER = "EnsLib.File.InboundAdapter"; Method OnProcessInput(pInput As %Stream.Object, Output pOutput As %RegisteredObject) As %Status { Do ..SendRequestSync("JSONFileProcess",pInput,pOutput) Quit $$$OK } } Class Samples.Introp.JSONFileProcess Extends Ens.BusinessProcess [ ClassType = persistent ] { Method OnRequest(pRequest As Ens.Request, Output pResponse As Ens.Response) As %Status { Set json = {}.%FromJSON(pRequest) Set iter = json.%GetIterator() while iter.%GetNext(.key,.val) { s ^test($Classname(),$NOW(),key)=val.%ToJSON() } Quit $$$OK } } Thanks!
go to post Ashok Kumar · Mar 18 Hi @Eduard Lebedyuk I use the same code and as well as use $ZU(41,-2) to get stack information .
go to post Ashok Kumar · Mar 5 Hello @Krishnaveni Kapu %SYS.Task is responsible for store, suspend and resume for all the tasks. so, your can execute the below method programmatically to achieve it. It expects the task id as the first argument You can execute the below query to get the task id, name and additional information select Suspended,Name,id from %SYS.Task suspend Flag 1 - Suspend the task, but leave it in task queue (default)2 - Suspend the task, remove from task queue, and reschedule for next time Set taskId = 1001 Set flag = 2 Write ##class(%SYS.Task).Suspend(taskId,flag) resume Set taskId=1001 Write ##class(%SYS.Task).Resume(taskId)
go to post Ashok Kumar · Feb 27 Hi @Sebastian Thiele Here is the Encounter resource. I'm using IRIS for Windows (x86-64) 2024.1.1 url : http://localhost:52773/csp/healthshare/learning/fhir/r4/Encounter?&date=lt2024-10-27T15:29:00Z Spoiler {"resourceType":"Encounter","id":"example-01","meta":{"lastUpdated":"2024-10-27T15:30:00Z","profile":["https://nrces.in/ndhm/fhir/r4/StructureDefinition/Encounter"]},"text":{"status":"generated","div":"<div xmlns=\"http://www.w3.org/1999/xhtml\"> Admitted to Cardiac Unit,UVW Hospital between June 28 and July 9 2020</div>"},"identifier":[{"system":"https://ndhm.in","value":"S100"}],"status":"finished","class":{"system":"http://terminology.hl7.org/CodeSystem/v3-ActCode","code":"IMP","display":"inpatient encounter"},"subject":{"reference":"Patient/example-01"},"period":{"start":"2024-10-29T15:30:00Z","end":"2024-10-29T19:30:00Z"},"hospitalization":{"dischargeDisposition":{"coding":[{"system":"http://terminology.hl7.org/CodeSystem/discharge-disposition","code":"home","display":"Home"}],"text":"Discharged to Home Care"}}}
go to post Ashok Kumar · Feb 27 Hello @Sebastian Thiele As per the documentation, date is fully supported search parameter. so, This should work prefix lt dates I've 2 encounter resource in my FHIR server and I've tested with different dates ex: &date=lt2024-10-27T15:29:00Z period and it works to me
go to post Ashok Kumar · Feb 26 Awesome, It's pretty useful. However, If alias is retains like :history -Display command history its' really helpful and no need to define the shortcuts again.
go to post Ashok Kumar · Feb 23 Hello @Kevin Mayfield Instead FromJSON() write a custom class to parse the Binary Resource and set it into the FHIR model class. Here I convert the the data (which is the Binary resource -pdf or anything) to stream and set it in the data field of the HS.FHIR.DTL.vR4.Model.Resource.Binary class ClassMethod SetBinaryR4(json As %DynamicObject) { Set obj = ##class(HS.FHIR.DTL.vR4.Model.Resource.Binary).%New() Set obj.contentType = json.contentType #; convert to stream to prevent from the <MAXSTRING> error Set dataAsStrm = json.%Get("data",,"stream") Set obj.data = dataAsStrm Set obj.id = json.id #; set binary data element as stream for "Binary" resource. ZWrite obj.data.Read() } Thanks!
go to post Ashok Kumar · Feb 21 Hello @Kevin Mayfield %GetNext retrieves values from the JSON object/array and assigns them to a local variable. However, the BLOB/streams exceed the maximum local length (3641144), MAXLEN doesn't cause the issue because it's a registered object, and the values are currently stored in memory. Therefore, AFAIK FromJSON is not suitable for handling such a large dataset.
go to post Ashok Kumar · Feb 13 Hello @Jan K Yes, PS256 is not supported. Can you try it in python JWT library packages.
go to post Ashok Kumar · Feb 10 Hello @Ali Chaib You need to create you're custom DTL under "HS.Local.FHIR.DTL" Once DTL is created. Execute set status = ##class(HS.FHIR.DTL.Util.API.ExecDefinition).SetCustomDTLPackage("HS.Local.FHIR.DTL") this and this will configure the customize DTL entry in the ^HS.XF.Config global it's responsible for execute your DTL Here is the documentation which covers most customization. As I mentioned earlier, You need to the additional properties in respective SDA extension class.
go to post Ashok Kumar · Feb 10 Hello @Ali Chaib FHIR to SDA Yes we have built in transformation class available to FHIR ⇆ SDA and HS.FHIR.DTL.Util.API.Transform.FHIRToSDA3 is used to convert to SDA3 to FHIRIf you're goal to to convert to FHIR to SDA object then "HS.FHIR.DTL.Util.HC.SDA3.FHIR.Process" use this Business Process(BP) class to convert but this will send the request to BO again based on the BP configuration. Otherwise programmatically construct the input and pass the required values to the method in TransformStream class transformation class(which is in FHIR to SDA conversion business process) HS.FHIR.DTL.Util.API.Transform.SDA3ToFHIR for convert FHIR to SDA SDA3 to HL7 conversion There is no method for programmatically converting from SDA to HL7 v2. from documentation. So, You need to read the JSON response, extract the required information, and transform it directly into an HL7 message There are multiple DTL's available for SDA3 to HL7 v2 in package "HS.Gateway.SDA3.SDA3ToHL7." Can you check and utilize if it's helps Thanks!
go to post Ashok Kumar · Feb 10 Hi @Phillip Wu If you're create new object values. Means, The %New() - Creates a new instance of object and It invokes the user provided callback method "%OnNew()". You can define your properties if you want in that call back methods. Class Backup.Task Extends %Persistent { Property TaskName As %String; Property TaskDescription As %String; Method %OnNew(pTaskName As %String, pTaskDescription As %String) As %Status { Set ..TaskName = pTaskName Set ..TaskDescription = pTaskDescription Return $$$OK } ClassMethod CreateNewTask() { Set taskObj = ##Class(Backup.Task).%New("DailyBackup","Runs a daily backup") Set st = taskObj.%Save() } } If you want to fetch the values of already stored. You have to use the %OpenId(id) and pass the id to open the instance of the expected object and you can fetch the values ClassMethod GetTaskDetails(taskId) { Set taskObj = ##Class(Backup.Task).%OpenId(taskId) Set lastRunStatus = taskObj.LastRunStatus }
go to post Ashok Kumar · Feb 8 You can download the latest community edition of InterSystems iris and iris for health in https://evaluation.intersystems.com/
go to post Ashok Kumar · Feb 7 Hello @Ali Chaib SDA, or Summary Document Architecture is an intermidary format. It's used to easily convert between multiple data formats--such as HL7 V2, C-CDA, C32, HL7 FHIR, and others. I hope You are sending a GET request via HTTPOperation in FHIR interoperability production. You'll get the http response. There is no predefined transformation available to do it. You need to programmatically convert the response. I just convert the FHIR operation outcome to FHIR R4 outcome object directly. ClassMethod fhirresponse() { #;Assume the json as a fhir response Set fhiResponse = {"resourceType":"OperationOutcome","issue":[{"severity":"error","code":"not-found","diagnostics":"<HSFHIRErr>ResourceNotFound","details":{"text":"No resource with type 'Task' and id '33'"}}]} #dim opoutcome As HS.FHIRModel.R4.OperationOutcome = ##Class(HS.FHIRModel.R4.OperationOutcome).fromDao(fhiResponse) Write opoutcome.issue }