mirror of
https://github.com/codeninjasllc/discourse.git
synced 2024-11-23 23:58:31 -05:00
Use a real placeholder avatar for all bad avatar links
This commit is contained in:
parent
878ae7628f
commit
36fa57f145
2 changed files with 11 additions and 9 deletions
|
@ -1,7 +1,6 @@
|
||||||
require_dependency 'letter_avatar'
|
require_dependency 'letter_avatar'
|
||||||
|
|
||||||
class UserAvatarsController < ApplicationController
|
class UserAvatarsController < ApplicationController
|
||||||
DOT = Base64.decode64("R0lGODlhAQABALMAAAAAAIAAAACAAICAAAAAgIAAgACAgMDAwICAgP8AAAD/AP//AAAA//8A/wD//wBiZCH5BAEAAA8ALAAAAAABAAEAAAQC8EUAOw==")
|
|
||||||
|
|
||||||
skip_before_filter :preload_json, :redirect_to_login_if_required, :check_xhr, :verify_authenticity_token, only: [:show, :show_letter, :show_proxy_letter]
|
skip_before_filter :preload_json, :redirect_to_login_if_required, :check_xhr, :verify_authenticity_token, only: [:show, :show_letter, :show_proxy_letter]
|
||||||
|
|
||||||
|
@ -49,7 +48,7 @@ class UserAvatarsController < ApplicationController
|
||||||
|
|
||||||
no_cookies
|
no_cookies
|
||||||
|
|
||||||
return render_dot if params[:version] != LetterAvatar.version
|
return render_blank if params[:version] != LetterAvatar.version
|
||||||
|
|
||||||
image = LetterAvatar.generate(params[:username].to_s, params[:size].to_i)
|
image = LetterAvatar.generate(params[:username].to_s, params[:size].to_i)
|
||||||
|
|
||||||
|
@ -73,18 +72,18 @@ class UserAvatarsController < ApplicationController
|
||||||
def show_in_site(hostname)
|
def show_in_site(hostname)
|
||||||
|
|
||||||
username = params[:username].to_s
|
username = params[:username].to_s
|
||||||
return render_dot unless user = User.find_by(username_lower: username.downcase)
|
return render_blank unless user = User.find_by(username_lower: username.downcase)
|
||||||
|
|
||||||
upload_id, version = params[:version].split("_")
|
upload_id, version = params[:version].split("_")
|
||||||
|
|
||||||
version = (version || OptimizedImage::VERSION).to_i
|
version = (version || OptimizedImage::VERSION).to_i
|
||||||
return render_dot if version != OptimizedImage::VERSION
|
return render_blank if version != OptimizedImage::VERSION
|
||||||
|
|
||||||
upload_id = upload_id.to_i
|
upload_id = upload_id.to_i
|
||||||
return render_dot unless upload_id > 0 && user_avatar = user.user_avatar
|
return render_blank unless upload_id > 0 && user_avatar = user.user_avatar
|
||||||
|
|
||||||
size = params[:size].to_i
|
size = params[:size].to_i
|
||||||
return render_dot if size < 8 || size > 500
|
return render_blank if size < 8 || size > 500
|
||||||
|
|
||||||
if !Discourse.avatar_sizes.include?(size) && Discourse.store.external?
|
if !Discourse.avatar_sizes.include?(size) && Discourse.store.external?
|
||||||
closest = Discourse.avatar_sizes.to_a.min { |a,b| (size-a).abs <=> (size-b).abs }
|
closest = Discourse.avatar_sizes.to_a.min { |a,b| (size-a).abs <=> (size-b).abs }
|
||||||
|
@ -113,7 +112,7 @@ class UserAvatarsController < ApplicationController
|
||||||
expires_in 1.year, public: true
|
expires_in 1.year, public: true
|
||||||
send_file image, disposition: nil
|
send_file image, disposition: nil
|
||||||
else
|
else
|
||||||
render_dot
|
render_blank
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -137,9 +136,12 @@ class UserAvatarsController < ApplicationController
|
||||||
end
|
end
|
||||||
|
|
||||||
# this protects us from a DoS
|
# this protects us from a DoS
|
||||||
def render_dot
|
def render_blank
|
||||||
|
path = Rails.root + "public/images/avatar.png"
|
||||||
expires_in 10.minutes, public: true
|
expires_in 10.minutes, public: true
|
||||||
render text: DOT, content_type: "image/png"
|
response.headers["Last-Modified"] = DateTime.parse("1-1-2000").httpdate
|
||||||
|
response.headers["Content-Length"] = File.size(path).to_s
|
||||||
|
send_file path, disposition: nil
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_optimized_image(upload, size)
|
def get_optimized_image(upload, size)
|
||||||
|
|
BIN
public/images/avatar.png
Normal file
BIN
public/images/avatar.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 8.7 KiB |
Loading…
Reference in a new issue