[CentOS] bash - safely pass untrusted strings?

Wed Feb 27 20:51:06 UTC 2008
Bart Schaefer <barton.schaefer at gmail.com>

On Wed, Feb 27, 2008 at 11:13 AM, Garrick Staples <garrick at usc.edu> wrote:
>
>  'name=val >$name' is a weird case that I can't explain.  It is not related to
>  'name=val command' because there is no command.  It acts like two statements
>  when syntacticaly it is one.  It think it is a bug.  Avoid it.

The tidbit that no one has pointed out yet is that redirections are
not actually part of the command in the sense that you might think
they are.

These are all the same:

$ >foo echo bar
$ echo >foo bar
$ echo bar >foo

The command is "echo bar" no matter where you put the redirection.  Hence this:

$ foo=bar

and this:

$ foo=bar >$foo

are exactly the same in so far as the execution of "foo=bar" is
concerned; and "foo=bar" all by itself is the special construct that
means "assign foo in the current shell", so that's what happens.  On
the other hand

$ foo=bar echo

is syntax that means (as has previously been explained) "assign foo in
the process environment of echo" so nothing happens in the current
shell.

The other tidbit (see the book link Les posted) is that assignments
happen very early and redirections happen very late, in the order of
evaluation.

If you really want to warp your brain, try this one (not in your only
login shell, though):

$ 2>$foo foo=yourOutputIsHere exec

And stop thinking from left to right.