go to post Julius Kavay · Aug 15, 2022 The only tricky thing is the (web)management portal. Put the following few lines into a "test.html" file and the open it with your favorite browser. <html> <head></head> <body> A simple text with some spaces<br> <pre>A simple text with some spaces</pre> </body> </html> You see the difference?
go to post Julius Kavay · Jul 27, 2022 You can take the line from your own code, but with a suitable parameter Set BASE64=BASE64_file.Read(someCount) // someCount = aNumber * 3 For example 30000 instead of 32000. By the way, you read (8 bit) bytes, so there is no need to do the output-UTF8 conversion.
go to post Julius Kavay · Jul 9, 2022 After spending about 30 seconds on Google, I found following links https://www.astm.org/e1394-97.html // ?? https://toolkits.horiba-abx.com/documentation/download.php?id=71068 // downloads a pdf https://meganorms.com/st-astm-e1394-97.html https://www.iso.org/obp/ui/#iso:std:iso:18812:ed-1:v1:en ... and many other links Don't ask me,how accurate they are...
go to post Julius Kavay · Jul 4, 2022 I have an (some ten years old) one which I use in the %ZSTART routine. Sometimes (for maintenance or whatever other reasons) you have to (re)start Cache and nowdays IRIS, but you want to start just some of the automatic processes listed in %ZSTART. If you forgot to disable those other before shutdown a init-file comes handy to disable things before start. A sample section looks like this: [Start] # 0 = do not start # 1 = start LoginServer = 1 UserLogin = 0 SystemTasks = 1 UserTasks = 0 I added some more comments to the class, you can download the InitFile.xml (class export) from my FTP server (which will be open for the next few days). Addr: ftp.kavay.at User: dcmember Pass: member-of-DC
go to post Julius Kavay · Jun 28, 2022 The general syntax for calling routines from another namespace is: do label^|namesapce|routine where - you can omit the label and - namespace is either the name of the namespace (like set namesapce="USER") or the path to the database (preceded by two carets), where the routine resides. I see right now, Config.MapGlobals accesses the ^SYS global via the path to the database (take a look at the Storage section) - so in theory, you can call all classmethods from the above class as: do zClassmethodname^|"%SYS"|Config.MapGlobals.1(args...) merely, I do NOT recommend to do this (the cass is in deployed mode, so we do not know, what the code really does and (instance)methods are private, so you can't call them from outside).
go to post Julius Kavay · Jun 28, 2022 First, the correct (or better) way for the above code snipet were: new $NAMESPACE zn "%SYS" do ##class(Config.MapGlobals).Delete(...) quit second, one can call routines (and (class)methodes are compiled to rotines) from another namespace by using extended syntax, but in that case such a routine uses the globals (if the routine does a global access) from the CALLING namespace. In Your case this won't work because the Config.MapGlobals uses globals which resides in %SYS namespace and not in the namesspace you are in.
go to post Julius Kavay · Jun 7, 2022 you miss the object reference! set context.strDocumentEncoded = B64EncodeStream(request.streamPDF) // ---------------------------^^^^^^^ this should be something set context.strDocumentEncoded = ##(your.class).B64EncodeStream(request.streamPDF) but you have another problems too: your context.strDocument and context.strDocumentEncoded are currently STRING properties (according to the operation you try to do), which are limitet to a maxlength of 3.47MB! You have to change both to a STREAM, so you can handle PDFs larger then ca. 2.6MB (because 2.6 * 4 / 3 ==> 3.46MB, the limit for a string variable). After you change context.strDocument and context.strDocumentEncoded to a stream properties, you could use this code: Class DC.Someclass Extends %RegisteredObject { Parameter CHUNKSIZE = 2097144; ClassMethod ToBase64(src As %Stream.Object, dst As %Stream.Object) As %Status { i ..#CHUNKSIZE#3=0, src.Rewind(), dst.Rewind() { set sts=$$$OK while 'src.AtEnd,sts { do dst.Write($system.Encryption.Base64Encode(src.Read(..#CHUNKSIZE,.sts),1)) } } else { set sts=$$Error^%apiOBJ(5001,"Chunksize or src/dst-problem") } quit sts } } if ##class(your.class).ToBase64(context.strDocument,context.strDocumentEncoded) write "OK" It seems, this task will take some time... you have to check, how context.strDocument is populated and how context.strDocumentEncoded is later in code used. Good luck.
go to post Julius Kavay · Jun 6, 2022 it looks like an OREF but it is just a string, try set obj = [1,2] write obj --> NN@%Library.DynamicArray write $isobject(obj) --> 1 set ^myGlobal = obj set obj=^myGlobal write obj --> NN@%Library.DynamicArray write $isobject(obj) --> 0 see also my answer in https://community.intersystems.com/post/handling-globalcharacterstream-production-service?page=1#comment-189746
go to post Julius Kavay · Jun 4, 2022 As an ObjectScript routine, remove the "ClassMethod" keyword (which, as the name indicates, belongs to classes. Then either add a "Public" keyword or you remove the brackets ("{", "}") too, but then all variables will have the same scope: ProcData(file = "c:\temp\zipcitystate.csv") Public { set str=##class(%Stream.FileCharacter).%New() do str.LinkToFile(file) while 'str.AtEnd { set $listbuild(ZIP,CITY,STATE)=$listfromstring(str.ReadLine()) // now you have the individual columns // in ZIP, CITY and STATE variables for further processing write "Zip=",ZIP,?12,"City=",CITY,?40,"State=",STATE,! } // depending on the way of your implementation, a "kill str" // would be needed to free up the file kill str } Oh, and to invoke the above procedure just do a: do ProcData^YourRoutineName() // or do ProcData^YourRoutineName("path-to-file")
go to post Julius Kavay · Jun 2, 2022 A simple method like ClassMethod ProcData(file = "c:\temp\zipcitystate.csv") { set str=##class(%Stream.FileCharacter).%New() do str.LinkToFile(file) while 'str.AtEnd { set $listbuild(ZIP,CITY,STATE)=$listfromstring(str.ReadLine()) // now you have the individual columns // in ZIP, CITY and STATE variables for further processing write "Zip=",ZIP,?12,"City=",CITY,?40,"State=",STATE,! } // depending on the way of your implementation, a "kill str" // would be needed to free up the file kill str } to do the job. Then call the method as do ##class(your.class).ProcData() // or do ##class(your.class).ProcData("path-to-the-file")