ifupdown-executor(7)

# NAME

*/usr/libexec/ifupdown-ng/program* - ifupdown executor protocol

# DESCRIPTION

The ifupdown executors are programs that are typically installed
into the ifupdown-ng executor path.  They follow a specific
protocol documented in this man page.

# PHASES

Executors are run to react to nine different phases and are not
required to take any specific action.  These phases are:

*depend*
	Called to determine if the executor wishes to change
	the dependency graph.  The executor should write a
	space-delimited list of interface names it is dependent
	upon to _stdout_.  Those interface names will be merged
	into the dependency graph.  If an executor does not have
	any dependencies, it may simply exit 0 without doing
	anything.

*create*
	Called before *pre-up*, to explicitly allow for interface
	creation if necessary.

*pre-up*
	Called before the interface is going to be brought up.

*up*
	Called when the interface is being brought up.

*post-up*
	Called after the interface was successfully brought up.

*pre-down*
	Called before the interface is going to be taken down.

*down*
	Called when the interface is being taken down.

*post-down*
	Called after the interface was successfully taken down.

*destroy*
	Called after *post-down* to allow for explicitly
	destroying an interface if necessary.

# ENVIRONMENT

Executors are guaranteed to run with a core set of environment
variables:

*IFACE*
	The name of the interface being configured.

*INTERFACES_FILE*
	The path to the interfaces database file being used.

*MODE*
	Either _start_, _stop_ or _depend_ depending on phase.
	This environment variable is present for compatibility
	with legacy ifupdown scripts and should not be used in
	ifupdown-ng executors.

*PHASE*
	The phase being executed.  See the phases section for
	more information about phases.

*VERBOSE*
	If present, verbose output is expected from the
	executor.

Additionally, the properties associated with an interface are
provided to executors.  The keys are rewritten to begin with
IF_ and are capitalized with dashes converted to underscores.
For example, the property _bridge-ports_ will be rewritten as
_IF_BRIDGE_PORTS_.

# SEE ALSO

ifup(8)++
ifdown(8)++
interfaces(5)

# AUTHORS

Ariadne Conill <ariadne@dereferenced.org>