DO NOT USE THIS MODULE. IT IS IN A VERY EARLY DEVELOPMENT STATE AND ITS BEHAVIOUR IS CHANGING CONSTANTLY.
####Table of Contents
- Changelog
- Module Description - What does the module do?
- Setup - The basics of getting started with puppet-accounts
- Usage - Configuration and customization options
- Reference - An under-the-hood peek at what the module is doing
- Limitations - OS compatibility, etc.
- Development - Guide for contributing to the module
##Changelog
##Module Description
The puppet-accounts module lets you manage user accounts with Puppet.
##Setup
The puppet-accounts module requires:
- puppetlabs-stdlib module.
- pluginsync enabled.
- valid yaml file containing user accounts information
##Usage
Both Include- and Resource-like class declarations are supported. This module is rather meant to by used with puppet >= 3.x, where all class parameters can be lookup by hiera by default. Sample hiera configuration file can be found in examples directory.
include accounts
class {'accounts':
}
Available parameters are:
purge
- use its with care. When set totrue
(default:no
), it will remove all users that are not managed by Puppet.skip_sys_users
- only has effect when used withpurge => true
(default:yes
). It keeps system users from being purged. By default, it does not purge users whose UIDs are less than or equal to 500, but you can specify a different UID as the inclusive limit.users
- hash of users and their attributes
class {'accounts':
purge => true,
skip_sys_users => 1500,
users => {
testuser => {
state => 'present',
shell => '/bin/bash',
uid => '10010',
gid => '10010',
password => '*',
groups => ['group1','group2'],
nodes => '!ruby/regexp "/some-node/"'
}
}
}
This will add user testuser and remove all users that aren't managed by Puppet and whose UID is greater than 1500 (user managed by puppet won't be remove even if his uid is greater than 1500).
##Reference
coming soon
##Limitations
Please note that the module was tested only on RedHat and Debian family operating systems. It is rather meant to be used with puppet >= 3.x (hiera integration).
##Development
- Fork it
- Clone it to your development environment (
git clone /~https://github.com/nagas/puppet-accounts
) - Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a Pull Request
###Testing
coming soon