Puppet Function: time
- Defined in:
- puppet/modules/stdlib/lib/puppet/parser/functions/time.rb
- Function type:
- Ruby 3.x API
Overview
This function will return the current time since epoch as an integer.
Examples:
time()
Will return something like: 1311972653
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'puppet/modules/stdlib/lib/puppet/parser/functions/time.rb', line 6 newfunction(:time, :type => :rvalue, :doc => <<-EOS This function will return the current time since epoch as an integer. *Examples:* time() Will return something like: 1311972653 EOS ) do |arguments| # The Time Zone argument is optional ... time_zone = arguments[0] if arguments[0] if (arguments.size != 0) and (arguments.size != 1) then raise(Puppet::ParseError, "time(): Wrong number of arguments "+ "given #{arguments.size} for 0 or 1") end time = Time.new # There is probably a better way to handle Time Zone ... if time_zone and not time_zone.empty? original_zone = ENV['TZ'] local_time = time.clone local_time = local_time.utc ENV['TZ'] = time_zone result = local_time.localtime.strftime('%s') ENV['TZ'] = original_zone else result = time.localtime.strftime('%s') end # Calling Time#to_i on a receiver changes it. Trust me I am the Doctor. result = result.to_i return result end |