-
-
Notifications
You must be signed in to change notification settings - Fork 3
envdir.8
envdir - run a program with environment modified according to files in a specified directory.
envdir [ -cipw ] d child
d is a single argument. child consists of one or more arguments.
envdir sets various environment variables as specified by files in the directory named d. It then runs child with the environment variables passed to execve(2). These environment variables are not set before the call to execve(2). You can however set these environment variables before the call to execve(2) like this
envdir d envdir d child
For the PATH variable to be set before the call to execve(2), you can use the -p option.
If d contains a file named s whose first line is t, envdir removes an environment variable named s if one exists, and then adds an environment variable named s with value t. The name s must not contain =. Spaces and tabs at the end of t are removed. Nulls in t are changed to newlines in the environment variable. If the file s is completely empty (0 bytes long), envdir removes an environment variable named s if one exists, without adding a new variable. envdir reads a maximum of 256 bytes from s.
If envdir finds a directory named .envdir or a link named modifies environment variables according to files in .envdir. envdir avoids infinite recursive loops, by storing the inode number of directories visited and checking against the list. Any directory already processed is silently ignored. Files in .envdir are read first. This prevents environment variables in .envdir from overriding or deleting environment variables set in d.
if envdir finds a file named .envdir, it assumes that a file contains a list of additional directories to be processed for environment variables. Any directory included in this file which have been already processed are silently ignored.
if envdir finds a file or a symbolic link named .envfile, it assumes that a file contains envirnoment variables in key=value format. Comments, blank lines and leading white spaces are removed from the file. If it finds a line of the form s=t, envdir removes an environment variable named s if one exists, and then adds an evironment variable named s with value t. Whitespace at end of t are preserved and are part of the value. Nulls in t are changed to newlines in the environment variable. If envdir finds a line s, without =, envdir removes an environment variable named s if one exists, without adding a new variable.
Apart from .envdir and .envfile, envdir skips all files and directories starting with the '.' dot character.
In case of any error, envdir will not modify or add to the existing set of environment variables. In case of error, envdir will exit 111 without executing child unless the -w has been specified.
To see what environment variables are getting set by d, you can use the command
envdir -c d /usr/bin/env
-c
This option clears all existing environment variables before modifying
any environment variables.
-i
This option ignores if it cannot read a file in d. This allows the
system administrator to specify different access to different users for
any environment variable
-p
This options sets the PATH environment variable if defined in d before
the call to execve(2). This may be useful for execve(2) to be
able to execute child passed to envdir without the full path.
-w
This option causes envdir to issue warnings on encountering errors
instead of quitting before executing child.
envdir exits 111 if it has trouble reading d, if it runs out of memory for environment variables, or if it cannot run child. Otherwise its exit code is the same as that of child.
supervise(8), svc(8), svok(8), svstat(8), svscanboot(8), svscan(8), readproctitle(8), fghack(8), pgrphack(8), multilog(8), tai64n(8), tai64nlocal(8), setuidgid(8), envuidgid(8), softlimit(8), setlock(8),