Commit Graph

1092 Commits (169d6e463ca0fb59adfaa955137bb16b83c990e0)

Author SHA1 Message Date
Brian Coca 0726933a5a added thirsty option to copy
Signed-off-by: Brian Coca <briancoca+dev@gmail.com>
12 years ago
Michael DeHaan a9162a86f2 Very basic --diff option for showing what happens when templates change.
Probably output is not useful if not used with --limit

Works well with --check mode
12 years ago
Michael DeHaan 3d6993221e service status 4 should also be stopped 12 years ago
Stanis Trendelenburg 8f70883541 Handle 'groups=' (empty string) in user module (Linux)
Makes it possible to remove a user from all but the primary group.

Setting 'groups=' is the equivalent to passing '-G ""' to
useradd/usermod, which is interpreted as "no group" on Linux.
12 years ago
Michael DeHaan 9113c01e37 Merge pull request #1990 from roller/devel
Specify repo option with hg pull
12 years ago
Daniel Hokka Zakrisson 7a49230e85 Merge pull request #2005 from ftao/supervisorctl-update
always restart the program when state=restarted
12 years ago
ftao 9174c52b1d always restart the program when state=restarted 12 years ago
Daniel Hokka Zakrisson b0932e1638 Merge pull request #1999 from dorfsmay/pullreq-lineinfile
Clarification on how to use insertafter with a regex.
12 years ago
Daniel Hokka Zakrisson dab31116b3 Actually add stdout data to stdout buffer for daemon mode 12 years ago
Yves Dorfsman 05a3876dc9 Clarification on how to use insertafter with a regex. 12 years ago
Blair Zajac 106fb10dab library/pip: add support for virtualenv's --system-site-packages. 12 years ago
Joel Roller ac716ac9ca Specify repo option with hg pull
Fixes #1989
12 years ago
Lester Wade 093a876a57 Added capability to enable CloudWatch monitoring when launching. 12 years ago
Michael DeHaan fed82c2188 This implements a basic --check mode which for now is only implemented on template & copy operations. More detail will be shared with the list
shortly.
12 years ago
Daniel Hokka Zakrisson 28cf95e585 Use module.get_bin_path for pkgin module instead of hardcoding paths 12 years ago
Michael DeHaan dc5c430f45 Merge pull request #1970 from piffey/devel
Devel
12 years ago
Daniel Hokka Zakrisson c1e0f0b4db sysctl was added in 1.0
Fixes #1972.
12 years ago
Piffey Parlance 0f44ba5a5a * Minor removal of some dumb I did. 12 years ago
Piffey Parlance 39c8becfc8 * Added support for multi-line key files. 12 years ago
Michael DeHaan 42daffdb38 Merge pull request #1948 from yeukhon/devel
hg module cleaned up
12 years ago
Michael DeHaan 602656f02c Merge pull request #1961 from skvidal/yum-mod
Yum mod
12 years ago
Seth Vidal 808554dee6 use a local copy of repoq so we don't inadvertently pollute the one for is_installed 12 years ago
Seth Vidal 1c067845f2 don't apply enablerepo's to is_installed() to work around yum-utils/repoquery drift from all things
good and proper
12 years ago
Lorin Hochstein 4d38c68489 If ec2 fact has ':' or '-', change to '_'
Change ec2 fact names with colons (:) or dashes (:) to undescore (_)
so that they can be used in templates.

Note that this makes copies instead of replacing the exisitng fact
names to avoid breaking existing playbooks.
12 years ago
Seth Vidal 5c26805ee7 test the repos in enablerepo/disablerepo and error out if they are broken 12 years ago
Elliott Foster a1ea366957 Adding mongodb_user module. 12 years ago
Yeukhon Wong cc6fc149c2 Merge remote-tracking branch 'upstream/devel' into devel 12 years ago
Yeukhon Wong 980ffde192 Changes is now determined by simply comparing before,after and cleaned (purge and/or force). Doc is updated. 12 years ago
Yeukhon Wong ccc903216b Use %s instead of .format for string replacement. Revisied the documentation. 12 years ago
Yeukhon Wong 99a8e95c98 Rewrote hg module based on feedback.
1. state option is removed
2. force is hg update -C
3. purge is hg clean/hg purge but default to no
4. relies on hg abililty to handle errors
12 years ago
Daniel Hokka Zakrisson 0243b7be7c Fix get_url to work on Python 2.4 12 years ago
diefans 65d0eb9621 proper bin path now called 12 years ago
Yeukhon Wong 92fd1c6578 Merge remote-tracking branch 'upstream/devel' into devel
Conflicts:
	library/hg
12 years ago
Michael DeHaan 4d8f3b0924 This standardizes the apt_key module some
* improves error handling and reporting
* uses run_command to reduce code
* fails quicker on errors as opposed to return codes and tracebacks
* can now also specify the key as data versus needing to wget it from a file
12 years ago
Daniel Hokka Zakrisson 0bfec51a04 Remove last remnants of daisychaining 12 years ago
Daniel Hokka Zakrisson 133874a577 Fix module.run_command usage in fireball 12 years ago
Les Aker 819da94ced adjusted assemble to use new file attribute handling 12 years ago
Michael DeHaan 12403abc2c Merge pull request #1924 from blair/consistly-use-underscores
library/apt: consistently use underscores in examples.
12 years ago
Blair Zajac 811c711328 library/apt: consistently use underscores in examples.
To be consistent with the table showing available options, use
underscores in the example tasks, not hyphens, as the table doesn't
list hyphenated versions of option names, so it looks like the
examples could have typos in them.
12 years ago
Michael DeHaan b749af0b10 New changelog additions from today's merging 12 years ago
Michael DeHaan 25f52d79d1 Tweak sysctl docs so they'll web-render 12 years ago
Michael DeHaan e9d5cf3bc2 Fix documentation YAML for pkgin module 12 years ago
Michael DeHaan 970ae584c9 fix documentation formatting for get_url 12 years ago
Michael DeHaan 36066d8664 Fixup ec2_facts docs parsing 12 years ago
Michael DeHaan 5e4d29565c Standardize the hg command execution around our run command function. 12 years ago
Lester Wade 2da3a54e29 Update library/ec2
updated indentation and redundant comment.
12 years ago
Yeukhon Wong e5b64b2f74 Added hg module to the core. 12 years ago
Lester Wade de833b3ae0 Update library/ec2
bumping up min_count value.
12 years ago
Lester Wade b0ecfbb26d Update library/ec2
I've uncommented and added a very little supporting stuff based on skvidal's work to allow us to launch more than one instance.
12 years ago
igor 005f864068 minor doc changes 12 years ago
igor d683c2431e add support for user:password syntax in urls to get_url 12 years ago
Michael DeHaan 634d59c97f Merge pull request #1913 from jlitola/apt_key
Fixed apt_key's add_key stalling indefinitely, and test code leaking into production
12 years ago
Michael DeHaan c55a822c1e Merge pull request #1906 from szinck/devel
Add basic pkgin package management
12 years ago
Michael DeHaan e0b5c35033 Merge pull request #1891 from silviud/ec2_facts_module
ec2 facts module - registers to ansible_facts key
12 years ago
Yeukhon Wong 7b0a3c3f2d Added hg module to the core. 12 years ago
Lorin Hochstein c337b64e35 Git module: fix for relative paths
If a relative path is passed as an argument, this change first
converts it to an absolute path.

This fixes a bug where the git module would attempt to chdir into an
invalid directory because of multiple chdir calls against a relative
path.
12 years ago
Shaun Zinck b2aed1a4ba pkgin: add stdout to error message when shell commands fail 12 years ago
Shaun Zinck e9ca960558 pkgin: use module.run_command to run stuff
This also fixes an issue where some console output for packages I was
installing was creating invalid JSON because it contained single-quotes.
12 years ago
Daniel Hokka Zakrisson 6e0cb14ba5 Merge pull request #1911 from tgerla/devel
Port ec2 module to Boto
12 years ago
Juha Litola 2796603c92 Removed apt_key tests, as they didn't test the real functionality.
Tests used heavily mocked version of the apt_key code, which meant that
it didn't properly test real life scenario.
12 years ago
Daniel Hokka Zakrisson 9f6f15f770 Fix unparseable documentation strings
Fixes #1902.
12 years ago
Juha Litola 05f5b5b279 Fixed add_key stalling indefinitely, and test code leaking into production setting 12 years ago
Shaun Zinck e34eaa423d pkgin: change install/remove to not use return code of pkgin
pkgin always returns 0 so can't be used to tell if the install or remove
worked.  Instead this just queries the installed packages after
performing an operation.
12 years ago
Silviu Dicu 2a893ab0bb ec2 facts module - updated as per comments 12 years ago
Stephen Fromm e0741e7810 Update apt_repository to query if repo is already configured
This adds two dependencies to the apt_repository module:  apt and
apt_pkg.  These come from the package python-apt.  This is used to parse
the host's sources.list and examine whether the repo is already
configured.  This then eliminates the unnecessary
'add-apt-repository --remove' from running.
12 years ago
Shaun Zinck 4a9201ad65 add pkgin to list of package managers in setup 12 years ago
Shaun Zinck 2eedec777f added first version of pkgin, just does install, remove (for SmartOS) 12 years ago
Brendan Taylor f18446e7a5 service module 'state' parameter comments should be processed by RST 12 years ago
John Gosset 54ef6015f6 add pacman to list of package managers in setup module 12 years ago
Silviu Dicu ce9e9af6a3 ec2 facts moduled - updated 12 years ago
Tim Gerla cafb717b55 Fail gracefully if boto is not available and add me to the author line. 12 years ago
Tim Gerla 139aee58e2 use connect_ec2_endpoint instead of connect_euca, and properly pass keys to connect_ec2 12 years ago
Silviu Dicu 1ab9bfa7cc ec2 module - registers to ansible_facts key 12 years ago
Tim Gerla 456e6f5a55 library/ec2:
- use boto instead of euca2ools
- improve error handling/propagation for run failures
- rename keypair to key_name (and preserve alias for old playbooks)
- should be 100% backward compatible with the euca2ools version
12 years ago
Daniel Hokka Zakrisson d4c0180494 Make service module daemonize for all the broken "daemons" out there 12 years ago
Daniel Hokka Zakrisson 48f48e8a44 module must be passed to repolist too 12 years ago
Pepe Barbe 8b4bd2ec3e module needs to be passed to local_nvra 12 years ago
Michael DeHaan e7223760c4 Merge pull request #1810 from davixx/sysctl
new module: sysctl to handle sysctl entry
12 years ago
Michael DeHaan c66d3200f8 Merge pull request #1670 from Afterburn/devel
Pacman module
12 years ago
Michael DeHaan 1721357a49 Merge pull request #1824 from jvantuyl/apt-key-module
add apt_key module
12 years ago
Michael DeHaan fa953ba6b3 Merge pull request #1867 from c0rner/devel
get_service_status() is now using self.service_control() to check status
12 years ago
Rune Kaagaard 27ab2e55d3 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 ad6373430b 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 471ee0c90d 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 4eaee3df0a 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 3fb21a5281 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 a19a13ffa7 Add check for multiple keys in one invocation 12 years ago
Gert Goet f4dcb33ccc 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 1cbc9569b3 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 060266e291 Python 2.4 fixes for modules 12 years ago
Daniel Hokka Zakrisson 3bc6228b97 Handle unreadable /proc/xen/capabilities
Fixes #1854.
12 years ago
Jure Triglav 3f43ede70c Fix indentation 12 years ago
Jure Triglav 2ee05f0c96 EC2 module should report back the public_dns_name too. 12 years ago
Daniel Hokka Zakrisson b57b1f4cbe Correct name is login_user
Fixes #1848.
12 years ago
Daniel Hokka Zakrisson 4955587d8c Merge pull request #1798 from dagwieers/raw-executable
Allow to change executable (shell/interpreter) when using raw
12 years ago
Michael DeHaan 713ce4c0cf Merge pull request #1832 from legrostdg/devel
add encoding documentation in postgresql_db
12 years ago
Félix Sipma 0ba7cf58e9 add encoding documentation in postgresql_db 12 years ago
willthames 4e50478a05 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 1fa83fa584 Merge pull request #1813 from legrostdg/devel
postgresql_db fails with owner containing a "-"
12 years ago
Félix Sipma 02f531c609 remove quotes in has_table_privilege and has_database_privilege 12 years ago
Daniel Hokka Zakrisson 451868630d Merge pull request #1817 from chrisberkhout/devel
git module documentation: removed incorrect use of term 'remote branch' ...
12 years ago
davixx 8efa62b0ea 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 8a262c2b20 add documentation for "template" parameter in postgresql_db 12 years ago
Félix Sipma cd7fe9875c use double-quotes in postgresql commands (fix bug with "-") 12 years ago
willthames 411b2bf7d9 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 c01bc23f63 git module documentation: removed incorrect use of term 'remote branch' (should just be 'remote'). 12 years ago
Dag Wieers eb36ff45b9 Make script module use raw module so it does not require python 12 years ago
Dag Wieers 846161a1a4 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 3d3deb9797 Merge pull request #1795 from dagwieers/raw-enhanced
Add return code and error output to raw module
12 years ago
Dag Wieers 988db558b3 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 85e0017a85 fix cron DOCUMENTATION 12 years ago
jkleint d732b25828 Clarify that lineinfile uses Python regexes. 12 years ago
Daniel Hokka Zakrisson eb57c9c430 Indicate the reboot option was added in 1.0
Fixes #1787.
12 years ago
Michael DeHaan 6fc6c37401 Merge pull request #1785 from TutoringAustralasia/devel
Add support for @reboot to cron module
12 years ago
Chelsea Robb 96e2805b31 Change check for date/time parts being set 12 years ago
Chelsea Robb 6a02e3d918 Added error message when reboot and extra params are passed, and added better boolean parsing on reboot 12 years ago
Chelsea Robb fc4ac70342 Add support for @reboot to cron module 12 years ago
Gregory Duchatelet 29f985aa2e do not conditionalize this for older Python, fix indentation, better use
of hash iteration.
12 years ago
Gregory Duchatelet e64de2ff88 Bugfix: in hosts with python-2.5, hash keys needs flatten string. 12 years ago
afterburn a6f01dcd6f version 1.0 eruption 12 years ago
afterburn 0bdd17ff3a updated description and examples 12 years ago
Daniel Hokka Zakrisson d4b1874d44 Merge pull request #1773 from jpmens/scriptdoc
fix and clarify 'script' docs
12 years ago
Jan-Piet Mens 4f8abd981a fix and clarify 'script' docs 12 years ago
Stephen Fromm ccca5fcd1c 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 f2893b6418 Merge pull request #1746 from njharman/subversion
Subverion module improvements
12 years ago
Michael DeHaan 5d31e8d1fc Merge pull request #1752 from jpmens/mail2
mail module: add MIME attachments, port and addresses with phrases
12 years ago
Norman J. Harman Jr ddc0507f65 Passing in module instead of just fail_json per upstream request. 12 years ago
Michael DeHaan ea5d79a712 Merge pull request #1755 from lorin/patch-1
Fix ppa syntax in apt_repository module doc
12 years ago
Norman J. Harman Jr 19b84d0527 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 165861dd2f if user has manually installed an intermediate version - don't ignore it: issue 1754 12 years ago
Jan-Piet Mens f9755ca36d mail module: add MIME attachments, port and addresses with phrases
Add HTML-escaping to code examples in rST tempate of module-formatter
 Add support for specifying port, addresses with phrases and attaching files
 Add support for custom headers and document version_added for new options
 X-Mailer header added :)
 protect empty address lists & attachment list, and add bcc
12 years ago
Lorin Hochstein f8821fa3d9 Fix ppa syntax in apt_repository module doc
The example for using a ppa had the wrong syntax.

Ironically, the correct syntax is illustrated in a comment on line 23.
12 years ago
Norman J. Harman Jr 2e6999dab9 Subverion module improvements
- Added username, password arguments.
  - Documented existing revision argument.
  - Corrected documentation/docstrings; removed git references, use svn
    nomenclature, etc.
  - Refactored duplicate code, redundant shell calls, filter abuse,
    inconsistent formating, etc.
  - Shell quoting so it doesn't break for one guy who has spaces in
    pathnames.
  - svn called with '--non-interactive' and '--no-auth-cache'.
12 years ago
Michael DeHaan 637883164e Merge pull request #1720 from bladypirat/devel
added support for scheduling downtime for all services on host
12 years ago
Alexandre Bourget 0b9cbcb270 supervisorctl: document the 'present' option 12 years ago
Dag Wieers ac2f396379 Fix "NameError: global name 'name' is not defined" exception 12 years ago
Daniel Hokka Zakrisson 11b64314df Select all fields from the user, as some of them are version-dependent 12 years ago
Stephen Fromm 1bcfdd94f3 Further refine remote branch tracking in b1ec6e8
Move operations that are dependant on a remote branch under a if
is_remote_branch() conditional.  While at it, remove assignment to cmd
string in same block that wasn't used when calling _run().
12 years ago
Stephen Fromm b1ec6e8163 Fix git module to update branch to latest when using version=<branch>
The git module would not pull in updates to a branch when
version=<branch>.  This updates that block to checkout the branch
and then do a git reset --hard <remote>/<branch>.  This
should now track updates to a branch.
12 years ago
Piotr Kweclich 9c20eb089b added support for scheduling downtime for all services on host 12 years ago
Stephen Fromm 5b7c8fcc38 Further tweak how to find pip in virtualenv on centos/redhat/fedora
In a virtualenv, pip is called just pip.  This fixes the pip module to
search for the virtualenv pip first before trying the pip-python and
python-pip variants.  Without this, pip module would not install to the
virtualenv when that parameter is provided.
12 years ago
Stephen Fromm e33e02950d Make use of mirrors in pip module configurable with use_mirrors option
Older versions of pip (anything less than 1.0?) do not support
--use-mirrors flag.  This makes it configurable.  Default is yes.
12 years ago
Daniel Hokka Zakrisson d5a456fbcf Merge pull request #1697 from bcoca/mint
Implements multiple interpreter overrides
12 years ago
Stephen Fromm d277953a53 Fix pip module to check if requirements already installed
This updates _is_package_installed() to accept a requirements file
as an argument.  This is used later in main() to check if python libs
specified in a requirements file are already installed.  I updated
main() to consolidate the handling of install/uninstall in a single
block.  This should help if someone wants to remove packages specified
by a requirements file.
12 years ago
Igor Galić 1ba5c5ae97 : doesn't work in this documentation. 12 years ago
Igor Galić e031054934 Fix subversion module's documentation
Let our users determine what they want to do with a given module.
Particularily when the mdoule doesn't pose any such restrictions.
12 years ago
Brian Coca 8ef2807305 removed env as per project policy
Signed-off-by: Brian Coca <briancoca+dev@gmail.com>
12 years ago
Jan-Piet Mens 910f1c042e ini_file: prohibit section name 'default'
allow update of default section
add blurb re template to create base file
12 years ago
Patrik Lundin d4af9e4c5c Use shlex for rc.conf parsing.
This makes the line parsing a lot more robust (and easier to read).
Code supplied by @dhozac, thanks!

Remove re import because this is not used anywhere.
12 years ago
Patrik Lundin fde00327b0 Rework "enabled" implementation for FreeBSD.
When trying to perform enabled=yes followed by enabled=no
against FreeBSD the module would die with the following error:
TypeError: sub() takes at most 4 arguments (5 given)

The target FreeBSD client (8.2) is running python 2.6.6. It seems the
extra 'flags' argument was added to re.sub() in 2.7.

In fixing this issue I have attempted to create a general atomic method
for modifying a rc.conf file. Hopefully this will make it easier to add
other rc based platorms. The strip/split magic was inspired by the user
module.
12 years ago