[chimerax-users] Remote control?

Conrad Huang conrad at cgl.ucsf.edu
Mon Jul 24 15:29:02 PDT 2017


"remotecontrol" is actually an umbrella command that covers several 
mechanisms including ReST and XML-RPC.  Both PROTOCOLS support access 
from remote hosts; however, due to security concerns, the current 
implementations for both in ChimeraX only allow for connections from the 
local host.  To support access across a network, you will need to modify 
the Python code, taking care of the security trade-off for your 
environment along the way.  Even if you are willing to ignore the 
security issues for now, you still need to decide on how the different 
ChimeraX instances find each other.  You may well want to stop at this 
point :-), but nitty gritty details are below if you're comfortable with 
programming in Python.

The code for supporting ReST and XML-RPC are in "chimerax/rest_server" 
and "chimerax/remote_control" respectively in the Python "site-packages" 
directory.  Since I wrote rest_server, I can tell you more about that. 
In rest_server/server.py, there is a line:

     self.httpd = HTTPServer(("localhost", port), RESTHandler)

that creates a HTTP server within ChimeraX.  As you can see, it only 
accepts connections on host "localhost" on a particular port.  You can 
change that to, for example, ("", 65000) to allow connections on port 
65000 from any host.  How you propagate the host and port information 
among multiple ChimeraX instances is a hard problem for which we have no 
solution yet.  To invoke a command via ReST, you simply send a request 
to, for example, "http://hostname:65000/run?cmd=open+1gcn", where 
"open+1gcn" is the HTTP GET encoded string for the ChimeraX command 
"open 1gcn"; the output from the command is the returned text from the 
HTTP request.

You can see how the rest_server code currently works by running the 
ChimeraX command:

   remote rest start

You should see some output like:

   REST server started on host 127.0.0.1 port XXXX

in the Log panel.  You can then go to a web browser and visit:

   http://localhost:XXXX/cmdline.html

to display a ChimeraX command line in the browser window, where you can 
issue commands and see the output.

Hope this helps.

Conrad

On 7/24/2017 11:48 AM, Simon Smith wrote:
> I'm trying to find a way to mirror ChimeraX commands from one machine 
> onto several others running on a network. Could someone tell me if the 
> 'remotecontrol' command would be a good way to do this, and if so, how I 
> could get started using it? As far as I can tell there's no 
> documentation available for it yet.
> 
> Thanks,
> Simon
> 
> 
> _______________________________________________
> ChimeraX-users mailing list
> ChimeraX-users at cgl.ucsf.edu
> Manage subscription:
> http://www.rbvi.ucsf.edu/mailman/listinfo/chimerax-users
> 



More information about the ChimeraX-users mailing list