- Description
- Requirements
- Usage - Configuration options and additional functionality
- Development - Guide for contributing to the module
This module includes a puppet task to help manage local groups.
This task can be used to remove or add members to local security groups. Allowing administrators and customers to add and remove multiple users to multiple machines.
This task can be exposed as a service via the puppet task endpoint to allow remote execution and self service access management.
PowerShell 5.1 is recommended to ensure full functionality. The task will use net.exe if version 5.1 is not present. See the Limitations section for more information.
This module is compatible with Puppet Enterprise and Puppet Bolt.
- To run tasks with Puppet Enterprise, PE 2018.1 or later must be installed on the machine from which you are running task commands. Machines receiving task requests must be Puppet agents.
- To run tasks with Puppet Bolt, Bolt 1.0 or later must be installed on the machine from which you are running task commands. Machines receiving task requests must have SSH or WinRM services enabled.
To run an groupmembers task, use the task command, specifying the command to be executed.
- With PE on the command line, run
puppet task run groupmembers ensure=<present|absent> group=<groupname> member=<String|Array>
. - With Bolt on the command line, run
bolt task run groupmembers ensure=<present|absent> group=<groupname> member=<String|Array>
.
For example, to add a example\jdoe to administrators group, run:
- With PE, run
puppet task run groupmembers ensure=present group=administrators member="example\\jdoe" --nodes saturn
. - With Bolt, run
bolt task run groupmembers ensure=present group=administrators member="example\\jdoe" --nodes saturn
.
endpoint: https://<puppet>:8143/orchestrator/v1/command/task
method: post
body:
{
"environment": "production",
"task": "groupmembers",
"params": {
"ensure": "present",
"group": "Administrators",
"member": ["example\\jdoe", "example\\dotterman"]
},
"description": "Description for task",
"scope": {
"nodes": ["saturn.example.com"]
}
}
You can also run tasks in the PE console. See PE task documentation for complete information.
The task will use PowerShell if version 5.1 is present. If not net.exe will be used which has a limitation of not being able to add/remove members with names longer than 20 characters. See this Microsoft Support Doc for more information.
If PowerShell 5.1 is not present, and a member with a name longer than 20 characters is passed the task will skip that member to avoid erroring and to ensure other valid members are added.
Feel free to fork it fix my crappy code and create a PR (: