Sha256: 445bb58bb43312284cd4ba506015efb2053df69ef98df0be43f7a88bab3f0f6f

Contents?: true

Size: 1.38 KB

Versions: 1

Compression:

Stored size: 1.38 KB

Contents

class ProconBypassMan::Bypass
  module UsbHidLogger
    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
      return unless bypass_value.to_text

      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
      return unless bypass_value.to_text

      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

      if ProconBypassMan.config.enable_reporting_pressed_buttons
        ProconBypassMan.cache.fetch key: 'pressed_buttons_reporter', expires_in: 5 do
          ProconBypassMan::ReportPressedButtonsJob.perform_async(
            bypass_value.binary.to_procon_reader.to_hash
          )
        end
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
procon_bypass_man-0.2.2 lib/procon_bypass_man/bypass/usb_hid_logger.rb