Sha256: f55218943ea7c2a7317a0ed4f976212a23dbba09253cbcb05441fe455ce84cf6
Contents?: true
Size: 994 Bytes
Versions: 1
Compression:
Stored size: 994 Bytes
Contents
require "logstash/namespace" # Provide our own Time wrapper for ISO8601 support # Example: # >> LogStash::Time.now.to_iso8601 # => "2010-10-17 00:25:24.619014-0700" # # >> LogStash::Time.now.utc.to_iso8601 # => "2010-10-17 07:25:26.788704Z" class LogStash::Time < ::Time ISO8601 = "%Y-%m-%dT%H:%M:%S" # Return a string that is this time in ISO8601 format. def to_iso8601 tz = self.utc? ? "Z" : self.strftime("%z") # zero-pad tv_usec so the time string is sortable. return "%s.%06d%s" % [self.strftime(ISO8601), self.tv_usec, tz] end def self.to_iso8601(obj) if obj.is_a?(DateTime) tz = obj.offset == 0 ? "Z" : obj.strftime("%z") # DateTime#sec_fraction is fractional seconds "of a day" sec_fraction = (obj.sec_fraction.to_f * 86400 * 1000000) return "%s.%06d%s" % [obj.strftime(ISO8601), sec_fraction, tz] else raise "Can't convert object of type #{obj.class} (#{obj}) to iso8601." end end end # class LogStash::Time
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
logstash-lite-0.2.20101124030048 | lib/logstash/time.rb |