lib/doorkeeper/models/concerns/expirable.rb



# frozen_string_literal: true

module Doorkeeper
  module Models
    module Expirable
      # Indicates whether the object is expired (`#expires_in` present and
      # expiration time has come).
      #
      # @return [Boolean] true if object expired and false in other case
      def expired?
        expires_in && Time.now.utc > expires_at
      end

      # Calculates expiration time in seconds.
      #
      # @return [Integer, nil] number of seconds if object has expiration time
      #   or nil if object never expires.
      def expires_in_seconds
        return nil if expires_in.nil?

        expires = expires_at - Time.now.utc
        expires_sec = expires.seconds.round(0)
        expires_sec > 0 ? expires_sec : 0
      end

      # Expiration time (date time of creation + TTL).
      #
      # @return [Time, nil] expiration time in UTC
      #   or nil if the object never expires.
      #
      def expires_at
        expires_in && created_at + expires_in.seconds
      end
    end
  end
end