#166 closed defect (fixed)

command line order is problematic

Reported by: zandr Owned by: warner
Priority: major Milestone: 1.10.0
Component: code-frontend-cli Version: 0.6.1
Keywords: security usability unix mac error reviewed Cc: gdt
Launchpad Bug:

Description

allmydata-tahoe put -u http://localhost:port LOCAL_FILE REMOTE_FILE

Assuming we're going to have to specify the -u at all (can we stash that in ~/.allmydata or similar?), it seems that options that are generic regardless of the command should be *before* the verb.

This is made more annoying by the fact that the usage/help specifies "put LOCAL_FILE REMOTE_FILE" with no meniton of -u, and the error if you get that wrong is an unhelpful "wrong number of arguments."

Attachments (3)

fix-args.diff (42.4 KB) - added by warner at 2012-05-31T21:55:55Z.
fix handling of --node-directory
166-2.diff (766 bytes) - added by warner at 2012-06-15T00:33:47Z.
improved patch (add default nodedir to --help in all commands, fix typo)
166-3.diff (776 bytes) - added by warner at 2012-06-15T01:35:28Z.
add "[global-opts]" to command synopses

Download all attachments as: .zip

Change History (49)

comment:1 Changed at 2007-10-11T10:04:40Z by warner

As of an hour ago, you no longer need the '-u' .. all CLI commands default to using ~/.tahoe , including 'create-client' and 'start'. See #120 for details.

The other criticisms are still outstanding though. The short answer is that not all commands accept those "generic" parameters, so they live after the verb. Also, the directory to use (for start/stop/restart) can come as an actual argument (as opposed to an option/parameter/flag), so 'tahoe start node1' works. This is specifically useful for 'tahoe restart -m node*', to kick a whole directory full of nodes at once.

That said, enough of the CLI commands take that argument that maybe it *should* be moved before the verb. And certainly the silent confusion with LOCAL_FILE REMOTE_FILE is a big problem.

comment:2 Changed at 2007-10-19T22:45:27Z by zooko

  • Version changed from 0.6.0 to 0.6.1

I kind of think the node-admin commands -- create-introducer, create-client, start, stop, and restart ought to be under a separate executable name than the "CLI" commands -- ls, put, get, mv, rm, etc..

This would fix Zandr's original complaint, and it would fit my brain. The first command could be tahoeadmin and the second one could be tahoe, for example.

comment:3 Changed at 2007-10-19T22:53:50Z by warner

sounds reasonable to me. That matches how svn/svnadmin works too.

I'll work on this if nobody else beats me to it.

comment:4 Changed at 2007-10-19T22:54:09Z by warner

  • Component changed from unknown to code-frontend
  • Milestone changed from undecided to 0.6.2
  • Owner changed from nobody to warner
  • Status changed from new to assigned

comment:5 Changed at 2007-10-22T19:22:27Z by warner

hm, or how about 'tahoe ls' vs 'tahoe admin create-client' ? That way we only install a single executable to /usr/bin/tahoe (reducing user-perceived complexity), while still hiding the admin-only commands from a normal 'tahoe --help' or bare 'tahoe' command.

If we write man pages, we could have separate ones for tahoe(1) and tahoe_admin(1). A couple tools I've been looking at recently do it this way, like imapfilter.

There are other projects that use this approach; the ones that come to mind are more distributed and make it more likely that regular users will be using the "admin"-oriented commands. darcs and mercurial both have 'init' and various repair/optimize operations as part of their normal subcommand set (they install exactly one executable), but still have a flat command namespace.

Hm, so I guess this is a flat-vs-nested question as well as a UI-affordance (keeping the 'tahoe help' listing short enough to find the interesting commands) question. So the three options here are:

  1. 'tahoe ls' vs 'tahoe create-client' (the 0.6.1 behavior)
  2. 'tahoe ls' vs 'tahoeadmin create-client'
  3. 'tahoe ls' vs 'tahoe admin create-client'

I'm leaning towards number three right now.. thoughts?

comment:6 Changed at 2007-10-22T19:33:15Z by zandr

I'm with you, 3. is the way to go. Attention should be paid to producing meaningful error/usage info, as described in the initial report.

comment:7 Changed at 2007-10-22T19:45:11Z by zooko

I'm happy with 3. I asked my friend Seb about it in e-mail, and his comment was something like "order of options shouldn't matter -- I didn't realize how much I cared about this until I met git, where order of options matters and it's a pain".

So, I don't know if tahoe can be made insensitive to order of options, but let it be known that there is at least one person out there who would like that.

comment:8 Changed at 2007-11-01T17:25:30Z by zooko

  • Milestone changed from 0.6.2 to 0.7.1

We're focussing on an imminent v0.7.0 (see the roadmap) which hopefully has Small Distributed Mutable Files and also a fix for bad SHA-256. So I'm bumping less urgent tickets to v0.7.1.

comment:9 Changed at 2007-11-13T19:40:31Z by zooko

  • Priority changed from major to minor

comment:10 Changed at 2008-01-15T21:37:05Z by zooko

  • Component changed from code-frontend to code-frontend-cli

comment:11 Changed at 2008-01-23T02:49:29Z by zooko

  • Milestone changed from 0.7.1 to undecided

As far as I understand the current cli is good enough for Zandr to use for Allmydata 3.0 rollout, so I'm bumping this ticket to "undecided" milestone and if Zandr wants something different then he should speak up.

comment:12 Changed at 2009-12-13T04:48:29Z by davidsarah

  • Keywords security usability unix mac added
  • Priority changed from minor to major

Putting options after the verb creates a security hazard on Unix platforms: if the user tries to use wildcards to specify multiple local files (for tahoe cp, say), then a local filename may begin with - and be treated as an argument. If options had to be before the verb, that couldn't happen.

Although this hazard can be worked around either by prefixing each wildcard argument with ./ or (for most commands) using -- before any filename arguments, it's very easy to forget to do that. Also, more users know about the -- workaround than ./, and Tahoe does not currently appear to support --.

OTOH, requiring tahoe -r cp would look backwards to many users. I don't know how to resolve that.

(Windows doesn't have this problem because the shell doesn't automatically glob arguments.)

comment:13 follow-up: Changed at 2010-10-24T18:53:13Z by davidsarah

  • Keywords error added

Riastradh on irc:

I typed `tahoe -d . ls root:' and it crashed, complaining that I have no ~/.tahoe directory, not complaining that I put the option in the wrong place.

So the problem is also that the error message when you get the argument order wrong can be quite unhelpful.

comment:14 in reply to: ↑ 13 Changed at 2011-02-16T04:04:17Z by davidsarah

Replying to davidsarah:

So the problem is also that the error message when you get the argument order wrong can be quite unhelpful.

Another example of that, from munderwo on IRC:

tahoe create-alias default -d infra-client
.../bin/tahoe:  Wrong number of arguments.

(should be "tahoe create-alias -d infra-client default").

comment:15 Changed at 2011-04-06T23:36:51Z by davidsarah

Greg Troxel wrote on tahoe-dev:

I'm trying to gradually get more serious in my tahoe usage - private grid and backups, not just playing with the pubgrid.

I now on several machines have client directories ~/.tahoe-pubgrid and ~/.tahoe-gdt. I have separate server processes on server machines.

So, I find myself doing

tahoe deep-check -d ~/.tahoe-gdt --add-lease --repair
tahoe deep-check -d ~/.tahoe-pubgrid --add-lease --repair

and naturally would like to have aliases

  tahoep () { tahoe -d ${HOME}/.tahoe-pubgrid $*; }
  tahoeg () { tahoe -d ${HOME}/.tahoe-gdt $*; }

but that won't work, because one must do "tahoe command [options]".

Since -d is about everything, it would be nice if it were accepted at the beginning.

comment:16 Changed at 2011-04-07T14:50:40Z by zooko

  • Cc gdt added

comment:17 Changed at 2012-05-31T18:29:45Z by davidsarah

  • Milestone changed from eventually to 1.11.0

comment:18 Changed at 2012-05-31T18:43:13Z by warner

#1751 was another aspect of this: --node-directory is ignored when it appears before the subcommand. In general, the tahoe command/subcommand parser looks for arguments in two places: tahoe --ARG1 SUBCOMMAND --ARG2, but how they're combined is up to the subcommand.

What do people think about the following proposal?:

  • the generic arguments (--quiet, --version, --version-and-path, --node-directory/-d) will only be accepted in the ARG1 slot, and all commands that use them (i.e. anything that needs a node directory to work with) will honor them from there.
  • the tahoe create-*/start/stop/restart NODEDIR shortcuts will continue to work
  • tahoe create-*/start/stop/restart will continue to accept a --basedir/-C option in the ARG2 slot
  • only one of ARG1--node-directory / ARG2--basedir / NODEDIR will be accepted. Providing more than one will produce an error.

Note that there are several tahoe commands that don't need a node-directory (everything under "tahoe debug" and "tahoe admin"), but seeing how those are in the minority, I think it's better to put --node-directory in the ARG1 slot and have those commands just ignore it, rather than putting --node-directory in the ARG2 slot for every single command that can use it.

Last edited at 2012-06-15T01:21:48Z by warner (previous) (diff)

comment:19 Changed at 2012-05-31T18:44:54Z by davidsarah

+1 for the comment:18 proposal.

comment:20 Changed at 2012-05-31T19:06:17Z by warner

Hm, actually, would anyone mind if I removed the --basedir/-C option too? It's never been accepted in the ARG1 position (only in the ARG2 position for create/start/stop/restart), so it'd be simpler to remove it completely than to move it to a new place.

Last edited at 2012-05-31T19:08:02Z by warner (previous) (diff)

comment:21 Changed at 2012-05-31T19:11:20Z by davidsarah

I think users probably have scripts using --basedir/-C in the ARG2 position for create/start/stop/restart, so that should continue to be accepted. It's easy in that case; just ignore the option.

Changed at 2012-05-31T21:55:55Z by warner

fix handling of --node-directory

comment:22 Changed at 2012-05-31T22:08:57Z by warner

  • Keywords needs-review added

Ok, that patch makes the changes proposed in comment:18, leaves --basedir in place according to comment:21 (but pays attention to --basedir rather than ignoring it). It also requires that --version, --version-and-path, and --quiet live in ARG1, rejecting them if they appear in ARG2. Tests that exercise command-line parsing have been updated to match.

The patch is a bit big because it changes the way we use base classes in src/allmydata/scripts/ . Previously common.BaseOptions provided --version and --node-directory, and both the ARG1-handling runner.Options and all the ARG2-handling parsers inherited from it, and then the basedir-needing parsers additionally inherited from common.BasedirMixin.

In the new world, BaseOptions is much smaller (it forbids --version and sets up .command_name), BasedirOptions is a parent class instead of a mixin, the ARG1 parser inherits from neither (but now contains the --node-directory handler), and the ARG2 parsers all inherit from BaseOptions, or BasedirOptions if they need --basedir/BASEDIR (create/start/stop/restart).

comment:23 Changed at 2012-05-31T22:42:44Z by davidsarah

  • Keywords review-needed added; needs-review removed
  • Milestone changed from 1.11.0 to 1.10.0
  • Owner changed from warner to davidsarah
  • Status changed from assigned to new

Will review.

comment:24 Changed at 2012-05-31T22:42:56Z by davidsarah

  • Status changed from new to assigned

comment:25 Changed at 2012-05-31T22:46:20Z by davidsarah

typo: 'argumnent' (on line 49 of the patch)

Changed at 2012-06-15T00:33:47Z by warner

improved patch (add default nodedir to --help in all commands, fix typo)

comment:26 follow-up: Changed at 2012-06-15T01:29:56Z by davidsarah

  • Keywords zookos-opinion-needed added
  • Owner changed from davidsarah to zooko
  • Status changed from assigned to new

After discussing this on IRC we ended up with the following unresolved issues:

  • --help for subcommands no longer mentions the global options
  • because the new version accepts -d/--node-directory only before the command, and the old version accepted it only after the command (and ignored it if before), there is no way to write a script that works with both.

We considered allowing -d both before and after but could not decide whether that was worth the complexity. Zooko?

Changed at 2012-06-15T01:35:28Z by warner

add "[global-opts]" to command synopses

comment:27 follow-up: Changed at 2012-06-15T01:39:35Z by warner

latest patch (also visible in https://github.com/warner/tahoe-lafs/tree/166-args) fixes the first issue (mentioning global options)

So the remaining question is -d before the subcommand. I'm not hugely motivated to make it possible to write new scripts that work with old versions (unlike py2/py3 I think once you've upgrated to a new tahoe version, you'll just stick with it). And I prefer the simplicity of having fewer options (I still want to remove the -C/--basedir option from the node-admin commands, but want to respect David-Sarah's opinion that people may have scripts that will break).

comment:28 Changed at 2012-09-04T16:06:42Z by zooko

  • Owner changed from zooko to davidsarah

comment:29 Changed at 2012-09-04T16:07:30Z by zooko

  • Owner changed from davidsarah to warner

comment:30 Changed at 2012-11-02T01:02:35Z by Zancas

I believed that I could pass options to the tahoe utility instead of its subcommand so I attempted to run: >tahoe -d /home/arc/myLAEgateway/ backup /home/arc/sandbox/KandRC/ KandR: which failed (with an ugly traceback).

comment:31 Changed at 2012-12-20T17:04:52Z by davidsarah

  • Owner changed from warner to davidsarah
  • Status changed from new to assigned

comment:32 Changed at 2012-12-20T17:51:18Z by warner

On the dev call this morning, we agreed that davidsarah will look at the 166-3.diff patch and if they don't raise any major objections, warner will land it this coming weekend. Hopefully we can resolve the -d issue in the 1.11 timeframe.

comment:33 Changed at 2013-01-03T16:27:35Z by davidsarah

  • Owner changed from davidsarah to zooko
  • Status changed from assigned to new

comment:34 in reply to: ↑ 26 Changed at 2013-01-03T16:38:04Z by zooko

Replying to davidsarah:

After discussing this on IRC we ended up with the following unresolved issues:

  • --help for subcommands no longer mentions the global options

This seems like an important issue to me. Users have a hard enough time that if they ask for help we should really give it.

  • because the new version accepts -d/--node-directory only before the command, and the old version accepted it only after the command (and ignored it if before), there is no way to write a script that works with both.

We considered allowing -d both before and after but could not decide whether that was worth the complexity. Zooko?

Hm... I'm not sure if there are any script-writers who are going to care about this. I guess since I don't have any evidence either way, I'd like to err on the side of ease-of-development on this. Especially since I'm reviewing this patch right now for inclusion in Tahoe-LAFS v1.10. So I think we should not worry about this compatibility-break.

comment:35 in reply to: ↑ 27 Changed at 2013-01-03T16:40:36Z by zooko

Replying to warner:

And I prefer the simplicity of having fewer options (I still want to remove the -C/--basedir option from the node-admin commands, but want to respect David-Sarah's opinion that people may have scripts that will break).

FWIW, I would prefer that simplicity too. I think Tahoe-LAFS currently has too much complexity in various ways, but one of those ways is the command-line syntax. I don't know whether anyone has scripts that would break, and if they do, maybe it would be not a big deal for them to detect the breakage and update their scripts. David-Sarah: is there any process by which we can prune old or redundant command-line syntax with sufficient grace period? Is it worth the effort to emit a "deprecation warning" sort of thing for options that we would like to remove in the future?

comment:36 Changed at 2013-01-03T16:41:07Z by zooko

  • Status changed from new to assigned

comment:38 Changed at 2013-01-03T16:55:52Z by zooko

reviewed: https://github.com/warner/tahoe-lafs/commit/96200cf7d26f1b0fd6f39856c403063f3f0f0211

Once again, this was *very* easy to review, since it simply renames a variable. Thanks to warner for making patches which are easy to review!

comment:39 Changed at 2013-04-09T06:43:38Z by zooko

  • Keywords reviewed added; review-needed zookos-opinion-needed removed
  • Owner changed from zooko to warner
  • Status changed from assigned to new

comment:40 Changed at 2013-04-09T18:21:46Z by warner

Rebased to 3ee950f09ed8b7f6 and landed.

Last edited at 2013-04-09T18:30:24Z by warner (previous) (diff)

comment:41 Changed at 2013-04-09T18:26:24Z by warner

  • Resolution set to fixed
  • Status changed from new to closed

comment:42 Changed at 2013-04-22T14:53:56Z by daira

The following are filesystem command options but should probably be global options:

  -u, --node-url=     Specify the URL of the Tahoe gateway node, such as
                      'http://127.0.0.1:3456'. This overrides the URL found in
                      the --node-directory .
      --dir-cap=      Specify which dirnode URI should be used as the 'tahoe'
                      alias.

Also, in e.g. tahoe ls --help, --version is listed as a command option but does not work in that position:

[...]/bin/tahoe:  --version not allowed on subcommands

comment:43 follow-up: Changed at 2013-04-22T15:02:46Z by daira

Some commands, such as tahoe ls, don't show "[global-opts]" in their --help synopsis.

comment:44 Changed at 2013-04-22T15:11:19Z by Daira Hopwood <david-sarah@…>

In 57e997809055960a:

Add "[global-opts]" to help synopsis for tahoe ls. refs #166

Signed-off-by: Daira Hopwood <david-sarah@…>

comment:45 in reply to: ↑ 43 Changed at 2013-04-22T15:13:20Z by daira

Replying to daira:

Some commands, such as tahoe ls, don't show "[global-opts]" in their --help synopsis.

tahoe ls was the only one.

comment:46 Changed at 2013-04-22T15:14:45Z by daira

NEWS entry added in becae165d2971bd3.

Note: See TracTickets for help on using tickets.