Sha256: 74ae07f244036478ab7dabc152ea4a47e594004d10c1fe3412fce0f912c8aba3

Contents?: true

Size: 1.29 KB

Versions: 2

Compression:

Stored size: 1.29 KB

Contents

class ProconBypassMan::Bypass
  module UsbHidLogger
    extend ProconBypassMan::Callbacks::ClassMethods
    include ProconBypassMan::Callbacks

    define_callbacks :send_gadget_to_procon
    define_callbacks :send_procon_to_gadget

    set_callback :send_gadget_to_procon, :after, :log_send_gadget_to_procon
    set_callback :send_procon_to_gadget, :after, :log_procon_to_gadget

    def log_send_gadget_to_procon
      if ProconBypassMan.config.verbose_bypass_log
        ProconBypassMan.logger.debug { ">>> #{bypass_value.to_text}" }
      else
        ProconBypassMan.cache.fetch key: 'bypass_log', expires_in: 1 do
          ProconBypassMan.logger.debug { ">>> #{bypass_value.to_text}" }
        end
      end
    end

    def log_procon_to_gadget
      if ProconBypassMan.config.verbose_bypass_log
        ProconBypassMan.logger.debug { "<<< #{bypass_value.to_text}" }
      else
        ProconBypassMan.cache.fetch key: 'bypass_log', expires_in: 1 do
          ProconBypassMan.logger.debug { "<<< #{bypass_value.to_text}" }
        end
      end

      ProconBypassMan.cache.fetch key: 'pressed_buttons_reporter', expires_in: 5 do
        ProconBypassMan::ReportPressedButtonsJob.perform_async(
          ProconBypassMan::ProconReader.new(binary: bypass_value.binary).to_hash
        )
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
procon_bypass_man-0.1.15 lib/procon_bypass_man/bypass/usb_hid_logger.rb
procon_bypass_man-0.1.14 lib/procon_bypass_man/bypass/usb_hid_logger.rb