FIX: use CDN for user card/profile background and user avatars (for real this time)

This commit is contained in:
Régis Hanol 2015-01-29 22:53:48 +01:00
parent 4a2786dbf2
commit 6a68e8c272
6 changed files with 26 additions and 18 deletions

View File

@ -24,6 +24,12 @@ window.Discourse = Ember.Application.createWithMixins(Discourse.Ajax, {
return u + url; return u + url;
}, },
getURLWithCDN: function(url) {
url = this.getURL(url);
if (Discourse.CDN) { url = Discourse.CDN + url; }
return url;
},
Resolver: DiscourseResolver, Resolver: DiscourseResolver,
_titleChanged: function() { _titleChanged: function() {

View File

@ -1,4 +1,5 @@
var esc = Handlebars.Utils.escapeExpression; var esc = Handlebars.Utils.escapeExpression;
Discourse.BBCode.register('quote', {noWrap: true, singlePara: true}, function(contents, bbParams, options) { Discourse.BBCode.register('quote', {noWrap: true, singlePara: true}, function(contents, bbParams, options) {
var params = {'class': 'quote'}, var params = {'class': 'quote'},
username = null; username = null;

View File

@ -72,10 +72,9 @@ Discourse.User = Discourse.Model.extend({
@type {String} @type {String}
**/ **/
profileBackground: function() { profileBackground: function() {
var background = this.get('profile_background'); var url = this.get('profile_background');
if(Em.isEmpty(background) || !Discourse.SiteSettings.allow_profile_backgrounds) { return; } if (Em.isEmpty(url) || !Discourse.SiteSettings.allow_profile_backgrounds) { return; }
return 'background-image: url(' + Discourse.getURLWithCDN(url) + ')';
return 'background-image: url(' + background + ')';
}.property('profile_background'), }.property('profile_background'),
/** /**
@ -442,6 +441,7 @@ Discourse.User.reopenClass(Discourse.Singleton, {
avatarTemplate: function(username, uploadedAvatarId) { avatarTemplate: function(username, uploadedAvatarId) {
var url; var url;
if (uploadedAvatarId) { if (uploadedAvatarId) {
url = "/user_avatar/" + url = "/user_avatar/" +
Discourse.BaseUrl + Discourse.BaseUrl +
@ -456,11 +456,7 @@ Discourse.User.reopenClass(Discourse.Singleton, {
Discourse.LetterAvatarVersion + ".png"; Discourse.LetterAvatarVersion + ".png";
} }
url = Discourse.getURL(url); return Discourse.getURLWithCDN(url);
if (Discourse.CDN) {
url = Discourse.CDN + url;
}
return url;
}, },
/** /**

View File

@ -11,6 +11,7 @@ export default Discourse.View.extend(CleansUp, {
addBackground: function() { addBackground: function() {
var url = this.get('controller.user.card_background'); var url = this.get('controller.user.card_background');
if (!this.get('allowBackgrounds')) { return; } if (!this.get('allowBackgrounds')) { return; }
var $this = this.$(); var $this = this.$();
@ -19,7 +20,7 @@ export default Discourse.View.extend(CleansUp, {
if (Ember.isEmpty(url)) { if (Ember.isEmpty(url)) {
$this.css('background-image', '').addClass('no-bg'); $this.css('background-image', '').addClass('no-bg');
} else { } else {
$this.css('background-image', "url(" + url + ")").removeClass('no-bg'); $this.css('background-image', "url(" + Discourse.getURLWithCDN(url) + ")").removeClass('no-bg');
} }
}.observes('controller.user.card_background'), }.observes('controller.user.card_background'),

View File

@ -1,11 +1,13 @@
require 'v8' require 'v8'
require 'nokogiri' require 'nokogiri'
require_dependency 'url_helper'
require_dependency 'excerpt_parser' require_dependency 'excerpt_parser'
require_dependency 'post' require_dependency 'post'
module PrettyText module PrettyText
class Helpers class Helpers
include UrlHelper
def t(key, opts) def t(key, opts)
key = "js." + key key = "js." + key
@ -21,15 +23,15 @@ module PrettyText
# function here are available to v8 # function here are available to v8
def avatar_template(username) def avatar_template(username)
return "" unless username return "" unless username
user = User.find_by(username_lower: username.downcase) user = User.find_by(username_lower: username.downcase)
user.avatar_template if user.present? return "" unless user.present?
schemaless absolute user.avatar_template
end end
def is_username_valid(username) def is_username_valid(username)
return false unless username return false unless username
username = username.downcase username = username.downcase
return User.exec_sql('SELECT 1 FROM users WHERE username_lower = ?', username).values.length == 1 User.exec_sql('SELECT 1 FROM users WHERE username_lower = ?', username).values.length == 1
end end
end end
@ -128,7 +130,9 @@ module PrettyText
context.eval("Discourse.SiteSettings = #{SiteSetting.client_settings_json};") context.eval("Discourse.SiteSettings = #{SiteSetting.client_settings_json};")
context.eval("Discourse.CDN = '#{Rails.configuration.action_controller.asset_host}';") context.eval("Discourse.CDN = '#{Rails.configuration.action_controller.asset_host}';")
context.eval("Discourse.BaseUrl = 'http://#{RailsMultisite::ConnectionManagement.current_hostname}';") context.eval("Discourse.BaseUrl = 'http://#{RailsMultisite::ConnectionManagement.current_hostname}';")
context.eval("Discourse.getURL = function(url) { return '#{Discourse::base_uri}' + url };") context.eval("Discourse.getURL = function(url) { return '#{Discourse::base_uri}' + url };")
context.eval("Discourse.getURLWithCDN = function(url) { url = Discourse.getURL(url); if (Discourse.CDN) { url = Discourse.CDN + url; } return url; };")
end end
def self.markdown(text, opts=nil) def self.markdown(text, opts=nil)

View File

@ -12,20 +12,20 @@ describe PrettyText do
before(:each) do before(:each) do
eviltrout = User.new eviltrout = User.new
eviltrout.stubs(:avatar_template).returns("http://test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/{size}.png") eviltrout.stubs(:avatar_template).returns("//test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/{size}.png")
User.expects(:find_by).with(username_lower: "eviltrout").returns(eviltrout) User.expects(:find_by).with(username_lower: "eviltrout").returns(eviltrout)
end end
it "produces a quote even with new lines in it" do it "produces a quote even with new lines in it" do
expect(PrettyText.cook("[quote=\"EvilTrout, post:123, topic:456, full:true\"]ddd\n[/quote]")).to match_html "<aside class=\"quote\" data-post=\"123\" data-topic=\"456\" data-full=\"true\"><div class=\"title\">\n<div class=\"quote-controls\"></div>\n<img width=\"20\" height=\"20\" src=\"http://test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/40.png\" class=\"avatar\">EvilTrout:</div>\n<blockquote><p>ddd</p></blockquote></aside>" expect(PrettyText.cook("[quote=\"EvilTrout, post:123, topic:456, full:true\"]ddd\n[/quote]")).to match_html "<aside class=\"quote\" data-post=\"123\" data-topic=\"456\" data-full=\"true\"><div class=\"title\">\n<div class=\"quote-controls\"></div>\n<img width=\"20\" height=\"20\" src=\"//test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/40.png\" class=\"avatar\">EvilTrout:</div>\n<blockquote><p>ddd</p></blockquote></aside>"
end end
it "should produce a quote" do it "should produce a quote" do
expect(PrettyText.cook("[quote=\"EvilTrout, post:123, topic:456, full:true\"]ddd[/quote]")).to match_html "<aside class=\"quote\" data-post=\"123\" data-topic=\"456\" data-full=\"true\"><div class=\"title\">\n<div class=\"quote-controls\"></div>\n<img width=\"20\" height=\"20\" src=\"http://test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/40.png\" class=\"avatar\">EvilTrout:</div>\n<blockquote><p>ddd</p></blockquote></aside>" expect(PrettyText.cook("[quote=\"EvilTrout, post:123, topic:456, full:true\"]ddd[/quote]")).to match_html "<aside class=\"quote\" data-post=\"123\" data-topic=\"456\" data-full=\"true\"><div class=\"title\">\n<div class=\"quote-controls\"></div>\n<img width=\"20\" height=\"20\" src=\"//test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/40.png\" class=\"avatar\">EvilTrout:</div>\n<blockquote><p>ddd</p></blockquote></aside>"
end end
it "trims spaces on quote params" do it "trims spaces on quote params" do
expect(PrettyText.cook("[quote=\"EvilTrout, post:555, topic: 666\"]ddd[/quote]")).to match_html "<aside class=\"quote\" data-post=\"555\" data-topic=\"666\"><div class=\"title\">\n<div class=\"quote-controls\"></div>\n<img width=\"20\" height=\"20\" src=\"http://test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/40.png\" class=\"avatar\">EvilTrout:</div>\n<blockquote><p>ddd</p></blockquote></aside>" expect(PrettyText.cook("[quote=\"EvilTrout, post:555, topic: 666\"]ddd[/quote]")).to match_html "<aside class=\"quote\" data-post=\"555\" data-topic=\"666\"><div class=\"title\">\n<div class=\"quote-controls\"></div>\n<img width=\"20\" height=\"20\" src=\"//test.localhost/uploads/default/avatars/42d/57c/46ce7ee487/40.png\" class=\"avatar\">EvilTrout:</div>\n<blockquote><p>ddd</p></blockquote></aside>"
end end
end end