Sha256: 7b3ca65833bc4fc32e26e1d5ce99f7858b37634f00aa3e3869198c0da2e0f6d1
Contents?: true
Size: 1.88 KB
Versions: 27
Compression:
Stored size: 1.88 KB
Contents
# frozen_string_literal: true # encoding: utf-8 module Mongoid module Extensions module DateTime # Mongoize the date time into a time. # # @example Mongoize the date time. # date_time.__mongoize_time__ # # @return [ Time | ActiveSupport::TimeWithZone ] The mongoized time. # # @since 3.0.0 def __mongoize_time__ if Mongoid.use_activesupport_time_zone? in_time_zone(::Time.zone) else time = to_time time.respond_to?(:getlocal) ? time.getlocal : time end end # Turn the object from the ruby type we deal with to a Mongo friendly # type. # # @example Mongoize the object. # date_time.mongoize # # @return [ Time ] The object mongoized. # # @since 3.0.0 def mongoize ::DateTime.mongoize(self) end module ClassMethods # Convert the object from its mongo friendly ruby type to this type. # # @example Demongoize the object. # DateTime.demongoize(object) # # @param [ Time ] object The time from Mongo. # # @return [ DateTime ] The object as a date. # # @since 3.0.0 def demongoize(object) ::Time.demongoize(object).try(:to_datetime) end # Turn the object from the ruby type we deal with to a Mongo friendly # type. # # @example Mongoize the object. # DateTime.mongoize("2012-1-1") # # @param [ Object ] object The object to convert. # # @return [ Time ] The object mongoized. # # @since 3.0.0 def mongoize(object) ::Time.mongoize(object) end end end end end ::DateTime.__send__(:include, Mongoid::Extensions::DateTime) ::DateTime.extend(Mongoid::Extensions::DateTime::ClassMethods)
Version data entries
27 entries across 27 versions & 2 rubygems