FEATURE: Add small action post to indicate forwarded email

This happens only when the sender of the email didn't write anything in their email.
This commit is contained in:
Gerhard Schlager 2020-02-11 15:48:58 +01:00
parent 0adab26e45
commit 453bec9394
4 changed files with 33 additions and 1 deletions

View File

@ -184,6 +184,7 @@ en:
banner: banner:
enabled: "made this a banner %{when}. It will appear at the top of every page until it is dismissed by the user." enabled: "made this a banner %{when}. It will appear at the top of every page until it is dismissed by the user."
disabled: "removed this banner %{when}. It will no longer appear at the top of every page." disabled: "removed this banner %{when}. It will no longer appear at the top of every page."
forwarded: "forwarded the above email"
topic_admin_menu: "topic actions" topic_admin_menu: "topic actions"

View File

@ -844,7 +844,7 @@ module Email
embedded_user: lambda { find_or_create_user(email, display_name) }) embedded_user: lambda { find_or_create_user(email, display_name) })
return false unless post return false unless post
if post&.topic if post.topic
# mark post as seen for the forwarder # mark post as seen for the forwarder
PostTiming.record_timing(user_id: user.id, topic_id: post.topic_id, post_number: post.post_number, msecs: 5000) PostTiming.record_timing(user_id: user.id, topic_id: post.topic_id, post_number: post.post_number, msecs: 5000)
@ -859,6 +859,8 @@ module Email
topic: post.topic, topic: post.topic,
post_type: post_type, post_type: post_type,
skip_validations: user.staged?) skip_validations: user.staged?)
else
post.topic.add_small_action(user, "forwarded")
end end
end end

View File

@ -888,6 +888,18 @@ describe Email::Receiver do
expect { process(:forwarded_email_3) }.to change(Topic, :count) expect { process(:forwarded_email_3) }.to change(Topic, :count)
end end
it "adds a small action post to explain who forwarded the email when the sender didn't write anything" do
expect { process(:forwarded_email_4) }.to change(Topic, :count)
forwarded_post, last_post = *Post.last(2)
expect(forwarded_post.user.email).to eq("some@one.com")
expect(forwarded_post.raw).to match(/XoXo/)
expect(last_post.user.email).to eq("ba@bar.com")
expect(last_post.post_type).to eq(Post.types[:small_action])
expect(last_post.action_code).to eq("forwarded")
end
end end
context "with forwarded emails behaviour set to quote" do context "with forwarded emails behaviour set to quote" do

View File

@ -0,0 +1,17 @@
Message-ID: <62@foo.bar.mail>
From: Ba Bar <ba@bar.com>
To: Team <team@bar.com>
Date: Mon, 1 Dec 2016 13:37:42 +0100
Subject: Fwd: Discoursing much?
---------- Forwarded message ---------
From: Some One <some@one.com>
To: Ba Bar <ba@bar.com>
Date: Mon, 1 Dec 2016 00:13:37 +0100
Subject: Discoursing much?
Hello Ba Bar,
Discoursing much today?
XoXo