2015-03-19 21:26:56 +01:00
#inifile
2012-08-17 04:30:58 +02:00
2014-10-11 00:13:09 +02:00
[![Build Status ](https://travis-ci.org/puppetlabs/puppetlabs-inifile.png?branch=master )](https://travis-ci.org/puppetlabs/puppetlabs-inifile)
2014-08-01 19:43:17 +02:00
####Table of Contents
2012-08-17 04:30:58 +02:00
2014-08-01 19:43:17 +02:00
1. [Overview ](#overview )
2. [Module Description - What the module does and why it is useful ](#module-description )
3. [Setup - The basics of getting started with inifile module ](#setup )
* [Beginning with inifile ](#beginning-with-inifile )
4. [Usage - Configuration options and additional functionality ](#usage )
5. [Reference - An under-the-hood peek at what the module is doing and how ](#reference )
5. [Limitations - OS compatibility, etc. ](#limitations )
6. [Development - Guide for contributing to the module ](#development )
2012-08-17 04:30:58 +02:00
2015-03-19 21:26:56 +01:00
##Overview
2013-02-15 10:56:44 +01:00
2015-03-19 21:26:56 +01:00
The inifile module lets Puppet manage settings stored in INI-style configuration files.
2013-02-15 10:56:44 +01:00
2014-08-01 19:43:17 +02:00
##Module Description
2013-02-15 10:56:44 +01:00
2015-03-19 21:26:56 +01:00
Many applications use INI-style configuration files to store their settings. This module supplies two custom resource types to let you manage those settings through Puppet.
2014-08-01 19:43:17 +02:00
##Setup
2015-03-19 21:26:56 +01:00
###Beginning with inifile
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
To manage a single setting in an INI file, add the `ini_setting` type to a class:
2014-08-01 19:43:17 +02:00
2015-07-28 00:50:03 +02:00
~~~puppet
2014-08-01 19:43:17 +02:00
ini_setting { "sample setting":
ensure => present,
path => '/tmp/foo.ini',
2015-03-19 21:26:56 +01:00
section => 'bar',
setting => 'baz',
value => 'quux',
2014-08-01 19:43:17 +02:00
}
2015-03-19 21:26:56 +01:00
~~~
##Usage
The inifile module tries hard not to manipulate your file any more than it needs to. In most cases, it doesn't affect the original whitespace, comments, ordering, etc.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
* Supports comments starting with either '#' or ';'.
* Supports either whitespace or no whitespace around '='.
* Adds any missing sections to the INI file.
###Manage multiple values in a setting
Use the `ini_subsetting` type:
2015-07-28 00:50:03 +02:00
~~~puppet
2014-08-01 19:43:17 +02:00
JAVA_ARGS="-Xmx192m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/var/log/pe-puppetdb/puppetdb-oom.hprof "
ini_subsetting {'sample subsetting':
2015-03-19 21:26:56 +01:00
ensure => present,
section => '',
2014-08-01 19:43:17 +02:00
key_val_separator => '=',
2015-03-19 21:26:56 +01:00
path => '/etc/default/pe-puppetdb',
setting => 'JAVA_ARGS',
subsetting => '-Xmx',
value => '512m',
2014-08-01 19:43:17 +02:00
}
2015-03-19 21:26:56 +01:00
~~~
2015-04-12 08:59:41 +02:00
###Use a non-standard section header
2015-07-28 00:50:03 +02:00
~~~puppet
2015-04-12 08:59:41 +02:00
default:
minage = 1
maxage = 13
ini_setting { 'default minage':
ensure => present,
path => '/etc/security/users',
section => 'default',
setting => 'minage',
value => '1',
section_prefix => '',
section_suffix => ':',
}
~~~
2015-03-19 21:26:56 +01:00
###Implement child providers
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
You might want to create child providers that inherit the `ini_setting` provider, for one or both of these purposes:
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
* Make a custom resource to manage an application that stores its settings in INI files, without recreating the code to manage the files themselves.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
* [Purge all unmanaged settings ](https://docs.puppetlabs.com/references/latest/type.html#resources-attribute-purge ) from a managed INI file.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
To implement child providers, first specify a custom type. Have it implement a namevar called `name` and a property called `value` :
2015-07-28 00:50:03 +02:00
~~~ruby
2014-08-01 19:43:17 +02:00
#my_module/lib/puppet/type/glance_api_config.rb
Puppet::Type.newtype(:glance_api_config) do
ensurable
newparam(:name, :namevar => true) do
desc 'Section/setting name to manage from glance-api.conf'
# namevar should be of the form section/setting
newvalues(/\S+\/\S+/)
end
newproperty(:value) do
2015-03-19 21:26:56 +01:00
desc 'The value of the setting to define'
2014-08-13 23:21:46 +02:00
munge do |v|
v.to_s.strip
2013-04-02 00:29:54 +02:00
end
2014-08-13 23:21:46 +02:00
end
end
2015-03-19 21:26:56 +01:00
~~~
2013-04-02 00:29:54 +02:00
2015-03-19 21:26:56 +01:00
Your type also needs a provider that uses the `ini_setting` provider as its parent:
2013-04-02 00:29:54 +02:00
2015-07-28 00:50:03 +02:00
~~~ruby
2014-08-01 19:43:17 +02:00
# my_module/lib/puppet/provider/glance_api_config/ini_setting.rb
Puppet::Type.type(:glance_api_config).provide(
:ini_setting,
# set ini_setting as the parent provider
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
) do
# implement section as the first part of the namevar
def section
resource[:name].split('/', 2).first
end
def setting
# implement setting as the second part of the namevar
resource[:name].split('/', 2).last
end
# hard code the file path (this allows purging)
def self.file_path
'/etc/glance/glance-api.conf'
end
end
2015-03-19 21:26:56 +01:00
~~~
2013-04-02 00:29:54 +02:00
2015-03-19 21:26:56 +01:00
Now the settings in /etc/glance/glance-api.conf file can be managed as individual resources:
2013-04-02 00:29:54 +02:00
2015-07-28 00:50:03 +02:00
~~~puppet
2014-08-01 19:43:17 +02:00
glance_api_config { 'HEADER/important_config':
value => 'secret_value',
}
2015-03-19 21:26:56 +01:00
~~~
2013-04-02 00:29:54 +02:00
2015-03-19 21:26:56 +01:00
If you've implemented self.file_path, you can have Puppet purge the file of all lines that aren't implemented as Puppet resources:
2013-04-02 00:29:54 +02:00
2015-07-28 00:50:03 +02:00
~~~puppet
2014-08-01 19:43:17 +02:00
resources { 'glance_api_config'
purge => true,
}
2015-03-19 21:26:56 +01:00
~~~
2013-04-02 00:29:54 +02:00
2015-07-28 00:50:03 +02:00
### Manage multiple ini_settings
To manage multiple ini_settings, use the [`create_ini_settings` ](#function-create_ini_settings ) function.
~~~puppet
$defaults = { 'path' => '/tmp/foo.ini' }
$example = { 'section1' => { 'setting1' => 'value1' } }
create_ini_settings($example, $defaults)
~~~
results in:
~~~puppet
ini_setting { '[section1] setting1':
ensure => present,
section => 'section1',
setting => 'setting1',
value => 'value1',
path => '/tmp/foo.ini',
}
~~~
To include special parameters, the following code:
~~~puppet
$defaults = { 'path' => '/tmp/foo.ini' }
$example = {
'section1' => {
'setting1' => 'value1',
'settings2' => {
'ensure' => 'absent'
}
}
}
create_ini_settings($example, $defaults)
~~~
results in:
~~~puppet
ini_setting { '[section1] setting1':
ensure => present,
section => 'section1',
setting => 'setting1',
value => 'value1',
path => '/tmp/foo.ini',
}
ini_setting { '[section1] setting2':
ensure => absent,
section => 'section1',
setting => 'setting2',
path => '/tmp/foo.ini',
}
~~~
#### Manage multiple ini_settings with Hiera
This example requires Puppet 3.x/4.x, as it uses automatic retrieval of Hiera data for class parameters and `puppetlabs/stdlib` .
For the profile `example` :
~~~puppet
class profile::example (
$settings,
) {
validate_hash($settings)
$defaults = { 'path' => '/tmp/foo.ini' }
create_ini_settings($settings, $defaults)
}
~~~
Provide this in your Hiera data:
~~~puppet
profile::example::settings:
section1:
setting1: value1
setting2: value2
setting3:
ensure: absent
~~~
Results in:
~~~puppet
ini_setting { '[section1] setting1':
ensure => present,
section => 'section1',
setting => 'setting1',
value => 'value1',
path => '/tmp/foo.ini',
}
ini_setting { '[section1] setting2':
ensure => present,
section => 'section1',
setting => 'setting2',
value => 'value2',
path => '/tmp/foo.ini',
}
ini_setting { '[section1] setting3':
ensure => absent,
section => 'section1',
setting => 'setting3',
path => '/tmp/foo.ini',
}
~~~
2014-08-01 19:43:17 +02:00
##Reference
2013-04-02 00:29:54 +02:00
2015-03-19 21:26:56 +01:00
###Public Types
* [`ini_setting` ](#type-ini_setting )
* [`ini_subsetting` ](#type-ini_subsetting )
2015-06-26 16:06:17 +02:00
###Public Functions
* [`create_ini_settings` ](#function-create_ini_settings )
2015-03-19 21:26:56 +01:00
### Type: ini_setting
Manages a setting within an INI file.
2014-08-01 19:43:17 +02:00
#### Parameters
2015-03-19 21:26:56 +01:00
##### `ensure`
Determines whether the specified setting should exist. Valid options: 'present' and 'absent'. Default value: 'present'.
##### `key_val_separator`
*Optional.* Specifies a string to use between each setting name and value (e.g., to determine whether the separator includes whitespace). Valid options: a string. Default value: ' = '.
##### `name`
*Optional.* Specifies an arbitrary name to identify the resource. Valid options: a string. Default value: the title of your declared resource.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `path`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Required.* Specifies an INI file containing the setting to manage. Valid options: a string containing an absolute path.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `section`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Required.* Designates a section of the specified INI file containing the setting to manage. To manage a global setting (at the beginning of the file, before any named sections) enter "". Valid options: a string.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `setting`
2014-08-01 19:43:17 +02:00
2015-07-07 12:07:25 +02:00
*Optional.* The name of the setting to define. Valid options: a string.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `value`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Optional.* Supplies a value for the specified setting. Valid options: a string. Default value: undefined.
2015-04-12 08:59:41 +02:00
##### `section_prefix`
*Optional.* Designates the string that will appear before the section's name. Default value: "["
##### `section_suffix`
2015-07-28 00:50:03 +02:00
*Optional.* Designates the string that will appear after the section's name. Default value: "]".
2015-03-19 21:26:56 +01:00
2015-07-28 00:50:03 +02:00
**NOTE:** This type finds all sections in the file by looking for lines like `${section_prefix}${title}${section_suffix}` .
2015-06-26 16:06:17 +02:00
### Type: ini_subsetting
2015-03-19 21:26:56 +01:00
Manages multiple values within the same INI setting.
2014-08-01 19:43:17 +02:00
#### Parameters
2015-03-19 21:26:56 +01:00
##### `ensure`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
Specifies whether the subsetting should be present. Valid options: 'present' and 'absent'. Default value: 'present'.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `key_val_separator`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Optional.* Specifies a string to use between subsetting name and value (e.g., to determine whether the separator includes whitespace). Valid options: a string. Default value: ' = '.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `path`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Required.* Specifies an INI file containing the subsetting to manage. Valid options: a string containing an absolute path.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `quote_char`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Optional.* The character used to quote the entire value of the setting. Valid values are '', '"', and "'". Defaults to ''. Valid options: '', '"' and "'". Default value: ''.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `section`
2014-08-01 19:43:17 +02:00
2015-03-18 23:09:13 +01:00
*Optional.* Designates a section of the specified INI file containing the setting to manage. To manage a global setting (at the beginning of the file, before any named sections) enter "". Defaults to "". Valid options: a string.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `setting`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Required.* Designates a setting within the specified section containing the subsetting to manage. Valid options: a string.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `subsetting`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Required.* Designates a subsetting to manage within the specified setting. Valid options: a string.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##### `subsetting_separator`
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
*Optional.* Specifies a string to use between subsettings. Valid options: a string. Default value: " ".
2014-10-11 00:13:09 +02:00
2015-03-19 21:26:56 +01:00
##### `value`
2014-10-11 00:13:09 +02:00
2015-03-19 21:26:56 +01:00
*Optional.* Supplies a value for the specified subsetting. Valid options: a string. Default value: undefined.
2014-08-01 19:43:17 +02:00
2015-06-26 16:06:17 +02:00
### Function: create_ini_settings
2015-07-28 00:50:03 +02:00
Manages multiple `ini_setting` resources from a hash. Note that this cannot be used with ini_subsettings.
2015-06-26 16:06:17 +02:00
2015-07-28 00:50:03 +02:00
`create_ini_settings($settings, $defaults)`
2015-06-26 16:06:17 +02:00
2015-07-28 00:50:03 +02:00
#### Arguments
2015-06-26 16:06:17 +02:00
2015-07-28 00:50:03 +02:00
##### First argument: `settings`
2015-06-26 16:06:17 +02:00
2015-07-28 00:50:03 +02:00
*Required.* Specify a hash representing the `ini_setting` resources you want to create.
2015-06-26 16:06:17 +02:00
2015-07-28 00:50:03 +02:00
##### `defaults`
2015-06-26 16:06:17 +02:00
2015-07-28 00:50:03 +02:00
*Optional.* Accepts a hash to be used as the values for any attributes not defined in the first argument.
~~~puppet
`$example = {
'section1' => {
'setting1' => {
'value' => 'value1', 'path' => '/tmp/foo.ini'
}
}
}`
2015-06-26 16:06:17 +02:00
~~~
Default value: '{}'.
2015-03-19 21:26:56 +01:00
##Limitations
2014-08-01 19:43:17 +02:00
2015-06-20 16:55:18 +02:00
This module has been tested on [all PE-supported platforms ](https://forge.puppetlabs.com/supported#compat-matrix ), and no issues have been identified. Additionally, it is tested (but not supported) on Windows 7, Mac OS X 10.9, and Solaris 12.
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
##Development
2014-08-01 19:43:17 +02:00
2015-03-19 21:26:56 +01:00
Puppet Labs modules on the Puppet Forge are open projects, and community contributions are essential for keeping them great. We can't access the huge number of platforms and myriad of hardware, software, and deployment configurations that Puppet is intended to serve.
We want to keep it as easy as possible to contribute changes so that our modules work in your environment. There are a few guidelines that we need contributors to follow so that we can have a chance of keeping on top of things.
2013-04-02 00:29:54 +02:00
2015-03-19 21:26:56 +01:00
For more information, see our [module contribution guide. ](https://docs.puppetlabs.com/forge/contributing.html )
2012-08-17 04:30:58 +02:00
2015-03-19 21:26:56 +01:00
###Contributors
2012-08-17 04:30:58 +02:00
2015-03-18 23:09:13 +01:00
To see who's already involved, see the [list of contributors. ](https://github.com/puppetlabs/puppetlabs-inifile/graphs/contributors )