You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

mail_handler_controller.rb 2.2KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. # frozen_string_literal: true
  2. # Redmine - project management software
  3. # Copyright (C) 2006-2023 Jean-Philippe Lang
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU General Public License
  7. # as published by the Free Software Foundation; either version 2
  8. # of the License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. class MailHandlerController < ActionController::Base
  19. include ActiveSupport::SecurityUtils
  20. before_action :check_credential
  21. # Requests from rdm-mailhandler.rb don't contain CSRF tokens
  22. skip_before_action :verify_authenticity_token
  23. # Displays the email submission form
  24. def new
  25. end
  26. # Submits an incoming email to MailHandler
  27. def index
  28. # MailHandlerController#index should permit all options set by
  29. # RedmineMailHandler#submit in rdm-mailhandler.rb.
  30. # It must be kept in sync.
  31. options = params.permit(
  32. :key,
  33. :email,
  34. :allow_override,
  35. :unknown_user,
  36. :default_group,
  37. :no_account_notice,
  38. :no_notification,
  39. :no_permission_check,
  40. :project_from_subaddress,
  41. {
  42. issue: [
  43. :project,
  44. :status,
  45. :tracker,
  46. :category,
  47. :priority,
  48. :assigned_to,
  49. :fixed_version,
  50. :is_private
  51. ]
  52. }
  53. ).to_h
  54. email = options.delete(:email)
  55. if MailHandler.safe_receive(email, options)
  56. head :created
  57. else
  58. head :unprocessable_entity
  59. end
  60. end
  61. private
  62. def check_credential
  63. User.current = nil
  64. unless Setting.mail_handler_api_enabled? && secure_compare(params[:key].to_s, Setting.mail_handler_api_key.to_s)
  65. render :plain => 'Access denied. Incoming emails WS is disabled or key is invalid.', :status => 403
  66. end
  67. end
  68. end