123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class SecureMailing::Backend::HandlerOutgoing < SecureMailing::Backend::Handler
- attr_accessor :mail, :security
- def initialize(mail, security)
- super()
- @mail = mail
- @security = security
- end
- def process
- return if !process?
- workaround_mail_bit_encoding_issue(mail) if type.eql?('S/MIME')
- overwrite_mail(do_process)
- end
- def process?
- return false if security.blank?
- return false if security[:type] != type
- security[:sign][:success] || security[:encryption][:success]
- end
- # S/MIME signing fails because of message encoding #3147
- # workaround for https://github.com/mikel/mail/issues/1190
- def workaround_mail_bit_encoding_issue(mail)
- # change 7bit/8bit encoding to binary so that
- # base64 will be used to encode the content
- if mail.body.encoding.include?('bit')
- mail.body.encoding = :binary
- end
- # go into recursion for nested parts
- mail.parts&.each do |part|
- workaround_mail_bit_encoding_issue(part)
- end
- mail
- end
- def overwrite_mail(processed)
- mail.body = nil
- mail.body = processed.body.encoded
- mail.content_disposition = processed.content_disposition
- mail.content_transfer_encoding = processed.content_transfer_encoding
- mail.content_type = processed.content_type
- end
- def log(action, status, error = nil)
- recipients = %i[to cc].map { |recipient| mail[recipient] }.join(' ').strip!
- HttpLog.create(
- direction: 'out',
- facility: type,
- url: "#{mail[:from]} -> #{recipients}",
- status: status,
- ip: nil,
- request: security,
- response: { error: error },
- method: action,
- created_by_id: 1,
- updated_by_id: 1,
- )
- end
- private
- def do_process
- if security[:sign][:success] && security[:encryption][:success]
- perform_sign_and_encrypt
- elsif security[:sign][:success]
- perform_sign
- elsif security[:encryption][:success]
- perform_encrypt
- end
- end
- def perform_sign_and_encrypt
- new_mail = encrypt(signed.encoded)
- log('sign', 'success')
- log('encryption', 'success')
- new_mail
- end
- def perform_sign
- new_mail = signed
- log('sign', 'success')
- new_mail
- end
- def perform_encrypt
- new_mail = encrypt(mail.encoded)
- log('encryption', 'success')
- new_mail
- end
- end
|