2019-05-02 18:17:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2014-01-17 11:47:01 -05:00
|
|
|
module Middleware
|
|
|
|
|
|
|
|
# In development mode, it is common to use a database from a production site for testing
|
|
|
|
# with their data. Unfortunately, you can end up with dozens of missing avatar requests
|
|
|
|
# due to the files not being present locally. This middleware, only enabled in development
|
|
|
|
# mode, will replace those with an appropriate image.
|
|
|
|
class MissingAvatars
|
2017-07-27 21:20:09 -04:00
|
|
|
def initialize(app, settings = {})
|
2014-01-17 11:47:01 -05:00
|
|
|
@app = app
|
|
|
|
end
|
|
|
|
|
|
|
|
def call(env)
|
|
|
|
if (env['REQUEST_PATH'] =~ /^\/uploads\/default\/avatars/)
|
|
|
|
path = "#{Rails.root}/public#{env['REQUEST_PATH']}"
|
2017-07-27 21:20:09 -04:00
|
|
|
unless File.exist?(path)
|
2014-01-17 11:47:01 -05:00
|
|
|
default_image = "#{Rails.root}/public/images/d-logo-sketch-small.png"
|
|
|
|
return [ 200, { 'Content-Type' => 'image/png' }, [ File.read(default_image)] ]
|
|
|
|
end
|
|
|
|
end
|
2017-07-27 21:20:09 -04:00
|
|
|
|
2014-01-17 11:47:01 -05:00
|
|
|
status, headers, response = @app.call(env)
|
|
|
|
[status, headers, response]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|