Sha256: 8fe3ede6a27250ed0549aba7d946d108723c9ee0ab58f85681cc3eb76395d21b
Contents?: true
Size: 823 Bytes
Versions: 6
Compression:
Stored size: 823 Bytes
Contents
require 'active_support/concern' require 'active_support/lazy_load_hooks' module CryptKeeper module LogSubscriber module MysqlAes extend ActiveSupport::Concern included do alias_method_chain :sql, :mysql_aes end # Public: Prevents sensitive data from being logged def sql_with_mysql_aes(event) filter = /(aes_(encrypt|decrypt))\(.*\)/i payload = event.payload[:sql] .encode('UTF-8', 'binary', invalid: :replace, undef: :replace, replace: '') event.payload[:sql] = payload.gsub(filter) do |_| "#{$1}([FILTERED])" end sql_without_mysql_aes(event) end end end end ActiveSupport.on_load :crypt_keeper_mysql_aes_log do ActiveRecord::LogSubscriber.send :include, CryptKeeper::LogSubscriber::MysqlAes end
Version data entries
6 entries across 6 versions & 1 rubygems