Sha256: 73d70f25ed4cab4b9b15cd71df1d854add349e1562ac07652d157c35bc9bbbe2

Contents?: true

Size: 1.44 KB

Versions: 32

Compression:

Stored size: 1.44 KB

Contents

# frozen_string_literal: true

# Unwraps a Sensitive value and returns the wrapped object.
# Returns the Value itself, if it is not Sensitive.
#
# @example Usage of unwrap
#
# ```puppet
# $plaintext = 'hunter2'
# $pw = Sensitive.new($plaintext)
# notice("Wrapped object is $pw") #=> Prints "Wrapped object is Sensitive [value redacted]"
# $unwrapped = $pw.unwrap
# notice("Unwrapped object is $unwrapped") #=> Prints "Unwrapped object is hunter2"
# ```
#
# You can optionally pass a block to unwrap in order to limit the scope where the
# unwrapped value is visible.
#
# @example Unwrapping with a block of code
#
# ```puppet
# $pw = Sensitive.new('hunter2')
# notice("Wrapped object is $pw") #=> Prints "Wrapped object is Sensitive [value redacted]"
# $pw.unwrap |$unwrapped| {
#   $conf = inline_template("password: ${unwrapped}\n")
#   Sensitive.new($conf)
# } #=> Returns a new Sensitive object containing an interpolated config file
# # $unwrapped is now out of scope
# ```
#
# @since 4.0.0
#
Puppet::Functions.create_function(:unwrap) do
  dispatch :from_sensitive do
    param 'Sensitive', :arg
    optional_block_param
  end

  dispatch :from_any do
    param 'Any', :arg
    optional_block_param
  end

  def from_sensitive(arg)
    unwrapped = arg.unwrap
    if block_given?
      yield(unwrapped)
    else
      unwrapped
    end
  end

  def from_any(arg)
    unwrapped = arg
    if block_given?
      yield(unwrapped)
    else
      unwrapped
    end
  end
end

Version data entries

32 entries across 32 versions & 1 rubygems

Version Path
puppet-8.10.0 lib/puppet/functions/unwrap.rb
puppet-8.10.0-x86-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.10.0-x64-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.10.0-universal-darwin lib/puppet/functions/unwrap.rb
puppet-8.9.0 lib/puppet/functions/unwrap.rb
puppet-8.9.0-x86-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.9.0-x64-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.9.0-universal-darwin lib/puppet/functions/unwrap.rb
puppet-8.8.1 lib/puppet/functions/unwrap.rb
puppet-8.8.1-x86-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.8.1-x64-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.8.1-universal-darwin lib/puppet/functions/unwrap.rb
puppet-8.7.0 lib/puppet/functions/unwrap.rb
puppet-8.7.0-x86-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.7.0-x64-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.7.0-universal-darwin lib/puppet/functions/unwrap.rb
puppet-8.6.0 lib/puppet/functions/unwrap.rb
puppet-8.6.0-x86-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.6.0-x64-mingw32 lib/puppet/functions/unwrap.rb
puppet-8.6.0-universal-darwin lib/puppet/functions/unwrap.rb