]> git.openstreetmap.org Git - rails.git/commitdiff
Join and normalize og:image url using Addressable
authorAnton Khorev <tony29@yandex.ru>
Sat, 15 Jun 2024 12:03:22 +0000 (15:03 +0300)
committerAnton Khorev <tony29@yandex.ru>
Sat, 15 Jun 2024 12:06:07 +0000 (15:06 +0300)
Avoids failing on urls that are not strictly rfc2396 URIs.

Gemfile
Gemfile.lock
app/helpers/open_graph_helper.rb
test/controllers/diary_entries_controller_test.rb

diff --git a/Gemfile b/Gemfile
index 77a9f1c97ff252c30ce1cd4f66dbd1034c1307ec..5a21c7f7ad4ae3a0f1fe79fe716b2a348996ec38 100644 (file)
--- a/Gemfile
+++ b/Gemfile
@@ -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
index 246a3740714a60701ac73169d143dafa5ce00fbd..a8cc3a94ff0144f3134a0f8cc69799419c4d6a92 100644 (file)
@@ -602,6 +602,7 @@ DEPENDENCIES
   actionpack-page_caching (>= 1.2.0)
   active_record_union
   activerecord-import
+  addressable (~> 2.8)
   annotate
   argon2
   autoprefixer-rails
index aebb5d85678b05a581ea25936fafc8977eb78ca6..b7654ee89a388821797d70b81d1edfbcf1ba215a 100644 (file)
@@ -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 ? Addressable::URI.join(root_url, og_image).normalize : image_url("osm_logo_256.png"),
       "og:url" => url_for(:only_path => false),
       "og:description" => t("layouts.intro_text")
     }
index 1dfd5ec1a293287021ed589792502abc1f0c046f..f3ca40f418d4a952fe8b0057b8d97f76987a44e1 100644 (file)
@@ -766,6 +766,28 @@ class DiaryEntriesControllerTest < ActionDispatch::IntegrationTest
     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_hide
     user = create(:user)
     diary_entry = create(:diary_entry, :user => user)