Sha256: e6de948ec4dccb5cf5e4443e3a5ccf8e4ed613aab8a29fa34a938749abb1b826

Contents?: true

Size: 1.24 KB

Versions: 2

Compression:

Stored size: 1.24 KB

Contents

# Flow (2017)
# for flow errors

require 'digest/sha1'

class Flow::Error < StandardError

  # logs error to file for easy discovery and fix
  def self.log(exception, request)
    history = exception.backtrace.reject{ |el| el.index('/gems/') }.map{ |el| el.sub(Rails.root.to_s, '') }.join($/)

    msg  = '%s in %s' % [exception.class, request.url]
    data = [msg, exception.message, history].join("\n\n")
    key  = Digest::SHA1.hexdigest exception.backtrace.first.split(' ').first

    folder = Rails.root.join('log/exceptions').to_s
    Dir.mkdir(folder) unless Dir.exists?(folder)

    folder += "/#{exception.class.to_s.tableize.gsub('/','-')}"
    Dir.mkdir(folder) unless Dir.exists?(folder)

    "#{folder}/#{key}.txt".tap do |path|
      File.write(path, data)
    end
  end

  def self.format_message order, flow_experience=nil
    message = if order['messages']
      msg = order['messages'].join(', ')

      if order['numbers']
        msg += ' (%s)' % Spree::Variant.where(id: order['numbers']).map(&:name).join(', ')
      end

      msg
    else
      'Order not properly localized (sync issue)'
    end

    sub_info = 'Flow.io'
    sub_info += ' - %s' % flow_experience.key[0, 15] if flow_experience

    '%s (%s)' % [message, sub_info]
  end

end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
flowcommerce-solidus-0.1.12 ./static/app/flow/flow/error.rb
flowcommerce-solidus-0.1.11 ./static/app/flow/flow/error.rb