go to post Dmitry Maslennikov · Mar 19, 2019 Look at this my article where you will find some details, how to build Cache in docker on centos.Instead of COPY and tar I would recommend using ADD command because it doing extract at the same time.And for doing such build, you should have file cache-2017.1.3.317.0.18571-lnxrhx64.tar.gz close to the Dockerfile, or in the root of build context.If you do build this way. Cache distributive should be in the current folder. docker build . But, you will face an issue with Storage Driver. It will look like, successful build but PROTECT error during startup. With previous versions of Docker it was possible to change Storage driver to aufs, but not with the latest version, where support for such driver already removed. There are some tricks on how to manage to work with it, but I would not recommend it. Nowadays only IRIS 2019.1 works quite well in Docker with the default storage driver out of the box.
go to post Dmitry Maslennikov · Mar 12, 2019 I usually prefer ways when I can automate as most as possible. So, I would suggest, to use simple export but, and automate it, as you already use %Installer to automate installation.
go to post Dmitry Maslennikov · Mar 8, 2019 If you would like to do it with %Installer Manifiest, it is not going to be easy, unfortunately. CSPApplication there quite limited.I can't just do it this way. <CSPApplication Url="${CSPApp}" Directory="${CSPAppDir}" iKnowEnabled="yes"/> You should first create simple csp application <CSPApplication Url="${CSPApp}" Directory="${CSPAppDir}"/> Add something like this method ClassMethod EnableiKnow(pCSPName As %String = "") As %Status { new $namespace znspace "%SYS" set props("iKnowEnabled")=1 d ##class(Security.Applications).Modify(pCSPName,.props) quit $$$OK } But unfortunately, I also can't just call it from an installer, Invoke tag should be placed in Namespace tag. which is actually current namespace, but you should compute it first. This may help to declare a couple more default variables. Just place two first lines before your Installer generator do %code.WriteLine($c(9)_"set pVars(""CURRENTCLASS"")="""_%classname_"""") do %code.WriteLine($c(9)_"set pVars(""CURRENTNS"")=$namespace") quit ##class(%Installer.Manifest).%Generate(%compiledclass, %code, "setup") And finally, you can add this to your installer. Place it after CSPApplication creation, but outside of Namespace tag. <Namespace Name="${CURRENTNS}"> <Invoke Class="${CURRENTCLASS}" Method="EnableiKnow" CheckStatus="true"> <Arg Value="${CSPAPP}"/> </Invoke> </Namespace>
go to post Dmitry Maslennikov · Mar 6, 2019 I did not know about "%%UPDATE","%%INSERT". I decided to add an extra field CREATE TABLE "test" ( "identifier" VARCHAR(200) NOT NULL, "value" INTEGER COMPUTECODE { Set {*}={*}+{increment} } COMPUTEONCHANGE ("%%UPDATE","%%INSERT"), "increment" INTEGER, PRIMARY KEY ("identifier") ) and INSERT OR UPDATE INTO "test" ("identifier", "increment") VALUES ('someid', 1) this solved my issue
go to post Dmitry Maslennikov · Mar 6, 2019 We do not have any way to suppress warnings, yet. As I know only SonarQube for Java supports it.
go to post Dmitry Maslennikov · Mar 2, 2019 I would not be so sure in your doubts about VSCode. VSCode itself supports refactoring staff, we just do not have it in ObjectScript extension, yet. Deleting obsolete classes, for sure very interesting and quite difficult task. But better to solve it another way, with just clean rebuild. Or for example I can add action delete in the context menu in server explorer, so, a developer will be able to manually delete any class/routine on the server from VSCode.
go to post Dmitry Maslennikov · Mar 2, 2019 To activate OS authentication in your docker image, you can run this code, in %SYS namespace Do ##class(Security.System).Get(,.p) Set p("AutheEnabled")=p("AutheEnabled")+16 Do ##class(Security.System).Modify(,.p) If you work with community edition, you can use my image, where you can easily define also user and password for external use. Running server $ docker run -d --rm --name iris \ -p 52773:52773 \ -e IRIS_USER=test \ -e IRIS_PASSWORD=test \ daimor/intersystems-iris:2019.1.0S.111.0-community Terminal connect $ docker exec -it iris iris session iris Node: 413a4da758e7, Instance: IRIS USER>write $username root USER>write $roles %All Or with docker-compose, something like this iris: image: daimor/intersystems-iris:2019.1.0S.111.0-community ports: - 52773:52773 environment: IRIS_USER: ${IRIS_PASSWORD:-test} IRIS_PASSWORD: ${IRIS_PASSWORD:-test}
go to post Dmitry Maslennikov · Feb 21, 2019 Just published version 0.7.10:New logoFixed backward compatibility with previous versions of Atelier APIFixed issue with license usage, due to losing cookiesSome other small fixes
go to post Dmitry Maslennikov · Feb 21, 2019 Unfortunately VSCode marketplace doesn't have any good analytics, but as I can see I have now already more then 300 installs.
go to post Dmitry Maslennikov · Feb 21, 2019 Hi, very interesting, could you the issue, I'll try to investigate it. And I think I will make next release with API version fix out of the schedule.
go to post Dmitry Maslennikov · Feb 20, 2019 You can extend UrlMap only by splitting routesWhile in one class you have this XData UrlMap [ XMLNamespace = "http://www.intersystems.com/urlmap" ] { <Routes> <Route Url="/class/:namespace/:classname" Method="GET" Call="GetClass" Cors="true"/> <Map Prefix="/something" Forward="Some.Your.Class"/> </Routes> } You can add one more class, whic will work only with routes started with /something with XData UrlMap [ XMLNamespace = "http://www.intersystems.com/urlmap" ] { <Routes> <Route Url="/more" Method="GET" Call="More" Cors="true"/> </Routes> } Where real route will be /something/more
go to post Dmitry Maslennikov · Feb 18, 2019 I need a new good icon for the project, can anybody suggest or draw something?
go to post Dmitry Maslennikov · Feb 17, 2019 Hi Jiri, please fill the issue. I will add a check for any previous versions of API. So, something which will require a newer version of API, will not work, but others should work.
go to post Dmitry Maslennikov · Feb 17, 2019 Set ht = ##class(%Net.HttpRequest).%New() Set ht.Server = "server" Do ht.SetParam("param1", "true") Do ht.SetHeader("myheader", "headervalue") Set tSC = ht.Get("/api/get", 1) Look at the second parameter in the call of Get method, it is a test flag, helps to understand how your request will actually go GET /api/get?param1=true HTTP/1.1 User-Agent: Mozilla/4.0 (compatible; InterSystems IRIS;) Host: server Accept-Encoding: gzip myheader: headervalue Look at this code, it will do the same Set ht = ##class(%Net.HttpRequest).%New() Set ht.Server = "server" Do ht.SetParam("param1", "true") Do ht.SetHeader("myheader", "headervalue") Set ht.Location = "/api/get" Set tSC = ht.Get(, 1) Or even this code Set ht = ##class(%Net.HttpRequest).%New() Do ht.SetHeader("myheader", "headervalue") Set tSC = ht.Get("http://server/api/get?param1=true", 1)
go to post Dmitry Maslennikov · Feb 17, 2019 You can find them in the source of README [](https://www.intersystems.com/products/intersystems-iris/) [](https://www.intersystems.com/products/cache/) [](https://www.intersystems.com/products/ensemble/)
go to post Dmitry Maslennikov · Feb 13, 2019 It would be better if you could provide some of your code.
go to post Dmitry Maslennikov · Feb 5, 2019 I don't know exact task of Eduard, but I think, some time when you only one way to communicate with the server, and you need to do some task, why not to use it. But not all those tasks have to be asynchronous. Like here, you can connect, get response and disconnect, as well as with plain HTTP. Or connect, send request for some data, get response and disconnect. Websockets should keep connection alive. That's how it works, when you connected, you send any data, and get response, at any time, or get only response.
go to post Dmitry Maslennikov · Feb 5, 2019 And how it looks like just with telnet $ telnet echo.websocket.org 80 Copy-Paste this data GET / HTTP/1.1 Accept: */* Host: echo.websocket.org Connection: Upgrade Upgrade: websocket Sec-WebSocket-Key: 7BOhi3I1WkBoazaXv+MfWA== Sec-WebSocket-Version: 13 After the empty line, it will show response HTTP/1.1 101 Web Socket Protocol Handshake Connection: Upgrade Date: Tue, 05 Feb 2019 10:37:17 GMT Sec-WebSocket-Accept: /gSfI5y+P3MMhONARUXNHG5vrHc= Server: Kaazing Gateway Upgrade: websocket
go to post Dmitry Maslennikov · Feb 5, 2019 You should not forget that WebSockets is still used the HTTP protocol, so, you should send some headers first.Look at this my code, it uses plain OPEN, and I'm not sure if my example 100% correct, but works. set securityKey = $SYSTEM.Util.CreateGUID() set securityKey = $SYSTEM.Encryption.MD5Hash(securityKey) set securityKey = $SYSTEM.Encryption.Base64Encode(securityKey) set host = "echo.websocket.org" set url = "/" set port = 80 set device = "|TCP|"_port Open device:(host:port:"SCWD"::8192:8192:/TCPNOXY) Use device Write "GET ",url," HTTP/1.1",! Write "Accept: */*",! Write "Host: ",host,! Write "Connection: Upgrade",! Write "Upgrade: websocket",! Write "Sec-WebSocket-Key: ",securityKey,! Write "Sec-WebSocket-Version: 13",! Write !,*-3 Use device:(::"A":$char(13)) Set fullResponse = "" Do { Set response = "" Read response:1 Quit:'$test Set fullResponse = fullResponse_response_$char(13) } While $test Use 0 Close device Write !!,fullResponse In this case, it only reads the first response, which actually should be with HTTP headers as well. Something like this. HTTP/1.1 101 Web Socket Protocol Handshake Connection: Upgrade Date: Tue, 05 Feb 2019 10:51:37 GMT Sec-WebSocket-Accept: qU2IAmlBvnSoEctnti8lcbc4bVA= Server: Kaazing Gateway Upgrade: websocket It does not contain the first portion of data, which some WebSocket servers may send after initial connect. But if your server sends it, you should see it at the and of response. If you have to send something before, you should do it after the first response, which says that connection established and you can send any data. But not any, it should be in binary format, more details you can find here. Any responses also decoded.