Compare commits
241 commits
ff81517e1c
...
9224143da2
Author | SHA1 | Date | |
---|---|---|---|
|
9224143da2 | ||
|
e723c7c292 | ||
|
a2f980d44d | ||
|
be70aeba33 | ||
|
9465eeaea7 | ||
|
daa80f168f | ||
|
5c51463c1f | ||
|
6bab96ec26 | ||
|
3f86e3a731 | ||
|
70d543e66a | ||
|
af875b11ff | ||
|
50cf8bd5b7 | ||
|
7053868eaf | ||
|
d401d7f252 | ||
|
7b1250478c | ||
|
098e82e694 | ||
|
b7e1f8974b | ||
|
dd71c02880 | ||
|
ecfdbb2690 | ||
|
7a008a70b6 | ||
|
1b00c3bf3d | ||
|
f47df3b4b5 | ||
|
8f1efdad22 | ||
|
b2165dfc34 | ||
|
f46c9fdbce | ||
|
540546b9b4 | ||
|
f48747b8af | ||
|
420f76d8dc | ||
|
9e1f74f3fc | ||
|
2a75ed08a1 | ||
|
db6e2f81b4 | ||
|
870a272cee | ||
|
fc18517905 | ||
|
19752a7ff3 | ||
|
232de137f1 | ||
|
24797bb5ad | ||
|
ee6413b95a | ||
|
27236a73b2 | ||
|
79c871322f | ||
|
768b6ce9f4 | ||
|
cf171a7279 | ||
|
d9f65387c9 | ||
|
085035dcce | ||
|
733508677d | ||
|
0d46515b57 | ||
|
e3a6e2c601 | ||
|
60864fd39b | ||
|
bfe6cf68b3 | ||
|
44596e73da | ||
|
be1ff3f09e | ||
|
6248d241bc | ||
|
0624c3f806 | ||
|
5639828bff | ||
|
3860512d56 | ||
|
27458aff98 | ||
|
c5486aba62 | ||
|
29961218a7 | ||
|
e6a3436fd0 | ||
|
0cea94a82e | ||
|
7e408ca797 | ||
|
b63849c786 | ||
|
eca43f41cd | ||
|
db2a321434 | ||
|
85ff2a28a8 | ||
|
b6383d259c | ||
|
be6d4d2ffb | ||
|
52f6af3acc | ||
|
7943b25ec1 | ||
|
72f6e379a6 | ||
|
0da9ca7e4a | ||
|
0378336f9c | ||
|
69ca8d09c6 | ||
|
2c3beace24 | ||
|
dc64e721ee | ||
|
e2206fd153 | ||
|
c83a70e674 | ||
|
8f037d23b2 | ||
|
3169a43f4c | ||
|
990e1d7575 | ||
|
7ff944daa0 | ||
|
d85aec41a3 | ||
|
2a510169d6 | ||
|
b7df76cf7a | ||
|
e5be901e0e | ||
|
1659d478b9 | ||
|
4eba9364f1 | ||
|
f875770245 | ||
|
41f9319bbd | ||
|
4acba73b00 | ||
|
97320ab421 | ||
|
fdf3f22e24 | ||
|
33b79f3497 | ||
|
9cce93054a | ||
|
39644a69af | ||
|
27782242bc | ||
|
00973036b2 | ||
|
0073c6d8de | ||
|
1c6ae4793f | ||
|
35b5d6bcc1 | ||
|
8ea26c4c45 | ||
|
02965b89e5 | ||
|
1da820e61e | ||
|
1b048ff9d6 | ||
|
d2ae00cd5f | ||
|
0b4822be3d | ||
|
8fcefcfdb1 | ||
|
802e3adf16 | ||
|
d00bccc96f | ||
|
4abc6e6e3b | ||
|
9a1d8be10d | ||
|
964e24a637 | ||
|
93600e45b0 | ||
|
7a745deec6 | ||
|
8aecd63378 | ||
|
88a9a314c3 | ||
|
fe23e01a4b | ||
|
f684fb817c | ||
|
01c42d5212 | ||
|
06b2cfbf73 | ||
|
7b068781a5 | ||
|
ef0c13b1af | ||
|
c43924682a | ||
|
0d2020001d | ||
|
13e307b2c6 | ||
|
13e5d467c9 | ||
|
61333cfc48 | ||
|
99db982741 | ||
|
dc9b81d87e | ||
|
5d8a5ac631 | ||
|
7fdc312348 | ||
|
45ec648cdf | ||
|
1421aa4a87 | ||
|
143d4aa7be | ||
|
2c3c6fde98 | ||
|
2db7440c67 | ||
|
6de1a6e062 | ||
|
39126a7bc8 | ||
|
6aa7f2db99 | ||
|
57a8485223 | ||
|
25410c4598 | ||
|
0f8df10084 | ||
|
5b3c623394 | ||
|
ad173f2d05 | ||
|
4e62223801 | ||
|
d73fd3c5ef | ||
|
e1a9bf5063 | ||
|
76db98120a | ||
|
c7c4d41a82 | ||
|
6f1d164da6 | ||
|
48b658fc1c | ||
|
bfa21edbae | ||
|
39e81aa8b5 | ||
|
440245d40d | ||
|
ce6e8679b6 | ||
|
4d1bca3359 | ||
|
6bb1c27b99 | ||
|
92b068ad20 | ||
|
cebb9f333f | ||
|
b20239e796 | ||
|
97bd656efb | ||
|
799c38e14e | ||
|
9b1932c538 | ||
|
55ece7815a | ||
|
399ce03f68 | ||
|
169f8af506 | ||
|
0ea0e40228 | ||
|
c0df8192ee | ||
|
00c881d0da | ||
|
2a7a93ffb4 | ||
|
00b11c20c8 | ||
|
411978db32 | ||
|
f2f2db4795 | ||
|
05c6587d85 | ||
|
6a1afae97e | ||
|
5ef5c6629f | ||
|
64267eb650 | ||
|
823a352f0f | ||
|
9352db77a6 | ||
|
6c2a003f21 | ||
|
b10978703a | ||
|
2d4f5aa4d9 | ||
|
eb948c4a0d | ||
|
1bed010dbb | ||
|
ba345abfb7 | ||
|
da0e063af6 | ||
|
aa23894dd3 | ||
|
24e57b5d28 | ||
|
1d9189d860 | ||
|
66e118a92a | ||
|
1d89df906e | ||
|
4cbe846750 | ||
|
e84090df1d | ||
|
605fffd852 | ||
|
57275061ab | ||
|
a72918f675 | ||
|
9baca7f755 | ||
|
cf5d4ff34b | ||
|
0a58b9382c | ||
|
a56e119f18 | ||
|
dfa98b89f7 | ||
|
9bacf14ca2 | ||
|
061d0c29fc | ||
|
a7adcda803 | ||
|
e815da5962 | ||
|
f411ee7119 | ||
|
d1f6c5c553 | ||
|
aca29129cb | ||
|
ebf73482e5 | ||
|
41a7297cb7 | ||
|
35e92645f7 | ||
|
956c329a8a | ||
|
44c4bad392 | ||
|
ac0b096d49 | ||
|
4d889cbcb6 | ||
|
c7403a4e05 | ||
|
a8d7563a44 | ||
|
24b1cd78db | ||
|
dca8bdba59 | ||
|
5c79107863 | ||
|
f996a38d11 | ||
|
615227918a | ||
|
dde8aa095a | ||
|
21feb4b1f1 | ||
|
78e8c73671 | ||
|
939aceffad | ||
|
1282649b91 | ||
|
14709d625b | ||
|
a022441289 | ||
|
f485e6e2eb | ||
|
01fe9dc15c | ||
|
224b644003 | ||
|
a2026bf13b | ||
|
07c38e518a | ||
|
b2aed66226 | ||
|
c64ecfb0c3 | ||
|
e96a818782 | ||
|
f820bb1560 | ||
|
a6dcb23f89 | ||
|
67bc57bcb6 | ||
|
5381dbd4b4 | ||
|
771320a830 |
171 changed files with 4413 additions and 901 deletions
5
.gitattributes
vendored
Normal file
5
.gitattributes
vendored
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
#This file is generated by ModuleSync, do not edit.
|
||||||
|
*.rb eol=lf
|
||||||
|
*.erb eol=lf
|
||||||
|
*.pp eol=lf
|
||||||
|
*.sh eol=lf
|
24
.gitignore
vendored
24
.gitignore
vendored
|
@ -1,12 +1,14 @@
|
||||||
/pkg/
|
#This file is generated by ModuleSync, do not edit.
|
||||||
/Gemfile.lock
|
pkg/
|
||||||
/vendor/
|
Gemfile.lock
|
||||||
/spec/fixtures/manifests/*
|
vendor/
|
||||||
/spec/fixtures/modules/*
|
spec/fixtures/
|
||||||
!/spec/fixtures/modules/stdlib
|
.vagrant/
|
||||||
!/spec/fixtures/modules/stdlib/*
|
.bundle/
|
||||||
/.vagrant/
|
coverage/
|
||||||
/.bundle/
|
log/
|
||||||
/coverage/
|
.idea/
|
||||||
/.idea/
|
|
||||||
*.iml
|
*.iml
|
||||||
|
!spec/fixtures/
|
||||||
|
spec/fixtures/manifests/site.pp
|
||||||
|
spec/fixtures/modules/*
|
||||||
|
|
4
.rspec
4
.rspec
|
@ -1,4 +1,2 @@
|
||||||
--color
|
--color
|
||||||
--format
|
--format documentation
|
||||||
progress
|
|
||||||
--backtrace
|
|
||||||
|
|
14
.sync.yml
14
.sync.yml
|
@ -1,9 +1,7 @@
|
||||||
---
|
---
|
||||||
.travis.yml:
|
.gitignore:
|
||||||
script: "\"bundle exec rake validate && bundle exec rake lint && bundle exec rake spec SPEC_OPTS='--color --format documentation'\""
|
paths:
|
||||||
Rakefile:
|
- '!spec/fixtures/'
|
||||||
unmanaged: true
|
- 'spec/fixtures/manifests/site.pp'
|
||||||
Gemfile:
|
- 'spec/fixtures/modules/*'
|
||||||
unmanaged: true
|
|
||||||
spec/spec_helper.rb:
|
|
||||||
unmanaged: true
|
|
||||||
|
|
32
.travis.yml
32
.travis.yml
|
@ -1,21 +1,35 @@
|
||||||
|
#This file is generated by ModuleSync, do not edit.
|
||||||
---
|
---
|
||||||
sudo: false
|
sudo: false
|
||||||
language: ruby
|
language: ruby
|
||||||
cache: bundler
|
cache: bundler
|
||||||
bundler_args: --without system_tests
|
script: "bundle exec rake validate lint spec"
|
||||||
script: "bundle exec rake validate && bundle exec rake lint && bundle exec rake spec SPEC_OPTS='--color --format documentation'"
|
|
||||||
matrix:
|
matrix:
|
||||||
fast_finish: true
|
fast_finish: true
|
||||||
include:
|
include:
|
||||||
- rvm: 1.8.7
|
- rvm: 2.1.6
|
||||||
|
dist: trusty
|
||||||
|
env: PUPPET_INSTALL_TYPE=agent BEAKER_debug=true BEAKER_set=docker/ubuntu-14.04
|
||||||
|
script: bundle exec rake beaker
|
||||||
|
services: docker
|
||||||
|
sudo: required
|
||||||
|
- rvm: 2.1.6
|
||||||
|
dist: trusty
|
||||||
|
env: PUPPET_INSTALL_TYPE=agent BEAKER_debug=true BEAKER_set=docker/centos-7
|
||||||
|
script: bundle exec rake beaker
|
||||||
|
services: docker
|
||||||
|
sudo: required
|
||||||
|
- rvm: 2.1.6
|
||||||
|
bundler_args: --without system_tests
|
||||||
|
env: PUPPET_GEM_VERSION="~> 4.0" STRICT_VARIABLES="yes"
|
||||||
|
- rvm: 2.1.5
|
||||||
|
bundler_args: --without system_tests
|
||||||
|
env: PUPPET_GEM_VERSION="~> 3.0" FUTURE_PARSER="yes"
|
||||||
|
- rvm: 2.1.5
|
||||||
|
bundler_args: --without system_tests
|
||||||
env: PUPPET_GEM_VERSION="~> 3.0"
|
env: PUPPET_GEM_VERSION="~> 3.0"
|
||||||
- rvm: 1.9.3
|
- rvm: 1.9.3
|
||||||
|
bundler_args: --without system_tests
|
||||||
env: PUPPET_GEM_VERSION="~> 3.0"
|
env: PUPPET_GEM_VERSION="~> 3.0"
|
||||||
- rvm: 2.1.5
|
|
||||||
env: PUPPET_GEM_VERSION="~> 3.0"
|
|
||||||
- rvm: 2.1.5
|
|
||||||
env: PUPPET_GEM_VERSION="~> 3.0" FUTURE_PARSER="yes"
|
|
||||||
- rvm: 2.1.6
|
|
||||||
env: PUPPET_GEM_VERSION="~> 4.0" STRICT_VARIABLES="yes"
|
|
||||||
notifications:
|
notifications:
|
||||||
email: false
|
email: false
|
||||||
|
|
144
CHANGELOG.md
144
CHANGELOG.md
|
@ -1,3 +1,143 @@
|
||||||
|
## Supported Release 4.12.0
|
||||||
|
###Summary
|
||||||
|
|
||||||
|
This release provides several new functions, bugfixes, modulesync changes, and some documentation updates.
|
||||||
|
|
||||||
|
####Features
|
||||||
|
- Adds `clamp`. This function keeps values within a specified range.
|
||||||
|
- Adds `validate_x509_rsa_key_pair`. This function validates an x509 RSA certificate and key pair.
|
||||||
|
- Adds `dig`. This function performs a deep lookup in nested hashes or arrays.
|
||||||
|
- Extends the `base64` support to fit `rfc2045` and `rfc4648`.
|
||||||
|
- Adds `is_ipv6_address` and `is_ipv4_address`. These functions validate the specified ipv4 or ipv6 addresses.
|
||||||
|
- Adds `enclose_ipv6`. This function encloses IPv6 addresses in square brackets.
|
||||||
|
- Adds `ensure_resources`. This function takes a list of resources and creates them if they do not exist.
|
||||||
|
- Extends `suffix` to support applying a suffix to keys in a hash.
|
||||||
|
- Apply modulesync changes.
|
||||||
|
- Add validate_email_address function.
|
||||||
|
|
||||||
|
####Bugfixes
|
||||||
|
- Fixes `fqdn_rand_string` tests, since Puppet 4.4.0 and later have a higher `fqdn_rand` ceiling.
|
||||||
|
- (MODULES-3152) Adds a check to `package_provider` to prevent failures if Gem is not installed.
|
||||||
|
- Fixes to README.md.
|
||||||
|
- Fixes catch StandardError rather than the gratuitous Exception
|
||||||
|
- Fixes file_line attribute validation.
|
||||||
|
- Fixes concat with Hash arguments.
|
||||||
|
|
||||||
|
## Supported Release 4.11.0
|
||||||
|
###Summary
|
||||||
|
|
||||||
|
Provides a validate_absolute_paths and Debian 8 support. There is a fix to the is_package_provider fact and a test improvement.
|
||||||
|
|
||||||
|
####Features
|
||||||
|
- Adds new parser called is_absolute_path
|
||||||
|
- Supports Debian 8
|
||||||
|
|
||||||
|
####Bugfixes
|
||||||
|
- Allow package_provider fact to resolve on PE 3.x
|
||||||
|
|
||||||
|
####Improvements
|
||||||
|
- ensures that the test passes independently of changes to rubygems for ensure_resource
|
||||||
|
|
||||||
|
##2015-12-15 - Supported Release 4.10.0
|
||||||
|
###Summary
|
||||||
|
|
||||||
|
Includes the addition of several new functions and considerable improvements to the existing functions, tests and documentation. Includes some bug fixes which includes compatibility, test and fact issues.
|
||||||
|
|
||||||
|
####Features
|
||||||
|
- Adds service_provider fact
|
||||||
|
- Adds is_a() function
|
||||||
|
- Adds package_provider fact
|
||||||
|
- Adds validate_ip_address function
|
||||||
|
- Adds seeded_rand function
|
||||||
|
|
||||||
|
####Bugfixes
|
||||||
|
- Fix backwards compatibility from an improvement to the parseyaml function
|
||||||
|
- Renaming of load_module_metadata test to include _spec.rb
|
||||||
|
- Fix root_home fact on AIX 5.x, now '-c' rather than '-C'
|
||||||
|
- Fixed Gemfile to work with ruby 1.8.7
|
||||||
|
|
||||||
|
####Improvements
|
||||||
|
- (MODULES-2462) Improvement of parseyaml function
|
||||||
|
- Improvement of str2bool function
|
||||||
|
- Improvement to readme
|
||||||
|
- Improvement of intersection function
|
||||||
|
- Improvement of validate_re function
|
||||||
|
- Improved speed on Facter resolution of service_provider
|
||||||
|
- empty function now handles numeric values
|
||||||
|
- Package_provider now prevents deprecation warning about the allow_virtual parameter
|
||||||
|
- load_module_metadata now succeeds on empty file
|
||||||
|
- Check added to ensure puppetversion value is not nil
|
||||||
|
- Improvement to bool2str to return a string of choice using boolean
|
||||||
|
- Improvement to naming convention in validate_ipv4_address function
|
||||||
|
|
||||||
|
## Supported Release 4.9.1
|
||||||
|
###Summary
|
||||||
|
|
||||||
|
Small release for support of newer PE versions. This increments the version of PE in the metadata.json file.
|
||||||
|
|
||||||
|
##2015-09-08 - Supported Release 4.9.0
|
||||||
|
###Summary
|
||||||
|
|
||||||
|
This release adds new features including the new functions dos2unix, unix2dos, try_get_value, convert_base as well as other features and improvements.
|
||||||
|
|
||||||
|
####Features
|
||||||
|
- (MODULES-2370) allow `match` parameter to influence `ensure => absent` behavior
|
||||||
|
- (MODULES-2410) Add new functions dos2unix and unix2dos
|
||||||
|
- (MODULE-2456) Modify union to accept more than two arrays
|
||||||
|
- Adds a convert_base function, which can convert numbers between bases
|
||||||
|
- Add a new function "try_get_value"
|
||||||
|
|
||||||
|
####Bugfixes
|
||||||
|
- n/a
|
||||||
|
|
||||||
|
####Improvements
|
||||||
|
- (MODULES-2478) Support root_home fact on AIX through "lsuser" command
|
||||||
|
- Acceptance test improvements
|
||||||
|
- Unit test improvements
|
||||||
|
- Readme improvements
|
||||||
|
|
||||||
|
## 2015-08-10 - Supported Release 4.8.0
|
||||||
|
### Summary
|
||||||
|
This release adds a function for reading metadata.json from any module, and expands file\_line's abilities.
|
||||||
|
|
||||||
|
#### Features
|
||||||
|
- New parameter `replace` on `file_line`
|
||||||
|
- New function `load_module_metadata()` to load metadata.json and return the content as a hash.
|
||||||
|
- Added hash support to `size()`
|
||||||
|
|
||||||
|
#### Bugfixes
|
||||||
|
- Fix various docs typos
|
||||||
|
- Fix `file_line` resource on puppet < 3.3
|
||||||
|
|
||||||
|
##2015-06-22 - Supported Release 4.7.0
|
||||||
|
###Summary
|
||||||
|
|
||||||
|
Adds Solaris 12 support along with improved Puppet 4 support. There are significant test improvements, and some minor fixes.
|
||||||
|
|
||||||
|
####Features
|
||||||
|
- Add support for Solaris 12
|
||||||
|
|
||||||
|
####Bugfixes
|
||||||
|
- Fix for AIO Puppet 4
|
||||||
|
- Fix time for ruby 1.8.7
|
||||||
|
- Specify rspec-puppet version
|
||||||
|
- range() fix for typeerror and missing functionality
|
||||||
|
- Fix pw_hash() on JRuby < 1.7.17
|
||||||
|
- fqdn_rand_string: fix argument error message
|
||||||
|
- catch and rescue from looking up non-existent facts
|
||||||
|
- Use puppet_install_helper, for Puppet 4
|
||||||
|
|
||||||
|
####Improvements
|
||||||
|
- Enforce support for Puppet 4 testing
|
||||||
|
- fqdn_rotate/fqdn_rand_string acceptance tests and implementation
|
||||||
|
- Simplify mac address regex
|
||||||
|
- validate_integer, validate_numeric: explicitely reject hashes in arrays
|
||||||
|
- Readme edits
|
||||||
|
- Remove all the pops stuff for rspec-puppet
|
||||||
|
- Sync via modulesync
|
||||||
|
- Add validate_slength optional 3rd arg
|
||||||
|
- Move tests directory to examples directory
|
||||||
|
|
||||||
##2015-04-14 - Supported Release 4.6.0
|
##2015-04-14 - Supported Release 4.6.0
|
||||||
###Summary
|
###Summary
|
||||||
|
|
||||||
|
@ -293,7 +433,7 @@ This is a supported release
|
||||||
|
|
||||||
* Add an ensure\_packages function. (8a8c09e)
|
* Add an ensure\_packages function. (8a8c09e)
|
||||||
|
|
||||||
##### 2012-11-23 - Erik Dalén <dalen@spotify.com> - 3.2.0
|
##### 2012-11-23 - Erik Dalén <dalen@spotify.com> - 3.2.0
|
||||||
|
|
||||||
* (#17797) min() and max() functions (9954133)
|
* (#17797) min() and max() functions (9954133)
|
||||||
|
|
||||||
|
@ -390,7 +530,7 @@ This is a supported release
|
||||||
|
|
||||||
* Add support for a 'match' parameter to file\_line (a06c0d8)
|
* Add support for a 'match' parameter to file\_line (a06c0d8)
|
||||||
|
|
||||||
##### 2012-08-07 - Erik Dalén <dalen@spotify.com> - 2.4.0
|
##### 2012-08-07 - Erik Dalén <dalen@spotify.com> - 2.4.0
|
||||||
|
|
||||||
* (#15872) Add to\_bytes function (247b69c)
|
* (#15872) Add to\_bytes function (247b69c)
|
||||||
|
|
||||||
|
|
|
@ -159,7 +159,7 @@ If you already have those gems installed, make sure they are up-to-date:
|
||||||
With all dependencies in place and up-to-date we can now run the tests:
|
With all dependencies in place and up-to-date we can now run the tests:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
% rake spec
|
% bundle exec rake spec
|
||||||
```
|
```
|
||||||
|
|
||||||
This will execute all the [rspec tests](http://rspec-puppet.com/) tests
|
This will execute all the [rspec tests](http://rspec-puppet.com/) tests
|
||||||
|
@ -178,8 +178,8 @@ installed on your system.
|
||||||
You can run them by issuing the following command
|
You can run them by issuing the following command
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
% rake spec_clean
|
% bundle exec rake spec_clean
|
||||||
% rspec spec/acceptance
|
% bundle exec rspec spec/acceptance
|
||||||
```
|
```
|
||||||
|
|
||||||
This will now download a pre-fabricated image configured in the [default node-set](./spec/acceptance/nodesets/default.yml),
|
This will now download a pre-fabricated image configured in the [default node-set](./spec/acceptance/nodesets/default.yml),
|
||||||
|
@ -208,11 +208,9 @@ review.
|
||||||
Additional Resources
|
Additional Resources
|
||||||
====================
|
====================
|
||||||
|
|
||||||
* [Getting additional help](http://puppetlabs.com/community/get-help)
|
* [Getting additional help](http://puppet.com/community/get-help)
|
||||||
|
|
||||||
* [Writing tests](http://projects.puppetlabs.com/projects/puppet/wiki/Development_Writing_Tests)
|
* [Writing tests](https://docs.puppet.com/guides/module_guides/bgtm.html#step-three-module-testing)
|
||||||
|
|
||||||
* [Patchwork](https://patchwork.puppetlabs.com)
|
|
||||||
|
|
||||||
* [General GitHub documentation](http://help.github.com/)
|
* [General GitHub documentation](http://help.github.com/)
|
||||||
|
|
||||||
|
|
66
Gemfile
66
Gemfile
|
@ -1,54 +1,40 @@
|
||||||
source ENV['GEM_SOURCE'] || 'https://rubygems.org'
|
#This file is generated by ModuleSync, do not edit.
|
||||||
|
|
||||||
def location_for(place, fake_version = nil)
|
source ENV['GEM_SOURCE'] || "https://rubygems.org"
|
||||||
|
|
||||||
|
def location_for(place, version = nil)
|
||||||
if place =~ /^(git[:@][^#]*)#(.*)/
|
if place =~ /^(git[:@][^#]*)#(.*)/
|
||||||
[fake_version, { :git => $1, :branch => $2, :require => false }].compact
|
[version, { :git => $1, :branch => $2, :require => false}].compact
|
||||||
elsif place =~ /^file:\/\/(.*)/
|
elsif place =~ /^file:\/\/(.*)/
|
||||||
['>= 0', { :path => File.expand_path($1), :require => false }]
|
['>= 0', { :path => File.expand_path($1), :require => false}]
|
||||||
else
|
else
|
||||||
[place, { :require => false }]
|
[place, version, { :require => false}].compact
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
group :development, :unit_tests do
|
group :development, :unit_tests do
|
||||||
gem 'rake', '~> 10.1.0', :require => false
|
gem 'json', :require => false
|
||||||
gem 'rspec', '~> 3.1.0', :require => false
|
gem 'metadata-json-lint', :require => false
|
||||||
gem 'rspec-puppet', '~> 2.2', :require => false
|
gem 'puppet_facts', :require => false
|
||||||
gem 'mocha', :require => false
|
gem 'puppetlabs_spec_helper', :require => false
|
||||||
# keep for its rake task for now
|
gem 'rspec-puppet', '>= 2.3.2', :require => false
|
||||||
gem 'puppetlabs_spec_helper', :require => false
|
gem 'simplecov', :require => false
|
||||||
gem 'puppet-lint', :require => false
|
gem 'puppet-blacksmith', :require => false
|
||||||
gem 'metadata-json-lint', :require => false
|
gem 'rest-client', '~> 1.8.0', :require => false
|
||||||
gem 'pry', :require => false
|
|
||||||
gem 'simplecov', :require => false
|
|
||||||
end
|
end
|
||||||
|
|
||||||
beaker_version = ENV['BEAKER_VERSION']
|
|
||||||
beaker_rspec_version = ENV['BEAKER_RSPEC_VERSION']
|
|
||||||
group :system_tests do
|
group :system_tests do
|
||||||
if beaker_version
|
gem 'beaker-rspec', *location_for(ENV['BEAKER_RSPEC_VERSION'] || '>= 3.4')
|
||||||
gem 'beaker', *location_for(beaker_version)
|
gem 'beaker', *location_for(ENV['BEAKER_VERSION'])
|
||||||
end
|
gem 'serverspec', :require => false
|
||||||
if beaker_rspec_version
|
gem 'beaker-puppet_install_helper', :require => false
|
||||||
gem 'beaker-rspec', *location_for(beaker_rspec_version)
|
gem 'master_manipulator', :require => false
|
||||||
else
|
gem 'beaker-hostgenerator', *location_for(ENV['BEAKER_HOSTGENERATOR_VERSION'])
|
||||||
gem 'beaker-rspec', :require => false
|
|
||||||
end
|
|
||||||
gem 'serverspec', :require => false
|
|
||||||
end
|
end
|
||||||
|
|
||||||
facterversion = ENV['GEM_FACTER_VERSION'] || ENV['FACTER_GEM_VERSION']
|
gem 'facter', *location_for(ENV['FACTER_GEM_VERSION'])
|
||||||
if facterversion
|
gem 'puppet', *location_for(ENV['PUPPET_GEM_VERSION'])
|
||||||
gem 'facter', *location_for(facterversion)
|
|
||||||
else
|
|
||||||
gem 'facter', :require => false
|
|
||||||
end
|
|
||||||
|
|
||||||
puppetversion = ENV['GEM_PUPPET_VERSION'] || ENV['PUPPET_GEM_VERSION']
|
|
||||||
if puppetversion
|
|
||||||
gem 'puppet', *location_for(puppetversion)
|
|
||||||
else
|
|
||||||
gem 'puppet', :require => false
|
|
||||||
end
|
|
||||||
|
|
||||||
# vim:ft=ruby
|
if File.exists? "#{__FILE__}.local"
|
||||||
|
eval(File.read("#{__FILE__}.local"), binding)
|
||||||
|
end
|
||||||
|
|
209
LICENSE
209
LICENSE
|
@ -1,19 +1,202 @@
|
||||||
Copyright (C) 2011 Puppet Labs Inc
|
|
||||||
|
|
||||||
and some parts:
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
Copyright (C) 2011 Krzysztof Wilczynski
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
Puppet Labs can be contacted at: info@puppetlabs.com
|
1. Definitions.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
you may not use this file except in compliance with the License.
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
other entities that control, are controlled by, or are under common
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
control with that entity. For the purposes of this definition,
|
||||||
See the License for the specific language governing permissions and
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
limitations under the License.
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
APPENDIX: How to apply the Apache License to your work.
|
||||||
|
|
||||||
|
To apply the Apache License to your work, attach the following
|
||||||
|
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||||
|
replaced with your own identifying information. (Don't include
|
||||||
|
the brackets!) The text should be enclosed in the appropriate
|
||||||
|
comment syntax for the file format. We also recommend that a
|
||||||
|
file or class name and description of purpose be included on the
|
||||||
|
same "printed page" as the copyright notice for easier
|
||||||
|
identification within third-party archives.
|
||||||
|
|
||||||
|
Copyright [yyyy] [name of copyright owner]
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
|
23
NOTICE
Normal file
23
NOTICE
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
stdlib puppet module
|
||||||
|
|
||||||
|
Copyright (C) 2011-2016 Puppet Labs, Inc.
|
||||||
|
|
||||||
|
and some parts:
|
||||||
|
|
||||||
|
Copyright (C) 2011 Krzysztof Wilczynski
|
||||||
|
|
||||||
|
|
||||||
|
Puppet Labs can be contacted at: info@puppetlabs.com
|
||||||
|
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
563
README.markdown
563
README.markdown
|
@ -76,30 +76,63 @@ The `stdlib::stages` class declares various run stages for deploying infrastruct
|
||||||
### Types
|
### Types
|
||||||
|
|
||||||
#### `file_line`
|
#### `file_line`
|
||||||
Ensures that a given line, including whitespace at the beginning and end, is contained within a file. If the line is not contained in the given file, Puppet will add the line. Multiple resources can be declared to manage multiple lines in the same file. You can also use `match` to replace existing lines.
|
|
||||||
|
|
||||||
~~~
|
Ensures that a given line is contained within a file. The implementation matches the full line, including whitespace at the beginning and end. If the line is not contained in the given file, Puppet appends the line to the end of the file to ensure the desired state. Multiple resources can be declared to manage multiple lines in the same file.
|
||||||
file_line { 'sudo_rule':
|
|
||||||
path => '/etc/sudoers',
|
Example:
|
||||||
line => '%sudo ALL=(ALL) ALL',
|
|
||||||
}
|
file_line { 'sudo_rule':
|
||||||
file_line { 'sudo_rule_nopw':
|
path => '/etc/sudoers',
|
||||||
path => '/etc/sudoers',
|
line => '%sudo ALL=(ALL) ALL',
|
||||||
line => '%sudonopw ALL=(ALL) NOPASSWD: ALL',
|
}
|
||||||
}
|
|
||||||
~~~
|
file_line { 'sudo_rule_nopw':
|
||||||
|
path => '/etc/sudoers',
|
||||||
|
line => '%sudonopw ALL=(ALL) NOPASSWD: ALL',
|
||||||
|
}
|
||||||
|
|
||||||
|
In this example, Puppet ensures that both of the specified lines are contained in the file `/etc/sudoers`.
|
||||||
|
|
||||||
|
Match Example:
|
||||||
|
|
||||||
|
file_line { 'bashrc_proxy':
|
||||||
|
ensure => present,
|
||||||
|
path => '/etc/bashrc',
|
||||||
|
line => 'export HTTP_PROXY=http://squid.puppetlabs.vm:3128',
|
||||||
|
match => '^export\ HTTP_PROXY\=',
|
||||||
|
}
|
||||||
|
|
||||||
|
In this code example, `match` looks for a line beginning with export followed by HTTP_PROXY and replaces it with the value in line.
|
||||||
|
|
||||||
|
Match Example With `ensure => absent`:
|
||||||
|
|
||||||
|
file_line { 'bashrc_proxy':
|
||||||
|
ensure => absent,
|
||||||
|
path => '/etc/bashrc',
|
||||||
|
line => 'export HTTP_PROXY=http://squid.puppetlabs.vm:3128',
|
||||||
|
match => '^export\ HTTP_PROXY\=',
|
||||||
|
match_for_absence => true,
|
||||||
|
}
|
||||||
|
|
||||||
|
In this code example, `match` looks for a line beginning with export
|
||||||
|
followed by HTTP_PROXY and delete it. If multiple lines match, an
|
||||||
|
error will be raised unless the `multiple => true` parameter is set.
|
||||||
|
|
||||||
|
**Autorequires:** If Puppet is managing the file that contains the line being managed, the `file_line` resource autorequires that file.
|
||||||
|
|
||||||
##### Parameters
|
##### Parameters
|
||||||
|
|
||||||
All parameters are optional, unless otherwise noted.
|
All parameters are optional, unless otherwise noted.
|
||||||
|
|
||||||
* `after`: Specifies the line after which Puppet will add any new lines. (Existing lines are added in place.) Valid options: String. Default: Undefined.
|
* `after`: Specifies the line after which Puppet adds any new lines. (Existing lines are added in place.) Valid options: String. Default: Undefined.
|
||||||
* `ensure`: Ensures whether the resource is present. Valid options: 'present', 'absent'. Default: 'present'.
|
* `ensure`: Ensures whether the resource is present. Valid options: 'present', 'absent'. Default: 'present'.
|
||||||
* `line`: **Required.** Sets the line to be added to the file located by the `path` parameter. Valid options: String. Default: Undefined.
|
* `line`: **Required.** Sets the line to be added to the file located by the `path` parameter. Valid options: String. Default: Undefined.
|
||||||
* `match`: Specifies a regular expression to run against existing lines in the file; if a match is found, it is replaced rather than adding a new line. Valid options: String containing a regex. Default: Undefined.
|
* `match`: Specifies a regular expression to run against existing lines in the file; if a match is found, it is replaced rather than adding a new line. A regex comparison is performed against the line value, and if it does not match, an exception is raised. Valid options: String containing a regex. Default: Undefined.
|
||||||
|
* `match_for_absence`: An optional value to determine if match should be applied when `ensure => absent`. If set to true and match is set, the line that matches match will be deleted. If set to false (the default), match is ignored when `ensure => absent` and the value of `line` is used instead. Default: false.
|
||||||
* `multiple`: Determines if `match` and/or `after` can change multiple lines. If set to false, an exception will be raised if more than one line matches. Valid options: 'true', 'false'. Default: Undefined.
|
* `multiple`: Determines if `match` and/or `after` can change multiple lines. If set to false, an exception will be raised if more than one line matches. Valid options: 'true', 'false'. Default: Undefined.
|
||||||
* `name`: Sets the name to use as the identity of the resource. This is necessary if you want the resource namevar to differ from the supplied `title` of the resource. Valid options: String. Default: Undefined.
|
* `name`: Sets the name to use as the identity of the resource. This is necessary if you want the resource namevar to differ from the supplied `title` of the resource. Valid options: String. Default: Undefined.
|
||||||
* `path`: **Required.** Defines the file in which Puppet will ensure the line specified by `line`. Must be an absolute path to the file.
|
* `path`: **Required.** Defines the file in which Puppet will ensure the line specified by `line`. Must be an absolute path to the file.
|
||||||
|
* `replace`: Defines whether the resource will overwrite an existing line that matches the `match` parameter. If set to false and a line is found matching the `match` param, the line will not be placed in the file. Valid options: true, false, yes, no. Default: true
|
||||||
|
|
||||||
### Functions
|
### Functions
|
||||||
|
|
||||||
|
@ -113,7 +146,34 @@ Converts any object to an array containing that object. Empty argument lists are
|
||||||
|
|
||||||
#### `base64`
|
#### `base64`
|
||||||
|
|
||||||
Converts a string to and from base64 encoding. Requires an action ('encode', 'decode') and either a plain or base64-encoded string. *Type*: rvalue.
|
Converts a string to and from base64 encoding. Requires an `action` ('encode', 'decode') and either a plain or base64-encoded `string`, and an optional `method` ('default', 'strict', 'urlsafe')
|
||||||
|
|
||||||
|
For backward compatibility, `method` will be set as `default` if not specified.
|
||||||
|
|
||||||
|
*Examples:*
|
||||||
|
~~~
|
||||||
|
base64('encode', 'hello')
|
||||||
|
base64('encode', 'hello', 'default')
|
||||||
|
# return: "aGVsbG8=\n"
|
||||||
|
|
||||||
|
base64('encode', 'hello', 'strict')
|
||||||
|
# return: "aGVsbG8="
|
||||||
|
|
||||||
|
base64('decode', 'aGVsbG8=')
|
||||||
|
base64('decode', 'aGVsbG8=\n')
|
||||||
|
base64('decode', 'aGVsbG8=', 'default')
|
||||||
|
base64('decode', 'aGVsbG8=\n', 'default')
|
||||||
|
base64('decode', 'aGVsbG8=', 'strict')
|
||||||
|
# return: "hello"
|
||||||
|
|
||||||
|
base64('encode', 'https://puppetlabs.com', 'urlsafe')
|
||||||
|
# return: "aHR0cHM6Ly9wdXBwZXRsYWJzLmNvbQ=="
|
||||||
|
|
||||||
|
base64('decode', 'aHR0cHM6Ly9wdXBwZXRsYWJzLmNvbQ==', 'urlsafe')
|
||||||
|
# return: "https://puppetlabs.com"
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `basename`
|
#### `basename`
|
||||||
|
|
||||||
|
@ -131,9 +191,22 @@ Converts a boolean to a number. Converts values:
|
||||||
* 'true', 't', '1', 'y', and 'yes' to 1.
|
* 'true', 't', '1', 'y', and 'yes' to 1.
|
||||||
Requires a single boolean or string as an input. *Type*: rvalue.
|
Requires a single boolean or string as an input. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `bool2str`
|
||||||
|
|
||||||
|
Converts a boolean to a string using optionally supplied arguments. The optional second and third arguments represent what true and false are converted to respectively. If only one argument is given, it is converted from a boolean to a string containing 'true' or 'false'.
|
||||||
|
|
||||||
|
*Examples:*
|
||||||
|
~~~
|
||||||
|
bool2str(true) => 'true'
|
||||||
|
bool2str(true, 'yes', 'no') => 'yes'
|
||||||
|
bool2str(false, 't', 'f') => 'f'
|
||||||
|
~~~
|
||||||
|
|
||||||
|
Requires a single boolean as input. *Type*: rvalue.
|
||||||
|
|
||||||
#### `capitalize`
|
#### `capitalize`
|
||||||
|
|
||||||
Capitalizes the first letter of a string or array of strings. Requires either a single string or an array as an input. *Type*: rvalue.
|
Capitalizes the first character of a string or array of strings and lowercases the remaining characters of each string. Requires either a single string or an array as an input. *Type*: rvalue.
|
||||||
|
|
||||||
#### `ceiling`
|
#### `ceiling`
|
||||||
|
|
||||||
|
@ -147,6 +220,14 @@ Removes the record separator from the end of a string or an array of strings; fo
|
||||||
|
|
||||||
Returns a new string with the last character removed. If the string ends with '\r\n', both characters are removed. Applying `chop` to an empty string returns an empty string. If you want to merely remove record separators, then you should use the `chomp` function. Requires a string or an array of strings as input. *Type*: rvalue.
|
Returns a new string with the last character removed. If the string ends with '\r\n', both characters are removed. Applying `chop` to an empty string returns an empty string. If you want to merely remove record separators, then you should use the `chomp` function. Requires a string or an array of strings as input. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `clamp`
|
||||||
|
|
||||||
|
Keeps value within the range [Min, X, Max] by sort based on integer value (order of params doesn't matter). Takes strings, arrays or numerics. Strings are converted and compared numerically. Arrays of values are flattened into a list for further handling. For example:
|
||||||
|
* `clamp('24', [575, 187])` returns 187.
|
||||||
|
* `clamp(16, 88, 661)` returns 88.
|
||||||
|
* `clamp([4, 3, '99'])` returns 4.
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `concat`
|
#### `concat`
|
||||||
|
|
||||||
Appends the contents of multiple arrays onto the first array given. For example:
|
Appends the contents of multiple arrays onto the first array given. For example:
|
||||||
|
@ -154,6 +235,12 @@ Appends the contents of multiple arrays onto the first array given. For example:
|
||||||
* `concat(['1','2','3'],'4',['5','6','7'])` returns ['1','2','3','4','5','6','7'].
|
* `concat(['1','2','3'],'4',['5','6','7'])` returns ['1','2','3','4','5','6','7'].
|
||||||
*Type*: rvalue.
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
#### `convert_base`
|
||||||
|
|
||||||
|
Converts a given integer or base 10 string representing an integer to a specified base, as a string. For example:
|
||||||
|
* `convert_base(5, 2)` results in: '101'
|
||||||
|
* `convert_base('254', '16')` results in: 'fe'
|
||||||
|
|
||||||
#### `count`
|
#### `count`
|
||||||
|
|
||||||
If called with only an array, it counts the number of elements that are **not** nil/undef. If called with a second argument, counts the number of elements in an array that matches the second argument. *Type*: rvalue.
|
If called with only an array, it counts the number of elements that are **not** nil/undef. If called with a second argument, counts the number of elements in an array that matches the second argument. *Type*: rvalue.
|
||||||
|
@ -176,12 +263,24 @@ Takes a resource reference and an optional hash of attributes. Returns 'true' if
|
||||||
|
|
||||||
#### `delete`
|
#### `delete`
|
||||||
|
|
||||||
Deletes all instances of a given element from an array, substring from a string, or key from a hash. For example, `delete(['a','b','c','b'], 'b')` returns ['a','c']; `delete('abracadabra', 'bra')` returns 'acada'. `delete({'a' => 1,'b' => 2,'c' => 3},['b','c'])` returns {'a'=> 1}. *Type*: rvalue.
|
Deletes all instances of a given element from an array, substring from a string, or key from a hash.
|
||||||
|
|
||||||
|
For example, `delete(['a','b','c','b'], 'b')` returns ['a','c']; `delete('abracadabra', 'bra')` returns 'acada'. `delete({'a' => 1,'b' => 2,'c' => 3},['b','c'])` returns {'a'=> 1}, `delete(['ab', 'b'], 'b')` returns ['ab'].
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `delete_at`
|
#### `delete_at`
|
||||||
|
|
||||||
Deletes a determined indexed value from an array. For example, `delete_at(['a','b','c'], 1)` returns ['a','c']. *Type*: rvalue.
|
Deletes a determined indexed value from an array. For example, `delete_at(['a','b','c'], 1)` returns ['a','c']. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `delete_regex`
|
||||||
|
|
||||||
|
Deletes all instances of a given element from an array or hash that match a provided regular expression. A string will be treated as a one-item array.
|
||||||
|
|
||||||
|
For example, `delete_regex(['a','b','c','b'], 'b')` returns ['a','c']; `delete_regex({'a' => 1,'b' => 2,'c' => 3},['b','c'])` returns {'a'=> 1}, `delete_regex(['abf', 'ab', 'ac'], '^ab.*')` returns ['ac']. `delete_regex(['ab', 'b'], 'b')` returns ['ab'].
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `delete_values`
|
#### `delete_values`
|
||||||
|
|
||||||
Deletes all instances of a given value from a hash. For example, `delete_values({'a'=>'A','b'=>'B','c'=>'C','B'=>'D'}, 'B')` returns {'a'=>'A','c'=>'C','B'=>'D'} *Type*: rvalue.
|
Deletes all instances of a given value from a hash. For example, `delete_values({'a'=>'A','b'=>'B','c'=>'C','B'=>'D'}, 'B')` returns {'a'=>'A','c'=>'C','B'=>'D'} *Type*: rvalue.
|
||||||
|
@ -194,25 +293,124 @@ Deletes all instances of the undef value from an array or hash. For example, `$h
|
||||||
|
|
||||||
Returns the difference between two arrays. The returned array is a copy of the original array, removing any items that also appear in the second array. For example, `difference(["a","b","c"],["b","c","d"])` returns ["a"]. *Type*: rvalue.
|
Returns the difference between two arrays. The returned array is a copy of the original array, removing any items that also appear in the second array. For example, `difference(["a","b","c"],["b","c","d"])` returns ["a"]. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `dig`
|
||||||
|
|
||||||
|
DEPRECATED: This function has been replaced in Puppet 4.5.0, use dig44() for backwards compatibility or use the new version.
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
Retrieves a value within multiple layers of hashes and arrays via an array of keys containing a path. The function goes through the structure by each path component and tries to return the value at the end of the path.
|
||||||
|
|
||||||
|
In addition to the required path argument, the function accepts the default argument. It is returned if the path is not correct, if no value was found, or if any other error has occurred.
|
||||||
|
|
||||||
|
~~~ruby
|
||||||
|
$data = {
|
||||||
|
'a' => {
|
||||||
|
'b' => [
|
||||||
|
'b1',
|
||||||
|
'b2',
|
||||||
|
'b3',
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$value = dig($data, ['a', 'b', 2])
|
||||||
|
# $value = 'b3'
|
||||||
|
|
||||||
|
# with all possible options
|
||||||
|
$value = dig($data, ['a', 'b', 2], 'not_found')
|
||||||
|
# $value = 'b3'
|
||||||
|
|
||||||
|
# using the default value
|
||||||
|
$value = dig($data, ['a', 'b', 'c', 'd'], 'not_found')
|
||||||
|
# $value = 'not_found'
|
||||||
|
~~~
|
||||||
|
|
||||||
|
1. **$data** The data structure we are working with.
|
||||||
|
2. **['a', 'b', 2]** The path array.
|
||||||
|
3. **'not_found'** The default value. It will be returned if nothing is found.
|
||||||
|
(optional, defaults to *undef*)
|
||||||
|
|
||||||
|
#### `dig44`
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
Retrieves a value within multiple layers of hashes and arrays via an array of keys containing a path. The function goes through the structure by each path component and tries to return the value at the end of the path.
|
||||||
|
|
||||||
|
In addition to the required path argument, the function accepts the default argument. It is returned if the path is not correct, if no value was found, or if any other error has occurred.
|
||||||
|
|
||||||
|
~~~ruby
|
||||||
|
$data = {
|
||||||
|
'a' => {
|
||||||
|
'b' => [
|
||||||
|
'b1',
|
||||||
|
'b2',
|
||||||
|
'b3',
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$value = dig44($data, ['a', 'b', 2])
|
||||||
|
# $value = 'b3'
|
||||||
|
|
||||||
|
# with all possible options
|
||||||
|
$value = dig44($data, ['a', 'b', 2], 'not_found')
|
||||||
|
# $value = 'b3'
|
||||||
|
|
||||||
|
# using the default value
|
||||||
|
$value = dig44($data, ['a', 'b', 'c', 'd'], 'not_found')
|
||||||
|
# $value = 'not_found'
|
||||||
|
~~~
|
||||||
|
|
||||||
|
1. **$data** The data structure we are working with.
|
||||||
|
2. **['a', 'b', 2]** The path array.
|
||||||
|
3. **'not_found'** The default value. It will be returned if nothing is found.
|
||||||
|
(optional, defaults to *undef*)
|
||||||
|
|
||||||
#### `dirname`
|
#### `dirname`
|
||||||
|
|
||||||
Returns the `dirname` of a path. For example, `dirname('/path/to/a/file.ext')` returns '/path/to/a'. *Type*: rvalue.
|
Returns the `dirname` of a path. For example, `dirname('/path/to/a/file.ext')` returns '/path/to/a'. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `dos2unix`
|
||||||
|
|
||||||
|
Returns the Unix version of the given string. Very useful when using a File resource with a cross-platform template. *Type*: rvalue.
|
||||||
|
|
||||||
|
~~~
|
||||||
|
file{$config_file:
|
||||||
|
ensure => file,
|
||||||
|
content => dos2unix(template('my_module/settings.conf.erb')),
|
||||||
|
}
|
||||||
|
~~~
|
||||||
|
|
||||||
|
See also [unix2dos](#unix2dos).
|
||||||
|
|
||||||
#### `downcase`
|
#### `downcase`
|
||||||
|
|
||||||
Converts the case of a string or of all strings in an array to lowercase. *Type*: rvalue.
|
Converts the case of a string or of all strings in an array to lowercase. *Type*: rvalue.
|
||||||
|
|
||||||
#### `empty`
|
#### `empty`
|
||||||
|
|
||||||
Returns 'true' if the variable is empty. *Type*: rvalue.
|
Returns true if the argument is an array or hash that contains no elements, or an empty string. Returns false when the argument is a numerical value. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `enclose_ipv6`
|
||||||
|
|
||||||
|
Takes an array of ip addresses and encloses the ipv6 addresses with square brackets. *Type*: rvalue.
|
||||||
|
|
||||||
#### `ensure_packages`
|
#### `ensure_packages`
|
||||||
|
|
||||||
Takes a list of packages and only installs them if they don't already exist. It optionally takes a hash as a second parameter to be passed as the third argument to the `ensure_resource()` function. *Type*: statement.
|
Takes a list of packages array/hash and only installs them if they don't already exist. It optionally takes a hash as a second parameter to be passed as the third argument to the `ensure_resource()` or `ensure_resources()` function. *Type*: statement.
|
||||||
|
|
||||||
|
For Array:
|
||||||
|
|
||||||
|
ensure_packages(['ksh','openssl'], {'ensure' => 'present'})
|
||||||
|
|
||||||
|
For Hash:
|
||||||
|
|
||||||
|
ensure_packages({'ksh' => { ensure => '20120801-1' } , 'mypackage' => { source => '/tmp/myrpm-1.0.0.x86_64.rpm', provider => "rpm" }}, {'ensure' => 'present'})
|
||||||
|
|
||||||
#### `ensure_resource`
|
#### `ensure_resource`
|
||||||
|
|
||||||
Takes a resource type, title, and a list of attributes that describe a resource.
|
Takes a resource type, title, and a hash of attributes that describe the resource(s).
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
user { 'dan':
|
user { 'dan':
|
||||||
|
@ -232,7 +430,37 @@ An array of resources can also be passed in, and each will be created with the t
|
||||||
|
|
||||||
*Type*: statement.
|
*Type*: statement.
|
||||||
|
|
||||||
#### `flatten`
|
#### `ensure_resources`
|
||||||
|
|
||||||
|
Takes a resource type, title (only hash), and a hash of attributes that describe the resource(s).
|
||||||
|
|
||||||
|
~~~
|
||||||
|
user { 'dan':
|
||||||
|
gid => 'mygroup',
|
||||||
|
ensure => present,
|
||||||
|
}
|
||||||
|
|
||||||
|
ensure_resources($user)
|
||||||
|
~~~
|
||||||
|
|
||||||
|
An hash of resources should be passed in and each will be created with the type and parameters specified if it doesn't already exist:
|
||||||
|
|
||||||
|
ensure_resources('user', {'dan' => { gid => 'mygroup', uid => '600' } , 'alex' => { gid => 'mygroup' }}, {'ensure' => 'present'})
|
||||||
|
|
||||||
|
From Hiera Backend:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
userlist:
|
||||||
|
dan:
|
||||||
|
gid: 'mygroup'
|
||||||
|
uid: '600'
|
||||||
|
alex:
|
||||||
|
gid: 'mygroup'
|
||||||
|
|
||||||
|
ensure_resources('user', hiera_hash('userlist'), {'ensure' => 'present'})
|
||||||
|
~~~
|
||||||
|
|
||||||
|
### `flatten`
|
||||||
|
|
||||||
Flattens deeply nested arrays and returns a single flat array as a result. For example, `flatten(['a', ['b', ['c']]])` returns ['a','b','c']. *Type*: rvalue.
|
Flattens deeply nested arrays and returns a single flat array as a result. For example, `flatten(['a', ['b', ['c']]])` returns ['a','b','c']. *Type*: rvalue.
|
||||||
|
|
||||||
|
@ -262,10 +490,13 @@ fqdn_rand_string(10, '', 'custom seed')
|
||||||
Rotates an array or string a random number of times, combining the `$fqdn` fact and an optional seed for repeatable randomness.
|
Rotates an array or string a random number of times, combining the `$fqdn` fact and an optional seed for repeatable randomness.
|
||||||
|
|
||||||
*Usage:*
|
*Usage:*
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
fqdn_rotate(VALUE, [SEED])
|
fqdn_rotate(VALUE, [SEED])
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
*Examples:*
|
*Examples:*
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
fqdn_rotate(['a', 'b', 'c', 'd'])
|
fqdn_rotate(['a', 'b', 'c', 'd'])
|
||||||
fqdn_rotate('abcd')
|
fqdn_rotate('abcd')
|
||||||
|
@ -383,6 +614,33 @@ Converts an array into a hash. For example, `hash(['a',1,'b',2,'c',3])` returns
|
||||||
|
|
||||||
Returns an array an intersection of two. For example, `intersection(["a","b","c"],["b","c","d"])` returns ["b","c"]. *Type*: rvalue.
|
Returns an array an intersection of two. For example, `intersection(["a","b","c"],["b","c","d"])` returns ["b","c"]. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `is_a`
|
||||||
|
|
||||||
|
Boolean check to determine whether a variable is of a given data type. This is equivalent to the `=~` type checks. This function is available only in Puppet 4 or in Puppet 3 with the "future" parser.
|
||||||
|
|
||||||
|
~~~
|
||||||
|
foo = 3
|
||||||
|
$bar = [1,2,3]
|
||||||
|
$baz = 'A string!'
|
||||||
|
|
||||||
|
if $foo.is_a(Integer) {
|
||||||
|
notify { 'foo!': }
|
||||||
|
}
|
||||||
|
if $bar.is_a(Array) {
|
||||||
|
notify { 'bar!': }
|
||||||
|
}
|
||||||
|
if $baz.is_a(String) {
|
||||||
|
notify { 'baz!': }
|
||||||
|
}
|
||||||
|
~~~
|
||||||
|
|
||||||
|
See the [the Puppet type system](https://docs.puppetlabs.com/references/latest/type.html#about-resource-types) for more information about types.
|
||||||
|
See the [`assert_type()`](https://docs.puppetlabs.com/references/latest/function.html#asserttype) function for flexible ways to assert the type of a value.
|
||||||
|
|
||||||
|
#### `is_absolute_path`
|
||||||
|
|
||||||
|
Returns 'true' if the given path is absolute. *Type*: rvalue.
|
||||||
|
|
||||||
#### `is_array`
|
#### `is_array`
|
||||||
|
|
||||||
Returns 'true' if the variable passed to this function is an array. *Type*: rvalue.
|
Returns 'true' if the variable passed to this function is an array. *Type*: rvalue.
|
||||||
|
@ -415,6 +673,14 @@ Returns 'true' if the variable returned to this string is an integer. *Type*: rv
|
||||||
|
|
||||||
Returns 'true' if the string passed to this function is a valid IP address. *Type*: rvalue.
|
Returns 'true' if the string passed to this function is a valid IP address. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `is_ipv6_address`
|
||||||
|
|
||||||
|
Returns 'true' if the string passed to this function is a valid IPv6 address. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `is_ipv4_address`
|
||||||
|
|
||||||
|
Returns 'true' if the string passed to this function is a valid IPv4 address. *Type*: rvalue.
|
||||||
|
|
||||||
#### `is_mac_address`
|
#### `is_mac_address`
|
||||||
|
|
||||||
Returns 'true' if the string passed to this function is a valid MAC address. *Type*: rvalue.
|
Returns 'true' if the string passed to this function is a valid MAC address. *Type*: rvalue.
|
||||||
|
@ -441,12 +707,62 @@ Returns the keys of a hash as an array. *Type*: rvalue.
|
||||||
|
|
||||||
#### `loadyaml`
|
#### `loadyaml`
|
||||||
|
|
||||||
Loads a YAML file containing an array, string, or hash, and returns the data in the corresponding native data type. For example:
|
Loads a YAML file containing an array, string, or hash, and returns the data in the corresponding native data type.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
$myhash = loadyaml('/etc/puppet/data/myhash.yaml')
|
$myhash = loadyaml('/etc/puppet/data/myhash.yaml')
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
|
The second parameter will be returned if the file was not found or could not be parsed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
$myhash = loadyaml('no-file.yaml', {'default'=>'value'})
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
#### `loadjson`
|
||||||
|
|
||||||
|
Loads a JSON file containing an array, string, or hash, and returns the data in the corresponding native data type.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
$myhash = loadjson('/etc/puppet/data/myhash.json')
|
||||||
|
~~~
|
||||||
|
|
||||||
|
The second parameter will be returned if the file was not found or could not be parsed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
$myhash = loadjson('no-file.json', {'default'=>'value'})
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
#### `load_module_metadata`
|
||||||
|
|
||||||
|
Loads the metadata.json of a target module. Can be used to determine module version and authorship for dynamic support of modules.
|
||||||
|
|
||||||
|
~~~
|
||||||
|
$metadata = load_module_metadata('archive')
|
||||||
|
notify { $metadata['author']: }
|
||||||
|
~~~
|
||||||
|
|
||||||
|
If you do not want to fail the catalog compilation when a module's metadata file is absent:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
$metadata = load_module_metadata('mysql', true)
|
||||||
|
if empty($metadata) {
|
||||||
|
notify { "This module does not have a metadata.json file.": }
|
||||||
|
}
|
||||||
|
~~~
|
||||||
|
|
||||||
*Type*: rvalue.
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `lstrip`
|
#### `lstrip`
|
||||||
|
@ -459,7 +775,7 @@ Returns the highest value of all arguments. Requires at least one argument. *Typ
|
||||||
|
|
||||||
#### `member`
|
#### `member`
|
||||||
|
|
||||||
This function determines if a variable is a member of an array. The variable can be either a string, array, or fixnum. For example, `member(['a','b'], 'b')` and `member(['a','b','c'], ['b','c'])` return 'true', while `member(['a','b'], 'c')` and `member(['a','b','c'], ['c','d'])` return 'false'. *Note*: This function does not support nested arrays. If the first argument contains nested arrays, it will not recurse through them.
|
This function determines if a variable is a member of an array. The variable can be either a string, array, or fixnum. For example, `member(['a','b'], 'b')` and `member(['a','b','c'], ['b','c'])` return 'true', while `member(['a','b'], 'c')` and `member(['a','b','c'], ['c','d'])` return 'false'. *Note*: This function does not support nested arrays. If the first argument contains nested arrays, it will not recurse through them.
|
||||||
|
|
||||||
*Type*: rvalue.
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
@ -489,11 +805,11 @@ Converts a number or a string representation of a number into a true boolean. Ze
|
||||||
|
|
||||||
#### `parsejson`
|
#### `parsejson`
|
||||||
|
|
||||||
Converts a string of JSON into the correct Puppet structure. *Type*: rvalue.
|
Converts a string of JSON into the correct Puppet structure. *Type*: rvalue. The optional second argument is returned if the data was not correct.
|
||||||
|
|
||||||
#### `parseyaml`
|
#### `parseyaml`
|
||||||
|
|
||||||
Converts a string of YAML into the correct Puppet structure. *Type*: rvalue.
|
Converts a string of YAML into the correct Puppet structure. *Type*: rvalue. The optional second argument is returned if the data was not correct.
|
||||||
|
|
||||||
#### `pick`
|
#### `pick`
|
||||||
|
|
||||||
|
@ -505,12 +821,16 @@ From a list of values, returns the first value that is not undefined or an empty
|
||||||
|
|
||||||
*Type*: rvalue.
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
#### `pick_default`
|
||||||
|
|
||||||
|
Returns the first value in a list of values. Contrary to the `pick()` function, the `pick_default()` does not fail if all arguments are empty. This allows it to use an empty value as default. *Type*: rvalue.
|
||||||
|
|
||||||
#### `prefix`
|
#### `prefix`
|
||||||
|
|
||||||
Applies a prefix to all elements in an array, or to the keys in a hash.
|
Applies a prefix to all elements in an array, or to the keys in a hash.
|
||||||
For example:
|
For example:
|
||||||
* `prefix(['a','b','c'], 'p')` returns ['pa','pb','pc']
|
* `prefix(['a','b','c'], 'p')` returns ['pa','pb','pc']
|
||||||
* `prefix({'a'=>'b','b'=>'c','c'=>'d'}, 'p')` returns {'pa'=>'b','pb'=>'c','pc'=>'d'}.
|
* `prefix({'a'=>'b','b'=>'c','c'=>'d'}, 'p')` returns {'pa'=>'b','pb'=>'c','pc'=>'d'}.
|
||||||
|
|
||||||
*Type*: rvalue.
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
@ -548,6 +868,8 @@ The second argument to this function is which type of hash to use. It will be co
|
||||||
|
|
||||||
The third argument to this function is the salt to use.
|
The third argument to this function is the salt to use.
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
**Note:** this uses the Puppet master's implementation of crypt(3). If your environment contains several different operating systems, ensure that they are compatible before using this function.
|
**Note:** this uses the Puppet master's implementation of crypt(3). If your environment contains several different operating systems, ensure that they are compatible before using this function.
|
||||||
|
|
||||||
#### `range`
|
#### `range`
|
||||||
|
@ -572,13 +894,51 @@ Reverses the order of a string or array. *Type*: rvalue.
|
||||||
|
|
||||||
Strips spaces to the right of the string. *Type*: rvalue.
|
Strips spaces to the right of the string. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `seeded_rand`
|
||||||
|
|
||||||
|
Takes an integer max value and a string seed value and returns a repeatable random integer smaller than max. Like `fqdn_rand`, but does not add node specific data to the seed. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `shell_escape`
|
||||||
|
|
||||||
|
Escapes a string so that it can be safely used in a Bourne shell command line. Note that the resulting string should be used unquoted and is not intended for use in double quotes nor in single quotes. This function behaves the same as ruby's `Shellwords.shellescape()` function, also see the [ruby documentation](http://ruby-doc.org/stdlib-2.3.0/libdoc/shellwords/rdoc/Shellwords.html#method-c-shellescape).
|
||||||
|
|
||||||
|
*Example:*
|
||||||
|
~~~
|
||||||
|
shell_escape('foo b"ar') => 'foo\ b\"ar'
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
#### `shell_join`
|
||||||
|
|
||||||
|
Builds a command line string from the given array of strings. Each array item is escaped for Bourne shell. All items are
|
||||||
|
then joined together, with a single space in between. This function behaves the same as ruby's `Shellwords.shelljoin()` function, also see the [ruby documentation](http://ruby-doc.org/stdlib-2.3.0/libdoc/shellwords/rdoc/Shellwords.html#method-c-shelljoin).
|
||||||
|
|
||||||
|
*Example:*
|
||||||
|
~~~
|
||||||
|
shell_join(['foo bar', 'ba"z']) => 'foo\ bar ba\"z'
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
#### `shell_split`
|
||||||
|
|
||||||
|
Splits a string into an array of tokens in the same way the Bourne shell does. This function behaves the same as ruby's `Shellwords.shellsplit()` function, also see the [ruby documentation](http://ruby-doc.org/stdlib-2.3.0/libdoc/shellwords/rdoc/Shellwords.html#method-c-shellsplit).
|
||||||
|
|
||||||
|
*Example:*
|
||||||
|
~~~
|
||||||
|
shell_split('foo\ bar ba\"z') => ['foo bar', 'ba"z']
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `shuffle`
|
#### `shuffle`
|
||||||
|
|
||||||
Randomizes the order of a string or array elements. *Type*: rvalue.
|
Randomizes the order of a string or array elements. *Type*: rvalue.
|
||||||
|
|
||||||
#### `size`
|
#### `size`
|
||||||
|
|
||||||
Returns the number of elements in a string or an array. *Type*: rvalue.
|
Returns the number of elements in a string, an array or a hash. *Type*: rvalue.
|
||||||
|
|
||||||
#### `sort`
|
#### `sort`
|
||||||
|
|
||||||
|
@ -590,7 +950,7 @@ Returns a new string where runs of the same character that occur in this set are
|
||||||
|
|
||||||
#### `str2bool`
|
#### `str2bool`
|
||||||
|
|
||||||
Converts a string to a boolean. This attempts to convert strings that contain values such as '1', 't', 'y', and 'yes' to 'true' and strings that contain values such as '0', 'f', 'n', and 'no' to 'false'. *Type*: rvalue.
|
Converts certain strings to a boolean. This attempts to convert strings that contain the values '1', 't', 'y', or 'yes' to true. Strings that contain values '0', 'f', 'n', or 'no', or that are an empty string or undefined are converted to false. Any other value causes an error. *Type*: rvalue.
|
||||||
|
|
||||||
#### `str2saltedsha512`
|
#### `str2saltedsha512`
|
||||||
|
|
||||||
|
@ -655,7 +1015,12 @@ Removes leading and trailing whitespace from a string or from every string insid
|
||||||
|
|
||||||
#### `suffix`
|
#### `suffix`
|
||||||
|
|
||||||
Applies a suffix to all elements in an array. For example, `suffix(['a','b','c'], 'p')` returns ['ap','bp','cp']. *Type*: rvalue.
|
Applies a suffix to all elements in an array, or to the keys in a hash.
|
||||||
|
For example:
|
||||||
|
* `suffix(['a','b','c'], 'p')` returns ['ap','bp','cp']
|
||||||
|
* `suffix({'a'=>'b','b'=>'c','c'=>'d'}, 'p')` returns {'ap'=>'b','bp'=>'c','cp'=>'d'}.
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
#### `swapcase`
|
#### `swapcase`
|
||||||
|
|
||||||
|
@ -669,6 +1034,50 @@ Returns the current Unix epoch time as an integer. For example, `time()` returns
|
||||||
|
|
||||||
Converts the argument into bytes, for example "4 kB" becomes "4096". Takes a single string value as an argument. *Type*: rvalue.
|
Converts the argument into bytes, for example "4 kB" becomes "4096". Takes a single string value as an argument. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `try_get_value`
|
||||||
|
|
||||||
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
DEPRECATED: replaced by `dig()`.
|
||||||
|
|
||||||
|
Retrieves a value within multiple layers of hashes and arrays via a string containing a path. The path is a string of hash keys or array indexes starting with zero, separated by the path separator character (default "/"). The function goes through the structure by each path component and tries to return the value at the end of the path.
|
||||||
|
|
||||||
|
In addition to the required path argument, the function accepts the default argument. It is returned if the path is not correct, if no value was found, or if any other error has occurred. The last argument can set the path separator character.
|
||||||
|
|
||||||
|
~~~ruby
|
||||||
|
$data = {
|
||||||
|
'a' => {
|
||||||
|
'b' => [
|
||||||
|
'b1',
|
||||||
|
'b2',
|
||||||
|
'b3',
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$value = try_get_value($data, 'a/b/2')
|
||||||
|
# $value = 'b3'
|
||||||
|
|
||||||
|
# with all possible options
|
||||||
|
$value = try_get_value($data, 'a/b/2', 'not_found', '/')
|
||||||
|
# $value = 'b3'
|
||||||
|
|
||||||
|
# using the default value
|
||||||
|
$value = try_get_value($data, 'a/b/c/d', 'not_found')
|
||||||
|
# $value = 'not_found'
|
||||||
|
|
||||||
|
# using custom separator
|
||||||
|
$value = try_get_value($data, 'a|b', [], '|')
|
||||||
|
# $value = ['b1','b2','b3']
|
||||||
|
~~~
|
||||||
|
|
||||||
|
1. **$data** The data structure we are working with.
|
||||||
|
2. **'a/b/2'** The path string.
|
||||||
|
3. **'not_found'** The default value. It will be returned if nothing is found.
|
||||||
|
(optional, defaults to *undef*)
|
||||||
|
4. **'/'** The path separator character.
|
||||||
|
(optional, defaults to *'/'*)
|
||||||
|
|
||||||
#### `type3x`
|
#### `type3x`
|
||||||
|
|
||||||
Returns a string description of the type when passed a value. Type can be a string, array, hash, float, integer, or boolean. This function will be removed when Puppet 3 support is dropped and the new type system can be used. *Type*: rvalue.
|
Returns a string description of the type when passed a value. Type can be a string, array, hash, float, integer, or boolean. This function will be removed when Puppet 3 support is dropped and the new type system can be used. *Type*: rvalue.
|
||||||
|
@ -679,12 +1088,25 @@ Returns the literal type when passed a value. Requires the new parser. Useful fo
|
||||||
|
|
||||||
#### `union`
|
#### `union`
|
||||||
|
|
||||||
Returns a union of two arrays, without duplicates. For example, `union(["a","b","c"],["b","c","d"])` returns ["a","b","c","d"].
|
Returns a union of two or more arrays, without duplicates. For example, `union(["a","b","c"],["b","c","d"])` returns ["a","b","c","d"]. *Type*: rvalue.
|
||||||
|
|
||||||
#### `unique`
|
#### `unique`
|
||||||
|
|
||||||
Removes duplicates from strings and arrays. For example, `unique("aabbcc")` returns 'abc', and `unique(["a","a","b","b","c","c"])` returns ["a","b","c"]. *Type*: rvalue.
|
Removes duplicates from strings and arrays. For example, `unique("aabbcc")` returns 'abc', and `unique(["a","a","b","b","c","c"])` returns ["a","b","c"]. *Type*: rvalue.
|
||||||
|
|
||||||
|
#### `unix2dos`
|
||||||
|
|
||||||
|
Returns the DOS version of the given string. Very useful when using a File resource with a cross-platform template. *Type*: rvalue.
|
||||||
|
|
||||||
|
~~~
|
||||||
|
file{$config_file:
|
||||||
|
ensure => file,
|
||||||
|
content => unix2dos(template('my_module/settings.conf.erb')),
|
||||||
|
}
|
||||||
|
~~~
|
||||||
|
|
||||||
|
See also [dos2unix](#dos2unix).
|
||||||
|
|
||||||
#### `upcase`
|
#### `upcase`
|
||||||
|
|
||||||
Converts an object, array or hash of objects that respond to upcase to uppercase. For example, `upcase('abcd')` returns 'ABCD'. *Type*: rvalue.
|
Converts an object, array or hash of objects that respond to upcase to uppercase. For example, `upcase('abcd')` returns 'ABCD'. *Type*: rvalue.
|
||||||
|
@ -888,10 +1310,42 @@ Validates that the first argument is an integer (or an array of integers). Abort
|
||||||
|
|
||||||
* Plus all of the above, but any combination of values passed as strings ('false' or "false").
|
* Plus all of the above, but any combination of values passed as strings ('false' or "false").
|
||||||
* Plus all of the above, but with incorrect combinations of negative integer values.
|
* Plus all of the above, but with incorrect combinations of negative integer values.
|
||||||
* Plus all of the above, but with non-integer crap in arrays or maximum / minimum argument.
|
* Plus all of the above, but with non-integer items in arrays or maximum / minimum argument.
|
||||||
|
|
||||||
*Type*: statement.
|
*Type*: statement.
|
||||||
|
|
||||||
|
#### `validate_ip_address`
|
||||||
|
|
||||||
|
Validates that the argument is an IP address, regardless of it is an IPv4 or an IPv6
|
||||||
|
address. It also validates IP address with netmask. The argument must be given as a string.
|
||||||
|
|
||||||
|
The following values will pass:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
validate_ip_address('0.0.0.0')
|
||||||
|
validate_ip_address('8.8.8.8')
|
||||||
|
validate_ip_address('127.0.0.1')
|
||||||
|
validate_ip_address('194.232.104.150')
|
||||||
|
validate_ip_address('3ffe:0505:0002::')
|
||||||
|
validate_ip_address('::1/64')
|
||||||
|
validate_ip_address('fe80::a00:27ff:fe94:44d6/64')
|
||||||
|
validate_ip_address('8.8.8.8/32')
|
||||||
|
~~~
|
||||||
|
|
||||||
|
The following values will fail, causing compilation to abort:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
validate_ip_address(1)
|
||||||
|
validate_ip_address(true)
|
||||||
|
validate_ip_address(0.0.0.256)
|
||||||
|
validate_ip_address('::1', {})
|
||||||
|
validate_ip_address('0.0.0.0.0')
|
||||||
|
validate_ip_address('3.3.3')
|
||||||
|
validate_ip_address('23.43.9.22/64')
|
||||||
|
validate_ip_address('260.2.32.43')
|
||||||
|
~~~
|
||||||
|
|
||||||
|
|
||||||
#### `validate_numeric`
|
#### `validate_numeric`
|
||||||
|
|
||||||
Validates that the first argument is a numeric value (or an array of numeric values). Aborts catalog compilation if any of the checks fail.
|
Validates that the first argument is a numeric value (or an array of numeric values). Aborts catalog compilation if any of the checks fail.
|
||||||
|
@ -934,17 +1388,24 @@ test, and the second argument should be a stringified regular expression (withou
|
||||||
validate_re($::puppetversion, '^2.7', 'The $puppetversion fact value does not match 2.7')
|
validate_re($::puppetversion, '^2.7', 'The $puppetversion fact value does not match 2.7')
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
|
Note: Compilation terminates if the first argument is not a string. Always use quotes to force stringification:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
validate_re("${::operatingsystemmajrelease}", '^[57]$')
|
||||||
|
~~~
|
||||||
|
|
||||||
*Type*: statement.
|
*Type*: statement.
|
||||||
|
|
||||||
#### `validate_slength`
|
#### `validate_slength`
|
||||||
|
|
||||||
Validates that the first argument is a string (or an array of strings), and is less than or equal to the length of the second argument. It fails if the first argument is not a string or array of strings, or if arg 2 is not convertable to a number.
|
Validates that the first argument is a string (or an array of strings), and is less than or equal to the length of the second argument. It fails if the first argument is not a string or array of strings, or if the second argument is not convertable to a number. Optionally, a minimum string length can be given as the third argument.
|
||||||
|
|
||||||
The following values pass:
|
The following values pass:
|
||||||
|
|
||||||
~~~
|
~~~
|
||||||
validate_slength("discombobulate",17)
|
validate_slength("discombobulate",17)
|
||||||
validate_slength(["discombobulate","moo"],17)
|
validate_slength(["discombobulate","moo"],17)
|
||||||
|
validate_slength(["discombobulate","moo"],17,3)
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
The following values fail:
|
The following values fail:
|
||||||
|
@ -952,6 +1413,7 @@ Validates that the first argument is a string (or an array of strings), and is l
|
||||||
~~~
|
~~~
|
||||||
validate_slength("discombobulate",1)
|
validate_slength("discombobulate",1)
|
||||||
validate_slength(["discombobulate","thermometer"],5)
|
validate_slength(["discombobulate","thermometer"],5)
|
||||||
|
validate_slength(["discombobulate","moo"],17,10)
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
*Type*: statement.
|
*Type*: statement.
|
||||||
|
@ -986,9 +1448,25 @@ Instead, use:
|
||||||
|
|
||||||
*Type*: statement.
|
*Type*: statement.
|
||||||
|
|
||||||
|
#### `validate_x509_rsa_key_pair`
|
||||||
|
|
||||||
|
Validates a PEM-formatted X.509 certificate and private key using OpenSSL.
|
||||||
|
Verifies that the certficate's signature was created from the supplied key.
|
||||||
|
|
||||||
|
Fails catalog compilation if any value fails this check.
|
||||||
|
|
||||||
|
Takes two arguments, the first argument must be a X.509 certificate and the
|
||||||
|
second must be an RSA private key:
|
||||||
|
|
||||||
|
~~~
|
||||||
|
validate_x509_rsa_key_pair($cert, $key)
|
||||||
|
~~~
|
||||||
|
|
||||||
|
*Type*: statement.
|
||||||
|
|
||||||
#### `values`
|
#### `values`
|
||||||
|
|
||||||
Returns the values of a given hash. For example, given `$hash = {'a'=1, 'b'=2, 'c'=3} values($hash)` returns [1,2,3].
|
Returns the values of a given hash. For example, given `$hash = {'a'=1, 'b'=2, 'c'=3} values($hash)` returns [1,2,3].
|
||||||
|
|
||||||
*Type*: rvalue.
|
*Type*: rvalue.
|
||||||
|
|
||||||
|
@ -1008,7 +1486,7 @@ Finds values inside an array based on location. The first argument is the array
|
||||||
|
|
||||||
Takes one element from first array given and merges corresponding elements from second array given. This generates a sequence of n-element arrays, where *n* is one more than the count of arguments. For example, `zip(['1','2','3'],['4','5','6'])` results in ["1", "4"], ["2", "5"], ["3", "6"]. *Type*: rvalue.
|
Takes one element from first array given and merges corresponding elements from second array given. This generates a sequence of n-element arrays, where *n* is one more than the count of arguments. For example, `zip(['1','2','3'],['4','5','6'])` results in ["1", "4"], ["2", "5"], ["3", "6"]. *Type*: rvalue.
|
||||||
|
|
||||||
##Limitations
|
## Limitations
|
||||||
|
|
||||||
As of Puppet Enterprise 3.7, the stdlib module is no longer included in PE. PE users should install the most recent release of stdlib for compatibility with Puppet modules.
|
As of Puppet Enterprise 3.7, the stdlib module is no longer included in PE. PE users should install the most recent release of stdlib for compatibility with Puppet modules.
|
||||||
|
|
||||||
|
@ -1019,21 +1497,18 @@ Versions | Puppet 2.6 | Puppet 2.7 | Puppet 3.x | Puppet 4.x |
|
||||||
**stdlib 2.x** | **yes** | **yes** | no | no
|
**stdlib 2.x** | **yes** | **yes** | no | no
|
||||||
**stdlib 3.x** | no | **yes** | **yes** | no
|
**stdlib 3.x** | no | **yes** | **yes** | no
|
||||||
**stdlib 4.x** | no | **yes** | **yes** | no
|
**stdlib 4.x** | no | **yes** | **yes** | no
|
||||||
|
**stdlib 4.6+** | no | **yes** | **yes** | **yes**
|
||||||
**stdlib 5.x** | no | no | **yes** | **yes**
|
**stdlib 5.x** | no | no | **yes** | **yes**
|
||||||
|
|
||||||
**stdlib 5.x**: When released, stdlib 5.x will drop support for Puppet 2.7.x. Please see [this discussion](https://github.com/puppetlabs/puppetlabs-stdlib/pull/176#issuecomment-30251414).
|
**stdlib 5.x**: When released, stdlib 5.x will drop support for Puppet 2.7.x. Please see [this discussion](https://github.com/puppetlabs/puppetlabs-stdlib/pull/176#issuecomment-30251414).
|
||||||
|
|
||||||
##Development
|
## Development
|
||||||
|
|
||||||
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 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. For more information, see our [module contribution guide.](https://docs.puppetlabs.com/forge/contributing.html)
|
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 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. For more information, see our [module contribution guide](https://docs.puppetlabs.com/forge/contributing.html).
|
||||||
|
|
||||||
To report or research a bug with any part of this module, please go to
|
To report or research a bug with any part of this module, please go to
|
||||||
[http://tickets.puppetlabs.com/browse/PUP](http://tickets.puppetlabs.com/browse/PUP).
|
[http://tickets.puppetlabs.com/browse/PUP](http://tickets.puppetlabs.com/browse/PUP).
|
||||||
|
|
||||||
##Contributors
|
## Contributors
|
||||||
|
|
||||||
The list of contributors can be found at: https://github.com/puppetlabs/puppetlabs-stdlib/graphs/contributors
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
The list of contributors can be found at: [https://github.com/puppetlabs/puppetlabs-stdlib/graphs/contributors](https://github.com/puppetlabs/puppetlabs-stdlib/graphs/contributors).
|
||||||
|
|
45
Rakefile
45
Rakefile
|
@ -1,7 +1,42 @@
|
||||||
require 'rubygems'
|
require 'puppet_blacksmith/rake_tasks'
|
||||||
# keep for compatibility for now
|
|
||||||
require 'puppetlabs_spec_helper/rake_tasks'
|
|
||||||
require 'puppet-lint/tasks/puppet-lint'
|
require 'puppet-lint/tasks/puppet-lint'
|
||||||
PuppetLint.configuration.send('disable_80chars')
|
require 'puppetlabs_spec_helper/rake_tasks'
|
||||||
PuppetLint.configuration.ignore_paths = ["spec/**/*.pp", "pkg/**/*.pp"]
|
|
||||||
|
|
||||||
|
PuppetLint.configuration.fail_on_warnings = true
|
||||||
|
PuppetLint.configuration.send('relative')
|
||||||
|
PuppetLint.configuration.send('disable_140chars')
|
||||||
|
PuppetLint.configuration.send('disable_class_inherits_from_params_class')
|
||||||
|
PuppetLint.configuration.send('disable_documentation')
|
||||||
|
PuppetLint.configuration.send('disable_single_quote_string_with_variables')
|
||||||
|
PuppetLint.configuration.ignore_paths = ["spec/**/*.pp", "pkg/**/*.pp", "bundle/**/*", "vendor/**/*"]
|
||||||
|
|
||||||
|
desc 'Generate pooler nodesets'
|
||||||
|
task :gen_nodeset do
|
||||||
|
require 'beaker-hostgenerator'
|
||||||
|
require 'securerandom'
|
||||||
|
require 'fileutils'
|
||||||
|
|
||||||
|
agent_target = ENV['TEST_TARGET']
|
||||||
|
if ! agent_target
|
||||||
|
STDERR.puts 'TEST_TARGET environment variable is not set'
|
||||||
|
STDERR.puts 'setting to default value of "redhat-64default."'
|
||||||
|
agent_target = 'redhat-64default.'
|
||||||
|
end
|
||||||
|
|
||||||
|
master_target = ENV['MASTER_TEST_TARGET']
|
||||||
|
if ! master_target
|
||||||
|
STDERR.puts 'MASTER_TEST_TARGET environment variable is not set'
|
||||||
|
STDERR.puts 'setting to default value of "redhat7-64mdcl"'
|
||||||
|
master_target = 'redhat7-64mdcl'
|
||||||
|
end
|
||||||
|
|
||||||
|
targets = "#{master_target}-#{agent_target}"
|
||||||
|
cli = BeakerHostGenerator::CLI.new([targets])
|
||||||
|
nodeset_dir = "tmp/nodesets"
|
||||||
|
nodeset = "#{nodeset_dir}/#{targets}-#{SecureRandom.uuid}.yaml"
|
||||||
|
FileUtils.mkdir_p(nodeset_dir)
|
||||||
|
File.open(nodeset, 'w') do |fh|
|
||||||
|
fh.print(cli.execute)
|
||||||
|
end
|
||||||
|
puts nodeset
|
||||||
|
end
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# This is a simple smoke test
|
# This is a simple smoke test
|
||||||
# of the file_line resource type.
|
# of the file_line resource type.
|
||||||
file { '/tmp/dansfile':
|
file { '/tmp/dansfile':
|
||||||
ensure => present
|
ensure => file,
|
||||||
}->
|
} ->
|
||||||
file_line { 'dans_line':
|
file_line { 'dans_line':
|
||||||
line => 'dan is awesome',
|
line => 'dan is awesome',
|
||||||
path => '/tmp/dansfile',
|
path => '/tmp/dansfile',
|
|
@ -1,4 +1,4 @@
|
||||||
include stdlib
|
include ::stdlib
|
||||||
info('has_interface_with(\'lo\'):', has_interface_with('lo'))
|
info('has_interface_with(\'lo\'):', has_interface_with('lo'))
|
||||||
info('has_interface_with(\'loX\'):', has_interface_with('loX'))
|
info('has_interface_with(\'loX\'):', has_interface_with('loX'))
|
||||||
info('has_interface_with(\'ipaddress\', \'127.0.0.1\'):', has_interface_with('ipaddress', '127.0.0.1'))
|
info('has_interface_with(\'ipaddress\', \'127.0.0.1\'):', has_interface_with('ipaddress', '127.0.0.1'))
|
||||||
|
@ -7,4 +7,3 @@ info('has_interface_with(\'network\', \'127.0.0.0\'):', has_interface_with('netw
|
||||||
info('has_interface_with(\'network\', \'128.0.0.0\'):', has_interface_with('network', '128.0.0.0'))
|
info('has_interface_with(\'network\', \'128.0.0.0\'):', has_interface_with('network', '128.0.0.0'))
|
||||||
info('has_interface_with(\'netmask\', \'255.0.0.0\'):', has_interface_with('netmask', '255.0.0.0'))
|
info('has_interface_with(\'netmask\', \'255.0.0.0\'):', has_interface_with('netmask', '255.0.0.0'))
|
||||||
info('has_interface_with(\'netmask\', \'256.0.0.0\'):', has_interface_with('netmask', '256.0.0.0'))
|
info('has_interface_with(\'netmask\', \'256.0.0.0\'):', has_interface_with('netmask', '256.0.0.0'))
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
include stdlib
|
include ::stdlib
|
||||||
info('has_ip_address(\'192.168.1.256\'):', has_ip_address('192.168.1.256'))
|
info('has_ip_address(\'192.168.1.256\'):', has_ip_address('192.168.1.256'))
|
||||||
info('has_ip_address(\'127.0.0.1\'):', has_ip_address('127.0.0.1'))
|
info('has_ip_address(\'127.0.0.1\'):', has_ip_address('127.0.0.1'))
|
|
@ -1,4 +1,3 @@
|
||||||
include stdlib
|
include ::stdlib
|
||||||
info('has_ip_network(\'127.0.0.0\'):', has_ip_network('127.0.0.0'))
|
info('has_ip_network(\'127.0.0.0\'):', has_ip_network('127.0.0.0'))
|
||||||
info('has_ip_network(\'128.0.0.0\'):', has_ip_network('128.0.0.0'))
|
info('has_ip_network(\'128.0.0.0\'):', has_ip_network('128.0.0.0'))
|
||||||
|
|
1
examples/init.pp
Normal file
1
examples/init.pp
Normal file
|
@ -0,0 +1 @@
|
||||||
|
include ::stdlib
|
|
@ -48,7 +48,7 @@ class Facter::Util::DotD
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rescue Exception => e
|
rescue StandardError => e
|
||||||
Facter.warn("Failed to handle #{file} as text facts: #{e.class}: #{e}")
|
Facter.warn("Failed to handle #{file} as text facts: #{e.class}: #{e}")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -65,7 +65,7 @@ class Facter::Util::DotD
|
||||||
setcode { v }
|
setcode { v }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rescue Exception => e
|
rescue StandardError => e
|
||||||
Facter.warn("Failed to handle #{file} as json facts: #{e.class}: #{e}")
|
Facter.warn("Failed to handle #{file} as json facts: #{e.class}: #{e}")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ class Facter::Util::DotD
|
||||||
setcode { v }
|
setcode { v }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rescue Exception => e
|
rescue StandardError => e
|
||||||
Facter.warn("Failed to handle #{file} as yaml facts: #{e.class}: #{e}")
|
Facter.warn("Failed to handle #{file} as yaml facts: #{e.class}: #{e}")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ class Facter::Util::DotD
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rescue Exception => e
|
rescue StandardError => e
|
||||||
Facter.warn("Failed to handle #{file} as script facts: #{e.class}: #{e}")
|
Facter.warn("Failed to handle #{file} as script facts: #{e.class}: #{e}")
|
||||||
Facter.debug(e.backtrace.join("\n\t"))
|
Facter.debug(e.backtrace.join("\n\t"))
|
||||||
end
|
end
|
||||||
|
|
21
lib/facter/package_provider.rb
Normal file
21
lib/facter/package_provider.rb
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
# Fact: package_provider
|
||||||
|
#
|
||||||
|
# Purpose: Returns the default provider Puppet will choose to manage packages
|
||||||
|
# on this system
|
||||||
|
#
|
||||||
|
# Resolution: Instantiates a dummy package resource and return the provider
|
||||||
|
#
|
||||||
|
# Caveats:
|
||||||
|
#
|
||||||
|
require 'puppet/type'
|
||||||
|
require 'puppet/type/package'
|
||||||
|
|
||||||
|
Facter.add(:package_provider) do
|
||||||
|
setcode do
|
||||||
|
if defined? Gem and Gem::Version.new(Facter.value(:puppetversion).split(' ')[0]) >= Gem::Version.new('3.6')
|
||||||
|
Puppet::Type.type(:package).newpackage(:name => 'dummy', :allow_virtual => 'true')[:provider].to_s
|
||||||
|
else
|
||||||
|
Puppet::Type.type(:package).newpackage(:name => 'dummy')[:provider].to_s
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -10,8 +10,13 @@
|
||||||
#
|
#
|
||||||
Facter.add("pe_version") do
|
Facter.add("pe_version") do
|
||||||
setcode do
|
setcode do
|
||||||
pe_ver = Facter.value("puppetversion").match(/Puppet Enterprise (\d+\.\d+\.\d+)/)
|
puppet_ver = Facter.value("puppetversion")
|
||||||
pe_ver[1] if pe_ver
|
if puppet_ver != nil
|
||||||
|
pe_ver = puppet_ver.match(/Puppet Enterprise (\d+\.\d+\.\d+)/)
|
||||||
|
pe_ver[1] if pe_ver
|
||||||
|
else
|
||||||
|
nil
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -30,3 +30,16 @@ Facter.add(:root_home) do
|
||||||
hash['dir'].strip
|
hash['dir'].strip
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Facter.add(:root_home) do
|
||||||
|
confine :kernel => :aix
|
||||||
|
root_home = nil
|
||||||
|
setcode do
|
||||||
|
str = Facter::Util::Resolution.exec("lsuser -c -a home root")
|
||||||
|
str && str.split("\n").each do |line|
|
||||||
|
next if line =~ /^#/
|
||||||
|
root_home = line.split(/:/)[1]
|
||||||
|
end
|
||||||
|
root_home
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
17
lib/facter/service_provider.rb
Normal file
17
lib/facter/service_provider.rb
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
# Fact: service_provider
|
||||||
|
#
|
||||||
|
# Purpose: Returns the default provider Puppet will choose to manage services
|
||||||
|
# on this system
|
||||||
|
#
|
||||||
|
# Resolution: Instantiates a dummy service resource and return the provider
|
||||||
|
#
|
||||||
|
# Caveats:
|
||||||
|
#
|
||||||
|
require 'puppet/type'
|
||||||
|
require 'puppet/type/service'
|
||||||
|
|
||||||
|
Facter.add(:service_provider) do
|
||||||
|
setcode do
|
||||||
|
Puppet::Type.type(:service).newservice(:name => 'dummy')[:provider].to_s
|
||||||
|
end
|
||||||
|
end
|
32
lib/puppet/functions/is_a.rb
Normal file
32
lib/puppet/functions/is_a.rb
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
# Boolean check to determine whether a variable is of a given data type. This is equivalent to the `=~` type checks.
|
||||||
|
#
|
||||||
|
# @example how to check a data type
|
||||||
|
# # check a data type
|
||||||
|
# foo = 3
|
||||||
|
# $bar = [1,2,3]
|
||||||
|
# $baz = 'A string!'
|
||||||
|
#
|
||||||
|
# if $foo.is_a(Integer) {
|
||||||
|
# notify { 'foo!': }
|
||||||
|
# }
|
||||||
|
# if $bar.is_a(Array) {
|
||||||
|
# notify { 'bar!': }
|
||||||
|
# }
|
||||||
|
# if $baz.is_a(String) {
|
||||||
|
# notify { 'baz!': }
|
||||||
|
# }
|
||||||
|
#
|
||||||
|
# See the documentation for "The Puppet Type System" for more information about types.
|
||||||
|
# See the `assert_type()` function for flexible ways to assert the type of a value.
|
||||||
|
#
|
||||||
|
Puppet::Functions.create_function(:is_a) do
|
||||||
|
dispatch :is_a do
|
||||||
|
param 'Any', :value
|
||||||
|
param 'Type', :type
|
||||||
|
end
|
||||||
|
|
||||||
|
def is_a(value, type)
|
||||||
|
# See puppet's lib/puppet/pops/evaluator/evaluator_impl.rb eval_MatchExpression
|
||||||
|
Puppet::Pops::Types::TypeCalculator.instance?(type, value)
|
||||||
|
end
|
||||||
|
end
|
55
lib/puppet/parser/functions/any2bool.rb
Normal file
55
lib/puppet/parser/functions/any2bool.rb
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
#
|
||||||
|
# any2bool.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:any2bool, :type => :rvalue, :doc => <<-EOS
|
||||||
|
This converts 'anything' to a boolean. In practise it does the following:
|
||||||
|
|
||||||
|
* Strings such as Y,y,1,T,t,TRUE,yes,'true' will return true
|
||||||
|
* Strings such as 0,F,f,N,n,FALSE,no,'false' will return false
|
||||||
|
* Booleans will just return their original value
|
||||||
|
* Number (or a string representation of a number) > 0 will return true, otherwise false
|
||||||
|
* undef will return false
|
||||||
|
* Anything else will return true
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
raise(Puppet::ParseError, "any2bool(): Wrong number of arguments " +
|
||||||
|
"given (#{arguments.size} for 1)") if arguments.size < 1
|
||||||
|
|
||||||
|
# If argument is already Boolean, return it
|
||||||
|
if !!arguments[0] == arguments[0]
|
||||||
|
return arguments[0]
|
||||||
|
end
|
||||||
|
|
||||||
|
arg = arguments[0]
|
||||||
|
|
||||||
|
if arg == nil
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
if arg == :undef
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
valid_float = !!Float(arg) rescue false
|
||||||
|
|
||||||
|
if arg.is_a?(Numeric)
|
||||||
|
return function_num2bool( [ arguments[0] ] )
|
||||||
|
end
|
||||||
|
|
||||||
|
if arg.is_a?(String)
|
||||||
|
if valid_float
|
||||||
|
return function_num2bool( [ arguments[0] ] )
|
||||||
|
else
|
||||||
|
return function_str2bool( [ arguments[0] ] )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return true
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
|
@ -6,14 +6,19 @@ module Puppet::Parser::Functions
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
|
|
||||||
$encodestring = base64('encode','thestring')
|
$encodestring = base64('encode', 'thestring')
|
||||||
$decodestring = base64('decode','dGhlc3RyaW5n')
|
$decodestring = base64('decode', 'dGhlc3RyaW5n')
|
||||||
|
|
||||||
|
# explicitly define encode/decode method: default, strict, urlsafe
|
||||||
|
$method = 'default'
|
||||||
|
$encodestring = base64('encode', 'thestring', $method)
|
||||||
|
$decodestring = base64('decode', 'dGhlc3RyaW5n', $method)
|
||||||
|
|
||||||
ENDHEREDOC
|
ENDHEREDOC
|
||||||
|
|
||||||
require 'base64'
|
require 'base64'
|
||||||
|
|
||||||
raise Puppet::ParseError, ("base64(): Wrong number of arguments (#{args.length}; must be = 2)") unless args.length == 2
|
raise Puppet::ParseError, ("base64(): Wrong number of arguments (#{args.length}; must be >= 2)") unless args.length >= 2
|
||||||
|
|
||||||
actions = ['encode','decode']
|
actions = ['encode','decode']
|
||||||
|
|
||||||
|
@ -25,11 +30,37 @@ module Puppet::Parser::Functions
|
||||||
raise Puppet::ParseError, ("base64(): the second argument must be a string to base64")
|
raise Puppet::ParseError, ("base64(): the second argument must be a string to base64")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
method = ['default','strict','urlsafe']
|
||||||
|
|
||||||
|
if args.length <= 2
|
||||||
|
chosenMethod = 'default'
|
||||||
|
else
|
||||||
|
chosenMethod = args[2]
|
||||||
|
end
|
||||||
|
|
||||||
|
unless method.include?(chosenMethod)
|
||||||
|
raise Puppet::ParseError, ("base64(): the third argument must be one of 'default', 'strict', or 'urlsafe'")
|
||||||
|
end
|
||||||
|
|
||||||
case args[0]
|
case args[0]
|
||||||
when 'encode'
|
when 'encode'
|
||||||
result = Base64.encode64(args[1])
|
case chosenMethod
|
||||||
|
when 'default'
|
||||||
|
result = Base64.encode64(args[1])
|
||||||
|
when 'strict'
|
||||||
|
result = Base64.strict_encode64(args[1])
|
||||||
|
when 'urlsafe'
|
||||||
|
result = Base64.urlsafe_encode64(args[1])
|
||||||
|
end
|
||||||
when 'decode'
|
when 'decode'
|
||||||
result = Base64.decode64(args[1])
|
case chosenMethod
|
||||||
|
when 'default'
|
||||||
|
result = Base64.decode64(args[1])
|
||||||
|
when 'strict'
|
||||||
|
result = Base64.strict_decode64(args[1])
|
||||||
|
when 'urlsafe'
|
||||||
|
result = Base64.urlsafe_decode64(args[1])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
|
@ -4,15 +4,29 @@
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:bool2str, :type => :rvalue, :doc => <<-EOS
|
newfunction(:bool2str, :type => :rvalue, :doc => <<-EOS
|
||||||
Converts a boolean to a string.
|
Converts a boolean to a string using optionally supplied arguments. The
|
||||||
|
optional second and third arguments represent what true and false will be
|
||||||
|
converted to respectively. If only one argument is given, it will be
|
||||||
|
converted from a boolean to a string containing 'true' or 'false'.
|
||||||
|
|
||||||
|
*Examples:*
|
||||||
|
|
||||||
|
bool2str(true) => 'true'
|
||||||
|
bool2str(true, 'yes', 'no') => 'yes'
|
||||||
|
bool2str(false, 't', 'f') => 'f'
|
||||||
|
|
||||||
Requires a single boolean as an input.
|
Requires a single boolean as an input.
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
raise(Puppet::ParseError, "bool2str(): Wrong number of arguments " +
|
unless arguments.size == 1 or arguments.size == 3
|
||||||
"given (#{arguments.size} for 1)") if arguments.size < 1
|
raise(Puppet::ParseError, "bool2str(): Wrong number of arguments " +
|
||||||
|
"given (#{arguments.size} for 3)")
|
||||||
|
end
|
||||||
|
|
||||||
value = arguments[0]
|
value = arguments[0]
|
||||||
|
true_string = arguments[1] || 'true'
|
||||||
|
false_string = arguments[2] || 'false'
|
||||||
klass = value.class
|
klass = value.class
|
||||||
|
|
||||||
# We can have either true or false, and nothing else
|
# We can have either true or false, and nothing else
|
||||||
|
@ -20,7 +34,11 @@ module Puppet::Parser::Functions
|
||||||
raise(Puppet::ParseError, 'bool2str(): Requires a boolean to work with')
|
raise(Puppet::ParseError, 'bool2str(): Requires a boolean to work with')
|
||||||
end
|
end
|
||||||
|
|
||||||
return value.to_s
|
unless [true_string, false_string].all?{|x| x.kind_of?(String)}
|
||||||
|
raise(Puppet::ParseError, "bool2str(): Requires strings to convert to" )
|
||||||
|
end
|
||||||
|
|
||||||
|
return value ? true_string : false_string
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
30
lib/puppet/parser/functions/clamp.rb
Normal file
30
lib/puppet/parser/functions/clamp.rb
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
#
|
||||||
|
# clamp.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:clamp, :type => :rvalue, :arity => -2, :doc => <<-EOS
|
||||||
|
Clamps value to a range.
|
||||||
|
EOS
|
||||||
|
) do |args|
|
||||||
|
|
||||||
|
args.flatten!
|
||||||
|
|
||||||
|
raise(Puppet::ParseError, 'clamp(): Wrong number of arguments, ' +
|
||||||
|
'need three to clamp') if args.size != 3
|
||||||
|
|
||||||
|
# check values out
|
||||||
|
args.each do |value|
|
||||||
|
case [value.class]
|
||||||
|
when [String]
|
||||||
|
raise(Puppet::ParseError, "clamp(): Required explicit numeric (#{value}:String)") unless value =~ /^\d+$/
|
||||||
|
when [Hash]
|
||||||
|
raise(Puppet::ParseError, "clamp(): The Hash type is not allowed (#{value})")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# convert to numeric each element
|
||||||
|
# then sort them and get a middle value
|
||||||
|
args.map{ |n| n.to_i }.sort[1]
|
||||||
|
end
|
||||||
|
end
|
|
@ -31,7 +31,7 @@ Would result in:
|
||||||
arguments.shift
|
arguments.shift
|
||||||
|
|
||||||
arguments.each do |x|
|
arguments.each do |x|
|
||||||
result = result + Array(x)
|
result = result + (x.is_a?(Array) ? x : [x])
|
||||||
end
|
end
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
35
lib/puppet/parser/functions/convert_base.rb
Normal file
35
lib/puppet/parser/functions/convert_base.rb
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
|
||||||
|
newfunction(:convert_base, :type => :rvalue, :arity => 2, :doc => <<-'ENDHEREDOC') do |args|
|
||||||
|
|
||||||
|
Converts a given integer or base 10 string representing an integer to a specified base, as a string.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
|
||||||
|
$binary_repr = convert_base(5, 2) # $binary_repr is now set to "101"
|
||||||
|
$hex_repr = convert_base("254", "16") # $hex_repr is now set to "fe"
|
||||||
|
|
||||||
|
ENDHEREDOC
|
||||||
|
|
||||||
|
raise Puppet::ParseError, ("convert_base(): First argument must be either a string or an integer") unless (args[0].is_a?(Integer) or args[0].is_a?(String))
|
||||||
|
raise Puppet::ParseError, ("convert_base(): Second argument must be either a string or an integer") unless (args[1].is_a?(Integer) or args[1].is_a?(String))
|
||||||
|
|
||||||
|
if args[0].is_a?(String)
|
||||||
|
raise Puppet::ParseError, ("convert_base(): First argument must be an integer or a string corresponding to an integer in base 10") unless args[0] =~ /^[0-9]+$/
|
||||||
|
end
|
||||||
|
|
||||||
|
if args[1].is_a?(String)
|
||||||
|
raise Puppet::ParseError, ("convert_base(): First argument must be an integer or a string corresponding to an integer in base 10") unless args[1] =~ /^[0-9]+$/
|
||||||
|
end
|
||||||
|
|
||||||
|
number_to_convert = args[0]
|
||||||
|
new_base = args[1]
|
||||||
|
|
||||||
|
number_to_convert = number_to_convert.to_i()
|
||||||
|
new_base = new_base.to_i()
|
||||||
|
|
||||||
|
raise Puppet::ParseError, ("convert_base(): base must be at least 2 and must not be greater than 36") unless new_base >= 2 and new_base <= 36
|
||||||
|
|
||||||
|
return number_to_convert.to_s(new_base)
|
||||||
|
end
|
||||||
|
end
|
|
@ -26,7 +26,10 @@ ENDOFDOC
|
||||||
ret = false
|
ret = false
|
||||||
if resource = findresource(reference.to_s)
|
if resource = findresource(reference.to_s)
|
||||||
matches = params.collect do |key, value|
|
matches = params.collect do |key, value|
|
||||||
resource[key] == value
|
# eql? avoids bugs caused by monkeypatching in puppet
|
||||||
|
resource_is_undef = resource[key].eql?(:undef) || resource[key].nil?
|
||||||
|
value_is_undef = value.eql?(:undef) || value.nil?
|
||||||
|
(resource_is_undef && value_is_undef) || (resource[key] == value)
|
||||||
end
|
end
|
||||||
ret = params.empty? || !matches.include?(false)
|
ret = params.empty? || !matches.include?(false)
|
||||||
end
|
end
|
||||||
|
|
|
@ -2,8 +2,6 @@
|
||||||
# delete.rb
|
# delete.rb
|
||||||
#
|
#
|
||||||
|
|
||||||
# TODO(Krzysztof Wilczynski): We need to add support for regular expression ...
|
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:delete, :type => :rvalue, :doc => <<-EOS
|
newfunction(:delete, :type => :rvalue, :doc => <<-EOS
|
||||||
Deletes all instances of a given element from an array, substring from a
|
Deletes all instances of a given element from an array, substring from a
|
||||||
|
@ -25,10 +23,8 @@ string, or key from a hash.
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
if (arguments.size != 2) then
|
raise(Puppet::ParseError, "delete(): Wrong number of arguments "+
|
||||||
raise(Puppet::ParseError, "delete(): Wrong number of arguments "+
|
"given #{arguments.size} for 2") unless arguments.size == 2
|
||||||
"given #{arguments.size} for 2.")
|
|
||||||
end
|
|
||||||
|
|
||||||
collection = arguments[0].dup
|
collection = arguments[0].dup
|
||||||
Array(arguments[1]).each do |item|
|
Array(arguments[1]).each do |item|
|
||||||
|
|
45
lib/puppet/parser/functions/delete_regex.rb
Normal file
45
lib/puppet/parser/functions/delete_regex.rb
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
#
|
||||||
|
# delete_regex.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:delete_regex, :type => :rvalue, :doc => <<-EOS
|
||||||
|
deletes all instances of a given element that match a regular expression
|
||||||
|
from an array or key from a hash. Multiple regular expressions are assumed
|
||||||
|
to be matched as an OR.
|
||||||
|
|
||||||
|
*Examples:*
|
||||||
|
|
||||||
|
delete_regex(['a','b','c','b'], 'b')
|
||||||
|
Would return: ['a','c']
|
||||||
|
|
||||||
|
delete_regex(['a','b','c','b'], ['b', 'c'])
|
||||||
|
Would return: ['a']
|
||||||
|
|
||||||
|
delete_regex({'a'=>1,'b'=>2,'c'=>3}, 'b')
|
||||||
|
Would return: {'a'=>1,'c'=>3}
|
||||||
|
|
||||||
|
delete_regex({'a'=>1,'b'=>2,'c'=>3}, '^a$')
|
||||||
|
Would return: {'b'=>2,'c'=>3}
|
||||||
|
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
raise(Puppet::ParseError, "delete_regex(): Wrong number of arguments "+
|
||||||
|
"given #{arguments.size} for 2") unless arguments.size == 2
|
||||||
|
|
||||||
|
collection = arguments[0].dup
|
||||||
|
Array(arguments[1]).each do |item|
|
||||||
|
case collection
|
||||||
|
when Array, Hash, String
|
||||||
|
collection.reject! { |coll_item| (coll_item =~ %r{\b#{item}\b}) }
|
||||||
|
else
|
||||||
|
raise(TypeError, "delete_regex(): First argument must be an Array, " +
|
||||||
|
"Hash, or String. Given an argument of class #{collection.class}.")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
collection
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
16
lib/puppet/parser/functions/dig.rb
Normal file
16
lib/puppet/parser/functions/dig.rb
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#
|
||||||
|
# dig.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:dig, :type => :rvalue, :doc => <<-EOS
|
||||||
|
DEPRECATED: This function has been replaced in Puppet 4.5.0, please use dig44() for backwards compatibility or use the new version.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
warning("dig() DEPRECATED: This function has been replaced in Puppet 4.5.0, please use dig44() for backwards compatibility or use the new version.")
|
||||||
|
if ! Puppet::Parser::Functions.autoloader.loaded?(:dig44)
|
||||||
|
Puppet::Parser::Functions.autoloader.load(:dig44)
|
||||||
|
end
|
||||||
|
function_dig44(arguments)
|
||||||
|
end
|
||||||
|
end
|
56
lib/puppet/parser/functions/dig44.rb
Normal file
56
lib/puppet/parser/functions/dig44.rb
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
#
|
||||||
|
# dig44.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:dig44, :type => :rvalue, :doc => <<-EOS
|
||||||
|
DEPRECATED: This function has been replaced in puppet 4.5.0.
|
||||||
|
|
||||||
|
Looks up into a complex structure of arrays and hashes and returns nil
|
||||||
|
or the default value if nothing was found.
|
||||||
|
|
||||||
|
Path is an array of keys to be looked up in data argument. The function
|
||||||
|
will go down the structure and try to extract the required value.
|
||||||
|
|
||||||
|
$data = {
|
||||||
|
'a' => {
|
||||||
|
'b' => [
|
||||||
|
'b1',
|
||||||
|
'b2',
|
||||||
|
'b3' ]}}
|
||||||
|
|
||||||
|
$value = dig44($data, ['a', 'b', '2'], 'not_found')
|
||||||
|
=> $value = 'b3'
|
||||||
|
|
||||||
|
a -> first hash key
|
||||||
|
b -> second hash key
|
||||||
|
2 -> array index starting with 0
|
||||||
|
|
||||||
|
not_found -> (optional) will be returned if there is no value or the path
|
||||||
|
did not match. Defaults to nil.
|
||||||
|
|
||||||
|
In addition to the required "path" argument, "dig44" accepts default
|
||||||
|
argument. It will be returned if no value was found or a path component is
|
||||||
|
missing. And the fourth argument can set a variable path separator.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
# Two arguments are required
|
||||||
|
raise(Puppet::ParseError, "dig44(): Wrong number of arguments " +
|
||||||
|
"given (#{arguments.size} for at least 2)") if arguments.size < 2
|
||||||
|
|
||||||
|
data, path, default = *arguments
|
||||||
|
|
||||||
|
if !(data.is_a?(Hash) || data.is_a?(Array))
|
||||||
|
raise(Puppet::ParseError, "dig44(): first argument must be a hash or an array, " <<
|
||||||
|
"given #{data.class.name}")
|
||||||
|
end
|
||||||
|
|
||||||
|
unless path.is_a? Array
|
||||||
|
raise(Puppet::ParseError, "dig44(): second argument must be an array, " <<
|
||||||
|
"given #{path.class.name}")
|
||||||
|
end
|
||||||
|
|
||||||
|
value = path.reduce(data) { |h, k| (h.is_a?(Hash) || h.is_a?(Array)) ? h[k] : break }
|
||||||
|
value.nil? ? default : value
|
||||||
|
end
|
||||||
|
end
|
15
lib/puppet/parser/functions/dos2unix.rb
Normal file
15
lib/puppet/parser/functions/dos2unix.rb
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
# Custom Puppet function to convert dos to unix format
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:dos2unix, :type => :rvalue, :arity => 1, :doc => <<-EOS
|
||||||
|
Returns the Unix version of the given string.
|
||||||
|
Takes a single string argument.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
unless arguments[0].is_a?(String)
|
||||||
|
raise(Puppet::ParseError, 'dos2unix(): Requires string as argument')
|
||||||
|
end
|
||||||
|
|
||||||
|
arguments[0].gsub(/\r\n/, "\n")
|
||||||
|
end
|
||||||
|
end
|
|
@ -13,14 +13,18 @@ Returns true if the variable is empty.
|
||||||
|
|
||||||
value = arguments[0]
|
value = arguments[0]
|
||||||
|
|
||||||
unless value.is_a?(Array) || value.is_a?(Hash) || value.is_a?(String)
|
unless value.is_a?(Array) || value.is_a?(Hash) || value.is_a?(String) || value.is_a?(Numeric)
|
||||||
raise(Puppet::ParseError, 'empty(): Requires either ' +
|
raise(Puppet::ParseError, 'empty(): Requires either ' +
|
||||||
'array, hash or string to work with')
|
'array, hash, string or integer to work with')
|
||||||
end
|
end
|
||||||
|
|
||||||
result = value.empty?
|
if value.is_a?(Numeric)
|
||||||
|
return false
|
||||||
|
else
|
||||||
|
result = value.empty?
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
45
lib/puppet/parser/functions/enclose_ipv6.rb
Normal file
45
lib/puppet/parser/functions/enclose_ipv6.rb
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
#
|
||||||
|
# enclose_ipv6.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:enclose_ipv6, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Takes an array of ip addresses and encloses the ipv6 addresses with square brackets.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
require 'ipaddr'
|
||||||
|
|
||||||
|
rescuable_exceptions = [ ArgumentError ]
|
||||||
|
if defined?(IPAddr::InvalidAddressError)
|
||||||
|
rescuable_exceptions << IPAddr::InvalidAddressError
|
||||||
|
end
|
||||||
|
|
||||||
|
if (arguments.size != 1) then
|
||||||
|
raise(Puppet::ParseError, "enclose_ipv6(): Wrong number of arguments "+
|
||||||
|
"given #{arguments.size} for 1")
|
||||||
|
end
|
||||||
|
unless arguments[0].is_a?(String) or arguments[0].is_a?(Array) then
|
||||||
|
raise(Puppet::ParseError, "enclose_ipv6(): Wrong argument type "+
|
||||||
|
"given #{arguments[0].class} expected String or Array")
|
||||||
|
end
|
||||||
|
|
||||||
|
input = [arguments[0]].flatten.compact
|
||||||
|
result = []
|
||||||
|
|
||||||
|
input.each do |val|
|
||||||
|
unless val == '*'
|
||||||
|
begin
|
||||||
|
ip = IPAddr.new(val)
|
||||||
|
rescue *rescuable_exceptions
|
||||||
|
raise(Puppet::ParseError, "enclose_ipv6(): Wrong argument "+
|
||||||
|
"given #{val} is not an ip address.")
|
||||||
|
end
|
||||||
|
val = "[#{ip.to_s}]" if ip.ipv6?
|
||||||
|
end
|
||||||
|
result << val
|
||||||
|
end
|
||||||
|
|
||||||
|
return result.uniq
|
||||||
|
end
|
||||||
|
end
|
|
@ -17,18 +17,29 @@ third argument to the ensure_resource() function.
|
||||||
raise(Puppet::ParseError, 'ensure_packages(): Requires second argument to be a Hash')
|
raise(Puppet::ParseError, 'ensure_packages(): Requires second argument to be a Hash')
|
||||||
end
|
end
|
||||||
|
|
||||||
packages = Array(arguments[0])
|
if arguments[0].is_a?(Hash)
|
||||||
|
if arguments[1]
|
||||||
|
defaults = { 'ensure' => 'present' }.merge(arguments[1])
|
||||||
|
else
|
||||||
|
defaults = { 'ensure' => 'present' }
|
||||||
|
end
|
||||||
|
|
||||||
if arguments[1]
|
Puppet::Parser::Functions.function(:ensure_resources)
|
||||||
defaults = { 'ensure' => 'present' }.merge(arguments[1])
|
function_ensure_resources(['package', Hash(arguments[0]), defaults ])
|
||||||
else
|
else
|
||||||
defaults = { 'ensure' => 'present' }
|
packages = Array(arguments[0])
|
||||||
end
|
|
||||||
|
|
||||||
Puppet::Parser::Functions.function(:ensure_resource)
|
if arguments[1]
|
||||||
packages.each { |package_name|
|
defaults = { 'ensure' => 'present' }.merge(arguments[1])
|
||||||
function_ensure_resource(['package', package_name, defaults ])
|
else
|
||||||
|
defaults = { 'ensure' => 'present' }
|
||||||
|
end
|
||||||
|
|
||||||
|
Puppet::Parser::Functions.function(:ensure_resource)
|
||||||
|
packages.each { |package_name|
|
||||||
|
function_ensure_resource(['package', package_name, defaults ])
|
||||||
}
|
}
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
54
lib/puppet/parser/functions/ensure_resources.rb
Normal file
54
lib/puppet/parser/functions/ensure_resources.rb
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
require 'puppet/parser/functions'
|
||||||
|
|
||||||
|
Puppet::Parser::Functions.newfunction(:ensure_resources,
|
||||||
|
:type => :statement,
|
||||||
|
:doc => <<-'ENDOFDOC'
|
||||||
|
Takes a resource type, title (only hash), and a list of attributes that describe a
|
||||||
|
resource.
|
||||||
|
|
||||||
|
user { 'dan':
|
||||||
|
gid => 'mygroup',
|
||||||
|
ensure => present,
|
||||||
|
}
|
||||||
|
|
||||||
|
An hash of resources should be passed in and each will be created with
|
||||||
|
the type and parameters specified if it doesn't already exist.
|
||||||
|
|
||||||
|
ensure_resources('user', {'dan' => { gid => 'mygroup', uid => '600' } , 'alex' => { gid => 'mygroup' }}, {'ensure' => 'present'})
|
||||||
|
|
||||||
|
From Hiera Backend:
|
||||||
|
|
||||||
|
userlist:
|
||||||
|
dan:
|
||||||
|
gid: 'mygroup'
|
||||||
|
uid: '600'
|
||||||
|
alex:
|
||||||
|
gid: 'mygroup'
|
||||||
|
|
||||||
|
Call:
|
||||||
|
ensure_resources('user', hiera_hash('userlist'), {'ensure' => 'present'})
|
||||||
|
|
||||||
|
ENDOFDOC
|
||||||
|
) do |vals|
|
||||||
|
type, title, params = vals
|
||||||
|
raise(ArgumentError, 'Must specify a type') unless type
|
||||||
|
raise(ArgumentError, 'Must specify a title') unless title
|
||||||
|
params ||= {}
|
||||||
|
|
||||||
|
if title.is_a?(Hash)
|
||||||
|
resource_hash = Hash(title)
|
||||||
|
resources = resource_hash.keys
|
||||||
|
|
||||||
|
Puppet::Parser::Functions.function(:ensure_resource)
|
||||||
|
resources.each { |resource_name|
|
||||||
|
if resource_hash[resource_name]
|
||||||
|
params_merged = params.merge(resource_hash[resource_name])
|
||||||
|
else
|
||||||
|
params_merged = params
|
||||||
|
end
|
||||||
|
function_ensure_resource([ type, resource_name, params_merged ])
|
||||||
|
}
|
||||||
|
else
|
||||||
|
raise(Puppet::ParseError, 'ensure_resources(): Requires second argument to be a Hash')
|
||||||
|
end
|
||||||
|
end
|
|
@ -38,8 +38,11 @@ has_interface_with("lo") => true
|
||||||
# Bug with 3.7.1 - 3.7.3 when using future parser throws :undefined_variable
|
# Bug with 3.7.1 - 3.7.3 when using future parser throws :undefined_variable
|
||||||
# https://tickets.puppetlabs.com/browse/PUP-3597
|
# https://tickets.puppetlabs.com/browse/PUP-3597
|
||||||
factval = nil
|
factval = nil
|
||||||
catch :undefined_variable do
|
begin
|
||||||
factval = lookupvar(kind)
|
catch :undefined_variable do
|
||||||
|
factval = lookupvar(kind)
|
||||||
|
end
|
||||||
|
rescue Puppet::ParseError # Eat the exception if strict_variables = true is set
|
||||||
end
|
end
|
||||||
if factval == value
|
if factval == value
|
||||||
return true
|
return true
|
||||||
|
|
|
@ -29,7 +29,7 @@ Would return: {'a'=>1,'b'=>2,'c'=>3}
|
||||||
# This is to make it compatible with older version of Ruby ...
|
# This is to make it compatible with older version of Ruby ...
|
||||||
array = array.flatten
|
array = array.flatten
|
||||||
result = Hash[*array]
|
result = Hash[*array]
|
||||||
rescue Exception
|
rescue StandardError
|
||||||
raise(Puppet::ParseError, 'hash(): Unable to compute ' +
|
raise(Puppet::ParseError, 'hash(): Unable to compute ' +
|
||||||
'hash from array given')
|
'hash from array given')
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,13 +4,13 @@
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:intersection, :type => :rvalue, :doc => <<-EOS
|
newfunction(:intersection, :type => :rvalue, :doc => <<-EOS
|
||||||
This function returns an array an intersection of two.
|
This function returns an array of the intersection of two.
|
||||||
|
|
||||||
*Examples:*
|
*Examples:*
|
||||||
|
|
||||||
intersection(["a","b","c"],["b","c","d"])
|
intersection(["a","b","c"],["b","c","d"]) # returns ["b","c"]
|
||||||
|
intersection(["a","b","c"],[1,2,3,4]) # returns [] (true, when evaluated as a Boolean)
|
||||||
|
|
||||||
Would return: ["b","c"]
|
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
|
|
50
lib/puppet/parser/functions/is_absolute_path.rb
Normal file
50
lib/puppet/parser/functions/is_absolute_path.rb
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:is_absolute_path, :type => :rvalue, :arity => 1, :doc => <<-'ENDHEREDOC') do |args|
|
||||||
|
Returns boolean true if the string represents an absolute path in the filesystem. This function works
|
||||||
|
for windows and unix style paths.
|
||||||
|
|
||||||
|
The following values will return true:
|
||||||
|
|
||||||
|
$my_path = 'C:/Program Files (x86)/Puppet Labs/Puppet'
|
||||||
|
is_absolute_path($my_path)
|
||||||
|
$my_path2 = '/var/lib/puppet'
|
||||||
|
is_absolute_path($my_path2)
|
||||||
|
$my_path3 = ['C:/Program Files (x86)/Puppet Labs/Puppet']
|
||||||
|
is_absolute_path($my_path3)
|
||||||
|
$my_path4 = ['/var/lib/puppet']
|
||||||
|
is_absolute_path($my_path4)
|
||||||
|
|
||||||
|
The following values will return false:
|
||||||
|
|
||||||
|
is_absolute_path(true)
|
||||||
|
is_absolute_path('../var/lib/puppet')
|
||||||
|
is_absolute_path('var/lib/puppet')
|
||||||
|
$undefined = undef
|
||||||
|
is_absolute_path($undefined)
|
||||||
|
|
||||||
|
ENDHEREDOC
|
||||||
|
|
||||||
|
require 'puppet/util'
|
||||||
|
|
||||||
|
path = args[0]
|
||||||
|
# This logic was borrowed from
|
||||||
|
# [lib/puppet/file_serving/base.rb](https://github.com/puppetlabs/puppet/blob/master/lib/puppet/file_serving/base.rb)
|
||||||
|
# Puppet 2.7 and beyond will have Puppet::Util.absolute_path? Fall back to a back-ported implementation otherwise.
|
||||||
|
if Puppet::Util.respond_to?(:absolute_path?) then
|
||||||
|
value = (Puppet::Util.absolute_path?(path, :posix) or Puppet::Util.absolute_path?(path, :windows))
|
||||||
|
else
|
||||||
|
# This code back-ported from 2.7.x's lib/puppet/util.rb Puppet::Util.absolute_path?
|
||||||
|
# Determine in a platform-specific way whether a path is absolute. This
|
||||||
|
# defaults to the local platform if none is specified.
|
||||||
|
# Escape once for the string literal, and once for the regex.
|
||||||
|
slash = '[\\\\/]'
|
||||||
|
name = '[^\\\\/]+'
|
||||||
|
regexes = {
|
||||||
|
:windows => %r!^(([A-Z]:#{slash})|(#{slash}#{slash}#{name}#{slash}#{name})|(#{slash}#{slash}\?#{slash}#{name}))!i,
|
||||||
|
:posix => %r!^/!
|
||||||
|
}
|
||||||
|
value = (!!(path =~ regexes[:posix])) || (!!(path =~ regexes[:windows]))
|
||||||
|
end
|
||||||
|
value
|
||||||
|
end
|
||||||
|
end
|
21
lib/puppet/parser/functions/is_email_address.rb
Normal file
21
lib/puppet/parser/functions/is_email_address.rb
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
#
|
||||||
|
# is_email_address.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:is_email_address, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Returns true if the string passed to this function is a valid email address.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
if arguments.size != 1
|
||||||
|
raise(Puppet::ParseError, 'is_email_address(): Wrong number of arguments '\
|
||||||
|
"given #{arguments.size} for 1")
|
||||||
|
end
|
||||||
|
|
||||||
|
# Taken from http://emailregex.com/ (simpler regex)
|
||||||
|
valid_email_regex = %r{\A([\w+\-].?)+@[a-z\d\-]+(\.[a-z]+)*\.[a-z]+\z}
|
||||||
|
return (arguments[0] =~ valid_email_regex) == 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
28
lib/puppet/parser/functions/is_ipv4_address.rb
Normal file
28
lib/puppet/parser/functions/is_ipv4_address.rb
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
#
|
||||||
|
# is_ipv4_address.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:is_ipv4_address, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Returns true if the string passed to this function is a valid IPv4 address.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
require 'ipaddr'
|
||||||
|
|
||||||
|
if (arguments.size != 1) then
|
||||||
|
raise(Puppet::ParseError, "is_ipv4_address(): Wrong number of arguments "+
|
||||||
|
"given #{arguments.size} for 1")
|
||||||
|
end
|
||||||
|
|
||||||
|
begin
|
||||||
|
ip = IPAddr.new(arguments[0])
|
||||||
|
rescue ArgumentError
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
return ip.ipv4?
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
28
lib/puppet/parser/functions/is_ipv6_address.rb
Normal file
28
lib/puppet/parser/functions/is_ipv6_address.rb
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
#
|
||||||
|
# is_ipv6_address.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:is_ipv6_address, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Returns true if the string passed to this function is a valid IPv6 address.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
require 'ipaddr'
|
||||||
|
|
||||||
|
if (arguments.size != 1) then
|
||||||
|
raise(Puppet::ParseError, "is_ipv6_address(): Wrong number of arguments "+
|
||||||
|
"given #{arguments.size} for 1")
|
||||||
|
end
|
||||||
|
|
||||||
|
begin
|
||||||
|
ip = IPAddr.new(arguments[0])
|
||||||
|
rescue ArgumentError
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
return ip.ipv6?
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
24
lib/puppet/parser/functions/load_module_metadata.rb
Normal file
24
lib/puppet/parser/functions/load_module_metadata.rb
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:load_module_metadata, :type => :rvalue, :doc => <<-EOT
|
||||||
|
EOT
|
||||||
|
) do |args|
|
||||||
|
raise(Puppet::ParseError, "load_module_metadata(): Wrong number of arguments, expects one or two") unless [1,2].include?(args.size)
|
||||||
|
mod = args[0]
|
||||||
|
allow_empty_metadata = args[1]
|
||||||
|
module_path = function_get_module_path([mod])
|
||||||
|
metadata_json = File.join(module_path, 'metadata.json')
|
||||||
|
|
||||||
|
metadata_exists = File.exists?(metadata_json)
|
||||||
|
if metadata_exists
|
||||||
|
metadata = PSON.load(File.read(metadata_json))
|
||||||
|
else
|
||||||
|
if allow_empty_metadata
|
||||||
|
metadata = {}
|
||||||
|
else
|
||||||
|
raise(Puppet::ParseError, "load_module_metadata(): No metadata.json file for module #{mod}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return metadata
|
||||||
|
end
|
||||||
|
end
|
34
lib/puppet/parser/functions/loadjson.rb
Normal file
34
lib/puppet/parser/functions/loadjson.rb
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:loadjson, :type => :rvalue, :arity => -2, :doc => <<-'ENDHEREDOC') do |args|
|
||||||
|
Load a JSON file containing an array, string, or hash, and return the data
|
||||||
|
in the corresponding native data type.
|
||||||
|
The second parameter is the default value. It will be returned if the file
|
||||||
|
was not found or could not be parsed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
$myhash = loadjson('/etc/puppet/data/myhash.json')
|
||||||
|
$myhash = loadjson('no-file.json', {'default' => 'value'})
|
||||||
|
ENDHEREDOC
|
||||||
|
|
||||||
|
raise ArgumentError, 'Wrong number of arguments. 1 or 2 arguments should be provided.' unless args.length >= 1
|
||||||
|
|
||||||
|
if File.exists?(args[0])
|
||||||
|
begin
|
||||||
|
content = File.read(args[0])
|
||||||
|
PSON::load(content) || args[1]
|
||||||
|
rescue Exception => e
|
||||||
|
if args[1]
|
||||||
|
args[1]
|
||||||
|
else
|
||||||
|
raise e
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
warning("Can't load '#{args[0]}' File does not exist!")
|
||||||
|
args[1]
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -1,23 +1,32 @@
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:loadyaml, :type => :rvalue, :arity => -2, :doc => <<-'ENDHEREDOC') do |args|
|
||||||
|
Load a YAML file containing an array, string, or hash, and return the data
|
||||||
|
in the corresponding native data type.
|
||||||
|
The second parameter is the default value. It will be returned if the file
|
||||||
|
was not found or could not be parsed.
|
||||||
|
|
||||||
newfunction(:loadyaml, :type => :rvalue, :doc => <<-'ENDHEREDOC') do |args|
|
For example:
|
||||||
Load a YAML file containing an array, string, or hash, and return the data
|
|
||||||
in the corresponding native data type.
|
|
||||||
|
|
||||||
For example:
|
$myhash = loadyaml('/etc/puppet/data/myhash.yaml')
|
||||||
|
$myhash = loadyaml('no-file.yaml', {'default' => 'value'})
|
||||||
|
ENDHEREDOC
|
||||||
|
|
||||||
$myhash = loadyaml('/etc/puppet/data/myhash.yaml')
|
raise ArgumentError, 'Wrong number of arguments. 1 or 2 arguments should be provided.' unless args.length >= 1
|
||||||
ENDHEREDOC
|
require 'yaml'
|
||||||
|
|
||||||
unless args.length == 1
|
if File.exists?(args[0])
|
||||||
raise Puppet::ParseError, ("loadyaml(): wrong number of arguments (#{args.length}; must be 1)")
|
begin
|
||||||
end
|
YAML::load_file(args[0]) || args[1]
|
||||||
|
rescue Exception => e
|
||||||
if File.exists?(args[0]) then
|
if args[1]
|
||||||
YAML.load_file(args[0])
|
args[1]
|
||||||
|
else
|
||||||
|
raise e
|
||||||
|
end
|
||||||
|
end
|
||||||
else
|
else
|
||||||
warning("Can't load " + args[0] + ". File does not exist!")
|
warning("Can't load '#{args[0]}' File does not exist!")
|
||||||
nil
|
args[1]
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,20 +4,25 @@
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:parsejson, :type => :rvalue, :doc => <<-EOS
|
newfunction(:parsejson, :type => :rvalue, :doc => <<-EOS
|
||||||
This function accepts JSON as a string and converts into the correct Puppet
|
This function accepts JSON as a string and converts it into the correct
|
||||||
structure.
|
Puppet structure.
|
||||||
EOS
|
|
||||||
) do |arguments|
|
|
||||||
|
|
||||||
if (arguments.size != 1) then
|
The optional second argument can be used to pass a default value that will
|
||||||
raise(Puppet::ParseError, "parsejson(): Wrong number of arguments "+
|
be returned if the parsing of YAML string have failed.
|
||||||
"given #{arguments.size} for 1")
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
raise ArgumentError, 'Wrong number of arguments. 1 or 2 arguments should be provided.' unless arguments.length >= 1
|
||||||
|
|
||||||
|
begin
|
||||||
|
PSON::load(arguments[0]) || arguments[1]
|
||||||
|
rescue StandardError => e
|
||||||
|
if arguments[1]
|
||||||
|
arguments[1]
|
||||||
|
else
|
||||||
|
raise e
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
json = arguments[0]
|
|
||||||
|
|
||||||
# PSON is natively available in puppet
|
|
||||||
PSON.load(json)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -6,17 +6,26 @@ module Puppet::Parser::Functions
|
||||||
newfunction(:parseyaml, :type => :rvalue, :doc => <<-EOS
|
newfunction(:parseyaml, :type => :rvalue, :doc => <<-EOS
|
||||||
This function accepts YAML as a string and converts it into the correct
|
This function accepts YAML as a string and converts it into the correct
|
||||||
Puppet structure.
|
Puppet structure.
|
||||||
EOS
|
|
||||||
|
The optional second argument can be used to pass a default value that will
|
||||||
|
be returned if the parsing of YAML string have failed.
|
||||||
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
raise ArgumentError, 'Wrong number of arguments. 1 or 2 arguments should be provided.' unless arguments.length >= 1
|
||||||
if (arguments.size != 1) then
|
|
||||||
raise(Puppet::ParseError, "parseyaml(): Wrong number of arguments "+
|
|
||||||
"given #{arguments.size} for 1")
|
|
||||||
end
|
|
||||||
|
|
||||||
require 'yaml'
|
require 'yaml'
|
||||||
|
|
||||||
YAML::load(arguments[0])
|
begin
|
||||||
|
YAML::load(arguments[0]) || arguments[1]
|
||||||
|
# in ruby 1.9.3 Psych::SyntaxError is a RuntimeException
|
||||||
|
# this still needs to catch that and work also on rubies that
|
||||||
|
# do not have Psych available.
|
||||||
|
rescue StandardError, Psych::SyntaxError => e
|
||||||
|
if arguments[1]
|
||||||
|
arguments[1]
|
||||||
|
else
|
||||||
|
raise e
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
22
lib/puppet/parser/functions/seeded_rand.rb
Normal file
22
lib/puppet/parser/functions/seeded_rand.rb
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
Puppet::Parser::Functions::newfunction(
|
||||||
|
:seeded_rand,
|
||||||
|
:arity => 2,
|
||||||
|
:type => :rvalue,
|
||||||
|
:doc => <<-EOS
|
||||||
|
Usage: `seeded_rand(MAX, SEED)`. MAX must be a positive integer; SEED is any string.
|
||||||
|
|
||||||
|
Generates a random whole number greater than or equal to 0 and less
|
||||||
|
than MAX, using the value of SEED for repeatable randomness. If SEED
|
||||||
|
starts with "$fqdn:", this is behaves the same as `fqdn_rand`.
|
||||||
|
|
||||||
|
EOS
|
||||||
|
) do |args|
|
||||||
|
require 'digest/md5'
|
||||||
|
|
||||||
|
raise(ArgumentError, "seeded_rand(): first argument must be a positive integer") unless function_is_integer([args[0]]) and args[0].to_i > 0
|
||||||
|
raise(ArgumentError, "seeded_rand(): second argument must be a string") unless args[1].is_a? String
|
||||||
|
|
||||||
|
max = args[0].to_i
|
||||||
|
seed = Digest::MD5.hexdigest(args[1]).hex
|
||||||
|
Puppet::Util.deterministic_rand(seed,max)
|
||||||
|
end
|
30
lib/puppet/parser/functions/shell_escape.rb
Normal file
30
lib/puppet/parser/functions/shell_escape.rb
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
#
|
||||||
|
# shell_escape.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
require 'shellwords'
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:shell_escape, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Escapes a string so that it can be safely used in a Bourne shell command line.
|
||||||
|
|
||||||
|
Note that the resulting string should be used unquoted and is not intended for use in double quotes nor in single
|
||||||
|
quotes.
|
||||||
|
|
||||||
|
This function behaves the same as ruby's Shellwords.shellescape() function.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
raise(Puppet::ParseError, "shell_escape(): Wrong number of arguments " +
|
||||||
|
"given (#{arguments.size} for 1)") if arguments.size != 1
|
||||||
|
|
||||||
|
# explicit conversion to string is required for ruby 1.9
|
||||||
|
string = arguments[0].to_s
|
||||||
|
|
||||||
|
result = Shellwords.shellescape(string)
|
||||||
|
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
31
lib/puppet/parser/functions/shell_join.rb
Normal file
31
lib/puppet/parser/functions/shell_join.rb
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
#
|
||||||
|
# shell_join.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
require 'shellwords'
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:shell_join, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Builds a command line string from the given array of strings. Each array item is escaped for Bourne shell. All items are
|
||||||
|
then joined together, with a single space in between.
|
||||||
|
|
||||||
|
This function behaves the same as ruby's Shellwords.shelljoin() function
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
raise(Puppet::ParseError, "shell_join(): Wrong number of arguments " +
|
||||||
|
"given (#{arguments.size} for 1)") if arguments.size != 1
|
||||||
|
|
||||||
|
array = arguments[0]
|
||||||
|
|
||||||
|
raise Puppet::ParseError, ("First argument is not an Array: #{array.inspect}") unless array.is_a?(Array)
|
||||||
|
|
||||||
|
# explicit conversion to string is required for ruby 1.9
|
||||||
|
array = array.map { |item| item.to_s }
|
||||||
|
result = Shellwords.shelljoin(array)
|
||||||
|
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
26
lib/puppet/parser/functions/shell_split.rb
Normal file
26
lib/puppet/parser/functions/shell_split.rb
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
#
|
||||||
|
# shell_split.rb
|
||||||
|
#
|
||||||
|
|
||||||
|
require 'shellwords'
|
||||||
|
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:shell_split, :type => :rvalue, :doc => <<-EOS
|
||||||
|
Splits a string into an array of tokens in the same way the Bourne shell does.
|
||||||
|
|
||||||
|
This function behaves the same as ruby's Shellwords.shellsplit() function
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
raise(Puppet::ParseError, "shell_split(): Wrong number of arguments " +
|
||||||
|
"given (#{arguments.size} for 1)") if arguments.size != 1
|
||||||
|
|
||||||
|
string = arguments[0].to_s
|
||||||
|
|
||||||
|
result = Shellwords.shellsplit(string)
|
||||||
|
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# vim: set ts=2 sw=2 et :
|
|
@ -2,11 +2,9 @@
|
||||||
# size.rb
|
# size.rb
|
||||||
#
|
#
|
||||||
|
|
||||||
# TODO(Krzysztof Wilczynski): Support for hashes would be nice too ...
|
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:size, :type => :rvalue, :doc => <<-EOS
|
newfunction(:size, :type => :rvalue, :doc => <<-EOS
|
||||||
Returns the number of elements in a string or array.
|
Returns the number of elements in a string, an array or a hash
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
|
@ -29,13 +27,13 @@ Returns the number of elements in a string or array.
|
||||||
Float(item)
|
Float(item)
|
||||||
|
|
||||||
raise(Puppet::ParseError, 'size(): Requires either ' +
|
raise(Puppet::ParseError, 'size(): Requires either ' +
|
||||||
'string or array to work with')
|
'string, array or hash to work with')
|
||||||
|
|
||||||
rescue ArgumentError
|
rescue ArgumentError
|
||||||
result = item.size
|
result = item.size
|
||||||
end
|
end
|
||||||
|
|
||||||
elsif item.is_a?(Array)
|
elsif item.is_a?(Array) || item.is_a?(Hash)
|
||||||
result = item.size
|
result = item.size
|
||||||
else
|
else
|
||||||
raise(Puppet::ParseError, 'size(): Unknown type given')
|
raise(Puppet::ParseError, 'size(): Unknown type given')
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:str2bool, :type => :rvalue, :doc => <<-EOS
|
newfunction(:str2bool, :type => :rvalue, :doc => <<-EOS
|
||||||
This converts a string to a boolean. This attempt to convert strings that
|
This converts a string to a boolean. This attempt to convert strings that
|
||||||
contain things like: y, 1, t, true to 'true' and strings that contain things
|
contain things like: Y,y, 1, T,t, TRUE,true to 'true' and strings that contain things
|
||||||
like: 0, f, n, false, no to 'false'.
|
like: 0, F,f, N,n, false, FALSE, no to 'false'.
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
|
@ -32,8 +32,8 @@ like: 0, f, n, false, no to 'false'.
|
||||||
# We yield false in this case.
|
# We yield false in this case.
|
||||||
#
|
#
|
||||||
when /^$/, '' then false # Empty string will be false ...
|
when /^$/, '' then false # Empty string will be false ...
|
||||||
when /^(1|t|y|true|yes)$/ then true
|
when /^(1|t|y|true|yes)$/i then true
|
||||||
when /^(0|f|n|false|no)$/ then false
|
when /^(0|f|n|false|no)$/i then false
|
||||||
when /^(undef|undefined)$/ then false # This is not likely to happen ...
|
when /^(undef|undefined)$/ then false # This is not likely to happen ...
|
||||||
else
|
else
|
||||||
raise(Puppet::ParseError, 'str2bool(): Unknown type of boolean given')
|
raise(Puppet::ParseError, 'str2bool(): Unknown type of boolean given')
|
||||||
|
|
|
@ -4,7 +4,8 @@
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:suffix, :type => :rvalue, :doc => <<-EOS
|
newfunction(:suffix, :type => :rvalue, :doc => <<-EOS
|
||||||
This function applies a suffix to all elements in an array.
|
This function applies a suffix to all elements in an array, or to the keys
|
||||||
|
in a hash.
|
||||||
|
|
||||||
*Examples:*
|
*Examples:*
|
||||||
|
|
||||||
|
@ -18,10 +19,10 @@ Will return: ['ap','bp','cp']
|
||||||
raise(Puppet::ParseError, "suffix(): Wrong number of arguments " +
|
raise(Puppet::ParseError, "suffix(): Wrong number of arguments " +
|
||||||
"given (#{arguments.size} for 1)") if arguments.size < 1
|
"given (#{arguments.size} for 1)") if arguments.size < 1
|
||||||
|
|
||||||
array = arguments[0]
|
enumerable = arguments[0]
|
||||||
|
|
||||||
unless array.is_a?(Array)
|
unless enumerable.is_a?(Array) or enumerable.is_a?(Hash)
|
||||||
raise Puppet::ParseError, "suffix(): expected first argument to be an Array, got #{array.inspect}"
|
raise Puppet::ParseError, "suffix(): expected first argument to be an Array or a Hash, got #{enumerable.inspect}"
|
||||||
end
|
end
|
||||||
|
|
||||||
suffix = arguments[1] if arguments[1]
|
suffix = arguments[1] if arguments[1]
|
||||||
|
@ -32,10 +33,17 @@ Will return: ['ap','bp','cp']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Turn everything into string same as join would do ...
|
if enumerable.is_a?(Array)
|
||||||
result = array.collect do |i|
|
# Turn everything into string same as join would do ...
|
||||||
i = i.to_s
|
result = enumerable.collect do |i|
|
||||||
suffix ? i + suffix : i
|
i = i.to_s
|
||||||
|
suffix ? i + suffix : i
|
||||||
|
end
|
||||||
|
else
|
||||||
|
result = Hash[enumerable.map do |k,v|
|
||||||
|
k = k.to_s
|
||||||
|
[ suffix ? k + suffix : k, v ]
|
||||||
|
end]
|
||||||
end
|
end
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
53
lib/puppet/parser/functions/try_get_value.rb
Normal file
53
lib/puppet/parser/functions/try_get_value.rb
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(
|
||||||
|
:try_get_value,
|
||||||
|
:type => :rvalue,
|
||||||
|
:arity => -2,
|
||||||
|
:doc => <<-eos
|
||||||
|
DEPRECATED: this function is deprecated, please use dig() instead.
|
||||||
|
|
||||||
|
Looks up into a complex structure of arrays and hashes and returns a value
|
||||||
|
or the default value if nothing was found.
|
||||||
|
|
||||||
|
Key can contain slashes to describe path components. The function will go down
|
||||||
|
the structure and try to extract the required value.
|
||||||
|
|
||||||
|
$data = {
|
||||||
|
'a' => {
|
||||||
|
'b' => [
|
||||||
|
'b1',
|
||||||
|
'b2',
|
||||||
|
'b3',
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$value = try_get_value($data, 'a/b/2', 'not_found', '/')
|
||||||
|
=> $value = 'b3'
|
||||||
|
|
||||||
|
a -> first hash key
|
||||||
|
b -> second hash key
|
||||||
|
2 -> array index starting with 0
|
||||||
|
|
||||||
|
not_found -> (optional) will be returned if there is no value or the path did not match. Defaults to nil.
|
||||||
|
/ -> (optional) path delimiter. Defaults to '/'.
|
||||||
|
|
||||||
|
In addition to the required "key" argument, "try_get_value" accepts default
|
||||||
|
argument. It will be returned if no value was found or a path component is
|
||||||
|
missing. And the fourth argument can set a variable path separator.
|
||||||
|
eos
|
||||||
|
) do |args|
|
||||||
|
warning("try_get_value() DEPRECATED: this function is deprecated, please use dig() instead.")
|
||||||
|
data = args[0]
|
||||||
|
path = args[1] || ''
|
||||||
|
default = args[2]
|
||||||
|
|
||||||
|
if !(data.is_a?(Hash) || data.is_a?(Array)) || path == ''
|
||||||
|
return default || data
|
||||||
|
end
|
||||||
|
|
||||||
|
separator = args[3] || '/'
|
||||||
|
path = path.split(separator).map{ |key| key =~ /^\d+$/ ? key.to_i : key }
|
||||||
|
function_dig([data, path, default])
|
||||||
|
end
|
||||||
|
end
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:union, :type => :rvalue, :doc => <<-EOS
|
newfunction(:union, :type => :rvalue, :doc => <<-EOS
|
||||||
This function returns a union of two arrays.
|
This function returns a union of two or more arrays.
|
||||||
|
|
||||||
*Examples:*
|
*Examples:*
|
||||||
|
|
||||||
|
@ -14,20 +14,15 @@ Would return: ["a","b","c","d"]
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
# Two arguments are required
|
# Check that 2 or more arguments have been given ...
|
||||||
raise(Puppet::ParseError, "union(): Wrong number of arguments " +
|
raise(Puppet::ParseError, "union(): Wrong number of arguments " +
|
||||||
"given (#{arguments.size} for 2)") if arguments.size != 2
|
"given (#{arguments.size} for < 2)") if arguments.size < 2
|
||||||
|
|
||||||
first = arguments[0]
|
arguments.each do |argument|
|
||||||
second = arguments[1]
|
raise(Puppet::ParseError, 'union(): Every parameter must be an array') unless argument.is_a?(Array)
|
||||||
|
|
||||||
unless first.is_a?(Array) && second.is_a?(Array)
|
|
||||||
raise(Puppet::ParseError, 'union(): Requires 2 arrays')
|
|
||||||
end
|
end
|
||||||
|
|
||||||
result = first | second
|
arguments.reduce(:|)
|
||||||
|
|
||||||
return result
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
15
lib/puppet/parser/functions/unix2dos.rb
Normal file
15
lib/puppet/parser/functions/unix2dos.rb
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
# Custom Puppet function to convert unix to dos format
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:unix2dos, :type => :rvalue, :arity => 1, :doc => <<-EOS
|
||||||
|
Returns the DOS version of the given string.
|
||||||
|
Takes a single string argument.
|
||||||
|
EOS
|
||||||
|
) do |arguments|
|
||||||
|
|
||||||
|
unless arguments[0].is_a?(String)
|
||||||
|
raise(Puppet::ParseError, 'unix2dos(): Requires string as argument')
|
||||||
|
end
|
||||||
|
|
||||||
|
arguments[0].gsub(/\r*\n/, "\r\n")
|
||||||
|
end
|
||||||
|
end
|
|
@ -12,7 +12,7 @@ Converts a string or an array of strings to uppercase.
|
||||||
|
|
||||||
Will return:
|
Will return:
|
||||||
|
|
||||||
ASDF
|
ABCD
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
|
|
|
@ -40,28 +40,10 @@ module Puppet::Parser::Functions
|
||||||
unless arg.is_a?(Array) then
|
unless arg.is_a?(Array) then
|
||||||
candidates = Array.new(1,arg)
|
candidates = Array.new(1,arg)
|
||||||
end
|
end
|
||||||
# iterate over all pathes within the candidates array
|
# iterate over all paths within the candidates array
|
||||||
candidates.each do |path|
|
candidates.each do |path|
|
||||||
# This logic was borrowed from
|
unless function_is_absolute_path([path])
|
||||||
# [lib/puppet/file_serving/base.rb](https://github.com/puppetlabs/puppet/blob/master/lib/puppet/file_serving/base.rb)
|
raise Puppet::ParseError, ("#{path.inspect} is not an absolute path.")
|
||||||
# Puppet 2.7 and beyond will have Puppet::Util.absolute_path? Fall back to a back-ported implementation otherwise.
|
|
||||||
if Puppet::Util.respond_to?(:absolute_path?) then
|
|
||||||
unless Puppet::Util.absolute_path?(path, :posix) or Puppet::Util.absolute_path?(path, :windows)
|
|
||||||
raise Puppet::ParseError, ("#{path.inspect} is not an absolute path.")
|
|
||||||
end
|
|
||||||
else
|
|
||||||
# This code back-ported from 2.7.x's lib/puppet/util.rb Puppet::Util.absolute_path?
|
|
||||||
# Determine in a platform-specific way whether a path is absolute. This
|
|
||||||
# defaults to the local platform if none is specified.
|
|
||||||
# Escape once for the string literal, and once for the regex.
|
|
||||||
slash = '[\\\\/]'
|
|
||||||
name = '[^\\\\/]+'
|
|
||||||
regexes = {
|
|
||||||
:windows => %r!^(([A-Z]:#{slash})|(#{slash}#{slash}#{name}#{slash}#{name})|(#{slash}#{slash}\?#{slash}#{name}))!i,
|
|
||||||
:posix => %r!^/!,
|
|
||||||
}
|
|
||||||
rval = (!!(path =~ regexes[:posix])) || (!!(path =~ regexes[:windows]))
|
|
||||||
rval or raise Puppet::ParseError, ("#{path.inspect} is not an absolute path.")
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -53,7 +53,7 @@ module Puppet::Parser::Functions
|
||||||
rescue Puppet::ExecutionFailure => detail
|
rescue Puppet::ExecutionFailure => detail
|
||||||
msg += "\n#{detail}"
|
msg += "\n#{detail}"
|
||||||
raise Puppet::ParseError, msg
|
raise Puppet::ParseError, msg
|
||||||
rescue Exception => detail
|
rescue StandardError => detail
|
||||||
msg += "\n#{detail.class.name} #{detail}"
|
msg += "\n#{detail.class.name} #{detail}"
|
||||||
raise Puppet::ParseError, msg
|
raise Puppet::ParseError, msg
|
||||||
ensure
|
ensure
|
||||||
|
|
31
lib/puppet/parser/functions/validate_email_address.rb
Normal file
31
lib/puppet/parser/functions/validate_email_address.rb
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:validate_email_address, :doc => <<-ENDHEREDOC
|
||||||
|
Validate that all values passed are valid email addresses.
|
||||||
|
Fail compilation if any value fails this check.
|
||||||
|
The following values will pass:
|
||||||
|
$my_email = "waldo@gmail.com"
|
||||||
|
validate_email_address($my_email)
|
||||||
|
validate_email_address("bob@gmail.com", "alice@gmail.com", $my_email)
|
||||||
|
|
||||||
|
The following values will fail, causing compilation to abort:
|
||||||
|
$some_array = [ 'bad_email@/d/efdf.com' ]
|
||||||
|
validate_email_address($some_array)
|
||||||
|
ENDHEREDOC
|
||||||
|
) do |args|
|
||||||
|
rescuable_exceptions = [ArgumentError]
|
||||||
|
|
||||||
|
if args.empty?
|
||||||
|
raise Puppet::ParseError, "validate_email_address(): wrong number of arguments (#{args.length}; must be > 0)"
|
||||||
|
end
|
||||||
|
|
||||||
|
args.each do |arg|
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a string." unless arg.is_a?(String)
|
||||||
|
|
||||||
|
begin
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a valid email address" unless function_is_email_address([arg])
|
||||||
|
rescue *rescuable_exceptions
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a valid email address"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -49,7 +49,7 @@ module Puppet::Parser::Functions
|
||||||
|
|
||||||
Plus all of the above, but any combination of values passed as strings ('false' or "false").
|
Plus all of the above, but any combination of values passed as strings ('false' or "false").
|
||||||
Plus all of the above, but with incorrect combinations of negative integer values.
|
Plus all of the above, but with incorrect combinations of negative integer values.
|
||||||
Plus all of the above, but with non-integer crap in arrays or maximum / minimum argument.
|
Plus all of the above, but with non-integer items in arrays or maximum / minimum argument.
|
||||||
|
|
||||||
ENDHEREDOC
|
ENDHEREDOC
|
||||||
|
|
||||||
|
|
50
lib/puppet/parser/functions/validate_ip_address.rb
Normal file
50
lib/puppet/parser/functions/validate_ip_address.rb
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
|
||||||
|
newfunction(:validate_ip_address, :doc => <<-ENDHEREDOC
|
||||||
|
Validate that all values passed are valid IP addresses,
|
||||||
|
regardless they are IPv4 or IPv6
|
||||||
|
Fail compilation if any value fails this check.
|
||||||
|
The following values will pass:
|
||||||
|
$my_ip = "1.2.3.4"
|
||||||
|
validate_ip_address($my_ip)
|
||||||
|
validate_ip_address("8.8.8.8", "172.16.0.1", $my_ip)
|
||||||
|
|
||||||
|
$my_ip = "3ffe:505:2"
|
||||||
|
validate_ip_address(1)
|
||||||
|
validate_ip_address($my_ip)
|
||||||
|
validate_ip_address("fe80::baf6:b1ff:fe19:7507", $my_ip)
|
||||||
|
|
||||||
|
The following values will fail, causing compilation to abort:
|
||||||
|
$some_array = [ 1, true, false, "garbage string", "3ffe:505:2" ]
|
||||||
|
validate_ip_address($some_array)
|
||||||
|
ENDHEREDOC
|
||||||
|
) do |args|
|
||||||
|
|
||||||
|
require "ipaddr"
|
||||||
|
rescuable_exceptions = [ ArgumentError ]
|
||||||
|
|
||||||
|
if defined?(IPAddr::InvalidAddressError)
|
||||||
|
rescuable_exceptions << IPAddr::InvalidAddressError
|
||||||
|
end
|
||||||
|
|
||||||
|
unless args.length > 0 then
|
||||||
|
raise Puppet::ParseError, ("validate_ip_address(): wrong number of arguments (#{args.length}; must be > 0)")
|
||||||
|
end
|
||||||
|
|
||||||
|
args.each do |arg|
|
||||||
|
unless arg.is_a?(String)
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a string."
|
||||||
|
end
|
||||||
|
|
||||||
|
begin
|
||||||
|
unless IPAddr.new(arg).ipv4? or IPAddr.new(arg).ipv6?
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a valid IP address."
|
||||||
|
end
|
||||||
|
rescue *rescuable_exceptions
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a valid IP address."
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -8,7 +8,7 @@ module Puppet::Parser::Functions
|
||||||
|
|
||||||
$my_ip = "1.2.3.4"
|
$my_ip = "1.2.3.4"
|
||||||
validate_ipv4_address($my_ip)
|
validate_ipv4_address($my_ip)
|
||||||
validate_bool("8.8.8.8", "172.16.0.1", $my_ip)
|
validate_ipv4_address("8.8.8.8", "172.16.0.1", $my_ip)
|
||||||
|
|
||||||
The following values will fail, causing compilation to abort:
|
The following values will fail, causing compilation to abort:
|
||||||
|
|
||||||
|
|
|
@ -23,16 +23,23 @@ module Puppet::Parser::Functions
|
||||||
|
|
||||||
validate_re($::puppetversion, '^2.7', 'The $puppetversion fact value does not match 2.7')
|
validate_re($::puppetversion, '^2.7', 'The $puppetversion fact value does not match 2.7')
|
||||||
|
|
||||||
|
Note: Compilation will also abort, if the first argument is not a String. Always use
|
||||||
|
quotes to force stringification:
|
||||||
|
|
||||||
|
validate_re("${::operatingsystemmajrelease}", '^[57]$')
|
||||||
|
|
||||||
ENDHEREDOC
|
ENDHEREDOC
|
||||||
if (args.length < 2) or (args.length > 3) then
|
if (args.length < 2) or (args.length > 3) then
|
||||||
raise Puppet::ParseError, ("validate_re(): wrong number of arguments (#{args.length}; must be 2 or 3)")
|
raise Puppet::ParseError, "validate_re(): wrong number of arguments (#{args.length}; must be 2 or 3)"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
raise Puppet::ParseError, "validate_re(): input needs to be a String, not a #{args[0].class}" unless args[0].is_a? String
|
||||||
|
|
||||||
msg = args[2] || "validate_re(): #{args[0].inspect} does not match #{args[1].inspect}"
|
msg = args[2] || "validate_re(): #{args[0].inspect} does not match #{args[1].inspect}"
|
||||||
|
|
||||||
# We're using a flattened array here because we can't call String#any? in
|
# We're using a flattened array here because we can't call String#any? in
|
||||||
# Ruby 1.9 like we can in Ruby 1.8
|
# Ruby 1.9 like we can in Ruby 1.8
|
||||||
raise Puppet::ParseError, (msg) unless [args[1]].flatten.any? do |re_str|
|
raise Puppet::ParseError, msg unless [args[1]].flatten.any? do |re_str|
|
||||||
args[0] =~ Regexp.compile(re_str)
|
args[0] =~ Regexp.compile(re_str)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@ module Puppet::Parser::Functions
|
||||||
newfunction(:validate_slength, :doc => <<-'ENDHEREDOC') do |args|
|
newfunction(:validate_slength, :doc => <<-'ENDHEREDOC') do |args|
|
||||||
Validate that the first argument is a string (or an array of strings), and
|
Validate that the first argument is a string (or an array of strings), and
|
||||||
less/equal to than the length of the second argument. An optional third
|
less/equal to than the length of the second argument. An optional third
|
||||||
parameter can be given a the minimum length. It fails if the first
|
parameter can be given the minimum length. It fails if the first
|
||||||
argument is not a string or array of strings, and if arg 2 and arg 3 are
|
argument is not a string or array of strings, and if arg 2 and arg 3 are
|
||||||
not convertable to a number.
|
not convertable to a number.
|
||||||
|
|
||||||
|
@ -43,9 +43,7 @@ module Puppet::Parser::Functions
|
||||||
min_length = 0
|
min_length = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
if min_length > max_length
|
raise Puppet::ParseError, "validate_slength(): Expected second argument to be equal to or larger than third argument" unless max_length >= min_length
|
||||||
raise Puppet::ParseError, "validate_slength(): Expected second argument to be larger than third argument"
|
|
||||||
end
|
|
||||||
|
|
||||||
validator = lambda do |str|
|
validator = lambda do |str|
|
||||||
unless str.length <= max_length and str.length >= min_length
|
unless str.length <= max_length and str.length >= min_length
|
||||||
|
|
47
lib/puppet/parser/functions/validate_x509_rsa_key_pair.rb
Normal file
47
lib/puppet/parser/functions/validate_x509_rsa_key_pair.rb
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
|
||||||
|
newfunction(:validate_x509_rsa_key_pair, :doc => <<-ENDHEREDOC
|
||||||
|
Validates a PEM-formatted X.509 certificate and RSA private key using
|
||||||
|
OpenSSL. Verifies that the certficate's signature was created from the
|
||||||
|
supplied key.
|
||||||
|
|
||||||
|
Fail compilation if any value fails this check.
|
||||||
|
|
||||||
|
validate_x509_rsa_key_pair($cert, $key)
|
||||||
|
|
||||||
|
ENDHEREDOC
|
||||||
|
) do |args|
|
||||||
|
|
||||||
|
require 'openssl'
|
||||||
|
|
||||||
|
NUM_ARGS = 2 unless defined? NUM_ARGS
|
||||||
|
|
||||||
|
unless args.length == NUM_ARGS then
|
||||||
|
raise Puppet::ParseError,
|
||||||
|
("validate_x509_rsa_key_pair(): wrong number of arguments (#{args.length}; must be #{NUM_ARGS})")
|
||||||
|
end
|
||||||
|
|
||||||
|
args.each do |arg|
|
||||||
|
unless arg.is_a?(String)
|
||||||
|
raise Puppet::ParseError, "#{arg.inspect} is not a string."
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
begin
|
||||||
|
cert = OpenSSL::X509::Certificate.new(args[0])
|
||||||
|
rescue OpenSSL::X509::CertificateError => e
|
||||||
|
raise Puppet::ParseError, "Not a valid x509 certificate: #{e}"
|
||||||
|
end
|
||||||
|
|
||||||
|
begin
|
||||||
|
key = OpenSSL::PKey::RSA.new(args[1])
|
||||||
|
rescue OpenSSL::PKey::RSAError => e
|
||||||
|
raise Puppet::ParseError, "Not a valid RSA key: #{e}"
|
||||||
|
end
|
||||||
|
|
||||||
|
unless cert.verify(key)
|
||||||
|
raise Puppet::ParseError, "Certificate signature does not match supplied key"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -1,24 +1,31 @@
|
||||||
Puppet::Type.type(:file_line).provide(:ruby) do
|
Puppet::Type.type(:file_line).provide(:ruby) do
|
||||||
def exists?
|
def exists?
|
||||||
lines.find do |line|
|
if resource[:replace].to_s != 'true' and count_matches(match_regex) > 0
|
||||||
line.chomp == resource[:line].chomp
|
true
|
||||||
|
else
|
||||||
|
lines.find do |line|
|
||||||
|
line.chomp == resource[:line].chomp
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def create
|
def create
|
||||||
if resource[:match]
|
unless resource[:replace].to_s != 'true' and count_matches(match_regex) > 0
|
||||||
handle_create_with_match
|
if resource[:match]
|
||||||
elsif resource[:after]
|
handle_create_with_match
|
||||||
handle_create_with_after
|
elsif resource[:after]
|
||||||
else
|
handle_create_with_after
|
||||||
append_line
|
else
|
||||||
|
append_line
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
local_lines = lines
|
if resource[:match_for_absence].to_s == 'true' and resource[:match]
|
||||||
File.open(resource[:path],'w') do |fh|
|
handle_destroy_with_match
|
||||||
fh.write(local_lines.reject{|l| l.chomp == resource[:line] }.join(''))
|
else
|
||||||
|
handle_destroy_line
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -32,10 +39,13 @@ Puppet::Type.type(:file_line).provide(:ruby) do
|
||||||
@lines ||= File.readlines(resource[:path])
|
@lines ||= File.readlines(resource[:path])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def match_regex
|
||||||
|
resource[:match] ? Regexp.new(resource[:match]) : nil
|
||||||
|
end
|
||||||
|
|
||||||
def handle_create_with_match()
|
def handle_create_with_match()
|
||||||
regex = resource[:match] ? Regexp.new(resource[:match]) : nil
|
|
||||||
regex_after = resource[:after] ? Regexp.new(resource[:after]) : nil
|
regex_after = resource[:after] ? Regexp.new(resource[:after]) : nil
|
||||||
match_count = count_matches(regex)
|
match_count = count_matches(match_regex)
|
||||||
|
|
||||||
if match_count > 1 && resource[:multiple].to_s != 'true'
|
if match_count > 1 && resource[:multiple].to_s != 'true'
|
||||||
raise Puppet::Error, "More than one line in file '#{resource[:path]}' matches pattern '#{resource[:match]}'"
|
raise Puppet::Error, "More than one line in file '#{resource[:path]}' matches pattern '#{resource[:match]}'"
|
||||||
|
@ -43,7 +53,7 @@ Puppet::Type.type(:file_line).provide(:ruby) do
|
||||||
|
|
||||||
File.open(resource[:path], 'w') do |fh|
|
File.open(resource[:path], 'w') do |fh|
|
||||||
lines.each do |l|
|
lines.each do |l|
|
||||||
fh.puts(regex.match(l) ? resource[:line] : l)
|
fh.puts(match_regex.match(l) ? resource[:line] : l)
|
||||||
if (match_count == 0 and regex_after)
|
if (match_count == 0 and regex_after)
|
||||||
if regex_after.match(l)
|
if regex_after.match(l)
|
||||||
fh.puts(resource[:line])
|
fh.puts(resource[:line])
|
||||||
|
@ -84,6 +94,25 @@ Puppet::Type.type(:file_line).provide(:ruby) do
|
||||||
lines.select{|l| l.match(regex)}.size
|
lines.select{|l| l.match(regex)}.size
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def handle_destroy_with_match
|
||||||
|
match_count = count_matches(match_regex)
|
||||||
|
if match_count > 1 && resource[:multiple].to_s != 'true'
|
||||||
|
raise Puppet::Error, "More than one line in file '#{resource[:path]}' matches pattern '#{resource[:match]}'"
|
||||||
|
end
|
||||||
|
|
||||||
|
local_lines = lines
|
||||||
|
File.open(resource[:path],'w') do |fh|
|
||||||
|
fh.write(local_lines.reject{|l| match_regex.match(l) }.join(''))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def handle_destroy_line
|
||||||
|
local_lines = lines
|
||||||
|
File.open(resource[:path],'w') do |fh|
|
||||||
|
fh.write(local_lines.reject{|l| l.chomp == resource[:line] }.join(''))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
##
|
##
|
||||||
# append the line to the file.
|
# append the line to the file.
|
||||||
#
|
#
|
||||||
|
|
|
@ -4,7 +4,7 @@ Puppet::Type.newtype(:file_line) do
|
||||||
Ensures that a given line is contained within a file. The implementation
|
Ensures that a given line is contained within a file. The implementation
|
||||||
matches the full line, including whitespace at the beginning and end. If
|
matches the full line, including whitespace at the beginning and end. If
|
||||||
the line is not contained in the given file, Puppet will append the line to
|
the line is not contained in the given file, Puppet will append the line to
|
||||||
the end of the file to ensure the desired state. Multiple resources may
|
the end of the file to ensure the desired state. Multiple resources may
|
||||||
be declared to manage multiple lines in the same file.
|
be declared to manage multiple lines in the same file.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
@ -31,12 +31,25 @@ Puppet::Type.newtype(:file_line) do
|
||||||
match => '^export\ HTTP_PROXY\=',
|
match => '^export\ HTTP_PROXY\=',
|
||||||
}
|
}
|
||||||
|
|
||||||
In this code example match will look for a line beginning with export
|
In this code example match will look for a line beginning with export
|
||||||
followed by HTTP_PROXY and replace it with the value in line.
|
followed by HTTP_PROXY and replace it with the value in line.
|
||||||
|
|
||||||
|
Match Example With `ensure => absent`:
|
||||||
|
|
||||||
|
file_line { 'bashrc_proxy':
|
||||||
|
ensure => absent,
|
||||||
|
path => '/etc/bashrc',
|
||||||
|
line => 'export HTTP_PROXY=http://squid.puppetlabs.vm:3128',
|
||||||
|
match => '^export\ HTTP_PROXY\=',
|
||||||
|
match_for_absence => true,
|
||||||
|
}
|
||||||
|
|
||||||
|
In this code example match will look for a line beginning with export
|
||||||
|
followed by HTTP_PROXY and delete it. If multiple lines match, an
|
||||||
|
error will be raised unless the `multiple => true` parameter is set.
|
||||||
|
|
||||||
**Autorequires:** If Puppet is managing the file that will contain the line
|
**Autorequires:** If Puppet is managing the file that will contain the line
|
||||||
being managed, the file_line resource will autorequire that file.
|
being managed, the file_line resource will autorequire that file.
|
||||||
|
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
ensurable do
|
ensurable do
|
||||||
|
@ -49,10 +62,18 @@ Puppet::Type.newtype(:file_line) do
|
||||||
end
|
end
|
||||||
|
|
||||||
newparam(:match) do
|
newparam(:match) do
|
||||||
desc 'An optional ruby regular expression to run against existing lines in the file.' +
|
desc 'An optional ruby regular expression to run against existing lines in the file.' +
|
||||||
' If a match is found, we replace that line rather than adding a new line.' +
|
' If a match is found, we replace that line rather than adding a new line.' +
|
||||||
' A regex comparisson is performed against the line value and if it does not' +
|
' A regex comparison is performed against the line value and if it does not' +
|
||||||
' match an exception will be raised. '
|
' match an exception will be raised.'
|
||||||
|
end
|
||||||
|
|
||||||
|
newparam(:match_for_absence) do
|
||||||
|
desc 'An optional value to determine if match should be applied when ensure => absent.' +
|
||||||
|
' If set to true and match is set, the line that matches match will be deleted.' +
|
||||||
|
' If set to false (the default), match is ignored when ensure => absent.'
|
||||||
|
newvalues(true, false)
|
||||||
|
defaultto false
|
||||||
end
|
end
|
||||||
|
|
||||||
newparam(:multiple) do
|
newparam(:multiple) do
|
||||||
|
@ -72,20 +93,31 @@ Puppet::Type.newtype(:file_line) do
|
||||||
newparam(:path) do
|
newparam(:path) do
|
||||||
desc 'The file Puppet will ensure contains the line specified by the line parameter.'
|
desc 'The file Puppet will ensure contains the line specified by the line parameter.'
|
||||||
validate do |value|
|
validate do |value|
|
||||||
unless (Puppet.features.posix? and value =~ /^\//) or (Puppet.features.microsoft_windows? and (value =~ /^.:\// or value =~ /^\/\/[^\/]+\/[^\/]+/))
|
unless Puppet::Util.absolute_path?(value)
|
||||||
raise(Puppet::Error, "File paths must be fully qualified, not '#{value}'")
|
raise Puppet::Error, "File paths must be fully qualified, not '#{value}'"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
newparam(:replace) do
|
||||||
|
desc 'If true, replace line that matches. If false, do not write line if a match is found'
|
||||||
|
newvalues(true, false)
|
||||||
|
defaultto true
|
||||||
|
end
|
||||||
|
|
||||||
# Autorequire the file resource if it's being managed
|
# Autorequire the file resource if it's being managed
|
||||||
autorequire(:file) do
|
autorequire(:file) do
|
||||||
self[:path]
|
self[:path]
|
||||||
end
|
end
|
||||||
|
|
||||||
validate do
|
validate do
|
||||||
unless self[:line] and self[:path]
|
unless self[:line]
|
||||||
raise(Puppet::Error, "Both line and path are required attributes")
|
unless (self[:ensure].to_s == 'absent') and (self[:match_for_absence].to_s == 'true') and self[:match]
|
||||||
|
raise(Puppet::Error, "line is a required attribute")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
unless self[:path]
|
||||||
|
raise(Puppet::Error, "path is a required attribute")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -14,5 +14,5 @@
|
||||||
# Requires: nothing
|
# Requires: nothing
|
||||||
#
|
#
|
||||||
class stdlib {
|
class stdlib {
|
||||||
include stdlib::stages
|
include ::stdlib::stages
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
# Sample Usage:
|
# Sample Usage:
|
||||||
#
|
#
|
||||||
# node default {
|
# node default {
|
||||||
# include stdlib
|
# include ::stdlib
|
||||||
# class { java: stage => 'runtime' }
|
# class { java: stage => 'runtime' }
|
||||||
# }
|
# }
|
||||||
#
|
#
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "puppetlabs-stdlib",
|
"name": "puppetlabs-stdlib",
|
||||||
"version": "4.6.0",
|
"version": "4.12.0",
|
||||||
"author": "puppetlabs",
|
"author": "puppetlabs",
|
||||||
"summary": "Standard library of resources for Puppet modules.",
|
"summary": "Standard library of resources for Puppet modules.",
|
||||||
"license": "Apache-2.0",
|
"license": "Apache-2.0",
|
||||||
|
@ -56,7 +56,8 @@
|
||||||
"operatingsystem": "Debian",
|
"operatingsystem": "Debian",
|
||||||
"operatingsystemrelease": [
|
"operatingsystemrelease": [
|
||||||
"6",
|
"6",
|
||||||
"7"
|
"7",
|
||||||
|
"8"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -71,7 +72,8 @@
|
||||||
"operatingsystem": "Solaris",
|
"operatingsystem": "Solaris",
|
||||||
"operatingsystemrelease": [
|
"operatingsystemrelease": [
|
||||||
"10",
|
"10",
|
||||||
"11"
|
"11",
|
||||||
|
"12"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -99,11 +101,11 @@
|
||||||
"requirements": [
|
"requirements": [
|
||||||
{
|
{
|
||||||
"name": "pe",
|
"name": "pe",
|
||||||
"version_requirement": "3.x"
|
"version_requirement": ">= 3.0.0 < 2015.4.0"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "puppet",
|
"name": "puppet",
|
||||||
"version_requirement": ">=2.7.20 <4.0.0"
|
"version_requirement": ">=2.7.20 <5.0.0"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": "Standard Library for Puppet Modules",
|
"description": "Standard Library for Puppet Modules",
|
||||||
|
|
40
spec/acceptance/clamp_spec.rb
Executable file
40
spec/acceptance/clamp_spec.rb
Executable file
|
@ -0,0 +1,40 @@
|
||||||
|
#! /usr/bin/env ruby -S rspec
|
||||||
|
require 'spec_helper_acceptance'
|
||||||
|
|
||||||
|
describe 'clamp function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
|
describe 'success' do
|
||||||
|
it 'clamps list of values' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$x = 17
|
||||||
|
$y = 225
|
||||||
|
$z = 155
|
||||||
|
$o = clamp($x, $y, $z)
|
||||||
|
if $o == $z {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'clamps array of values' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = [7, 19, 66]
|
||||||
|
$b = 19
|
||||||
|
$o = clamp($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
describe 'failure' do
|
||||||
|
it 'handles improper argument counts'
|
||||||
|
it 'handles no arguments'
|
||||||
|
end
|
||||||
|
end
|
|
@ -34,6 +34,20 @@ describe 'concat function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('oper
|
||||||
}
|
}
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true)
|
||||||
|
end
|
||||||
|
it 'should concat hash arguments' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$output = concat([{"a" => "b"}], {"c" => "d", "e" => "f"})
|
||||||
|
validate_array($output)
|
||||||
|
if size($output) != 2 {
|
||||||
|
fail("${output} should have 2 elements.")
|
||||||
|
}
|
||||||
|
if $output[1] != {"c" => "d", "e" => "f"} {
|
||||||
|
fail("${output} does not have the expected hash for the second element.")
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true)
|
apply_manifest(pp, :catch_failures => true)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -27,6 +27,20 @@ describe 'empty function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('opera
|
||||||
}
|
}
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'handles numerical values' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = 7
|
||||||
|
$b = false
|
||||||
|
$o = empty($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/Notice: output correct/)
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,22 +0,0 @@
|
||||||
#! /usr/bin/env ruby -S rspec
|
|
||||||
require 'spec_helper_acceptance'
|
|
||||||
|
|
||||||
describe 'ensure_packages function', :unless => fact('osfamily') =~ /windows/i do
|
|
||||||
describe 'success' do
|
|
||||||
it 'ensure_packages a package' do
|
|
||||||
apply_manifest('package { "rake": ensure => absent, provider => "gem", }')
|
|
||||||
pp = <<-EOS
|
|
||||||
$a = "rake"
|
|
||||||
ensure_packages($a,{'provider' => 'gem'})
|
|
||||||
EOS
|
|
||||||
|
|
||||||
apply_manifest(pp, :expect_changes => true)
|
|
||||||
end
|
|
||||||
it 'ensures a package already declared'
|
|
||||||
it 'takes defaults arguments'
|
|
||||||
end
|
|
||||||
describe 'failure' do
|
|
||||||
it 'handles no arguments'
|
|
||||||
it 'handles non strings'
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,18 +1,26 @@
|
||||||
#! /usr/bin/env ruby -S rspec
|
#! /usr/bin/env ruby -S rspec
|
||||||
require 'spec_helper_acceptance'
|
require 'spec_helper_acceptance'
|
||||||
|
|
||||||
describe 'ensure_resource function', :unless => fact('osfamily') =~ /windows/i do
|
describe 'ensure_resource function' do
|
||||||
describe 'success' do
|
describe 'success' do
|
||||||
it 'ensure_resource a package' do
|
it 'ensures a resource already declared' do
|
||||||
apply_manifest('package { "rake": ensure => absent, provider => "gem", }')
|
apply_manifest('')
|
||||||
pp = <<-EOS
|
pp = <<-EOS
|
||||||
$a = "rake"
|
notify { "test": loglevel => 'err' }
|
||||||
ensure_resource('package', $a, {'provider' => 'gem'})
|
ensure_resource('notify', 'test', { 'loglevel' => 'err' })
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :expect_changes => true)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'ensures a undeclared resource' do
|
||||||
|
apply_manifest('')
|
||||||
|
pp = <<-EOS
|
||||||
|
ensure_resource('notify', 'test', { 'loglevel' => 'err' })
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
apply_manifest(pp, :expect_changes => true)
|
apply_manifest(pp, :expect_changes => true)
|
||||||
end
|
end
|
||||||
it 'ensures a resource already declared'
|
|
||||||
it 'takes defaults arguments'
|
it 'takes defaults arguments'
|
||||||
end
|
end
|
||||||
describe 'failure' do
|
describe 'failure' do
|
||||||
|
|
|
@ -3,80 +3,59 @@ require 'spec_helper_acceptance'
|
||||||
|
|
||||||
describe 'fqdn_rand_string function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
describe 'fqdn_rand_string function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
describe 'success' do
|
describe 'success' do
|
||||||
let(:facts_d) do
|
include_context "with faked facts"
|
||||||
if fact('is_pe', '--puppet') == "true"
|
context "when the FQDN is 'fakehost.localdomain'" do
|
||||||
if fact('osfamily') =~ /windows/i
|
before :each do
|
||||||
if fact('kernelmajversion').to_f < 6.0
|
fake_fact("fqdn", "fakehost.localdomain")
|
||||||
'c:/documents and settings/all users/application data/puppetlabs/facter/facts.d'
|
end
|
||||||
else
|
|
||||||
'c:/programdata/puppetlabs/facter/facts.d'
|
it 'generates random alphanumeric strings' do
|
||||||
end
|
pp = <<-eos
|
||||||
else
|
$l = 10
|
||||||
'/etc/puppetlabs/facter/facts.d'
|
$o = fqdn_rand_string($l)
|
||||||
|
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
||||||
|
eos
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/fqdn_rand_string is "(7oDp0KOr1b|9Acvnhkt4J)"/)
|
||||||
end
|
end
|
||||||
else
|
|
||||||
'/etc/facter/facts.d'
|
|
||||||
end
|
end
|
||||||
end
|
it 'generates random alphanumeric strings with custom charsets' do
|
||||||
after :each do
|
pp = <<-eos
|
||||||
shell("if [ -f '#{facts_d}/fqdn.txt' ] ; then rm '#{facts_d}/fqdn.txt' ; fi")
|
$l = 10
|
||||||
end
|
$c = '0123456789'
|
||||||
before :each do
|
$o = fqdn_rand_string($l, $c)
|
||||||
#no need to create on windows, pe creates by default
|
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
||||||
if fact('osfamily') !~ /windows/i
|
eos
|
||||||
shell("mkdir -p '#{facts_d}'")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
it 'generates random alphanumeric strings' do
|
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
|
||||||
pp = <<-eos
|
|
||||||
$l = 10
|
|
||||||
$o = fqdn_rand_string($l)
|
|
||||||
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
|
||||||
eos
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/fqdn_rand_string is "7oDp0KOr1b"/)
|
expect(r.stdout).to match(/fqdn_rand_string is "(7203048515|2383756694)"/)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
it 'generates random alphanumeric strings with custom seeds' do
|
||||||
it 'generates random alphanumeric strings with custom charsets' do
|
pp = <<-eos
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
$l = 10
|
||||||
pp = <<-eos
|
$s = 'seed'
|
||||||
$l = 10
|
$o = fqdn_rand_string($l, undef, $s)
|
||||||
$c = '0123456789'
|
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
||||||
$o = fqdn_rand_string($l, $c)
|
eos
|
||||||
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
|
||||||
eos
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/fqdn_rand_string is "7203048515"/)
|
expect(r.stdout).to match(/fqdn_rand_string is "(3HS4mbuI3E|1jJtAMs94d)"/)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
it 'generates random alphanumeric strings with custom charsets and seeds' do
|
||||||
it 'generates random alphanumeric strings with custom seeds' do
|
pp = <<-eos
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
$l = 10
|
||||||
pp = <<-eos
|
$c = '0123456789'
|
||||||
$l = 10
|
$s = 'seed'
|
||||||
$s = 'seed'
|
$o = fqdn_rand_string($l, $c, $s)
|
||||||
$o = fqdn_rand_string($l, undef, $s)
|
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
||||||
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
eos
|
||||||
eos
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/fqdn_rand_string is "3HS4mbuI3E"/)
|
expect(r.stdout).to match(/fqdn_rand_string is "(3104058232|7100592312)"/)
|
||||||
end
|
end
|
||||||
end
|
|
||||||
it 'generates random alphanumeric strings with custom charsets and seeds' do
|
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
|
||||||
pp = <<-eos
|
|
||||||
$l = 10
|
|
||||||
$c = '0123456789'
|
|
||||||
$s = 'seed'
|
|
||||||
$o = fqdn_rand_string($l, $c, $s)
|
|
||||||
notice(inline_template('fqdn_rand_string is <%= @o.inspect %>'))
|
|
||||||
eos
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
|
||||||
expect(r.stdout).to match(/fqdn_rand_string is "3104058232"/)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -3,78 +3,57 @@ require 'spec_helper_acceptance'
|
||||||
|
|
||||||
describe 'fqdn_rotate function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
describe 'fqdn_rotate function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
describe 'success' do
|
describe 'success' do
|
||||||
let(:facts_d) do
|
include_context "with faked facts"
|
||||||
if fact('is_pe', '--puppet') == "true"
|
context "when the FQDN is 'fakehost.localdomain'" do
|
||||||
if fact('osfamily') =~ /windows/i
|
before :each do
|
||||||
if fact('kernelmajversion').to_f < 6.0
|
fake_fact("fqdn", "fakehost.localdomain")
|
||||||
'C:/Documents and Settings/All Users/Application Data/PuppetLabs/facter/facts.d'
|
end
|
||||||
else
|
|
||||||
'C:/ProgramData/PuppetLabs/facter/facts.d'
|
it 'rotates arrays' do
|
||||||
end
|
pp = <<-EOS
|
||||||
else
|
$a = ['a','b','c','d']
|
||||||
'/etc/puppetlabs/facter/facts.d'
|
$o = fqdn_rotate($a)
|
||||||
|
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/fqdn_rotate is \["d", "a", "b", "c"\]/)
|
||||||
end
|
end
|
||||||
else
|
|
||||||
'/etc/facter/facts.d'
|
|
||||||
end
|
end
|
||||||
end
|
it 'rotates arrays with custom seeds' do
|
||||||
after :each do
|
pp = <<-EOS
|
||||||
shell("if [ -f '#{facts_d}/fqdn.txt' ] ; then rm '#{facts_d}/fqdn.txt' ; fi")
|
$a = ['a','b','c','d']
|
||||||
end
|
$s = 'seed'
|
||||||
before :each do
|
$o = fqdn_rotate($a, $s)
|
||||||
#No need to create on windows, PE creates by default
|
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
||||||
if fact('osfamily') !~ /windows/i
|
EOS
|
||||||
shell("mkdir -p '#{facts_d}'")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
it 'rotates arrays' do
|
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
|
||||||
pp = <<-EOS
|
|
||||||
$a = ['a','b','c','d']
|
|
||||||
$o = fqdn_rotate($a)
|
|
||||||
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
|
||||||
EOS
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/fqdn_rotate is \["d", "a", "b", "c"\]/)
|
expect(r.stdout).to match(/fqdn_rotate is \["c", "d", "a", "b"\]/)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
it 'rotates strings' do
|
||||||
it 'rotates arrays with custom seeds' do
|
pp = <<-EOS
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
$a = 'abcd'
|
||||||
pp = <<-EOS
|
$o = fqdn_rotate($a)
|
||||||
$a = ['a','b','c','d']
|
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
||||||
$s = 'seed'
|
EOS
|
||||||
$o = fqdn_rotate($a, $s)
|
|
||||||
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
|
||||||
EOS
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/fqdn_rotate is \["c", "d", "a", "b"\]/)
|
expect(r.stdout).to match(/fqdn_rotate is "dabc"/)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
it 'rotates strings with custom seeds' do
|
||||||
it 'rotates strings' do
|
pp = <<-EOS
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
$a = 'abcd'
|
||||||
pp = <<-EOS
|
$s = 'seed'
|
||||||
$a = 'abcd'
|
$o = fqdn_rotate($a, $s)
|
||||||
$o = fqdn_rotate($a)
|
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
||||||
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
EOS
|
||||||
EOS
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
expect(r.stdout).to match(/fqdn_rotate is "dabc"/)
|
expect(r.stdout).to match(/fqdn_rotate is "cdab"/)
|
||||||
end
|
end
|
||||||
end
|
|
||||||
it 'rotates strings with custom seeds' do
|
|
||||||
shell("echo fqdn=fakehost.localdomain > '#{facts_d}/fqdn.txt'")
|
|
||||||
pp = <<-EOS
|
|
||||||
$a = 'abcd'
|
|
||||||
$s = 'seed'
|
|
||||||
$o = fqdn_rotate($a, $s)
|
|
||||||
notice(inline_template('fqdn_rotate is <%= @o.inspect %>'))
|
|
||||||
EOS
|
|
||||||
|
|
||||||
apply_manifest(pp, :catch_failures => true) do |r|
|
|
||||||
expect(r.stdout).to match(/fqdn_rotate is "cdab"/)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
30
spec/acceptance/is_a_spec.rb
Normal file
30
spec/acceptance/is_a_spec.rb
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
#! /usr/bin/env ruby -S rspec
|
||||||
|
require 'spec_helper_acceptance'
|
||||||
|
|
||||||
|
if get_puppet_version =~ /^4/
|
||||||
|
describe 'is_a function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
|
it 'should match a string' do
|
||||||
|
pp = <<-EOS
|
||||||
|
if 'hello world'.is_a(String) {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should not match a integer as string' do
|
||||||
|
pp = <<-EOS
|
||||||
|
if 5.is_a(String) {
|
||||||
|
notify { 'output wrong': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).not_to match(/Notice: output wrong/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
52
spec/acceptance/is_ipv4_address_spec.rb
Executable file
52
spec/acceptance/is_ipv4_address_spec.rb
Executable file
|
@ -0,0 +1,52 @@
|
||||||
|
#! /usr/bin/env ruby -S rspec
|
||||||
|
require 'spec_helper_acceptance'
|
||||||
|
|
||||||
|
describe 'is_ipv4_address function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
|
describe 'success' do
|
||||||
|
it 'is_ipv4_addresss' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = '1.2.3.4'
|
||||||
|
$b = true
|
||||||
|
$o = is_ipv4_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'is_ipv4_addresss strings' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = "aoeu"
|
||||||
|
$b = false
|
||||||
|
$o = is_ipv4_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'is_ipv4_addresss ipv4 out of range' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = '1.2.3.400'
|
||||||
|
$b = false
|
||||||
|
$o = is_ipv4_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
describe 'failure' do
|
||||||
|
it 'handles improper argument counts'
|
||||||
|
end
|
||||||
|
end
|
66
spec/acceptance/is_ipv6_address_spec.rb
Executable file
66
spec/acceptance/is_ipv6_address_spec.rb
Executable file
|
@ -0,0 +1,66 @@
|
||||||
|
#! /usr/bin/env ruby -S rspec
|
||||||
|
require 'spec_helper_acceptance'
|
||||||
|
|
||||||
|
describe 'is_ipv6_address function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
|
describe 'success' do
|
||||||
|
it 'is_ipv6_addresss' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = "fe80:0000:cd12:d123:e2f8:47ff:fe09:dd74"
|
||||||
|
$b = true
|
||||||
|
$o = is_ipv6_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'is_ipv6_addresss ipv6 compressed' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = "fe00::1"
|
||||||
|
$b = true
|
||||||
|
$o = is_ipv6_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'is_ipv6_addresss strings' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = "aoeu"
|
||||||
|
$b = false
|
||||||
|
$o = is_ipv6_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
it 'is_ipv6_addresss ip out of range' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$a = 'fe80:0000:cd12:d123:e2f8:47ff:fe09:gggg'
|
||||||
|
$b = false
|
||||||
|
$o = is_ipv6_address($a)
|
||||||
|
if $o == $b {
|
||||||
|
notify { 'output correct': }
|
||||||
|
}
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/Notice: output correct/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
describe 'failure' do
|
||||||
|
it 'handles improper argument counts'
|
||||||
|
end
|
||||||
|
end
|
52
spec/acceptance/loadjson_spec.rb
Normal file
52
spec/acceptance/loadjson_spec.rb
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
#! /usr/bin/env ruby -S rspec
|
||||||
|
require 'spec_helper_acceptance'
|
||||||
|
|
||||||
|
tmpdir = default.tmpdir('stdlib')
|
||||||
|
|
||||||
|
describe 'loadjson function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('operatingsystem')) do
|
||||||
|
describe 'success' do
|
||||||
|
it 'loadjsons array of values' do
|
||||||
|
shell("echo '{\"aaa\":1,\"bbb\":2,\"ccc\":3,\"ddd\":4}' > #{tmpdir}/testjson.json")
|
||||||
|
pp = <<-EOS
|
||||||
|
$o = loadjson('#{tmpdir}/testjson.json')
|
||||||
|
notice(inline_template('loadjson[aaa] is <%= @o["aaa"].inspect %>'))
|
||||||
|
notice(inline_template('loadjson[bbb] is <%= @o["bbb"].inspect %>'))
|
||||||
|
notice(inline_template('loadjson[ccc] is <%= @o["ccc"].inspect %>'))
|
||||||
|
notice(inline_template('loadjson[ddd] is <%= @o["ddd"].inspect %>'))
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/loadjson\[aaa\] is 1/)
|
||||||
|
expect(r.stdout).to match(/loadjson\[bbb\] is 2/)
|
||||||
|
expect(r.stdout).to match(/loadjson\[ccc\] is 3/)
|
||||||
|
expect(r.stdout).to match(/loadjson\[ddd\] is 4/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns the default value if there is no file to load' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$o = loadjson('#{tmpdir}/no-file.json', {'default' => 'value'})
|
||||||
|
notice(inline_template('loadjson[default] is <%= @o["default"].inspect %>'))
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/loadjson\[default\] is "value"/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns the default value if the file was parsed with an error' do
|
||||||
|
shell("echo '!' > #{tmpdir}/testjson.json")
|
||||||
|
pp = <<-EOS
|
||||||
|
$o = loadjson('#{tmpdir}/testjson.json', {'default' => 'value'})
|
||||||
|
notice(inline_template('loadjson[default] is <%= @o["default"].inspect %>'))
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/loadjson\[default\] is "value"/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
describe 'failure' do
|
||||||
|
it 'fails with no arguments'
|
||||||
|
end
|
||||||
|
end
|
|
@ -26,6 +26,29 @@ describe 'loadyaml function', :unless => UNSUPPORTED_PLATFORMS.include?(fact('op
|
||||||
expect(r.stdout).to match(/loadyaml\[ddd\] is 4/)
|
expect(r.stdout).to match(/loadyaml\[ddd\] is 4/)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'returns the default value if there is no file to load' do
|
||||||
|
pp = <<-EOS
|
||||||
|
$o = loadyaml('#{tmpdir}/no-file.yaml', {'default' => 'value'})
|
||||||
|
notice(inline_template('loadyaml[default] is <%= @o["default"].inspect %>'))
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/loadyaml\[default\] is "value"/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns the default value if the file was parsed with an error' do
|
||||||
|
shell("echo '!' > #{tmpdir}/testyaml.yaml")
|
||||||
|
pp = <<-EOS
|
||||||
|
$o = loadyaml('#{tmpdir}/testyaml.yaml', {'default' => 'value'})
|
||||||
|
notice(inline_template('loadyaml[default] is <%= @o["default"].inspect %>'))
|
||||||
|
EOS
|
||||||
|
|
||||||
|
apply_manifest(pp, :catch_failures => true) do |r|
|
||||||
|
expect(r.stdout).to match(/loadyaml\[default\] is "value"/)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
describe 'failure' do
|
describe 'failure' do
|
||||||
it 'fails with no arguments'
|
it 'fails with no arguments'
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
HOSTS:
|
|
||||||
centos-59-x64:
|
|
||||||
roles:
|
|
||||||
- master
|
|
||||||
platform: el-5-x86_64
|
|
||||||
box : centos-59-x64-vbox4210-nocm
|
|
||||||
box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-59-x64-vbox4210-nocm.box
|
|
||||||
hypervisor : vagrant
|
|
||||||
CONFIG:
|
|
||||||
type: git
|
|
|
@ -1,15 +0,0 @@
|
||||||
HOSTS:
|
|
||||||
'centos-6-vcloud':
|
|
||||||
roles:
|
|
||||||
- master
|
|
||||||
platform: el-6-x86_64
|
|
||||||
hypervisor: vcloud
|
|
||||||
template: centos-6-x86_64
|
|
||||||
CONFIG:
|
|
||||||
type: foss
|
|
||||||
ssh:
|
|
||||||
keys: "~/.ssh/id_rsa-acceptance"
|
|
||||||
datastore: instance0
|
|
||||||
folder: Delivery/Quality Assurance/Enterprise/Dynamic
|
|
||||||
resourcepool: delivery/Quality Assurance/Enterprise/Dynamic
|
|
||||||
pooling_api: http://vcloud.delivery.puppetlabs.net/
|
|
|
@ -1,12 +0,0 @@
|
||||||
HOSTS:
|
|
||||||
centos-64-x64:
|
|
||||||
roles:
|
|
||||||
- master
|
|
||||||
- database
|
|
||||||
- dashboard
|
|
||||||
platform: el-6-x86_64
|
|
||||||
box : centos-64-x64-vbox4210-nocm
|
|
||||||
box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-64-x64-vbox4210-nocm.box
|
|
||||||
hypervisor : vagrant
|
|
||||||
CONFIG:
|
|
||||||
type: pe
|
|
|
@ -1,10 +0,0 @@
|
||||||
HOSTS:
|
|
||||||
centos-64-x64:
|
|
||||||
roles:
|
|
||||||
- master
|
|
||||||
platform: el-6-x86_64
|
|
||||||
box : centos-64-x64-vbox4210-nocm
|
|
||||||
box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-64-x64-vbox4210-nocm.box
|
|
||||||
hypervisor : vagrant
|
|
||||||
CONFIG:
|
|
||||||
type: foss
|
|
|
@ -1,10 +0,0 @@
|
||||||
HOSTS:
|
|
||||||
centos-65-x64:
|
|
||||||
roles:
|
|
||||||
- master
|
|
||||||
platform: el-6-x86_64
|
|
||||||
box : centos-65-x64-vbox436-nocm
|
|
||||||
box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-65-x64-virtualbox-nocm.box
|
|
||||||
hypervisor : vagrant
|
|
||||||
CONFIG:
|
|
||||||
type: foss
|
|
10
spec/acceptance/nodesets/centos-7-x64.yml
Normal file
10
spec/acceptance/nodesets/centos-7-x64.yml
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
HOSTS:
|
||||||
|
centos-7-x64:
|
||||||
|
roles:
|
||||||
|
- agent
|
||||||
|
- default
|
||||||
|
platform: redhat-7-x86_64
|
||||||
|
hypervisor: vagrant
|
||||||
|
box: puppetlabs/centos-7.2-64-nocm
|
||||||
|
CONFIG:
|
||||||
|
type: foss
|
10
spec/acceptance/nodesets/debian-8-x64.yml
Normal file
10
spec/acceptance/nodesets/debian-8-x64.yml
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
HOSTS:
|
||||||
|
debian-8-x64:
|
||||||
|
roles:
|
||||||
|
- agent
|
||||||
|
- default
|
||||||
|
platform: debian-8-amd64
|
||||||
|
hypervisor: vagrant
|
||||||
|
box: puppetlabs/debian-8.2-64-nocm
|
||||||
|
CONFIG:
|
||||||
|
type: foss
|
|
@ -1,10 +1,10 @@
|
||||||
HOSTS:
|
HOSTS:
|
||||||
centos-65-x64:
|
ubuntu-1404-x64:
|
||||||
roles:
|
roles:
|
||||||
- master
|
- agent
|
||||||
platform: el-6-x86_64
|
- default
|
||||||
box : centos-65-x64-vbox436-nocm
|
platform: ubuntu-14.04-amd64
|
||||||
box_url : http://puppet-vagrant-boxes.puppetlabs.com/centos-65-x64-virtualbox-nocm.box
|
hypervisor: vagrant
|
||||||
hypervisor : vagrant
|
box: puppetlabs/ubuntu-14.04-64-nocm
|
||||||
CONFIG:
|
CONFIG:
|
||||||
type: foss
|
type: foss
|
||||||
|
|
12
spec/acceptance/nodesets/docker/centos-7.yml
Normal file
12
spec/acceptance/nodesets/docker/centos-7.yml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
HOSTS:
|
||||||
|
centos-7-x64:
|
||||||
|
platform: el-7-x86_64
|
||||||
|
hypervisor: docker
|
||||||
|
image: centos:7
|
||||||
|
docker_preserve_image: true
|
||||||
|
docker_cmd: '["/usr/sbin/init"]'
|
||||||
|
# install various tools required to get the image up to usable levels
|
||||||
|
docker_image_commands:
|
||||||
|
- 'yum install -y crontabs tar wget openssl sysvinit-tools iproute which initscripts'
|
||||||
|
CONFIG:
|
||||||
|
trace_limit: 200
|
11
spec/acceptance/nodesets/docker/debian-8.yml
Normal file
11
spec/acceptance/nodesets/docker/debian-8.yml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
HOSTS:
|
||||||
|
debian-8-x64:
|
||||||
|
platform: debian-8-amd64
|
||||||
|
hypervisor: docker
|
||||||
|
image: debian:8
|
||||||
|
docker_preserve_image: true
|
||||||
|
docker_cmd: '["/sbin/init"]'
|
||||||
|
docker_image_commands:
|
||||||
|
- 'apt-get update && apt-get install -y net-tools wget locales strace lsof && echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && locale-gen'
|
||||||
|
CONFIG:
|
||||||
|
trace_limit: 200
|
12
spec/acceptance/nodesets/docker/ubuntu-14.04.yml
Normal file
12
spec/acceptance/nodesets/docker/ubuntu-14.04.yml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
HOSTS:
|
||||||
|
ubuntu-1404-x64:
|
||||||
|
platform: ubuntu-14.04-amd64
|
||||||
|
hypervisor: docker
|
||||||
|
image: ubuntu:14.04
|
||||||
|
docker_preserve_image: true
|
||||||
|
docker_cmd: '["/sbin/init"]'
|
||||||
|
docker_image_commands:
|
||||||
|
# ensure that upstart is booting correctly in the container
|
||||||
|
- 'rm /usr/sbin/policy-rc.d && rm /sbin/initctl && dpkg-divert --rename --remove /sbin/initctl && apt-get update && apt-get install -y net-tools wget && locale-gen en_US.UTF-8'
|
||||||
|
CONFIG:
|
||||||
|
trace_limit: 200
|
|
@ -1,10 +0,0 @@
|
||||||
HOSTS:
|
|
||||||
fedora-18-x64:
|
|
||||||
roles:
|
|
||||||
- master
|
|
||||||
platform: fedora-18-x86_64
|
|
||||||
box : fedora-18-x64-vbox4210-nocm
|
|
||||||
box_url : http://puppet-vagrant-boxes.puppetlabs.com/fedora-18-x64-vbox4210-nocm.box
|
|
||||||
hypervisor : vagrant
|
|
||||||
CONFIG:
|
|
||||||
type: foss
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue