Added ability to specify section_prefix and section_suffix to accomodate files with sections that don't follow [section_name] format. AIX for example uses section_name: format.

This commit is contained in:
WhatsARanjit 2015-04-12 02:59:41 -04:00
parent 5d70bafff5
commit b0fb47d4ec
5 changed files with 375 additions and 5 deletions

View file

@ -65,6 +65,24 @@ ini_subsetting {'sample subsetting':
} }
~~~ ~~~
###Use a non-standard section header
~~~
default:
minage = 1
maxage = 13
ini_setting { 'default minage':
ensure => present,
path => '/etc/security/users',
section => 'default',
setting => 'minage',
value => '1',
section_prefix => '',
section_suffix => ':',
}
~~~
###Implement child providers ###Implement child providers
@ -176,6 +194,16 @@ Determines whether the specified setting should exist. Valid options: 'present'
*Optional.* Supplies a value for the specified setting. Valid options: a string. Default value: undefined. *Optional.* Supplies a value for the specified setting. Valid options: a string. Default value: undefined.
##### `section_prefix`
*Optional.* Designates the string that will appear before the section's name. Default value: "["
##### `section_suffix`
*Optional.* Designates the string that will appear after the section's name. Default value: "]"
**NOTE:** The way this type finds all sections in the file is by looking for lines like `${section_prefix}${title}${section_suffix}`
### Type: ini_subsetting ### Type: ini_subsetting

View file

@ -94,9 +94,25 @@ Puppet::Type.type(:ini_setting).provide(:ruby) do
end end
end end
def section_prefix
if resource.class.validattr?(:section_prefix)
resource[:section_prefix] || '['
else
'['
end
end
def section_suffix
if resource.class.validattr?(:section_suffix)
resource[:section_suffix] || ']'
else
']'
end
end
private private
def ini_file def ini_file
@ini_file ||= Puppet::Util::IniFile.new(file_path, separator) @ini_file ||= Puppet::Util::IniFile.new(file_path, separator, section_prefix, section_suffix)
end end
end end

View file

@ -39,5 +39,16 @@ Puppet::Type.newtype(:ini_setting) do
desc 'The value of the setting to be defined.' desc 'The value of the setting to be defined.'
end end
newparam(:section_prefix) do
desc 'The prefix to the section name\'s header.' +
'Defaults to \'[\'.'
defaultto('[')
end
newparam(:section_suffix) do
desc 'The suffix to the section name\'s header.' +
'Defaults to \']\'.'
defaultto(']')
end
end end

View file

@ -5,11 +5,14 @@ module Puppet
module Util module Util
class IniFile class IniFile
def initialize(path, key_val_separator = ' = ') def initialize(path, key_val_separator = ' = ', section_prefix = '[', section_suffix = ']')
k_v_s = key_val_separator.strip k_v_s = key_val_separator.strip
@@SECTION_REGEX = /^\s*\[([^\]]*)\]\s*$/ @section_prefix = section_prefix
@section_suffix = section_suffix
@@SECTION_REGEX = section_regex
@@SETTING_REGEX = /^(\s*)([^#;\s]|[^#;\s].*?[^\s#{k_v_s}])(\s*#{k_v_s}\s*)(.*)\s*$/ @@SETTING_REGEX = /^(\s*)([^#;\s]|[^#;\s].*?[^\s#{k_v_s}])(\s*#{k_v_s}\s*)(.*)\s*$/
@@COMMENTED_SETTING_REGEX = /^(\s*)[#;]+(\s*)(.*?[^\s#{k_v_s}])(\s*#{k_v_s}[ \t]*)(.*)\s*$/ @@COMMENTED_SETTING_REGEX = /^(\s*)[#;]+(\s*)(.*?[^\s#{k_v_s}])(\s*#{k_v_s}[ \t]*)(.*)\s*$/
@ -22,6 +25,26 @@ module Util
end end
end end
def section_regex
# Only put in prefix/suffix if they exist
# Also, if the prefix is '', the negated
# set match should be a match all instead.
r_string = '^\s*'
r_string += Regexp.escape(@section_prefix)
r_string += '('
if @section_prefix != ''
r_string += '[^'
r_string += Regexp.escape(@section_prefix)
r_string += ']'
else
r_string += '.'
end
r_string += '*)'
r_string += Regexp.escape(@section_suffix)
r_string += '\s*$'
/#{r_string}/
end
def section_names def section_names
@section_names @section_names
end end
@ -107,7 +130,7 @@ module Util
whitespace_buffer = [] whitespace_buffer = []
if (section.is_new_section?) && (! section.is_global?) if (section.is_new_section?) && (! section.is_global?)
fh.puts("\n[#{section.name}]") fh.puts("\n#{@section_prefix}#{section.name}#{@section_suffix}")
end end
if ! section.is_new_section? if ! section.is_new_section?

View file

@ -137,6 +137,9 @@ url = http://192.168.1.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS EOS
} }
@ -164,6 +167,42 @@ yahoo = yippee
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS
)
end
it "should add a missing setting to the correct section with pre/suffix" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => 'nonstandard',
:setting => 'yahoo', :value => 'yippee',
:section_prefix => '-', :section_suffix => '-'))
provider = described_class.new(resource)
provider.exists?.should be false
provider.create
validate_file(<<-EOS
# This is a comment
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
shoes = purple
yahoo = yippee
EOS EOS
) )
end end
@ -191,6 +230,9 @@ url = http://192.168.1.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
yahoo = yippee yahoo = yippee
EOS EOS
) )
@ -219,6 +261,41 @@ url = http://192.168.1.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS
)
end
it "should modify an existing setting with pre/suffix with a different value" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => 'nonstandard',
:setting => 'shoes', :value => 'orange',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be true
provider.value=('orange')
validate_file(<<-EOS
# This is a comment
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
shoes = orange
EOS EOS
) )
end end
@ -247,6 +324,9 @@ url = http://192.168.1.1:8080
subby=foo subby=foo
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS EOS
) )
end end
@ -276,6 +356,43 @@ url = http://192.168.0.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS
)
end
it "should be able to handle settings with pre/suffix with non alphanumbering settings " do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => 'nonstandard',
:setting => 'shoes', :value => 'http://192.168.0.1:8080',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be true
provider.value.should == 'purple'
provider.value=('http://192.168.0.1:8080')
validate_file( <<-EOS
# This is a comment
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
shoes = http://192.168.0.1:8080
EOS EOS
) )
end end
@ -287,6 +404,15 @@ subby=bar
provider.exists?.should be true provider.exists?.should be true
end end
it "should recognize an existing setting with pre/suffix with the specified value" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => 'nonstandard',
:setting => 'shoes', :value => 'purple',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be true
end
it "should add a new section if the section does not exist" do it "should add a new section if the section does not exist" do
resource = Puppet::Type::Ini_setting.new(common_params.merge( resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section3", :setting => 'huzzah', :value => 'shazaam')) :section => "section3", :setting => 'huzzah', :value => 'shazaam'))
@ -311,12 +437,49 @@ subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
[section3] [section3]
huzzah = shazaam huzzah = shazaam
EOS EOS
) )
end end
it "should add a new section with pre/suffix if the section does not exist" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section3", :setting => 'huzzah', :value => 'shazaam',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be false
provider.create
validate_file(<<-EOS
# This is a comment
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
shoes = purple
-section3-
huzzah = shazaam
EOS
)
end
it "should add a new section if the section does not exist - with colon" do it "should add a new section if the section does not exist - with colon" do
resource = Puppet::Type::Ini_setting.new(common_params.merge( resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section:subsection", :setting => 'huzzah', :value => 'shazaam')) :section => "section:subsection", :setting => 'huzzah', :value => 'shazaam'))
@ -341,12 +504,49 @@ subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
[section:subsection] [section:subsection]
huzzah = shazaam huzzah = shazaam
EOS EOS
) )
end end
it "should add a new section with pre/suffix if the section does not exist - with colon" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section:subsection", :setting => 'huzzah', :value => 'shazaam',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be false
provider.create
validate_file(<<-EOS
# This is a comment
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
shoes = purple
-section:subsection-
huzzah = shazaam
EOS
)
end
it "should add a new section if no sections exists" do it "should add a new section if no sections exists" do
resource = Puppet::Type::Ini_setting.new(common_params.merge( resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section1", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile)) :section => "section1", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile))
@ -359,6 +559,19 @@ setting1 = hellowworld
", emptyfile) ", emptyfile)
end end
it "should add a new section with pre/suffix if no sections exists" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section1", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile,
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be false
provider.create
validate_file("
-section1-
setting1 = hellowworld
", emptyfile)
end
it "should add a new section with colon if no sections exists" do it "should add a new section with colon if no sections exists" do
resource = Puppet::Type::Ini_setting.new(common_params.merge( resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section:subsection", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile)) :section => "section:subsection", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile))
@ -371,6 +584,18 @@ setting1 = hellowworld
", emptyfile) ", emptyfile)
end end
it "should add a new section with pre/suffix with colon if no sections exists" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section:subsection", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile,
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be false
provider.create
validate_file("
-section:subsection-
setting1 = hellowworld
", emptyfile)
end
it "should be able to handle variables of any type" do it "should be able to handle variables of any type" do
resource = Puppet::Type::Ini_setting.new(common_params.merge( resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => "section1", :setting => 'master', :value => true)) :section => "section1", :setting => 'master', :value => true))
@ -576,6 +801,9 @@ url = http://192.168.1.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS EOS
} }
@ -600,6 +828,38 @@ url = http://192.168.1.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS
)
end
it "should remove a setting with pre/suffix that exists" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => 'nonstandard', :setting => 'shoes', :ensure => 'absent',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be true
provider.destroy
validate_file(<<-EOS
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
EOS EOS
) )
end end
@ -626,12 +886,44 @@ url = http://192.168.1.1:8080
subby=bar subby=bar
#another comment #another comment
; yet another comment ; yet another comment
-nonstandard-
shoes = purple
EOS
)
end
it "should do nothing for a setting with pre/suffix that does not exist" do
resource = Puppet::Type::Ini_setting.new(common_params.merge(
:section => 'nonstandard', :setting => 'foo', :ensure => 'absent',
:section_prefix => '-', :section_suffix => '-' ))
provider = described_class.new(resource)
provider.exists?.should be false
provider.destroy
validate_file(<<-EOS
[section1]
; This is also a comment
foo=foovalue
bar = barvalue
master = true
[section2]
foo= foovalue2
baz=bazvalue
url = http://192.168.1.1:8080
[section:sub]
subby=bar
#another comment
; yet another comment
-nonstandard-
shoes = purple
EOS EOS
) )
end end
end end
context "when dealing with indentation in sections" do context "when dealing with indentation in sections" do
let(:orig_content) { let(:orig_content) {
<<-EOS <<-EOS