Merge branch 'revert_fix_email_images' into 'master'
Revert "Merge branch 'fix_email_images' into 'master'" This reverts commitd66148ef39
, reversing changes made tocdb64a81a8
. This change needed to be reverted, because not enough email clients support inline images. /cc @DouweM As discussed before. I'll try to create a MR to allow access to all images this week. I'm a bit busy at the moment so no guarantees. ;) See merge request !513
This commit is contained in:
commit
36537c65e3
5 changed files with 6 additions and 107 deletions
|
@ -1,6 +1,3 @@
|
|||
require 'html/pipeline'
|
||||
require 'html/pipeline/gitlab'
|
||||
|
||||
module EmailsHelper
|
||||
|
||||
# Google Actions
|
||||
|
@ -38,26 +35,4 @@ module EmailsHelper
|
|||
lexer = Rugments::Lexers::Diff.new
|
||||
raw formatter.format(lexer.lex(diffcontent))
|
||||
end
|
||||
|
||||
def replace_image_links_with_base64(text, project)
|
||||
# Used pipelines in GitLab:
|
||||
# GitlabEmailImageFilter - replaces images that have been uploaded as attachments with inline images in emails.
|
||||
#
|
||||
# see https://gitlab.com/gitlab-org/html-pipeline-gitlab for more filters
|
||||
filters = [
|
||||
HTML::Pipeline::Gitlab::GitlabEmailImageFilter
|
||||
]
|
||||
|
||||
context = {
|
||||
base_url: File.join(Gitlab.config.gitlab.url, project.path_with_namespace, 'uploads'),
|
||||
upload_path: File.join(Rails.root, 'public', 'uploads', project.path_with_namespace),
|
||||
}
|
||||
|
||||
pipeline = HTML::Pipeline::Gitlab.new(filters).pipeline
|
||||
|
||||
result = pipeline.call(text, context)
|
||||
text = result[:output].to_html(save_with: 0)
|
||||
|
||||
text.html_safe
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,2 +1,2 @@
|
|||
%div
|
||||
= replace_image_links_with_base64(markdown(@note.note, reference_only_path: false), @note.project)
|
||||
= markdown(@note.note, reference_only_path: false)
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
-if @issue.description
|
||||
= replace_image_links_with_base64(markdown(@issue.description, reference_only_path: false), @issue.project)
|
||||
= markdown(@issue.description, reference_only_path: false)
|
||||
|
||||
- if @issue.assignee_id.present?
|
||||
%p
|
||||
|
|
|
@ -6,4 +6,4 @@
|
|||
Assignee: #{@merge_request.author_name} → #{@merge_request.assignee_name}
|
||||
|
||||
-if @merge_request.description
|
||||
= replace_image_links_with_base64(markdown(@merge_request.description, reference_only_path: false), @merge_request.project)
|
||||
= markdown(@merge_request.description, reference_only_path: false)
|
||||
|
|
|
@ -191,13 +191,6 @@ describe Notify do
|
|||
context 'for issues' do
|
||||
let(:issue) { create(:issue, author: current_user, assignee: assignee, project: project) }
|
||||
let(:issue_with_description) { create(:issue, author: current_user, assignee: assignee, project: project, description: Faker::Lorem.sentence) }
|
||||
let(:issue_with_image) do
|
||||
create(:issue,
|
||||
author: current_user,
|
||||
assignee: assignee,
|
||||
project: project,
|
||||
description: "![test](#{Gitlab.config.gitlab.url}/#{project.path_with_namespace}/uploads/12345/test.jpg)")
|
||||
end
|
||||
|
||||
describe 'that are new' do
|
||||
subject { Notify.new_issue_email(issue.assignee_id, issue.id) }
|
||||
|
@ -222,22 +215,6 @@ describe Notify do
|
|||
end
|
||||
end
|
||||
|
||||
describe 'that contain images' do
|
||||
let(:png) { File.read("#{Rails.root}/spec/fixtures/dk.png") }
|
||||
let(:png_encoded) { Base64::encode64(png) }
|
||||
|
||||
before :each do
|
||||
file_path = File.join(Rails.root, 'public', 'uploads', issue_with_image.project.path_with_namespace, '12345/test.jpg')
|
||||
allow(File).to receive(:file?).with(file_path).and_return(true)
|
||||
allow(File).to receive(:read).with(file_path).and_return(png)
|
||||
end
|
||||
|
||||
subject { Notify.new_issue_email(issue_with_image.assignee_id, issue_with_image.id) }
|
||||
it 'replaces attached images with inline images' do
|
||||
is_expected.to have_body_text URI.encode(png_encoded)
|
||||
end
|
||||
end
|
||||
|
||||
describe 'that have been reassigned' do
|
||||
subject { Notify.reassigned_issue_email(recipient.id, issue.id, previous_assignee.id, current_user) }
|
||||
|
||||
|
@ -302,14 +279,6 @@ describe Notify do
|
|||
let(:merge_author) { create(:user) }
|
||||
let(:merge_request) { create(:merge_request, author: current_user, assignee: assignee, source_project: project, target_project: project) }
|
||||
let(:merge_request_with_description) { create(:merge_request, author: current_user, assignee: assignee, source_project: project, target_project: project, description: Faker::Lorem.sentence) }
|
||||
let(:merge_request_with_image) do
|
||||
create(:merge_request,
|
||||
author: current_user,
|
||||
assignee: assignee,
|
||||
source_project: project,
|
||||
target_project: project,
|
||||
description: "![test](#{Gitlab.config.gitlab.url}/#{project.path_with_namespace}/uploads/12345/test.jpg)")
|
||||
end
|
||||
|
||||
describe 'that are new' do
|
||||
subject { Notify.new_merge_request_email(merge_request.assignee_id, merge_request.id) }
|
||||
|
@ -346,22 +315,6 @@ describe Notify do
|
|||
end
|
||||
end
|
||||
|
||||
describe 'that are new and contain contain images in the description' do
|
||||
let(:png) {File.read("#{Rails.root}/spec/fixtures/dk.png")}
|
||||
let(:png_encoded) { Base64::encode64(png) }
|
||||
|
||||
before :each do
|
||||
file_path = File.join(Rails.root, 'public', 'uploads', merge_request_with_image.project.path_with_namespace, '/12345/test.jpg')
|
||||
allow(File).to receive(:file?).with(file_path).and_return(true)
|
||||
allow(File).to receive(:read).with(file_path).and_return(png)
|
||||
end
|
||||
|
||||
subject { Notify.new_merge_request_email(merge_request_with_image.assignee_id, merge_request_with_image.id) }
|
||||
it 'replaces attached images with inline images' do
|
||||
is_expected.to have_body_text URI.encode(png_encoded)
|
||||
end
|
||||
end
|
||||
|
||||
describe 'that are reassigned' do
|
||||
subject { Notify.reassigned_merge_request_email(recipient.id, merge_request.id, previous_assignee.id, current_user.id) }
|
||||
|
||||
|
@ -470,12 +423,9 @@ describe Notify do
|
|||
describe 'project access changed' do
|
||||
let(:project) { create(:project) }
|
||||
let(:user) { create(:user) }
|
||||
let(:project_member) do
|
||||
create(:project_member,
|
||||
project: project,
|
||||
user: user)
|
||||
end
|
||||
|
||||
let(:project_member) { create(:project_member,
|
||||
project: project,
|
||||
user: user) }
|
||||
subject { Notify.project_access_granted_email(project_member.id) }
|
||||
|
||||
it_behaves_like 'an email sent from GitLab'
|
||||
|
@ -515,32 +465,6 @@ describe Notify do
|
|||
end
|
||||
end
|
||||
|
||||
describe 'on a commit that contains an image' do
|
||||
let(:commit) { project.repository.commit }
|
||||
let(:note_with_image) do
|
||||
create(:note,
|
||||
project: project,
|
||||
author: note_author,
|
||||
note: "![test](#{Gitlab.config.gitlab.url}/#{project.path_with_namespace}/uploads/12345/test.jpg)")
|
||||
end
|
||||
|
||||
let(:png) {File.read("#{Rails.root}/spec/fixtures/dk.png")}
|
||||
let(:png_encoded) { Base64::encode64(png) }
|
||||
|
||||
before :each do
|
||||
file_path = File.join(Rails.root, 'public', 'uploads', note_with_image.project.path_with_namespace, '12345/test.jpg')
|
||||
allow(File).to receive(:file?).with(file_path).and_return(true)
|
||||
allow(File).to receive(:read).with(file_path).and_return(png)
|
||||
allow(Note).to receive(:find).with(note_with_image.id).and_return(note_with_image)
|
||||
allow(note_with_image).to receive(:noteable).and_return(commit)
|
||||
end
|
||||
|
||||
subject { Notify.note_commit_email(recipient.id, note_with_image.id) }
|
||||
it 'replaces attached images with inline images' do
|
||||
is_expected.to have_body_text URI.encode(png_encoded)
|
||||
end
|
||||
end
|
||||
|
||||
describe 'on a commit' do
|
||||
let(:commit) { project.repository.commit }
|
||||
|
||||
|
|
Loading…
Reference in a new issue