Update constants.py to pull module path and the hosts file from the

environment (ANSIBLE_{LIBRARY,HOSTS}) if defined.

Update manpages to represent this.

Also update the env-setup script to set ANSIBLE_{LIBRARY,HOSTS}.
This commit is contained in:
Tim Bielawa 2012-03-05 16:06:02 -05:00
parent 3c20f4000f
commit f2c2786a14
5 changed files with 51 additions and 14 deletions

View file

@ -25,7 +25,7 @@ SSH.
ARGUMENTS ARGUMENTS
--------- ---------
*hostspec* *host-pattern*::
A name of a group in the inventory file, a shell-like glob selecting hosts in inventory A name of a group in the inventory file, a shell-like glob selecting hosts in inventory
file, or any combination of the two seperated by semicolons. file, or any combination of the two seperated by semicolons.
@ -75,6 +75,16 @@ FILES
/usr/share/ansible -- Default module library /usr/share/ansible -- Default module library
ENVIRONMENT
-----------
The following environment variables may specified.
ANSIBLE_HOSTS -- Override the default ansible hosts file
ANSIBLE_LIBRARY -- Override the default ansible module library path
AUTHOR AUTHOR
------ ------
@ -95,7 +105,7 @@ SEE ALSO
Ansible home page: <https://github.com/mpdehaan/ansible/> Ansible home page: <https://github.com/mpdehaan/ansible/>
*ansible-modules*(5), *ansible-modules*(5)
*ansible-playbook*(5), *ansible-playbook*(5)

View file

@ -3,7 +3,7 @@ ansible-modules(5)
:doctype:manpage :doctype:manpage
:man source: Ansible-modules :man source: Ansible-modules
:man version: 0.0.1 :man version: 0.0.1
:man manual: System administration commands :man manual: Ansible
NAME NAME
@ -23,7 +23,7 @@ IDEMPOTENCE
Most modules other than command are idempotent, meaning they will seek to avoid changes Most modules other than command are idempotent, meaning they will seek to avoid changes
unless a change needs to be made. When using ansible playbooks, these modules can unless a change needs to be made. When using ansible playbooks, these modules can
trigger change events, as described in ansible-playbooks (5). trigger change events, as described in *ansible-playbooks*(5).
Unless otherwise noted, all modules support change hooks. Unless otherwise noted, all modules support change hooks.
@ -212,6 +212,13 @@ To support change hooks, modules should return hashes, with a changed: True/Fals
element at the top level. Modules can also choose to indicate a failure scenario element at the top level. Modules can also choose to indicate a failure scenario
by returning a top level 'failure' element with a True value. by returning a top level 'failure' element with a True value.
ENVIRONMENT
-----------
ANSIBLE_LIBRARY -- Override the default ansible module library path
AUTHOR AUTHOR
------ ------

View file

@ -3,7 +3,7 @@ ansible-modules(5)
:doctype:manpage :doctype:manpage
:man source: Ansible-playbook :man source: Ansible-playbook
:man version: 0.0.1 :man version: 0.0.1
:man manual: System administration commands :man manual: Ansible
NAME NAME
@ -28,13 +28,13 @@ Playbooks are written in YAML.
EXAMPLE EXAMPLE
------- -------
see See:
https://github.com/mpdehaan/ansible/blob/master/examples/playbook.yml - https://github.com/mpdehaan/ansible/blob/master/examples/playbook.yml
https://github.com/mpdehaan/ansible/blob/master/examples/base.yml - https://github.com/mpdehaan/ansible/blob/master/examples/base.yml
https://github.com/mpdehaan/ansible/blob/master/examples/handlers.yml - https://github.com/mpdehaan/ansible/blob/master/examples/handlers.yml
WHAT THE EXAMPLE MEANS WHAT THE EXAMPLE MEANS
----------------------- -----------------------
@ -100,6 +100,12 @@ If a host has a failure, the host will be ignored for the remainder
of the playbook execution. of the playbook execution.
ENVIRONMENT
-----------
ANSIBLE_LIBRARY -- Override the default ansible module library path
AUTHOR AUTHOR
------ ------

View file

@ -2,10 +2,20 @@
PREFIX_PYTHONPATH="`pwd`/lib/ansible:`pwd`/lib" PREFIX_PYTHONPATH="`pwd`/lib/ansible:`pwd`/lib"
PREFIX_PATH="`pwd`/bin" PREFIX_PATH="`pwd`/bin"
PREFIX_MANPATH="`pwd`/docs/man" PREFIX_MANPATH="`pwd`/docs/man"
PREFIX_ANS_LIBRARY="`pwd`/library"
PREFIX_ANS_HOSTS="`pwd`/examples/ansible_hosts"
echo "Prefixing PYTHONPATH with $PREFIX_PYTHONPATH" echo "Prefixing PYTHONPATH with $PREFIX_PYTHONPATH"
export PYTHONPATH=$PREFIX_PYTHONPATH:$PYTHONPATH export PYTHONPATH=$PREFIX_PYTHONPATH:$PYTHONPATH
echo "Prefixing PATH with $PREFIX_PATH" echo "Prefixing PATH with $PREFIX_PATH"
export PATH=$PREFIX_PATH:$PATH export PATH=$PREFIX_PATH:$PATH
echo "Prefixing MANPATH with $PREFIX_MANPATH" echo "Prefixing MANPATH with $PREFIX_MANPATH"
export MANPATH=$PREFIX_MANPATH:$MANPATH export MANPATH=$PREFIX_MANPATH:$MANPATH
echo "Setting ANSIBLE_LIBRARY to ${PREFIX_ANS_LIBRARY}"
export ANSIBLE_LIBRARY=${PREFIX_ANS_LIBRARY}
echo "Setting ANSIBLE_HOSTS to ${PREFIX_ANS_HOSTS}"
export ANSIBLE_HOSTS=${PREFIX_ANS_HOSTS}

View file

@ -16,9 +16,14 @@
# along with Ansible. If not, see <http://www.gnu.org/licenses/>. # along with Ansible. If not, see <http://www.gnu.org/licenses/>.
# #
import os
# control side (aka 'overlord') # control side (aka 'overlord')
DEFAULT_HOST_LIST = '/etc/ansible/hosts' DEFAULT_HOST_LIST = os.environ.get('ANSIBLE_HOSTS',
DEFAULT_MODULE_PATH = '/usr/share/ansible' '/etc/ansible/hosts')
DEFAULT_MODULE_PATH = os.environ.get('ANSIBLE_LIBRARY',
'/usr/share/ansible')
DEFAULT_MODULE_NAME = 'command' DEFAULT_MODULE_NAME = 'command'
DEFAULT_PATTERN = '*' DEFAULT_PATTERN = '*'
DEFAULT_FORKS = 5 DEFAULT_FORKS = 5
@ -26,4 +31,3 @@ DEFAULT_MODULE_ARGS = ''
DEFAULT_TIMEOUT = 10 DEFAULT_TIMEOUT = 10
DEFAULT_REMOTE_USER = 'root' DEFAULT_REMOTE_USER = 'root'
DEFAULT_REMOTE_PASS = None DEFAULT_REMOTE_PASS = None