summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2023-03-26 05:35:50 +0000
committerGo MAEDA <maeda@farend.jp>2023-03-26 05:35:50 +0000
commit421dc8320fdbcfccbf5d73c377d2ff21b7e28bc7 (patch)
tree3366ec016d6b98da2b6abf35a7f173abced457d1 /app
parent260ba2e04a02945f24068fe3402cf0b838b74d63 (diff)
downloadredmine-421dc8320fdbcfccbf5d73c377d2ff21b7e28bc7.tar.gz
redmine-421dc8320fdbcfccbf5d73c377d2ff21b7e28bc7.zip
Receive e-mail replies to news and news comments (#38274).
Patch by Felix Schäfer. git-svn-id: https://svn.redmine.org/redmine/trunk@22160 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app')
-rw-r--r--app/models/mail_handler.rb35
1 files changed, 35 insertions, 0 deletions
diff --git a/app/models/mail_handler.rb b/app/models/mail_handler.rb
index 8a4084769..67cb016d1 100644
--- a/app/models/mail_handler.rb
+++ b/app/models/mail_handler.rb
@@ -306,6 +306,41 @@ class MailHandler < ActionMailer::Base
end
end
+ # Receives a reply to a news entry
+ def receive_news_reply(news_id)
+ news = News.find_by_id(news_id)
+ if news.nil?
+ raise MissingContainer, "reply to nonexistant news [#{news_id}]"
+ end
+
+ # Never receive emails to projects where adding news comments is not possible
+ project = news.project
+ raise NotAllowedInProject, "not possible to add news comments to project [#{project.name}]" unless project.allows_to?(:comment_news)
+
+ unless handler_options[:no_permission_check]
+ unless news.commentable?(user)
+ raise InsufficientPermissions, "not allowed to comment on news item [#{news.id} #{news.title}]"
+ end
+ end
+
+ comment = news.comments.new
+ comment.author = user
+ comment.comments = cleaned_up_text_body
+ comment.save!
+ comment
+ end
+
+ # Receives a reply to a comment to a news entry
+ def receive_comment_reply(comment_id)
+ comment = Comment.find_by_id(comment_id)
+
+ if comment && comment.commented_type == 'News'
+ receive_news_reply(comment.commented.id)
+ else
+ raise MissingContainer, "reply to nonexistant comment [#{comment_id}]"
+ end
+ end
+
def add_attachments(obj)
if email.attachments && email.attachments.any?
email.attachments.each do |attachment|