Sha256: ed54427d173bc01916cea2aa0f4e6bd612226782132f1a44bae2eae43ee6bc3b
Contents?: true
Size: 890 Bytes
Versions: 2
Compression:
Stored size: 890 Bytes
Contents
require 'active_support/concern' require 'active_support/lazy_load_hooks' module CryptKeeper module LogSubscriber module PostgresPgp # Public: Prevents sensitive data from being logged # # event - An ActiveSupport::Notifications::Event # # Returns a boolean. def sql(event) filter = /(\(*)pgp_(sym|pub)_(?<operation>decrypt|encrypt)(\(+.*\)+)/im payload = event.payload[:sql] .encode('UTF-8', 'binary', invalid: :replace, undef: :replace, replace: '') return if CryptKeeper.silence_logs? && payload =~ filter event.payload[:sql] = payload.gsub(filter) do |_| "#{$~[:operation]}([FILTERED])" end super(event) end end end end ActiveSupport.on_load :crypt_keeper_postgres_pgp_log do ActiveRecord::LogSubscriber.prepend CryptKeeper::LogSubscriber::PostgresPgp end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
crypt_keeper-1.0.0 | lib/crypt_keeper/log_subscriber/postgres_pgp.rb |
crypt_keeper-1.0.0.beta1 | lib/crypt_keeper/log_subscriber/postgres_pgp.rb |