go to post Ashok Kumar T · Apr 29 Hello @Evgeny Shvarov I intended to implement the same logic written by Mr @David Hockenbroch - specifically, fetching the `rowID` using a query, then opening the ID and invoking JSON adaptor methods to create a JSON object and write it to a stream. However, instead of following that approach, I tried same in SQL by constructed the query using SQL’s JSON_OBJECT and JSON_ARRAY functions to consolidate rows directly at the database level. Unlike the JSON adaptor, which conveniently exports all columns and fields in a single method, this approach required me to manually specify each column and field in the query. Additionally, I had to use implicit joins to handle object properties, and I couldn’t export entire values of stream properties as well. If the JSON_OBJECT function offered a more direct and extensive way to gather all necessary data, the process would be much more straightforward. So, I’ve submitted this as an idea in the idea portal to add this JSON_OBJECT() include all the fields dynamically. It's simple and eliminates the need for object instances. Sample SQL SELECT JSON_OBJECT( 'Name' :Name, 'Email' :JSON_OBJECT('EmailType' :Email->EmailType->Type,'EmailId':Email->Email), 'Phone':JSON_ARRAY($LISTTOSTRING(Phone)), 'Address': JSON_OBJECT( 'Door':Address->Door, 'State':JSON_OBJECT( 'stateId':Address->state->stateid, 'state':Address->state->state ), 'City':JSON_OBJECT( 'cityId':Address->city->cityid, 'city':Address->city->city ), 'Country':JSON_OBJECT( 'countryId':Address->Country->Countryid, 'country':Address->Country->Country ) ) ) FROM Sample.Person WHERE ID=1 Thank you!
go to post Ashok Kumar T · Apr 29 Hello @Yaron Munz I’m using Set sc = workMgr.Queue("..Cleanup", QueueId). I intentionally commented out Set sc = workMgr.WaitForComplete() because I'm not concerned (for now) with the completion status. Is it mandatory to include WaitForComplete()/Sync() when working with WorkMgr?
go to post Ashok Kumar T · Apr 24 Hello @Evgeny Shvarov I directly use %DymaicObject and %DynamicArray and its methods depends on the response type (array or object) to set the values into the JSON response and I use %WriteResponse to write that response to the API call Class sample.Impl Extends %REST.Impl { ClassMethod GetAllPersons() As %Stream.Object { d ..%SetContentType("application/json") set res = {"name":"test" do ..%SetStatusCode(200) do ..%WriteResponse(res) q 1 } Mixed of stream data types and other datas then creates a stream and convert into DynamicObject if required and write that response.
go to post Ashok Kumar T · Apr 15 Right, It worked! The issue was a mismatch in the super server port.
go to post Ashok Kumar T · Apr 15 Hello @Vitaliy Serdtsev, I executed the routine invocation commands in native python script.
go to post Ashok Kumar T · Apr 15 Thank you @Eduard Lebedyuk. Could you please paste the link of DP-422635 and DP-424156.that would be helpful.
go to post Ashok Kumar T · Apr 11 Hello @Yaron Munz Calling the label or subroutine directly without specifying the routine name—for example, set sc=wqm.Queue("subr1")—always works. However, using the label^routine syntax does not work as expected. If I need to execute a subroutine from a different routine, I have to wrap that subroutine inside another function and call that function instead. test.mac set wqm = ##class(%SYSTEM.WorkMgr).%New() set sc = wqm.Queue("f1^test1") quit ; test1.mac ; f1() do subr1 quit subr1 set ^test($NOW()) = "" quit I agree that return values are always not required when executing a routine, even when using methods like wqm.WaitForComplete() or wqm.Sync(). However, return values are mandatory for class when use wqm.WaitForComplete() or wqm.Sync(). Class When invoking class methods, you can call them with or without parameters, and with or without return values. Return values are not required if you don't need to capture the status using wqm.WaitForComplete() or wqm.Sync() Set wqm = ##class(%SYSTEM.WorkMgr).%New() Set sc=wqm.Queue("..func1",1) Set sc=wqm.Queue("##Class(Sample.Person).func1") return values required if the status by using "wqm.WaitForComplete()" or "wqm.Sync()" Set wqm = ##class(%SYSTEM.WorkMgr).%New() Set sc=wqm.Queue("..func1",1) Set sc=wqm.Queue("##Class(Sample.Person).func1",1) Set sc=wqm.WaitForComplete() If ('sc) W $SYSTEM.OBJ.DisplayError(sc) thanks!
go to post Ashok Kumar T · Apr 11 Hi @Julian Matthews The Ens.StreamContainer class is a %Persistent class and it stores the different types of stream in it. So, If you delete the row/record by id / or by query it will delete the entry as well as the stream contents(it's also part of the row) from the Ens.StreamContainer table. So, be cautious before deleting the container. %OnDelete callback method is used to do some additional function while deleting the object.
go to post Ashok Kumar T · 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 T · 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 T · 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 T · Mar 28 You can use $$$CurrentMethod from Ensemble.inc used to get the current classmethod in your methods.
go to post Ashok Kumar T · 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 T · 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 T · 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 T · 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 T · 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 T · 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.