CLI client » History » Revision 2
Revision 1 (Tom Clegg, 02/19/2016 05:56 PM) → Revision 2/4 (Tom Clegg, 09/01/2017 02:05 PM)
h1. CLI client
Arvados exposes lots of functionality via REST/HTTP. Most of them deserve to be exposed through a command line tool that is easy to use interactively and in shell scripts.
h2. Background / current status
Currently there is an "arv" command line tool in source:sdk/cli (packaged as a Ruby gem and deb/rpm). It exposes REST APIs (as found in the discovery document) generically by mapping API names and parameters to command line arguments. It also knows how to invoke some Python programs (e.g., "arv put" passes through to "arv-put") which have their own calling syntax.
Problems:
* Awkward interface: <code>arv job list --filters '[["script","in",["foo","bar"]]]'</code>
* Lots of conventions: <code>arv collection get --uuid FOO</code> vs. <code>arv get FOO</code> vs. <code>arv-get FOO</code> (download files), <code>arv edit FOO</code> vs. <code>arv collection update --uuid FOO --collection '{...}'</code>
* Annoying to install (especially on older systems) because of Ruby requirements, and because both Ruby and Python pieces are needed to get a full set
* Slow to start up (partly because of Bundler?)
h2. Desired scope
Command line tool should be able to
* Display/list Arvados objects in human- and machine-readable form
* Create/edit all Arvados objects in a generic way (current @"arv edit"@ is pretty good)
* Perform common actions in a natural way (@"arv cancel JOB_UUID"@)
* Watch job logs in real time (@"arv tail -f JOB_OR_PIPELINE_UUID"@?)
* Transfer files/dirs between the local filesystem and Arvados collections (Keep)
* Expose collection data (and other Arvados objects) as a local filesystem through a FUSE mount
* Search/get objects across multiple sites, similar to workbench multi-site search
* ...more features go here
h2. Desired interface (patterns)
As with git, everything should be accessible through an "arv" front door. Some commands might result in forking other binaries like "arv-get" but this is an implementation detail that can change over time, not part of the public API.
Calling syntax should look familiar/normal to people who use related tools like Docker. In many cases one should be able to take a non-Arvados command, prefix it with the word "arv", and have it do the analogous thing with Arvados: e.g., @"arv less PDH/file.txt"@ or @"arv rm UUID"@.
(More rules/patterns go here)
h2. Desired interface (specifics)
(Specific commands go here)
h2. Implementation
For portability and ease of installation, 100% Python would be better than a Ruby/Python mix. 100% Go would be the best.
For speed (startup delay and data transfer are the main concerns) Go would be the best.
For implementation speed Python might be better than Go. (Currently the Python SDK is more complete.)