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:
parent
9792e03c63
commit
78bb367b0a
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue