Sha256: 3952daf3538f4de2e32e3e4d7cbe39b2eeccd813d3d8850aa49494274e9c447a
Contents?: true
Size: 1.94 KB
Versions: 2
Compression:
Stored size: 1.94 KB
Contents
class Card class Format module Error def ok? task task = :create if task == :update && card.new_card? card.ok? task end def anyone_can? task return false unless task.is_a? Symbol @anyone_can ||= {} @anyone_can[task] = card.anyone_can? task if @anyone_can[task].nil? @anyone_can[task] end def view_for_unknown setting_view if main? root.error_status = 404 :not_found else setting_view || :unknown end end def view_for_denial view, task @denied_task = task root.error_status = 403 if focal? && voo.root? view_setting(:denial, view) || :denial end def monitor_depth if depth >= Card.config.max_depth raise Card::Error::UserError, t(:format_too_deep) end yield end def rescue_view e, view method = loud_error? ? :loud_error : :quiet_error send method, e, view end def error_cardname _exception if card&.name.present? safe_name else ::I18n.t :lib_no_cardname end end def loud_error? focal? || Card.config.raise_all_rendering_errors end def loud_error e, view log_error e if focal? && voo.root? card.errors.add "#{view} view", rendering_error(e, view) if card.errors.empty? raise e end def quiet_error e, view # TODO: unify with Card::Error#report log_error e rendering_error e, view end def log_error e Rails.logger.info e.message Rails.logger.debug e.backtrace.join("\n") end def rendering_error exception, view if exception.is_a? Card::Error::UserError exception.message else t :lib_error_rendering, cardname: error_cardname(exception), view: view end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
card-1.104.2 | lib/card/format/error.rb |
card-1.104.1 | lib/card/format/error.rb |