effective_logging 3.1.5 → 3.1.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: fded3d821985ef83c7634533c8160498abfaef98e23976e1cd1e0df89646bc91
4
- data.tar.gz: 4a662a9883fb91fdcadf09969e0f826e5e9e5a339d6a150b3b902b05420fb86c
3
+ metadata.gz: b6f5721d058755a622fc522fc7a7719e733a1bea00fae1d308c28c60d1bfcac4
4
+ data.tar.gz: da5b0e20de3dfd5d81eaa6d4867e1f905746179e6e09839347658992d1604bd3
5
5
  SHA512:
6
- metadata.gz: dfbeda5d1e61db271cc68476f00c31a3ada3ab4fcb6726ee5496f4cd2132cabf5e449def28339dde8533eed82cf0be2ac7b1e69d5c54cdf61b6682fa7ab4d5ed
7
- data.tar.gz: cab6daf708f644c173844c3b7b01e8a98145c1afe7f8ba6824f248804f59dc4b4a98250b5d363239549be5f789789c249f21f6eb95fc453183c058f1f3c3c631
6
+ metadata.gz: 5ded4680a0bdc0153e98dc07fcfd5616b179148f153232fdb31526ac971ceee4223105cde4a2f8a564aa9d7fd05a0da3f0fa8a40184e002e04691657c3b47b74
7
+ data.tar.gz: 4e82583d2ec520e19b55a9e0e064b978de34194fe70dc193f9e7c3ee7f2ed625dc876b239c7e744d069ede9b5f20e0e721858f198aad5595d1ce39445894ed9e
@@ -47,7 +47,7 @@ module Effective
47
47
  def html_part
48
48
  @log = Effective::Log.find(params[:id])
49
49
 
50
- EffectiveLogging.authorize!(self, :show, @log)
50
+ EffectiveResources.authorize!(self, :show, @log)
51
51
 
52
52
  value = @log.details[(params[:key] || '').to_sym].to_s
53
53
 
@@ -3,8 +3,6 @@ require 'effective_logging/engine'
3
3
  require 'effective_logging/version'
4
4
 
5
5
  module EffectiveLogging
6
- mattr_accessor :supressed
7
-
8
6
  def self.config_keys
9
7
  [
10
8
  :logs_table_name, :layout, :additional_statuses,
@@ -47,6 +45,11 @@ module EffectiveLogging
47
45
  Thread.current[:effective_logging_current_user]
48
46
  end
49
47
 
48
+ # Used to supress all logging
49
+ def self.supressed=(value)
50
+ Thread.current[:effective_logging_supressed] = value
51
+ end
52
+
50
53
  def self.supressed(&block)
51
54
  Thread.current[:effective_logging_supressed] = true
52
55
  yield
@@ -4,6 +4,8 @@ module EffectiveLogging
4
4
  module ActiveStorageLogger
5
5
 
6
6
  def track_downloads
7
+ return if EffectiveLogging.supressed?
8
+
7
9
  user = current_user if respond_to?(:current_user)
8
10
 
9
11
  key = decode_verified_key()
@@ -9,21 +9,21 @@ module EffectiveLogging
9
9
 
10
10
  # Add a log header to your mailer to pass some objects or additional things to EffectiveLogger
11
11
  # mail(to: 'admin@example.com', subject: @post.title, log: @post)
12
+ log = if message.header['log'].present?
13
+ value = message.header['log'].instance_variable_get(:@unparsed_value)
14
+ value ||= message.header['log'].instance_variable_get(:@value)
15
+ message.header['log'] = nil
16
+ value
17
+ end
12
18
 
13
- if message.header['log'].present?
14
- obj = message.header['log'].instance_variable_get(:@unparsed_value)
15
- obj ||= message.header['log'].instance_variable_get(:@value)
16
-
17
- if obj.kind_of?(ActiveRecord::Base)
18
- fields.merge!(associated: obj)
19
- elsif obj.kind_of?(Hash)
20
- fields.merge!(obj)
19
+ if log.present?
20
+ if log.kind_of?(ActiveRecord::Base)
21
+ fields.merge!(associated: log)
22
+ elsif log.kind_of?(Hash)
23
+ fields.merge!(log)
21
24
  else
22
25
  raise('log expected an ActiveRecord object or Hash')
23
26
  end
24
-
25
- # Get rid of the extra header, as it should not be set in the real mail message.
26
- message.header['log'] = nil
27
27
  end
28
28
 
29
29
  # Pass a tenant to your mailer
@@ -32,17 +32,17 @@ module EffectiveLogging
32
32
  value = message.header['tenant'].to_s.to_sym # OptionalField, not a String here
33
33
  message.header['tenant'] = nil
34
34
  value
35
- end || (Tenant.current if defined?(Tenant))
35
+ end
36
36
 
37
37
  user_klass = "#{tenant.to_s.classify}::User".safe_constantize
38
38
 
39
- body = (message.body.try(:parts) || []).find { |part| part.content_type.to_s.downcase.include?('text/html') }
40
- body ||= message.body
39
+ parts = (message.body.try(:parts) || []).map { |part| [part, (part.parts if part.respond_to?(:parts))] }.flatten
40
+ body = parts.find { |part| part.content_type.to_s.downcase.include?('text/html') } || message.body
41
41
 
42
42
  fields[:email] = "#{message.header}<hr>#{body}"
43
43
 
44
- if tenant.present?
45
- Tenant.as(tenant) { log_email(message, fields, user_klass) }
44
+ if tenant.present? && defined?(Tenant)
45
+ Tenant.as_if(tenant) { log_email(message, fields, user_klass) }
46
46
  else
47
47
  log_email(message, fields, user_klass)
48
48
  end
@@ -37,7 +37,7 @@ module EffectiveLogging
37
37
  def effective_logging_log_page_view
38
38
  return if EffectiveLogging.supressed?
39
39
  return if @_effective_logging_skip_log_page_view == true
40
- return if (self.class.log_page_views_opts[:skip_namespace] || []).include?(self.class.parent)
40
+ return if (self.class.log_page_views_opts[:skip_namespace] || []).include?(self.class.ancestors.first)
41
41
 
42
42
  user = EffectiveLogging.current_user || (current_user if respond_to?(:current_user))
43
43
 
@@ -1,3 +1,3 @@
1
1
  module EffectiveLogging
2
- VERSION = '3.1.5'.freeze
2
+ VERSION = '3.1.10'.freeze
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: effective_logging
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.1.5
4
+ version: 3.1.10
5
5
  platform: ruby
6
6
  authors:
7
7
  - Code and Effect
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-03-16 00:00:00.000000000 Z
11
+ date: 2021-06-09 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails