From 25f34d351c5db50426f42bfd4937d0ae36a421f5 Mon Sep 17 00:00:00 2001 From: Ben Ford Date: Fri, 3 Jan 2020 16:59:26 -0800 Subject: [PATCH] Porting functions to the modern Puppet 4.x API --- lib/puppet/functions/mysql/mysql_dirname.rb | 41 ++++++++++++++++ lib/puppet/functions/mysql/mysql_password.rb | 44 +++++++++++++++++ .../functions/mysql/mysql_strip_hash.rb | 49 +++++++++++++++++++ spec/functions/mysql_mysql_dirname_spec.rb | 41 ++++++++++++++++ spec/functions/mysql_mysql_password_spec.rb | 41 ++++++++++++++++ spec/functions/mysql_mysql_strip_hash_spec.rb | 41 ++++++++++++++++ 6 files changed, 257 insertions(+) create mode 100644 lib/puppet/functions/mysql/mysql_dirname.rb create mode 100644 lib/puppet/functions/mysql/mysql_password.rb create mode 100644 lib/puppet/functions/mysql/mysql_strip_hash.rb create mode 100644 spec/functions/mysql_mysql_dirname_spec.rb create mode 100644 spec/functions/mysql_mysql_password_spec.rb create mode 100644 spec/functions/mysql_mysql_strip_hash_spec.rb diff --git a/lib/puppet/functions/mysql/mysql_dirname.rb b/lib/puppet/functions/mysql/mysql_dirname.rb new file mode 100644 index 000000000..2efe87df8 --- /dev/null +++ b/lib/puppet/functions/mysql/mysql_dirname.rb @@ -0,0 +1,41 @@ +# This is an autogenerated function, ported from the original legacy version. +# It /should work/ as is, but will not have all the benefits of the modern +# function API. You should see the function docs to learn how to add function +# signatures for type safety and to document this function using puppet-strings. +# +# https://puppet.com/docs/puppet/latest/custom_functions_ruby.html +# +# ---- original file header ---- + +# ---- original file header ---- +# +# @summary +# Returns the dirname of a path. +# +# +Puppet::Functions.create_function(:'mysql::mysql_dirname') do + # @param arguments + # The original array of arguments. Port this to individually managed params + # to get the full benefit of the modern function API. + # + # @return [Data type] + # Describe what the function returns here + # + dispatch :default_impl do + # Call the method named 'default_impl' when this is matched + # Port this to match individual params for better type safety + repeated_param 'Any', :arguments + end + + + def default_impl(*arguments) + + + raise(Puppet::ParseError, "mysql_dirname(): Wrong number of arguments " + + "given (#{arguments.size} for 1)") if arguments.size < 1 + + path = arguments[0] + return File.dirname(path) + + end +end diff --git a/lib/puppet/functions/mysql/mysql_password.rb b/lib/puppet/functions/mysql/mysql_password.rb new file mode 100644 index 000000000..c3e58f03d --- /dev/null +++ b/lib/puppet/functions/mysql/mysql_password.rb @@ -0,0 +1,44 @@ +# This is an autogenerated function, ported from the original legacy version. +# It /should work/ as is, but will not have all the benefits of the modern +# function API. You should see the function docs to learn how to add function +# signatures for type safety and to document this function using puppet-strings. +# +# https://puppet.com/docs/puppet/latest/custom_functions_ruby.html +# +# ---- original file header ---- +# hash a string as mysql's "PASSWORD()" function would do it +require 'digest/sha1' + +# ---- original file header ---- +# +# @summary +# Returns the mysql password hash from the clear text password. +# +# +Puppet::Functions.create_function(:'mysql::mysql_password') do + # @param args + # The original array of arguments. Port this to individually managed params + # to get the full benefit of the modern function API. + # + # @return [Data type] + # Describe what the function returns here + # + dispatch :default_impl do + # Call the method named 'default_impl' when this is matched + # Port this to match individual params for better type safety + repeated_param 'Any', :args + end + + + def default_impl(*args) + + + raise(Puppet::ParseError, 'mysql_password(): Wrong number of arguments ' + + "given (#{args.size} for 1)") if args.size != 1 + + return '' if args[0].empty? + return args[0] if args[0] =~ /\*[A-F0-9]{40}$/ + '*' + Digest::SHA1.hexdigest(Digest::SHA1.digest(args[0])).upcase + + end +end diff --git a/lib/puppet/functions/mysql/mysql_strip_hash.rb b/lib/puppet/functions/mysql/mysql_strip_hash.rb new file mode 100644 index 000000000..99c66d8d4 --- /dev/null +++ b/lib/puppet/functions/mysql/mysql_strip_hash.rb @@ -0,0 +1,49 @@ +# This is an autogenerated function, ported from the original legacy version. +# It /should work/ as is, but will not have all the benefits of the modern +# function API. You should see the function docs to learn how to add function +# signatures for type safety and to document this function using puppet-strings. +# +# https://puppet.com/docs/puppet/latest/custom_functions_ruby.html +# +# ---- original file header ---- + +# ---- original file header ---- +# +# @summary +# TEMPORARY FUNCTION: EXPIRES 2014-03-10 +#When given a hash this function strips out all blank entries. +# +# +Puppet::Functions.create_function(:'mysql::mysql_strip_hash') do + # @param args + # The original array of arguments. Port this to individually managed params + # to get the full benefit of the modern function API. + # + # @return [Data type] + # Describe what the function returns here + # + dispatch :default_impl do + # Call the method named 'default_impl' when this is matched + # Port this to match individual params for better type safety + repeated_param 'Any', :args + end + + + def default_impl(*args) + + + hash = args[0] + unless hash.is_a?(Hash) + raise(Puppet::ParseError, 'mysql_strip_hash(): Requires hash to work with') + end + + # Filter out all the top level blanks. + hash.reject{|k,v| v == ''}.each do |k,v| + if v.is_a?(Hash) + v.reject!{|ki,vi| vi == '' } + end + end + + + end +end diff --git a/spec/functions/mysql_mysql_dirname_spec.rb b/spec/functions/mysql_mysql_dirname_spec.rb new file mode 100644 index 000000000..326eb6ccd --- /dev/null +++ b/spec/functions/mysql_mysql_dirname_spec.rb @@ -0,0 +1,41 @@ +require 'spec_helper' + +describe 'mysql::mysql_dirname' do + # without knowing details about the implementation, this is the only test + # case that we can autogenerate. You should add more examples below! + it { is_expected.not_to eq(nil) } + +################################# +# Below are some example test cases. You may uncomment and modify them to match +# your needs. Notice that they all expect the base error class of `StandardError`. +# This is because the autogenerated function uses an untyped array for parameters +# and relies on your implementation to do the validation. As you convert your +# function to proper dispatches and typed signatures, you should change the +# expected error of the argument validation examples to `ArgumentError`. +# +# Other error types you might encounter include +# +# * StandardError +# * ArgumentError +# * Puppet::ParseError +# +# Read more about writing function unit tests at https://rspec-puppet.com/documentation/functions/ +# +# it 'raises an error if called with no argument' do +# is_expected.to run.with_params.and_raise_error(StandardError) +# end +# +# it 'raises an error if there is more than 1 arguments' do +# is_expected.to run.with_params({ 'foo' => 1 }, 'bar' => 2).and_raise_error(StandardError) +# end +# +# it 'raises an error if argument is not the proper type' do +# is_expected.to run.with_params('foo').and_raise_error(StandardError) +# end +# +# it 'returns the proper output' do +# is_expected.to run.with_params(123).and_return('the expected output') +# end +################################# + +end diff --git a/spec/functions/mysql_mysql_password_spec.rb b/spec/functions/mysql_mysql_password_spec.rb new file mode 100644 index 000000000..ba1bef2fb --- /dev/null +++ b/spec/functions/mysql_mysql_password_spec.rb @@ -0,0 +1,41 @@ +require 'spec_helper' + +describe 'mysql::mysql_password' do + # without knowing details about the implementation, this is the only test + # case that we can autogenerate. You should add more examples below! + it { is_expected.not_to eq(nil) } + +################################# +# Below are some example test cases. You may uncomment and modify them to match +# your needs. Notice that they all expect the base error class of `StandardError`. +# This is because the autogenerated function uses an untyped array for parameters +# and relies on your implementation to do the validation. As you convert your +# function to proper dispatches and typed signatures, you should change the +# expected error of the argument validation examples to `ArgumentError`. +# +# Other error types you might encounter include +# +# * StandardError +# * ArgumentError +# * Puppet::ParseError +# +# Read more about writing function unit tests at https://rspec-puppet.com/documentation/functions/ +# +# it 'raises an error if called with no argument' do +# is_expected.to run.with_params.and_raise_error(StandardError) +# end +# +# it 'raises an error if there is more than 1 arguments' do +# is_expected.to run.with_params({ 'foo' => 1 }, 'bar' => 2).and_raise_error(StandardError) +# end +# +# it 'raises an error if argument is not the proper type' do +# is_expected.to run.with_params('foo').and_raise_error(StandardError) +# end +# +# it 'returns the proper output' do +# is_expected.to run.with_params(123).and_return('the expected output') +# end +################################# + +end diff --git a/spec/functions/mysql_mysql_strip_hash_spec.rb b/spec/functions/mysql_mysql_strip_hash_spec.rb new file mode 100644 index 000000000..e4173251b --- /dev/null +++ b/spec/functions/mysql_mysql_strip_hash_spec.rb @@ -0,0 +1,41 @@ +require 'spec_helper' + +describe 'mysql::mysql_strip_hash' do + # without knowing details about the implementation, this is the only test + # case that we can autogenerate. You should add more examples below! + it { is_expected.not_to eq(nil) } + +################################# +# Below are some example test cases. You may uncomment and modify them to match +# your needs. Notice that they all expect the base error class of `StandardError`. +# This is because the autogenerated function uses an untyped array for parameters +# and relies on your implementation to do the validation. As you convert your +# function to proper dispatches and typed signatures, you should change the +# expected error of the argument validation examples to `ArgumentError`. +# +# Other error types you might encounter include +# +# * StandardError +# * ArgumentError +# * Puppet::ParseError +# +# Read more about writing function unit tests at https://rspec-puppet.com/documentation/functions/ +# +# it 'raises an error if called with no argument' do +# is_expected.to run.with_params.and_raise_error(StandardError) +# end +# +# it 'raises an error if there is more than 1 arguments' do +# is_expected.to run.with_params({ 'foo' => 1 }, 'bar' => 2).and_raise_error(StandardError) +# end +# +# it 'raises an error if argument is not the proper type' do +# is_expected.to run.with_params('foo').and_raise_error(StandardError) +# end +# +# it 'returns the proper output' do +# is_expected.to run.with_params(123).and_return('the expected output') +# end +################################# + +end