Sha256: 423aff36f19fba9fb96c7df3bc3a2913a049a576cd3b3fd8593c57be0ac4107d
Contents?: true
Size: 1.92 KB
Versions: 6
Compression:
Stored size: 1.92 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 _view if main? root.error_status = 404 :not_found else :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
6 entries across 6 versions & 1 rubygems