From fa6f22dd39adaf692dc36af59dc2412a5896c2b8 Mon Sep 17 00:00:00 2001 From: Sam Date: Fri, 30 May 2014 14:17:35 +1000 Subject: [PATCH] Move letter avatars out of upload system FIX: S3 issues around system avatars FIX: reduced backup file size --- .../discourse/helpers/application_helpers.js | 2 +- .../javascripts/discourse/models/user.js | 19 +- app/controllers/application_controller.rb | 1 + app/controllers/user_avatars_controller.rb | 16 +- app/jobs/scheduled/create_missing_avatars.rb | 10 - app/jobs/scheduled/periodical_updates.rb | 5 +- app/models/optimized_image.rb | 2 - app/models/user.rb | 20 +- app/models/user_avatar.rb | 25 +- .../common/_discourse_javascript.html.erb | 1 + config/initializers/06-mini_profiler.rb | 1 + config/routes.rb | 2 + ...remove_system_avatars_from_user_avatars.rb | 44 ++ lib/letter_avatar.rb | 505 +++++++++--------- lib/tasks/avatars.rake | 12 - lib/tasks/qunit.rake | 1 + spec/models/user_avatar_spec.rb | 16 - spec/models/user_spec.rb | 16 +- 18 files changed, 367 insertions(+), 331 deletions(-) create mode 100644 db/migrate/20140530002535_remove_system_avatars_from_user_avatars.rb diff --git a/app/assets/javascripts/discourse/helpers/application_helpers.js b/app/assets/javascripts/discourse/helpers/application_helpers.js index f97669ee5f7..0f0e2e9cc3a 100644 --- a/app/assets/javascripts/discourse/helpers/application_helpers.js +++ b/app/assets/javascripts/discourse/helpers/application_helpers.js @@ -200,7 +200,7 @@ Handlebars.registerHelper('avatar', function(user, options) { } // this is simply done to ensure we cache images correctly - var uploadedAvatarId = Em.get(user, 'uploaded_avatar_id') || Em.get(user, 'user.uploaded_avatar_id') || "_1"; + var uploadedAvatarId = Em.get(user, 'uploaded_avatar_id') || Em.get(user, 'user.uploaded_avatar_id'); var avatarTemplate = Discourse.User.avatarTemplate(username,uploadedAvatarId); return new Handlebars.SafeString(Discourse.Utilities.avatarImg({ diff --git a/app/assets/javascripts/discourse/models/user.js b/app/assets/javascripts/discourse/models/user.js index 470242580fc..f4a7a301690 100644 --- a/app/assets/javascripts/discourse/models/user.js +++ b/app/assets/javascripts/discourse/models/user.js @@ -417,7 +417,24 @@ Discourse.User = Discourse.Model.extend({ Discourse.User.reopenClass(Discourse.Singleton, { avatarTemplate: function(username, uploadedAvatarId){ - var url = Discourse.getURL("/user_avatar/" + Discourse.BaseUrl + "/" + username.toLowerCase() + "/{size}/" + uploadedAvatarId + ".png"); + var url; + if(uploadedAvatarId){ + url = "/user_avatar/" + + Discourse.BaseUrl + + "/" + + username.toLowerCase() + + "/{size}/" + + uploadedAvatarId + ".png"; + + + } else { + url = "/letter_avatar/" + + username.toLowerCase() + + "/{size}/" + + Discourse.LetterAvatarVersion + ".png"; + } + + url = Discourse.getURL(url); if(Discourse.CDN){ url = Discourse.CDN + url; } diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index 76b4d2bdfa0..7fee212d2a6 100644 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -6,6 +6,7 @@ require_dependency 'archetype' require_dependency 'rate_limiter' require_dependency 'crawler_detection' require_dependency 'json_error' +require_dependency 'letter_avatar' class ApplicationController < ActionController::Base include CurrentUser diff --git a/app/controllers/user_avatars_controller.rb b/app/controllers/user_avatars_controller.rb index 717ef6e9f9b..a82eebe62fe 100644 --- a/app/controllers/user_avatars_controller.rb +++ b/app/controllers/user_avatars_controller.rb @@ -3,7 +3,7 @@ require_dependency 'letter_avatar' class UserAvatarsController < ApplicationController DOT = Base64.decode64("R0lGODlhAQABALMAAAAAAIAAAACAAICAAAAAgIAAgACAgMDAwICAgP8AAAD/AP//AAAA//8A/wD//wBiZCH5BAEAAA8ALAAAAAABAAEAAAQC8EUAOw==") - skip_before_filter :check_xhr, :verify_authenticity_token, only: :show + skip_before_filter :check_xhr, :verify_authenticity_token, only: [:show, :show_letter] def refresh_gravatar @@ -20,6 +20,20 @@ class UserAvatarsController < ApplicationController end end + def show_letter + params.require(:username) + params.require(:version) + params.require(:size) + + if params[:version].to_i > LetterAvatar::VERSION + return render_dot + end + + image = LetterAvatar.generate(params[:username].to_s, params[:size].to_i) + expires_in 1.year, public: true + send_file image, disposition: nil + end + def show # we need multisite support to keep a single origin pull for CDNs RailsMultisite::ConnectionManagement.with_hostname(params[:hostname]) do diff --git a/app/jobs/scheduled/create_missing_avatars.rb b/app/jobs/scheduled/create_missing_avatars.rb index 9e4d3391ea1..42a2b01dc8f 100644 --- a/app/jobs/scheduled/create_missing_avatars.rb +++ b/app/jobs/scheduled/create_missing_avatars.rb @@ -2,16 +2,6 @@ module Jobs class CreateMissingAvatars < Jobs::Scheduled every 1.hour def execute(args) - UserAvatar - .where("system_upload_id IS NULL OR system_avatar_version != ?", UserAvatar::SYSTEM_AVATAR_VERSION) - .find_each do |a| - if a.user - a.update_system_avatar! - else - Rails.logger.warn("Detected stray avatar for avatar_user_id #{a.id}") - end - end - # backfill in batches 5000 an hour UserAvatar.where(last_gravatar_download_attempt: nil).includes(:user) .order("users.last_posted_at desc") diff --git a/app/jobs/scheduled/periodical_updates.rb b/app/jobs/scheduled/periodical_updates.rb index 77f40888d31..be77a683390 100644 --- a/app/jobs/scheduled/periodical_updates.rb +++ b/app/jobs/scheduled/periodical_updates.rb @@ -28,10 +28,7 @@ module Jobs Topic.auto_close # Forces rebake of old posts where needed, as long as no system avatars need updating - unless UserAvatar - .where("last_gravatar_download_attempt IS NULL OR system_upload_id IS NULL OR system_avatar_version != ?", UserAvatar::SYSTEM_AVATAR_VERSION) - .limit(1) - .first + unless UserAvatar.where("last_gravatar_download_attempt IS NULL").limit(1).first Post.rebake_old(250) end end diff --git a/app/models/optimized_image.rb b/app/models/optimized_image.rb index 7c8c2c44c12..13fe45ac241 100644 --- a/app/models/optimized_image.rb +++ b/app/models/optimized_image.rb @@ -67,8 +67,6 @@ class OptimizedImage < ActiveRecord::Base end end - protected - def self.resize(from, to, width, height) instructions = %W{ #{from} diff --git a/app/models/user.rb b/app/models/user.rb index c2e299d3d44..8ef6111c1ae 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -8,6 +8,7 @@ require_dependency 'post_destroyer' require_dependency 'user_name_suggester' require_dependency 'pretty_text' require_dependency 'url_helper' +require_dependency 'letter_avatar' class User < ActiveRecord::Base include Roleable @@ -354,11 +355,16 @@ class User < ActiveRecord::Base end def self.avatar_template(username,uploaded_avatar_id) - id = uploaded_avatar_id || -1 + return letter_avatar_template(username) if !uploaded_avatar_id + id = uploaded_avatar_id username ||= "" "/user_avatar/#{RailsMultisite::ConnectionManagement.current_hostname}/#{username.downcase}/{size}/#{id}.png" end + def self.letter_avatar_template(username) + "/letter_avatar/#{username.downcase}/{size}/#{LetterAvatar::VERSION}.png" + end + def avatar_template self.class.avatar_template(username,uploaded_avatar_id) end @@ -627,16 +633,8 @@ class User < ActiveRecord::Base gravatar_downloaded = avatar.gravatar_upload_id end - if SiteSetting.enable_system_avatars? - avatar.update_system_avatar! if !avatar.system_upload_id || - username_changed? || - avatar.system_avatar_version != UserAvatar::SYSTEM_AVATAR_VERSION - end - - desired_avatar_id = avatar.gravatar_upload_id || avatar.system_upload_id - - if (!self.uploaded_avatar_id || gravatar_downloaded) && desired_avatar_id - self.update_column(:uploaded_avatar_id, desired_avatar_id) + if (!self.uploaded_avatar_id && gravatar_downloaded) + self.update_column(:uploaded_avatar_id, avatar.gravatar_upload_id) end end diff --git a/app/models/user_avatar.rb b/app/models/user_avatar.rb index bfb3a3f26a5..7cfd1da16ea 100644 --- a/app/models/user_avatar.rb +++ b/app/models/user_avatar.rb @@ -2,34 +2,13 @@ require_dependency 'letter_avatar' class UserAvatar < ActiveRecord::Base MAX_SIZE = 240 - SYSTEM_AVATAR_VERSION = 1 belongs_to :user - belongs_to :system_upload, class_name: 'Upload', dependent: :destroy belongs_to :gravatar_upload, class_name: 'Upload', dependent: :destroy belongs_to :custom_upload, class_name: 'Upload', dependent: :destroy def contains_upload?(id) - system_upload_id == id || gravatar_upload_id == id || custom_upload_id == id - end - - # updates the letter based avatar - def update_system_avatar! - old_id = nil - if system_upload - old_id = system_upload_id - system_upload.destroy! - end - - file = File.open(LetterAvatar.generate(user.username, MAX_SIZE, cache: false), "r") - self.system_upload = Upload.create_for(user_id, file, "avatar.png", file.size) - self.system_avatar_version = SYSTEM_AVATAR_VERSION - - if old_id == user.uploaded_avatar_id - user.update_column(:uploaded_avatar_id, system_upload_id) - end - - save! + gravatar_upload_id == id || custom_upload_id == id end def update_gravatar! @@ -63,13 +42,11 @@ end # # id :integer not null, primary key # user_id :integer not null -# system_upload_id :integer # custom_upload_id :integer # gravatar_upload_id :integer # last_gravatar_download_attempt :datetime # created_at :datetime # updated_at :datetime -# system_avatar_version :integer default(0) # # Indexes # diff --git a/app/views/common/_discourse_javascript.html.erb b/app/views/common/_discourse_javascript.html.erb index 060783800b1..61aaf13c1d2 100644 --- a/app/views/common/_discourse_javascript.html.erb +++ b/app/views/common/_discourse_javascript.html.erb @@ -35,6 +35,7 @@ Discourse.BaseUri = '<%= Discourse::base_uri "/" %>'; Discourse.Environment = '<%= Rails.env %>'; Discourse.SiteSettings = PreloadStore.get('siteSettings'); + Discourse.LetterAvatarVersion = <%= LetterAvatar::VERSION %>; Discourse.Router = Ember.Router.extend({ location: 'discourse-location' }); Discourse.Route.mapRoutes(); Discourse.start(); diff --git a/config/initializers/06-mini_profiler.rb b/config/initializers/06-mini_profiler.rb index b9bdd2d9078..66a2b86cf4b 100644 --- a/config/initializers/06-mini_profiler.rb +++ b/config/initializers/06-mini_profiler.rb @@ -23,6 +23,7 @@ if defined?(Rack::MiniProfiler) (path !~ /topics\/timings/) && (path !~ /assets/) && (path !~ /\/user_avatar\//) && + (path !~ /\/letter_avatar\//) && (path !~ /qunit/) && (path !~ /srv\/status/) && (path !~ /commits-widget/) && diff --git a/config/routes.rb b/config/routes.rb index f0321c619b9..8b347cf5083 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -212,6 +212,8 @@ Discourse::Application.routes.draw do delete "users/:username" => "users#destroy", constraints: {username: USERNAME_ROUTE_FORMAT} post "user_avatar/:username/refresh_gravatar" => "user_avatars#refresh_gravatar" + get "letter_avatar/:username/:size/:version.png" => "user_avatars#show_letter", + format: false, constraints: {hostname: /[\w\.-]+/} get "user_avatar/:hostname/:username/:size/:version.png" => "user_avatars#show", format: false, constraints: {hostname: /[\w\.-]+/} diff --git a/db/migrate/20140530002535_remove_system_avatars_from_user_avatars.rb b/db/migrate/20140530002535_remove_system_avatars_from_user_avatars.rb new file mode 100644 index 00000000000..ae4a8f364af --- /dev/null +++ b/db/migrate/20140530002535_remove_system_avatars_from_user_avatars.rb @@ -0,0 +1,44 @@ +# This takes all the system avatars out of the upload system, saving us a huge +# amount of space on backups +class RemoveSystemAvatarsFromUserAvatars < ActiveRecord::Migration + def up + execute "UPDATE users SET uploaded_avatar_id = NULL WHERE uploaded_avatar_id IN ( + SELECT system_upload_id FROM user_avatars + )" + + # normally we dont reach into the object model, but we have to here. + # otherwise we will wait a real long time for uploads to go away + skip = -1 + while skip=destroy_system_avatar_batch(skip) do + puts "Destroyed up to id: #{skip}" + end + + remove_column :user_avatars, :system_upload_id + remove_column :user_avatars, :system_avatar_version + end + + def destroy_system_avatar_batch(skip) + initial = skip + + Upload.where('id IN (SELECT system_upload_id FROM user_avatars) AND id > ?', skip) + .order(:id) + .limit(500) + .each do |upload| + skip = upload.id + begin + upload.destroy + rescue + Rails.logger.warn "Could not destroy system avatar #{upload.id}" + end + end + + skip == initial ? nil : skip + rescue + Rails.logger.warn "Could not destroy system avatars, skipping" + nil + end + + def down + raise ActiveRecord::IrreversibleMigration + end +end diff --git a/lib/letter_avatar.rb b/lib/letter_avatar.rb index 88861166c6d..b5446478e5f 100644 --- a/lib/letter_avatar.rb +++ b/lib/letter_avatar.rb @@ -1,52 +1,73 @@ class LetterAvatar + + # BUMP UP if avatar algorithm changes + VERSION = 1 + + # Largest avatar generated, one day when pixel ratio hit 3 + # we will need to change this + FULLSIZE = 240 + class< FULLSIZE - filename = cached_path(username, size) + filename = cached_path(identity, size) if cache && File.exists?(filename) return filename end - fullsize = fullsize_path(username) + fullsize = fullsize_path(identity) if !cache || !File.exists?(fullsize) - generate_fullsize(username) + generate_fullsize(identity) end - resize(fullsize, filename, size) + OptimizedImage.resize(fullsize, filename, size, size) + filename end - def cached_path(username, size) - dir = "#{cache_path}/#{username}" + def cached_path(identity, size) + dir = "#{cache_path}/#{identity.letter}/#{identity.color.join("_")}" FileUtils.mkdir_p(dir) "#{dir}/#{size}.png" end - def fullsize_path(username) - cached_path(username, FULLSIZE) + def fullsize_path(identity) + cached_path(identity, FULLSIZE) end - def resize(from, to, size) - `convert #{from} -resize #{size}x#{size} #{to}` - to - end + def generate_fullsize(identity) - def generate_fullsize(username) + color = identity.color + letter = identity.letter - filename = fullsize_path(username) - color = colors[Digest::MD5.hexdigest(username)[0...15].to_i(16) % 216] + filename = fullsize_path(identity) stroke = darken(color, 0.8) instructions = %W{ @@ -58,7 +79,7 @@ class LetterAvatar -font 'Helvetica' -stroke #{to_rgb(stroke)} -strokewidth 2 - -annotate -5+25 '#{username[0].upcase}' + -annotate -5+25 '#{letter}' '#{filename}' } @@ -77,230 +98,228 @@ class LetterAvatar r,g,b = color "'rgb(#{r},#{g},#{b})'" end - - # palette of 216 optimally disctinct colors - # cf. http://tools.medialab.sciences-po.fr/iwanthue/index.php - # parameters used: - # - H: 0 - 360 - # - C: 0 - 2 - # - L: 0.75 - 1.5 - def colors - [[198,125,40], - [61,155,243], - [74,243,75], - [238,89,166], - [52,240,224], - [177,156,155], - [247,242,53], - [111,154,78], - [237,179,245], - [237,101,95], - [89,239,155], - [242,233,158], - [163,212,245], - [65,152,142], - [165,135,246], - [181,166,38], - [187,229,206], - [77,164,25], - [179,246,101], - [234,93,37], - [225,155,115], - [142,140,188], - [223,120,140], - [249,174,27], - [244,117,225], - [137,141,102], - [75,191,146], - [188,239,142], - [164,199,145], - [173,120,149], - [59,195,89], - [222,198,220], - [68,145,187], - [236,204,179], - [159,195,72], - [188,121,189], - [166,160,85], - [181,233,37], - [236,177,85], - [121,147,160], - [234,218,110], - [241,157,191], - [62,200,234], - [133,243,34], - [88,149,110], - [226,235,237], - [183,119,118], - [192,247,192], - [113,196,122], - [197,115,70], - [80,175,187], - [103,231,238], - [240,72,133], - [228,149,241], - [180,188,159], - [172,132,85], - [221,236,102], - [236,194,58], - [217,176,109], - [88,244,199], - [186,157,239], - [113,230,96], - [206,115,165], - [244,178,163], - [230,139,26], - [241,125,89], - [83,160,66], - [107,190,166], - [197,161,210], - [198,203,245], - [238,117,19], - [228,119,116], - [131,156,41], - [145,178,168], - [139,170,220], - [233,95,125], - [87,178,230], - [157,200,119], - [237,140,76], - [229,185,186], - [144,206,212], - [236,209,158], - [185,189,79], - [34,208,66], - [84,238,129], - [133,140,134], - [219,229,175], - [168,179,25], - [140,145,240], - [151,241,125], - [67,162,107], - [200,156,21], - [169,173,189], - [226,116,189], - [133,231,191], - [194,161,63], - [241,77,99], - [241,217,53], - [123,204,105], - [210,201,119], - [229,108,155], - [240,91,72], - [187,115,210], - [240,163,100], - [178,217,57], - [179,135,116], - [204,211,24], - [186,135,57], - [223,176,135], - [204,148,151], - [116,223,50], - [95,195,46], - [123,160,236], - [181,172,131], - [142,220,202], - [240,140,112], - [172,145,164], - [228,124,45], - [222,234,142], - [42,205,125], - [192,233,116], - [119,170,114], - [158,138,26], - [73,190,183], - [185,229,243], - [227,107,55], - [196,205,202], - [132,143,60], - [233,192,237], - [62,150,220], - [205,201,141], - [106,140,190], - [161,131,205], - [226,226,75], - [198,139,81], - [115,171,32], - [101,181,67], - [149,137,119], - [222,245,86], - [183,130,175], - [168,125,133], - [124,142,87], - [236,156,171], - [232,194,91], - [219,200,69], - [144,219,34], - [219,95,187], - [145,154,217], - [165,185,100], - [127,238,163], - [224,178,198], - [119,153,120], - [124,212,92], - [172,161,105], - [231,155,135], - [157,132,101], - [122,185,146], - [53,166,51], - [70,163,90], - [150,190,213], - [234,235,219], - [166,152,185], - [159,194,159], - [222,242,47], - [202,176,161], - [95,140,229], - [156,246,80], - [93,170,203], - [159,142,54], - [185,237,230], - [94,150,149], - [187,206,136], - [157,224,166], - [235,158,208], - [109,232,216], - [141,201,87], - [208,124,118], - [142,125,214], - [226,234,123], - [72,219,41], - [234,102,111], - [168,142,79], - [188,135,35], - [214,233,195], - [148,173,116], - [223,112,95], - [228,128,236], - [206,114,54], - [195,119,88], - [235,140,94], - [235,202,125], - [233,155,153], - [214,214,238], - [246,200,35], - [151,125,171], - [132,145,172], - [131,142,118], - [199,126,150], - [61,162,123], - [58,176,151], - [215,141,69], - [225,154,220], - [224,244,174], - [233,161,64], - [130,221,137], - [81,191,129], - [169,162,140], - [174,177,222], - [236,174,47], - [196,240,159], - [69,222,172], - [71,232,93], - [118,211,238], - [157,224,83], - [218,105,73], - [165,241,221]] - end end + + # palette of optimally disctinct colors + # cf. http://tools.medialab.sciences-po.fr/iwanthue/index.php + # parameters used: + # - H: 0 - 360 + # - C: 0 - 2 + # - L: 0.75 - 1.5 + COLORS = [[198,125,40], + [61,155,243], + [74,243,75], + [238,89,166], + [52,240,224], + [177,156,155], + [247,242,53], + [111,154,78], + [237,179,245], + [237,101,95], + [89,239,155], + [242,233,158], + [163,212,245], + [65,152,142], + [165,135,246], + [181,166,38], + [187,229,206], + [77,164,25], + [179,246,101], + [234,93,37], + [225,155,115], + [142,140,188], + [223,120,140], + [249,174,27], + [244,117,225], + [137,141,102], + [75,191,146], + [188,239,142], + [164,199,145], + [173,120,149], + [59,195,89], + [222,198,220], + [68,145,187], + [236,204,179], + [159,195,72], + [188,121,189], + [166,160,85], + [181,233,37], + [236,177,85], + [121,147,160], + [234,218,110], + [241,157,191], + [62,200,234], + [133,243,34], + [88,149,110], + [226,235,237], + [183,119,118], + [192,247,192], + [113,196,122], + [197,115,70], + [80,175,187], + [103,231,238], + [240,72,133], + [228,149,241], + [180,188,159], + [172,132,85], + [221,236,102], + [236,194,58], + [217,176,109], + [88,244,199], + [186,157,239], + [113,230,96], + [206,115,165], + [244,178,163], + [230,139,26], + [241,125,89], + [83,160,66], + [107,190,166], + [197,161,210], + [198,203,245], + [238,117,19], + [228,119,116], + [131,156,41], + [145,178,168], + [139,170,220], + [233,95,125], + [87,178,230], + [157,200,119], + [237,140,76], + [229,185,186], + [144,206,212], + [236,209,158], + [185,189,79], + [34,208,66], + [84,238,129], + [133,140,134], + [219,229,175], + [168,179,25], + [140,145,240], + [151,241,125], + [67,162,107], + [200,156,21], + [169,173,189], + [226,116,189], + [133,231,191], + [194,161,63], + [241,77,99], + [241,217,53], + [123,204,105], + [210,201,119], + [229,108,155], + [240,91,72], + [187,115,210], + [240,163,100], + [178,217,57], + [179,135,116], + [204,211,24], + [186,135,57], + [223,176,135], + [204,148,151], + [116,223,50], + [95,195,46], + [123,160,236], + [181,172,131], + [142,220,202], + [240,140,112], + [172,145,164], + [228,124,45], + [222,234,142], + [42,205,125], + [192,233,116], + [119,170,114], + [158,138,26], + [73,190,183], + [185,229,243], + [227,107,55], + [196,205,202], + [132,143,60], + [233,192,237], + [62,150,220], + [205,201,141], + [106,140,190], + [161,131,205], + [226,226,75], + [198,139,81], + [115,171,32], + [101,181,67], + [149,137,119], + [222,245,86], + [183,130,175], + [168,125,133], + [124,142,87], + [236,156,171], + [232,194,91], + [219,200,69], + [144,219,34], + [219,95,187], + [145,154,217], + [165,185,100], + [127,238,163], + [224,178,198], + [119,153,120], + [124,212,92], + [172,161,105], + [231,155,135], + [157,132,101], + [122,185,146], + [53,166,51], + [70,163,90], + [150,190,213], + [234,235,219], + [166,152,185], + [159,194,159], + [222,242,47], + [202,176,161], + [95,140,229], + [156,246,80], + [93,170,203], + [159,142,54], + [185,237,230], + [94,150,149], + [187,206,136], + [157,224,166], + [235,158,208], + [109,232,216], + [141,201,87], + [208,124,118], + [142,125,214], + [226,234,123], + [72,219,41], + [234,102,111], + [168,142,79], + [188,135,35], + [214,233,195], + [148,173,116], + [223,112,95], + [228,128,236], + [206,114,54], + [195,119,88], + [235,140,94], + [235,202,125], + [233,155,153], + [214,214,238], + [246,200,35], + [151,125,171], + [132,145,172], + [131,142,118], + [199,126,150], + [61,162,123], + [58,176,151], + [215,141,69], + [225,154,220], + [224,244,174], + [233,161,64], + [130,221,137], + [81,191,129], + [169,162,140], + [174,177,222], + [236,174,47], + [196,240,159], + [69,222,172], + [71,232,93], + [118,211,238], + [157,224,83], + [218,105,73], + [165,241,221]] end diff --git a/lib/tasks/avatars.rake b/lib/tasks/avatars.rake index fdeaba8c857..c598a5ae6a2 100644 --- a/lib/tasks/avatars.rake +++ b/lib/tasks/avatars.rake @@ -1,15 +1,3 @@ -desc "Rebuild all system avatars" -task "avatars:rebuild_system" => :environment do - i = 0 - puts "Regenerating system avatars" - puts - UserAvatar.find_each do |a| - a.update_system_avatar! - putc "." if (i+=1)%10 == 0 - end - puts -end - desc "Refresh all avatars (download missing gravatars, refresh system)" task "avatars:refresh" => :environment do i = 0 diff --git a/lib/tasks/qunit.rake b/lib/tasks/qunit.rake index b39b37e4cfd..a35b41a8e93 100644 --- a/lib/tasks/qunit.rake +++ b/lib/tasks/qunit.rake @@ -25,6 +25,7 @@ task "qunit:test" => :environment do end unless pid = fork + Discourse.after_fork Rack::Server.start(:config => "config.ru", :AccessLog => [], :Port => port) diff --git a/spec/models/user_avatar_spec.rb b/spec/models/user_avatar_spec.rb index 7c3f20ea37b..a621580e932 100644 --- a/spec/models/user_avatar_spec.rb +++ b/spec/models/user_avatar_spec.rb @@ -6,22 +6,6 @@ describe UserAvatar do user.create_user_avatar! } - it 'can generate a system avatar' do - avatar.update_system_avatar! - avatar.system_upload.should_not be_nil - end - - it 'corrects old system avatars on refresh' do - upload = Fabricate(:upload) - user = Fabricate(:user, uploaded_avatar_id: upload.id) - avatar = UserAvatar.create!(user_id: user.id, system_upload_id: upload.id) - avatar.update_system_avatar! - - user.reload - user.uploaded_avatar_id.should_not == upload.id - avatar.system_upload_id.should == user.uploaded_avatar_id - end - it 'can update gravatars' do temp = Tempfile.new('test') temp.binmode diff --git a/spec/models/user_spec.rb b/spec/models/user_spec.rb index 7b0f34692eb..2e1dce54513 100644 --- a/spec/models/user_spec.rb +++ b/spec/models/user_spec.rb @@ -978,7 +978,7 @@ describe User do let(:user) { build(:user, username: 'Sam') } it "returns a 45-pixel-wide avatar" do - user.small_avatar_url.should == "//test.localhost/user_avatar/test.localhost/sam/45/-1.png" + user.small_avatar_url.should == "//test.localhost/letter_avatar/sam/45/#{LetterAvatar::VERSION}.png" end end @@ -1139,8 +1139,8 @@ describe User do SiteSetting.enable_system_avatars = true u = User.create!(username: "bob", email: "bob@bob.com") u.reload - u.user_avatar.system_upload_id.should == u.uploaded_avatar_id - u.uploaded_avatar_id.should_not == nil + u.uploaded_avatar_id.should == nil + u.avatar_template.should == "/letter_avatar/bob/{size}/#{LetterAvatar::VERSION}.png" end end @@ -1178,9 +1178,6 @@ describe User do body: png ) user = User.create!(username: "bob", name: "bob", email: "a@a.com") - user.create_user_avatar - user.user_avatar.update_system_avatar! - user.save user.reload SiteSetting.automatically_download_gravatars = true @@ -1190,6 +1187,13 @@ describe User do user.reload user.user_avatar.gravatar_upload_id.should == user.uploaded_avatar_id + + user.uploaded_avatar_id = nil + user.save + user.refresh_avatar + + user.reload + user.uploaded_avatar_id.should == nil end end