actionmailer 8.1.0.beta1 → 8.1.0.rc1

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: b0efbf96899cfb20369bd74bc03bd6b0126d56679906f5e15df90edae16ab15c
4
+ data.tar.gz: 92f132cfbf3573e6cb5bae1ac18f7e6c5156cea11b283f90854aa2310e5ffd48
5
5
  SHA512:
6
- metadata.gz: 28a8c6237d1fdaad721c68938d34a72cab21fdc0053a3887a272a18b8206a83bb0582edcb13bf8f6fe43bda3acca9b413a872d4c0cedc4c8c8b6921c8df0523e
7
- data.tar.gz: c1b4b1958b5d80a2e2251bb850d98672a33d15997679b4f9826e3e5f3589aa59f5c36e0ca7cd0957838a94b621252c188852ebed27ee547c8ba275022f2bafaa
6
+ metadata.gz: 86e8af8f9ac090f22ec8712d58397c9ed57ea732cd7fb221cf62bb732413514ba5d40211b8678ef5908d3d4dfd18b6ad55ece9cb3db6d8a5b396a73f132cb6ac
7
+ data.tar.gz: 4847e03c0c03c743471e06f8c44ef5baf93a55602f7cd1b87bb22d942e134258dc3540912706999bab991ee0f120a7f28ea39b180a96e93caeee46a2432ed8ba
data/CHANGELOG.md CHANGED
@@ -1,3 +1,11 @@
1
+ ## Rails 8.1.0.rc1 (October 15, 2025) ##
2
+
3
+ * Add structured events for Action Mailer:
4
+ - `action_mailer.delivered`
5
+ - `action_mailer.processed`
6
+
7
+ *Gannon McGibbon*
8
+
1
9
  ## Rails 8.1.0.beta1 (September 04, 2025) ##
2
10
 
3
11
  * Add `deliver_all_later` to enqueue multiple emails at once.
@@ -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 = "rc1"
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.rc1
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.rc1
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.rc1
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.rc1
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.rc1
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.rc1
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.rc1
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.rc1
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.rc1
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.rc1/actionmailer/CHANGELOG.md
138
+ documentation_uri: https://api.rubyonrails.org/v8.1.0.rc1/
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.rc1/actionmailer
140
141
  rubygems_mfa_required: 'true'
141
142
  rdoc_options: []
142
143
  require_paths: