Commit Graph

1026 Commits (7ba63ce7ffccbfeacf03c78d37d517664ead65a7)
 

Author SHA1 Message Date
Michael DeHaan 97fd76991b Merge pull request #1867 from c0rner/devel
get_service_status() is now using self.service_control() to check status
12 years ago
Rune Kaagaard 50280f4fc4 Service mod.: Proper(?) handling of return code 69
This adds "69" to the return codes from the status command that should be
considered as not running. At least "django-celery" uses this return code,
maybe others::

    /venv/bin/python /code/project/manage.py celeryctl status
    echo $? # 69 when not running.

A bit of googling let me to http://tldp.org/LDP/abs/html/exitcodes.html and
on a Ubuntu Server 12.10 I get::

    ~# cat /usr/include/sysexits.h | grep 69
    #define EX_UNAVAILABLE	69	/* service unavailable */

I'm not sure if the content of sysexits.h is the same on other OS'es.
12 years ago
Jayson Vantuyl 732be11781 add apt_key module
Pretty straightforward.  Give it a URL with an exported GPG key for signing an
Apt repository.  It downloads it and will install it using apt-key.  It's even
smart enough to tell if it's already there (i.e. actually tells you if it
changed or not).
12 years ago
root 99fe051fb8 get_service_status() is now using self.service_control() to check status
Fixes a bug where init-scripts were not used
12 years ago
Stephen Fromm 3f88a14b86 Various cleanup to run_command
* Rename fail_on_rc_non_zero to check_rc, much more succinct.
* Simplify method defintion
* Fix command module and drop shell=shell option; whether to use
  shell is determined by if args is a list.
12 years ago
Stephen Fromm e4964f42e0 Update modules to use run_command in module_common.py
This updates apt, apt_repository, command, cron, easy_install, facter,
fireball, git, group, mount, ohai, pip, service, setup, subversion,
supervisorctl, svr4pkg, user, and yum to take advantage of run_command
in module_common.py.
12 years ago
Daniel Hokka Zakrisson 54390d5f21 Add check for multiple keys in one invocation 12 years ago
Gert Goet 2db7cc3314 Prevent permission denied when cloning
Without read permission to the current working directory, git-clone will
fail:
root@host:~$ sudo -u git -H git clone \
  git://github.com/ansible/ansible.git /home/git/ansible
fatal: Could not change back to '/root': Permission denied

This commit ensures that the working directory is changed to the
parent-folder of the destination before doing the clone.
12 years ago
Michael DeHaan 3a003c2430 Merge pull request #1853 from jure/more_info_from_ec2
EC2 module should report back the public_dns_name too
12 years ago
Daniel Hokka Zakrisson f16ab9169c Python 2.4 fixes for modules 12 years ago
Daniel Hokka Zakrisson 360701ea43 Handle unreadable /proc/xen/capabilities
Fixes #1854.
12 years ago
Jure Triglav b549ea68ee Fix indentation 12 years ago
Jure Triglav c2306e441f EC2 module should report back the public_dns_name too. 12 years ago
Daniel Hokka Zakrisson 74679a5f4b Correct name is login_user
Fixes #1848.
12 years ago
Daniel Hokka Zakrisson ca042dd719 Merge pull request #1798 from dagwieers/raw-executable
Allow to change executable (shell/interpreter) when using raw
12 years ago
Michael DeHaan a325fd5c4c Merge pull request #1832 from legrostdg/devel
add encoding documentation in postgresql_db
12 years ago
Félix Sipma 77753eb897 add encoding documentation in postgresql_db 12 years ago
willthames a7a0927298 Fix behaviour when file handles a path with tilde
Two problems here
* unchecked exception handling and erroneous assumption as to why
  an exception might fire
* although the file module expands the path, when using file_args
  the unexpanded path is passed.

Expected result: ~/path/to/file should work fine
Actual result: exception is because it doesn't find file with a message
about not being able to get the selinux context
12 years ago
Daniel Hokka Zakrisson 9ea8a679d1 Merge pull request #1813 from legrostdg/devel
postgresql_db fails with owner containing a "-"
12 years ago
Félix Sipma 329b2c63d9 remove quotes in has_table_privilege and has_database_privilege 12 years ago
Daniel Hokka Zakrisson 453d42aed0 Merge pull request #1817 from chrisberkhout/devel
git module documentation: removed incorrect use of term 'remote branch' ...
12 years ago
davixx 7335ee6620 new module: sysctl to handle sysctl entry
sysctl now capable to search for sys entry into /sys if not under /proc/sys

module/sysctl rolling back to 0.5

write sysctl.conf safely, tempfile first, atomic replace after.
See comments in  https://github.com/ansible/ansible/pull/1810

Patch to replace .format with % () to handle python-2.4 ,
See also https://github.com/ansible/ansible/pull/1810

using name instead key for default arg name. key putted as alias.
also, val become an alias of value arg name.
See also : https://github.com/ansible/ansible/pull/1810
12 years ago
Félix Sipma 2bb74e5f29 add documentation for "template" parameter in postgresql_db 12 years ago
Félix Sipma cc4be53dd4 use double-quotes in postgresql commands (fix bug with "-") 12 years ago
willthames 389c59024e Added additional template variables
Added two additional template variables
* template_fullpath - absolute path to the template
* template_run_date - date that the template was rendered
Documented these additional variables in the module documentation
12 years ago
Chris Berkhout bb482bd112 git module documentation: removed incorrect use of term 'remote branch' (should just be 'remote'). 12 years ago
Dag Wieers 61f8c0b07e Make script module use raw module so it does not require python 12 years ago
Dag Wieers cb162046f1 Allow to change executable (shell/interpreter) when using raw
This patch adds an optional 'executable=' option to the raw command line to override the default shell (/bin/sh), much like the shell module does.
12 years ago
Michael DeHaan 02fdec102e Merge pull request #1795 from dagwieers/raw-enhanced
Add return code and error output to raw module
12 years ago
Dag Wieers 0ef97cd917 Add return code and error output to raw module
Since we use 'raw' heavily on equipment where 'command' and 'shell' are not (yet) working (and python may need to be installed first using raw) these improvements are necessary in order to write more complex scripts (with return code handling and separated stdout/stderr).

This change includes the following changes:

 - exec_command() now returns the return code of the command
 - _low_level_exec_command() now returns a dict, including 'rc', 'stdout' and 'stderr'
 - all users of the above interfaces have been improved to make use of the above changes
 - all connection plugins have been modified to return rc and stderr
 - fix the newline problem (stdout and stderr would have excess newlines)

In a future commit I intend to add assertions or error handling code to verify the return code in those places where it wasn't done. Since only the output was available, the return code was ignored, even though we expect them to be 0.
12 years ago
Jan-Piet Mens f1ab8d163d fix cron DOCUMENTATION 12 years ago
jkleint 7c8fa2cb6f Clarify that lineinfile uses Python regexes. 12 years ago
Daniel Hokka Zakrisson 0fe2d4e5e3 Indicate the reboot option was added in 1.0
Fixes #1787.
12 years ago
Michael DeHaan 140d056238 Merge pull request #1785 from TutoringAustralasia/devel
Add support for @reboot to cron module
12 years ago
Chelsea Robb ae0e1b541e Change check for date/time parts being set 12 years ago
Chelsea Robb 47f9a72454 Added error message when reboot and extra params are passed, and added better boolean parsing on reboot 12 years ago
Chelsea Robb 7830a4aac2 Add support for @reboot to cron module 12 years ago
Gregory Duchatelet c25de60c03 do not conditionalize this for older Python, fix indentation, better use
of hash iteration.
12 years ago
Gregory Duchatelet c963e33824 Bugfix: in hosts with python-2.5, hash keys needs flatten string. 12 years ago
afterburn a883006ab7 version 1.0 eruption 12 years ago
afterburn 39047cad49 updated description and examples 12 years ago
Daniel Hokka Zakrisson 560082bc93 Merge pull request #1773 from jpmens/scriptdoc
fix and clarify 'script' docs
12 years ago
Jan-Piet Mens 27f1785b9d fix and clarify 'script' docs 12 years ago
Stephen Fromm d8e3a00933 Ensure files created by authorized_key have correct selinux context
Three changes:
* Add set_default_selinux_context() to module_common that sets
  a file's context according to the defaults in the policy
* In atomic_replace(), set the default context for the file if
  selinux is enabled and the destination file does not exist.
* In authorized_key, set the default context when creating
  $HOME/.ssh and $HOME/.ssh/authorized_keys.  If these already
  exist, this won't touch them.
12 years ago
Michael DeHaan 393079d5e4 Merge pull request #1746 from njharman/subversion
Subverion module improvements
12 years ago
Michael DeHaan 7d9a1031a5 Merge pull request #1752 from jpmens/mail2
mail module: add MIME attachments, port and addresses with phrases
12 years ago
Norman J. Harman Jr 4afce8a311 Passing in module instead of just fail_json per upstream request. 12 years ago
Michael DeHaan 12219dd0fa Merge pull request #1755 from lorin/patch-1
Fix ppa syntax in apt_repository module doc
12 years ago
Norman J. Harman Jr 900289f83d pip module improvements
- Do not silently ignore malformed pip requirements files.
- Properly reports changed when removing packages.
- "latest" i.e. --upgrade is *not* incompatible with requirements files.
- Less branchy, simpler logic.
- Removed pointless variable "initializations", Python doesn't need that.
  Other code simplifications.
- Fun fact; pip install is (kind of) case insensitive, pip freeze is not.
  So, 'sqlalchemy' will be reported as installed by install, but missing
  by freeze.

The perhaps controversial change and the one that led to finding /
fixing above issues...

Instead of adding command parameters 'index', and 'find', and 'mirrors',
and etc.  Added 'extra_args' which are passed onto pip.

The use case for --index-url is having a private pypi repo, like
http://pypi.python.org/pypi/localshop, to which you publish private
packages.  I'm sure most every pip option has a use case for someone.
extra_args handles all those. Can reserve ansible command parameters for
the most common.

Tested with pip 1.1.
12 years ago
Seth Vidal 498f44f372 if user has manually installed an intermediate version - don't ignore it: issue 1754 12 years ago