1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
# Augeas Puppet module
[![Puppet Forge Version](http://img.shields.io/puppetforge/v/camptocamp/augeas.svg)](https://forge.puppetlabs.com/camptocamp/augeas)
[![Puppet Forge Downloads](http://img.shields.io/puppetforge/dt/camptocamp/augeas.svg)](https://forge.puppetlabs.com/camptocamp/augeas)
[![Build Status](https://img.shields.io/travis/camptocamp/puppet-augeas/master.svg)](https://travis-ci.org/camptocamp/puppet-augeas)
[![Gemnasium](https://img.shields.io/gemnasium/camptocamp/puppet-augeas.svg)](https://gemnasium.com/camptocamp/puppet-augeas)
[![By Camptocamp](https://img.shields.io/badge/by-camptocamp-fb7047.svg)](http://www.camptocamp.com)
**Install and configure Augeas.**
This module is provided by [Camptocamp](http://www.camptocamp.com/)
## Usage
Simple usage:
include augeas
### Classes
The module provides an `augeas` class which installs and configures Augeas.
* lets you force the augeas version by defining `$augeas_version`, otherwise puppet will
only ensure the packages are present;
* lets you force the ruby library version by defining `$augeas_ruby_version`, otherwise puppet will
only ensure the libaugeas-ruby version will be installed according to internal critera;
* provides an `augeas()` master-side function to manipulate strings using Augeas;
Note: the `augeas` class realizes all `augeas` resources in order to ensure they are managed after the required Augeas packages.
### Definitions
#### `augeas::lens`
The `augeas::lens` definition allows you to deploy an Augeas lens and any associated test files, running unit tests and not installing if they fail:
Parameters:
- *ensure*: present/absent
- *lens_content*: the content of the lens
- *lens_source*: deprecated, the source for the lens
- *test_content*: optionally, the content of the test file
- *test_source*: deprecated, the source for the test file.
- *stock_since*: optionally, indicate in which version of Augeas
the lens became stock, so it will not be deployed above that version.
Example usage:
```puppet
augeas::lens { 'networkmanager':
lens_content => file('networkmanager/lenses/networkmanager.aug'),
test_content => file('networkmanager/lenses/test_networkmanager.aug'),
stock_since => '1.0.0',
}
```
### Functions
#### `augeas()`
Modifies a string using Augeas.
*Example:*
augeas("proc /proc proc nodev,noexec,nosuid 0 0\n", 'Fstab.lns', ['rm ./1/opt[3]'])
Would result in:
"proc /proc proc nodev,noexec 0 0\n"
- *Type*: rvalue
## Contributing
Please report bugs and feature request using [GitHub issue
tracker](https://github.com/camptocamp/puppet-augeas/issues).
For pull requests, it is very much appreciated to check your Puppet manifest
with [puppet-lint](https://github.com/camptocamp/puppet-augeas/issues) to follow the recommended Puppet style guidelines from the
[Puppet Labs style guide](http://docs.puppetlabs.com/guides/style_guide.html).
|