go to post Kurro Lopez · Mar 11, 2021 Thanks for your tip, using LogFile I've found what is the error. The problem was that the configuration of the URL but it works if "Web Service URL" has the full path. I have other WS Clients and they are working with the Client Class in "Web Service Client Class" field I think if the WS is like "http://myserver.com/path/service.asmx" it should be separated in both fields. However, if it is a Java WS (it hasn't class file) it sould be in URL field. I'll bear in mind for future implementations. Thanks for all your help. Kurro
go to post Kurro Lopez · Feb 25, 2021 Thanks Mark, Finally I've used that solution. Best regards,Kurro
go to post Kurro Lopez · Jan 27, 2021 If you are using IRIS Community Edition, please have a look this link https://community.intersystems.com/post/avoid-exceed-databases-license-l... Best regards, Francisco Lopez
go to post Kurro Lopez · Jan 27, 2021 Hi. Try use this command from console (Powershell, console Linux, etc..) for Intersytems Ensemble ccontrol.exe force HEALTHSHARE HEALTHSHARE is the name of your instance This command should be executed in bin folder (ex. c:\Intersystems\Healthshare\bin) For IRIS the command is iris.exe forece IRISHealth IRISHealth is the name of your instance, it is in the folder bin (ex. c:\Intersystems\IRISHealth\bin) Best regardsFrancisco Lopez
go to post Kurro Lopez · Jan 4, 2021 Happy new year Feliz año nuevo Feliç any nou C Новым Годом Feliz Ano Novo 明けましておめでとうございます
go to post Kurro Lopez · Dec 31, 2020 Hi, Have a look this link https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=RC... Best regards, Kurro Lopez
go to post Kurro Lopez · Dec 21, 2020 A new interface to export production, select several class at the same time. Export MAC in the same file, add default value by environment, etc... By this way, you can create a export file (xml) that you can load using implemetation menu option.
go to post Kurro Lopez · Sep 18, 2020 if you want to use the DTL programmatically.... ClassMethod Clone(pRequest As EnsLib.HL7.Message) As EnsLib.HL7.Message [ Final ] { set sc=##class(Kurro.DTL.EDCoder).Transform(pRequest,.request) if $$$ISERR(sc) {do $system.Status.DisplayError(sc)} Quit request }
go to post Kurro Lopez · Sep 18, 2020 I think the best approach to your goal is create a DTL and clone the message directly, then check the value of DG1:4.1 and set the value in target that you want. See below You can call to the DTL and you'll have your new message. Regards,Kurro Lopez
go to post Kurro Lopez · Sep 18, 2020 Hi, One question... the third line is using ind variable, but you are evaluating ind2 variable, is it a mistake? Regards, Kurro Lopez
go to post Kurro Lopez · Sep 17, 2020 This is the transformation code (if you want). In my example, I was transforming OUL^R22 to OUL^R22 Class Kurro.DTL.test Extends Ens.DataTransformDTL [ DependsOn = EnsLib.HL7.Message ] { Parameter IGNOREMISSINGSOURCE = 1; Parameter REPORTERRORS = 1; Parameter TREATEMPTYREPEATINGFIELDASNULL = 0; XData DTL [ XMLNamespace = "http://www.intersystems.com/dtl" ] { <transform sourceClass='EnsLib.HL7.Message' targetClass='EnsLib.HL7.Message' sourceDocType='2.7:OUL_R22' targetDocType='2.7:OUL_R22' create='new' language='objectscript' > <assign value='source.{PIDgrp.PID}' property='target.{PIDgrp.PID}' action='set' /> <if condition='..Length(source.{PIDgrp.PID:11(1).8})>0' > <true> <assign value='source.{PIDgrp.PID:11(1).1}_" "_source.{PIDgrp.PID:11(1).2}' property='target.{PIDgrp.PID:11(1).1}' action='set' /> <assign value='source.{PIDgrp.PID:11(1).8}' property='target.{PIDgrp.PID:11(1).2}' action='set' /> <assign value='""' property='target.{PIDgrp.PID:11(1).8}' action='set' /> </true> <false> <assign value='""' property='target.{PIDgrp.PID:11(1).8}' action='set' /> </false> </if> </transform> } } Regards, Kurro Lopez
go to post Kurro Lopez · Sep 17, 2020 Hi, if you read your requirements, that is that you have to write in your DTL The first line copy all your PID in the new destination (green box) the condition, check if the 11(1).8 has value, in this case, concatenate PID:11(1).1_PID:11(1).2 to new PID:11(1).1 I understand, when you say "move 11(1).8 to 11(1).2 means that the value in 11(1).8 will be empty (red box), if it is not the case, don't use this line. For other case (step 7). remove the value of the PID:11(1).8 The DTL conditions are executed in order, It means, that the value in PID:11(1).2 in step 3 is the original then it is replaced by PID:11(1).8 in the following step. This is the test result: I hope it helps you, Regards, Kurro Lopez
go to post Kurro Lopez · Sep 10, 2020 Welcome Kevin, To get badges, you should to participate in Global Master, please add a replay to this link and welcome to Global Master https://community.intersystems.com/post/join-intersystems-global-masters... Regards,Kurro
go to post Kurro Lopez · Sep 10, 2020 Hi Kurt, Check if you are using ODBC 32 or 64 bits. Maybe there are two applications (one for each configuration) and not all ODBC connection are displayed. I'm using ODBC 64 bits and my connections are availables Also, check if your ADO .Net driver is for 32 or 64 bits compatible. I hope it is help for you, Regards,Kurro
go to post Kurro Lopez · Sep 7, 2020 Hi Tim, I know that is a old question, and I don't know if you have resolved your problem. I have something like you are asking in a process. Maybe it could help you. I created a persistent class with theses properties, also add a Query to retrieve info from a ProcessId: Class FtpFileReport Extends %Persistent { /// ProcessId Property ProcessId As %String; /// Filename Property FileName As %String; /// Retrieve records of a ProcessId Query GetRecordsByProcessId(pProcessId As %String) As %SQLQuery { SELECT ProcessId, FileName FROM FtpFileReport WHERE ProcessId = :pProcessId } } Then, when my process start to grabs the file, create a ProcessId, for example, using a combination of horolog and cryptotoken, to create an unique Id. set pProcessId = "ID"_$PIECE($HOROLOG,",")_$PIECE($HOROLOG,",",*)_$SYSTEM.Encryption.GenCryptToken() For each file grabbed, you save a record in your persistent class set obj=##class(FtpFileReport).%New() set obj.ProcessId = pProcessId ;pProcessId is the variable with the Id created previously set obj.FileName = pFileName ;if you are using retrieveFile method, it is the name the file that is grabbing do obj.%Save() Afterward, create a message to a BO that send the email with the ID of the process and create the message body based on ProcessId files: Class SendEmail Extends Ens.BusinessOperation { Parameter ADAPTER = "EnsLib.EMail.OutboundAdapter"; Parameter INVOCATION = "Queue"; /// Send email of FTP Report Method SendFtpReport(pRequest As Ens.StringRequest, Output pResponse As Ens.StringResponse) As %Status { #dim myList As %Library.ListOfObjects set report = ##class(FtpFileReport).%New() set myList = ##class(%Library.ListOfObjects).%New() set resultset = report.GetRecordsByProcessId(pRequest.StringValue) set data = ##class(%Stream.GlobalCharacter).%New() while resultset.%Next() { set fileNum = $Increment(fileNum) do data.Write("<b>"_fileNum_":</b><p>"_resultset.%Get("FileName")_"</p><hr>") do myList.Insert(data) } set msg = ##class(%Net.MailMessage).%New() set msg.IsHTML = 1 do msg.TextData.WriteLine("<h1>FileReport</h1><br><h2>This is the FTP report: <h2><br><br>") ; This is the body of the email for pos=1:1:myList.Size { do msg.TextData.Write(myList.GetAt(pos).Read()) } set msg.To = ##class(%Library.ListOfObjects).%New() ;Destinations address do msg.To.Insert("destination@mydomain.com") set msg.Subject= "File report" do ..Adapter.SendMail(msg) set pResponse = ##Class(Ens.StringResponse).%New("Ok") quit $$$OK } XData MessageMap { <MapItems> <MapItem MessageType="Ens.StringRequest"> <Method>SendFtpReport</Method> </MapItem> </MapItems> } } I hope helps you. Regards,Francisco Lopez
go to post Kurro Lopez · Sep 4, 2020 I think the user _purges has the same privileges than the other task that is working, isn't it?