FIX: Discobot's certificate shouldn't blow up on non 200 response.

https://meta.discourse.org/t/discobot-assets-certificate-svg/65523/6
This commit is contained in:
Guo Xiang Tan 2017-07-14 15:16:29 +09:00
parent 9792e03c63
commit 78bb367b0a
1 changed files with 17 additions and 3 deletions

View File

@ -464,7 +464,7 @@ module DiscourseNarrativeBot
<clipPath id="clipCircle"> <clipPath id="clipCircle">
<circle r="15" cx="15" cy="15"/> <circle r="15" cx="15" cy="15"/>
</clipPath> </clipPath>
<image clip-path="url(#clipCircle)" height="30px" width="30px" xlink:href="data:image/png;base64,#{Base64.strict_encode64(URI(avatar_url).open('rb', redirect: true, allow_redirections: :all).read)}"/> <image clip-path="url(#clipCircle)" height="30px" width="30px" #{base64_image_link(avatar_url)}/>
</g> </g>
<text x="#{width / 2}" y="240.94" text-anchor="middle" font-size="24" fill="#020403" font-family="Tangerine, Tangerine"> <text x="#{width / 2}" y="240.94" text-anchor="middle" font-size="24" fill="#020403" font-family="Tangerine, Tangerine">
#{name} #{name}
@ -530,7 +530,7 @@ module DiscourseNarrativeBot
<clipPath id="clipCircle"> <clipPath id="clipCircle">
<circle r="19" cx="19" cy="19"/> <circle r="19" cx="19" cy="19"/>
</clipPath> </clipPath>
<image clip-path="url(#clipCircle)" height="38px" width="38px" xlink:href="data:image/png;base64,#{Base64.strict_encode64(URI(avatar_url).open('rb', redirect: true, allow_redirections: :all).read)}"/> <image clip-path="url(#clipCircle)" height="38px" width="38px" #{base64_image_link(avatar_url)}/>
</g> </g>
<text transform="matrix(1.0705 0 0 1 544.2073 388.3629)" fill="#020403" font-family="'Tangerine'" font-size="24.9219px"> <text transform="matrix(1.0705 0 0 1 544.2073 388.3629)" fill="#020403" font-family="'Tangerine'" font-size="24.9219px">
#{@discobot_user.username} #{@discobot_user.username}
@ -568,7 +568,7 @@ module DiscourseNarrativeBot
<<~URL <<~URL
<g transform="translate(#{width / 2 - (size / 2)} #{height})"> <g transform="translate(#{width / 2 - (size / 2)} #{height})">
<image height="#{size}px" width="#{size}px" xlink:href="data:image/png;base64,#{Base64.strict_encode64(logo_uri.open('rb', redirect: true, allow_redirections: :all).read)}"/> <image height="#{size}px" width="#{size}px" #{base64_image_link(logo_uri)}/>
</g> </g>
URL URL
rescue URI::InvalidURIError rescue URI::InvalidURIError
@ -576,6 +576,20 @@ module DiscourseNarrativeBot
end end
end end
def base64_image_link(url)
if image = fetch_image(url)
"xlink:href=\"data:image/png;base64,#{Base64.strict_encode64(image)}\""
else
""
end
end
def fetch_image(url)
URI(url).open('rb', redirect: true, allow_redirections: :all).read
rescue OpenURI::HTTPError
# Ignore if fetching image returns a non 200 response
end
def avatar_url def avatar_url
UrlHelper.absolute(Discourse.base_uri + @user.avatar_template.gsub('{size}', '250')) UrlHelper.absolute(Discourse.base_uri + @user.avatar_template.gsub('{size}', '250'))
end end