我进行了一些调查并提出了解决方案。你说你有一个模块可以在其中进行加密。我猜该模块代表一个单例。然而,我的解决方案需要您有一个实例。
class Crypto
def self.instance
@__instance__ ||= new
end
end
提取模块中的加密行为。
module Encryptable
def encrypt
# ...
end
def decrypt
# ...
end
end
创建一个处理异常的新模块。
module ExceptionHandler
extend ActiveSupport::Concern
included do
include ActiveSupport::Rescuable
rescue_from StandardError, :with => :known_error
end
def handle_known_exceptions
yield
rescue => ex
rescue_with_handler(ex) || raise
end
def known_error(ex)
Rails.logger.error "[ExceptionHandler] Exception #{ex.class}: #{ex.message}"
end
end
所以现在你可以使用新定义的handle_known_exceptions
在你的里面Crypto
。这不是很方便,因为你没有获得太多。您仍然必须在每个方法中调用异常处理程序:
class Crypto
include ExceptionHandler
def print_bunnies
handle_known_exceptions do
File.open("bunnies")
end
end
end
如果我们定义一个委托人来为我们做这件事,则不需要这样做:
class CryptoDelegator
include ExceptionHandler
def initialize(target)
@target = target
end
def method_missing(*args, &block)
handle_known_exceptions do
@target.send(*args, &block)
end
end
end
完全覆盖初始化Crypto
,改为使用委托者。
class Crypto
include Encryptable
def self.new(*args, &block)
CryptoDelegator.new(super)
end
def self.instance
@__instance__ ||= new
end
end
就是这样!