Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/pull/4891'
Browse files Browse the repository at this point in the history
  • Loading branch information
tomhughes committed Jun 17, 2024
2 parents eab4eec + b97834f commit 2d09b94
Show file tree
Hide file tree
Showing 4 changed files with 60 additions and 1 deletion.
1 change: 1 addition & 0 deletions Gemfile
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ gem "validates_email_format_of", ">= 1.5.1"
gem "quad_tile", "~> 1.0.1"

# Sanitise URIs
gem "addressable", "~> 2.8"
gem "rack-uri_sanitizer"

# Omniauth for authentication
Expand Down
1 change: 1 addition & 0 deletions Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -602,6 +602,7 @@ DEPENDENCIES
actionpack-page_caching (>= 1.2.0)
active_record_union
activerecord-import
addressable (~> 2.8)
annotate
argon2
autoprefixer-rails
Expand Down
15 changes: 14 additions & 1 deletion app/helpers/open_graph_helper.rb
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
module OpenGraphHelper
require "addressable/uri"

def opengraph_tags(title = nil, og_image = nil)
tags = {
"og:site_name" => t("layouts.project_name.title"),
"og:title" => title || t("layouts.project_name.title"),
"og:type" => "website",
"og:image" => og_image ? URI.join(root_url, og_image) : image_url("osm_logo_256.png"),
"og:image" => og_image_url(og_image),
"og:url" => url_for(:only_path => false),
"og:description" => t("layouts.intro_text")
}
Expand All @@ -13,4 +15,15 @@ def opengraph_tags(title = nil, og_image = nil)
tag.meta(:property => property, :content => content)
end, "\n")
end

private

def og_image_url(og_image)
begin
return Addressable::URI.join(root_url, og_image).normalize if og_image
rescue Addressable::URI::InvalidURIError
# return default image
end
image_url("osm_logo_256.png")
end
end
44 changes: 44 additions & 0 deletions test/controllers/diary_entries_controller_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -736,6 +736,17 @@ def test_show_hidden_comments
end
end

def test_show_og_image_with_no_image
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "nothing")

get diary_entry_path(user, diary_entry)
assert_response :success
assert_dom "head meta[property='og:image']" do
assert_dom "> @content", ActionController::Base.helpers.image_url("osm_logo_256.png", :host => root_url)
end
end

def test_show_og_image
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "![some picture](https://example.com/picture.jpg)")
Expand All @@ -758,6 +769,39 @@ def test_show_og_image_with_relative_uri
end
end

def test_show_og_image_with_spaces
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "![some picture](https://example.com/the picture.jpg)")

get diary_entry_path(user, diary_entry)
assert_response :success
assert_dom "head meta[property='og:image']" do
assert_dom "> @content", "https://example.com/the%20picture.jpg"
end
end

def test_show_og_image_with_relative_uri_and_spaces
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "![some local picture](/the picture.jpg)")

get diary_entry_path(user, diary_entry)
assert_response :success
assert_dom "head meta[property='og:image']" do
assert_dom "> @content", "#{root_url}the%20picture.jpg"
end
end

def test_show_og_image_with_invalid_uri
user = create(:user)
diary_entry = create(:diary_entry, :user => user, :body => "![](:)")

get diary_entry_path(user, diary_entry)
assert_response :success
assert_dom "head meta[property='og:image']" do
assert_dom "> @content", ActionController::Base.helpers.image_url("osm_logo_256.png", :host => root_url)
end
end

def test_hide
user = create(:user)
diary_entry = create(:diary_entry, :user => user)
Expand Down

0 comments on commit 2d09b94

Please sign in to comment.