actionmailer 8.1.0.beta1 → 8.1.0

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: 33226491c029ce11c633514799ee91adc191c4ca0e0ecd62f757f8739a391760
4
- data.tar.gz: 79bdbc4be17dabd4cbbf04cd9f6290203f03dcffd84494cb3a90529cb1f331f0
3
+ metadata.gz: 88f1f6c224f50cb6b6f9d696849cee934e66006b8e4737d40399803ec7585bf9
4
+ data.tar.gz: e85c8a33fba53b30abb08dea2040f7aef1230cfb4c96b09b4c5a72f826eef92a
5
5
  SHA512:
6
- metadata.gz: 28a8c6237d1fdaad721c68938d34a72cab21fdc0053a3887a272a18b8206a83bb0582edcb13bf8f6fe43bda3acca9b413a872d4c0cedc4c8c8b6921c8df0523e
7
- data.tar.gz: c1b4b1958b5d80a2e2251bb850d98672a33d15997679b4f9826e3e5f3589aa59f5c36e0ca7cd0957838a94b621252c188852ebed27ee547c8ba275022f2bafaa
6
+ metadata.gz: 66634214e536663cfc491fb82d1aeda9967e7a3915ec99b411695cdf4bfd9ef60ded5761187645497bfc312526dc2fc7678d0a86d098ba9a623f3fdd04279537
7
+ data.tar.gz: 2a809be068e48230d06c1cf37648de4956f0fbbd0078e344f5c32d4f38303d1dda9c4554a5f54e0cb9d8efe39f1f903fe52087fcf709eb76f23df699a8b230fa
data/CHANGELOG.md CHANGED
@@ -1,4 +1,10 @@
1
- ## Rails 8.1.0.beta1 (September 04, 2025) ##
1
+ ## Rails 8.1.0 (October 22, 2025) ##
2
+
3
+ * Add structured events for Action Mailer:
4
+ - `action_mailer.delivered`
5
+ - `action_mailer.processed`
6
+
7
+ *Gannon McGibbon*
2
8
 
3
9
  * Add `deliver_all_later` to enqueue multiple emails at once.
4
10
 
@@ -7,6 +7,7 @@ require "active_support/core_ext/hash/except"
7
7
  require "active_support/core_ext/module/anonymous"
8
8
 
9
9
  require "action_mailer/log_subscriber"
10
+ require "action_mailer/structured_event_subscriber"
10
11
  require "action_mailer/rescuable"
11
12
 
12
13
  module ActionMailer
@@ -10,7 +10,7 @@ module ActionMailer
10
10
  MAJOR = 8
11
11
  MINOR = 1
12
12
  TINY = 0
13
- PRE = "beta1"
13
+ PRE = nil
14
14
 
15
15
  STRING = [MAJOR, MINOR, TINY, PRE].compact.join(".")
16
16
  end
@@ -3,11 +3,7 @@
3
3
  require "active_support/log_subscriber"
4
4
 
5
5
  module ActionMailer
6
- # = Action Mailer \LogSubscriber
7
- #
8
- # Implements the ActiveSupport::LogSubscriber for logging notifications when
9
- # email is delivered or received.
10
- class LogSubscriber < ActiveSupport::LogSubscriber
6
+ class LogSubscriber < ActiveSupport::LogSubscriber # :nodoc:
11
7
  # An email was delivered.
12
8
  def deliver(event)
13
9
  info do
@@ -20,7 +20,7 @@ module ActionMailer
20
20
 
21
21
  private
22
22
  def _deliver_all_later(delivery_method, *deliveries, **options)
23
- deliveries.flatten!
23
+ deliveries = deliveries.first if deliveries.first.is_a?(Array)
24
24
 
25
25
  jobs = deliveries.map do |delivery|
26
26
  mailer_class = delivery.mailer_class
@@ -0,0 +1,38 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "active_support/structured_event_subscriber"
4
+
5
+ module ActionMailer
6
+ class StructuredEventSubscriber < ActiveSupport::StructuredEventSubscriber # :nodoc:
7
+ # An email was delivered.
8
+ def deliver(event)
9
+ exception = event.payload[:exception_object]
10
+ payload = {
11
+ message_id: event.payload[:message_id],
12
+ duration_ms: event.duration.round(2),
13
+ mail: event.payload[:mail],
14
+ perform_deliveries: event.payload[:perform_deliveries],
15
+ }
16
+
17
+ if exception
18
+ payload[:exception_class] = exception.class.name
19
+ payload[:exception_message] = exception.message
20
+ end
21
+
22
+ emit_debug_event("action_mailer.delivered", payload)
23
+ end
24
+ debug_only :deliver
25
+
26
+ # An email was generated.
27
+ def process(event)
28
+ emit_debug_event("action_mailer.processed",
29
+ mailer: event.payload[:mailer],
30
+ action: event.payload[:action],
31
+ duration_ms: event.duration.round(2),
32
+ )
33
+ end
34
+ debug_only :process
35
+ end
36
+ end
37
+
38
+ ActionMailer::StructuredEventSubscriber.attach_to :action_mailer
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: actionmailer
3
3
  version: !ruby/object:Gem::Version
4
- version: 8.1.0.beta1
4
+ version: 8.1.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - David Heinemeier Hansson
@@ -15,56 +15,56 @@ dependencies:
15
15
  requirements:
16
16
  - - '='
17
17
  - !ruby/object:Gem::Version
18
- version: 8.1.0.beta1
18
+ version: 8.1.0
19
19
  type: :runtime
20
20
  prerelease: false
21
21
  version_requirements: !ruby/object:Gem::Requirement
22
22
  requirements:
23
23
  - - '='
24
24
  - !ruby/object:Gem::Version
25
- version: 8.1.0.beta1
25
+ version: 8.1.0
26
26
  - !ruby/object:Gem::Dependency
27
27
  name: actionpack
28
28
  requirement: !ruby/object:Gem::Requirement
29
29
  requirements:
30
30
  - - '='
31
31
  - !ruby/object:Gem::Version
32
- version: 8.1.0.beta1
32
+ version: 8.1.0
33
33
  type: :runtime
34
34
  prerelease: false
35
35
  version_requirements: !ruby/object:Gem::Requirement
36
36
  requirements:
37
37
  - - '='
38
38
  - !ruby/object:Gem::Version
39
- version: 8.1.0.beta1
39
+ version: 8.1.0
40
40
  - !ruby/object:Gem::Dependency
41
41
  name: actionview
42
42
  requirement: !ruby/object:Gem::Requirement
43
43
  requirements:
44
44
  - - '='
45
45
  - !ruby/object:Gem::Version
46
- version: 8.1.0.beta1
46
+ version: 8.1.0
47
47
  type: :runtime
48
48
  prerelease: false
49
49
  version_requirements: !ruby/object:Gem::Requirement
50
50
  requirements:
51
51
  - - '='
52
52
  - !ruby/object:Gem::Version
53
- version: 8.1.0.beta1
53
+ version: 8.1.0
54
54
  - !ruby/object:Gem::Dependency
55
55
  name: activejob
56
56
  requirement: !ruby/object:Gem::Requirement
57
57
  requirements:
58
58
  - - '='
59
59
  - !ruby/object:Gem::Version
60
- version: 8.1.0.beta1
60
+ version: 8.1.0
61
61
  type: :runtime
62
62
  prerelease: false
63
63
  version_requirements: !ruby/object:Gem::Requirement
64
64
  requirements:
65
65
  - - '='
66
66
  - !ruby/object:Gem::Version
67
- version: 8.1.0.beta1
67
+ version: 8.1.0
68
68
  - !ruby/object:Gem::Dependency
69
69
  name: mail
70
70
  requirement: !ruby/object:Gem::Requirement
@@ -121,6 +121,7 @@ files:
121
121
  - lib/action_mailer/queued_delivery.rb
122
122
  - lib/action_mailer/railtie.rb
123
123
  - lib/action_mailer/rescuable.rb
124
+ - lib/action_mailer/structured_event_subscriber.rb
124
125
  - lib/action_mailer/test_case.rb
125
126
  - lib/action_mailer/test_helper.rb
126
127
  - lib/action_mailer/version.rb
@@ -133,10 +134,10 @@ licenses:
133
134
  - MIT
134
135
  metadata:
135
136
  bug_tracker_uri: https://github.com/rails/rails/issues
136
- changelog_uri: https://github.com/rails/rails/blob/v8.1.0.beta1/actionmailer/CHANGELOG.md
137
- documentation_uri: https://api.rubyonrails.org/v8.1.0.beta1/
137
+ changelog_uri: https://github.com/rails/rails/blob/v8.1.0/actionmailer/CHANGELOG.md
138
+ documentation_uri: https://api.rubyonrails.org/v8.1.0/
138
139
  mailing_list_uri: https://discuss.rubyonrails.org/c/rubyonrails-talk
139
- source_code_uri: https://github.com/rails/rails/tree/v8.1.0.beta1/actionmailer
140
+ source_code_uri: https://github.com/rails/rails/tree/v8.1.0/actionmailer
140
141
  rubygems_mfa_required: 'true'
141
142
  rdoc_options: []
142
143
  require_paths: