go to post Guillaume Rongier · Jul 7, 2021 Is Amir's solution not satisfactory? In some cases, it is preferable to use a < code > activity that directly calls the transformation and assigns the status code to the status variable, which will be processed by the try/catch. Set status = $classmethod(tTransformClass, "Transform", request, .normalizedRequest
go to post Guillaume Rongier · Jun 28, 2021 Hi, Great news about Direct Messages. In the meantime, is there any plan to make a dark mode for the community front end (as githut, stakoverflow, and so on does) ?
go to post Guillaume Rongier · Jun 24, 2021 Hi Muhammad, We have our own fhir repository : https://docs.intersystems.com/irisforhealthlatest/csp/docbook/Doc.View.c... But if you still want to use HAPI FHIR from a production you can use this adaptor : https://docs.intersystems.com/irisforhealthlatest/csp/docbook/Doc.View.c...
go to post Guillaume Rongier · Jun 23, 2021 It depends on what you are looking for. To create applications to expose data on IRIS with custom APIs and make custom applications, you can use IRIS Studio and/or VsCode with the IRIS extension. https://docs.intersystems.com/components/csp/docbook/Doc.View.cls?KEY=PA... For database administration, you can use the management portal. https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=PA... For 100% SQL administration, I recommend DbBeaver. https://community.intersystems.com/post/dbeaver-officially-supports-inte...
go to post Guillaume Rongier · Jun 17, 2021 You are right Benjamin, the R gateway go through the Java gateway with two helper classes : com.intersystems.rgateway.Helper org.rosuda.REngine.Rserve An example can be found here : https://github.com/grongierisc/iris-r-gateway-template If I may, I prefer the approach of Eduard for the R gateway : https://github.com/intersystems-community/RGateway who by pass the java gateway and directly use socket connection to the R Server. @Eduard Lebedyuk : you are right no documentation a this time for the R Gateway.
go to post Guillaume Rongier · Jun 2, 2021 Ready to cook ! I'm such a fan of my cat that he has his own Instagram: https://www.instagram.com/cat_philibert/
go to post Guillaume Rongier · May 26, 2021 You can't work directly in HSLIB, you have to create your own namespace to work with. In a terminal : zn "HSLIB" // Install a Foundation namespace and change to it Do ##class(HS.HC.Util.Installer).InstallFoundation("NEW_NAMESPACE") zn "NEW_NAMESPACE" If you are not familiar with Namespace, HSLIB, Ensemble first check for training here : https://learning.intersystems.com/course/view.php?id=243
go to post Guillaume Rongier · May 25, 2021 Hi Xiong, To convert FHIR R4 to SDA you have to use this helper class : HS.FHIR.DTL.Util.HC.FHIR.SDA3.Process This class take in input a message of this kind : HS.FHIRServer.Interop.Request or HS.Message.FHIR.Request. So if you want to convert an json FHIR file to SDA, you have to read the file from a business service cast you file to one of this message and send it to the helper class. Here is and Business service example of reading fhir json files : Class BS.FHIRFileService Extends Ens.BusinessService { Parameter ADAPTER = "EnsLib.File.InboundAdapter"; Property TargetConfigNames As %String(MAXLEN = 1000) [ InitialExpression = "BusinessProcess" ]; Parameter SETTINGS = "TargetConfigNames:Basic:selector?multiSelect=1&context={Ens.ContextSearch/ProductionItems?targets=1&productionName=@productionId}"; Method OnProcessInput(pDocIn As %RegisteredObject, Output pDocOut As %RegisteredObject) As %Status { set status = $$$OK try { set pInput = ##class(HS.FHIRServer.Interop.Request).%New() set tQuickStream = ##class(HS.SDA3.QuickStream).%New() do tQuickStream.CopyFrom(pDocIn) set pInput.QuickStreamId= tQuickStream.Id for iTarget=1:1:$L(..TargetConfigNames, ",") { set tOneTarget=$ZStrip($P(..TargetConfigNames,",",iTarget),"<>W") Continue:""=tOneTarget $$$ThrowOnError(..SendRequestSync(tOneTarget,pInput,.pDocOut)) } } catch ex { set status = ex.AsStatus() } Quit status } } You can find more information from this documentation : https://docs.intersystems.com/irisforhealthlatest/csp/docbook/Doc.View.c...
go to post Guillaume Rongier · May 18, 2021 Hi Lucas, A simple solution to you question can be this : Property numDossiersMER As list Of %Integer(SQLPROJECTION = "table/column", STORAGEDEFAULT = "array"); Index numDossiersMERIdx On numDossiersMER(ELEMENTS); With those parameters you can achieve : 'As list Of %Integer' allows you to use the Insert() in ObjectScript and 'for some %element' in SQL command 'SQLPROJECTION = "table/column"' allows you to display the table as a column (note, the column does not appear in a select * it must be specified : select numDossierMER, numDossiersMER from User_TestList_Data.Titre ) 'STORAGEDEFAULT = "array"' allows a separate table for the normalized representation 'Index numDossiersMERIdx On numDossiersMER(ELEMENTS);' bring the ability to use index on values with this SQL query : select numDossierMER, numDossiersMER from User_TestList_Data.Titre where for some %element(numDossiersMER) (%Value in (345))
go to post Guillaume Rongier · Apr 30, 2021 Thanks you all ! I am glad to see that this little module is used and useful :)
go to post Guillaume Rongier · Apr 29, 2021 Hi Cindy, To deploy your services, routes and plugins to another environment you can use CI/CD with postman (newman) Some examples here : https://github.com/grongierisc/iam-training/tree/main#12-cicd Another possibility is to use deck (decK helps manage Kong’s configuration in a declarative fashion) from kong https://docs.konghq.com/deck/ I haven't tried this one, I can't give you feedback on it.
go to post Guillaume Rongier · Apr 21, 2021 Nice, the support of ZPM in the json config file is a major improvement. Now we can use this module as a total replacement of the manifest installer ! Great work !
go to post Guillaume Rongier · Apr 16, 2021 I tried your module as a replacement for the Manifest installer, see this example: https://github.com/grongierisc/intersystems-iris-dev-template However, I'm stuck for the part with ZPM.The problem is, with your module, I can create a database, its rights, etc., but how to tell ZPM to load the classes in the freshly installed NameSpace? What are the possible solutions? Add an option to your module to load code ? Add an option to ZPM to take into account your configurations ? What to do with the CPF module? https://docs.intersystems.com/irisforhealthlatest/csp/docbook/DocBook.UI... We have today many options to load configuration IRIS, are they in competition? How to federate these modules who are all complementary?
go to post Guillaume Rongier · Apr 15, 2021 What a nice feature. If I understand correctly, this module can be considered as a replacement for the Manifest installer? If so, then this module has the benefit of exposing the configuration as JSON and API rather than a compiled class.
go to post Guillaume Rongier · Apr 12, 2021 If I understand correctly, you want to replace an HTTP Header basic auth with a bearer token. If the bearer token is static, you can implement a solution like this: - https://github.com/grongierisc/iam-training/tree/training#6-third-add-ou... If it is dynamic, I think you will have to develop your own plug-in: - https://github.com/grongierisc/iam-training/tree/training#11-plugins A good base to start working on could be this plugin: - https://github.com/grongierisc/kong-plugin-jwt-crafter
go to post Guillaume Rongier · Apr 12, 2021 Super benchmark, it's very interesting.Personally, I prefer the squash method because it is easy to implement (no change in the dockefile).
go to post Guillaume Rongier · Jan 28, 2021 Yes your code is correct. Id1 still exist and it's sync with id. When you index a new primary key, id will have that value. In your case Id1 is call as is because you name a column Id. I think, you can't get rid off ID (Id1 in your case). Should ask an expert on that. @Eduard Lebedyuk @Benjamin De Boe @Robert C. Cemper
go to post Guillaume Rongier · Jan 28, 2021 Hi Michael, No plan for that yet, but the solution is quiet similar, fetch the internal data of step count, transform it to FHIR, send them to the registry. But, as soon as I change my iPhone to an Android, I will reconsider to do it for Android ;)
go to post Guillaume Rongier · Jan 28, 2021 Hi Yeung, First how-to auto increment an integer, you can use this property : %Library.AutoIncrement Doc : https://docs.intersystems.com/irisforhealthlatest/csp/docbook/Doc.View.c... Then, why you have ID1 in your table, because by default any persistent class have an column called ID who is an auto increment and indexed as a primary key.You can overload this primary key by your own with this index : Index name On property_expression_list [ PrimaryKey ]; Doc : https://docs.intersystems.com/irisforhealthlatest/csp/docbook/Doc.View.c...
go to post Guillaume Rongier · Dec 7, 2020 Hi, What you can do is a snapshot of this ResultSet. Then use the global of this snapshot for another Operation : Get snapshot global : Method OnGetSnapshot(pRequest As Ens.Request, Output pResponse As Ens.StringResponse) As %Status { set tStatus = $$$OK try{ set pResponse = ##class(Ens.StringResponse).%New() set tQuery = "SELECT * FROM [sqlserver].[dbo].[whatever] " //$$$TRACE(tQuery) Set pSnap = ##class(EnsLib.SQL.Snapshot).%New() //size of snapshot // -1 = Max set pSnap.MaxRowsToGet = -1 $$$ThrowOnError(..Adapter.ExecuteQueryBatch(pSnap,tQuery,1000)) $$$ThrowOnError(pSnap.%Save()) set pResponse.StringValue = pSnap.%GblRef } catch exp { Set tStatus = exp.AsStatus() } Quit tStatus } Use snapshot global : Method UseSnapshot(pRequest As Ens.StringRequest, Output pResponse As Ens.Response) As %Status { set status = $$$OK try { set pResponse = ##class(Ens.Response).%New() set nRow = 0 set tSequence = 0 //Get SnapShot Set tSnap = ##class(EnsLib.SQL.Snapshot).%New() set tSnap.%GblRef = pRequest.StringValue // use of global SnapShot set tSnap.%CurrentRow = 0 set tSnap.FirstRow = 1 set tSnap.MaxRowsToGet = -1 $$$TRACE("MaxRowsToGet : "_tSnap.RowCountGet()) while tSnap.Next() { try { set nRow = nRow + 1 set tSequence = tSequence + 1 set i = 0 set i = i + 1 set tParam(i) = tSnap.Get("Col1") set i = i + 1 set tParam(i) = tSnap.Get("Col2") set i = i + 1 set tParam(i) = tSnap.Get("Col3") set i = i + 1 set tParam(i) = tSnap.Get("ColX") set tParam = i set tQuery = "UPDATE Whatever "_ "SET "_ "Col1 = ? "_ ",Col2 = ? "_ ",Col3 = ? "_ " WHERE ColX = ? " $$$ThrowOnError(..Adapter.ExecuteUpdateParmArray(.tResult,tQuery,.tParam)) } catch exSnap { // Update exeption } } } catch ex { set status = ex.AsStatus() } return status } Furthermore, If you have big table to query/insert in JDBC consider this ZPM module : https://github.com/grongierisc/BatchSqlOutboundAdapter