Merge pull request #4455 from tgxworld/fix_category_logo_url
FIX: Form CDN URL client side instead.
This commit is contained in:
commit
9aecf4e6d1
|
@ -1,12 +0,0 @@
|
||||||
export default Em.Component.extend({
|
|
||||||
tagName: 'a',
|
|
||||||
attributeBindings: ['href'],
|
|
||||||
href: function() {
|
|
||||||
return Discourse.getURL('/c/') + Discourse.Category.slugFor(this.get('category'));
|
|
||||||
}.property(),
|
|
||||||
|
|
||||||
render(buffer) {
|
|
||||||
const categoryLogo = this.get('category.logo_url');
|
|
||||||
buffer.push(`<img class="category-logo" src='${categoryLogo}'/>`);
|
|
||||||
}
|
|
||||||
});
|
|
|
@ -1,17 +1,10 @@
|
||||||
import { iconHTML } from 'discourse/helpers/fa-icon';
|
import computed from 'ember-addons/ember-computed-decorators';
|
||||||
|
|
||||||
export default Em.Component.extend({
|
export default Em.Component.extend({
|
||||||
tagName: 'h3',
|
tagName: 'h3',
|
||||||
|
|
||||||
render(buffer) {
|
@computed("category.name")
|
||||||
const category = this.get('category');
|
categoryName(name) {
|
||||||
const categoryUrl = Discourse.getURL('/c/') + Discourse.Category.slugFor(category);
|
return Handlebars.Utils.escapeExpression(name);
|
||||||
const categoryName = Handlebars.Utils.escapeExpression(category.get('name'));
|
|
||||||
|
|
||||||
if (category.get('read_restricted')) { buffer.push(iconHTML('lock')); }
|
|
||||||
|
|
||||||
buffer.push(`<a href='${categoryUrl}'>`);
|
|
||||||
buffer.push(`<span class='category-name'>${categoryName}</span>`);
|
|
||||||
buffer.push(`</a>`);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -15,9 +15,6 @@
|
||||||
<td class="category" style={{border-color c.color}}>
|
<td class="category" style={{border-color c.color}}>
|
||||||
<div>
|
<div>
|
||||||
{{category-title-link category=c}}
|
{{category-title-link category=c}}
|
||||||
{{#if c.logo_url}}
|
|
||||||
{{category-logo-link category=c}}
|
|
||||||
{{/if}}
|
|
||||||
<div class="category-description">
|
<div class="category-description">
|
||||||
{{{c.description_excerpt}}}
|
{{{c.description_excerpt}}}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
<a href={{category.url}}>
|
||||||
|
{{#if category.read_restricted}}
|
||||||
|
{{fa-icon 'lock'}}
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
|
<span class="category-name">{{categoryName}}</span>
|
||||||
|
|
||||||
|
{{#if category.logo_url}}
|
||||||
|
<div>{{cdn-img src=category.logo_url class="category-logo"}}</div>
|
||||||
|
{{/if}}
|
||||||
|
</a>
|
|
@ -132,7 +132,7 @@ class CategoriesController < ApplicationController
|
||||||
|
|
||||||
render_serialized(@category, CategorySerializer)
|
render_serialized(@category, CategorySerializer)
|
||||||
else
|
else
|
||||||
render_json_error(@category) unless @category.save
|
return render_json_error(@category) unless @category.save
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -151,10 +151,6 @@ class CategoriesController < ApplicationController
|
||||||
|
|
||||||
old_permissions = cat.permissions_params
|
old_permissions = cat.permissions_params
|
||||||
|
|
||||||
# remove asset host & cdn from both logo_url and background_url (never trust the client)
|
|
||||||
category_params[:logo_url] = fix_upload_url(category_params[:logo_url])
|
|
||||||
category_params[:background_url] = fix_upload_url(category_params[:background_url])
|
|
||||||
|
|
||||||
if result = cat.update_attributes(category_params)
|
if result = cat.update_attributes(category_params)
|
||||||
Scheduler::Defer.later "Log staff action change category settings" do
|
Scheduler::Defer.later "Log staff action change category settings" do
|
||||||
@staff_action_logger.log_category_settings_change(@category, category_params, old_permissions)
|
@staff_action_logger.log_category_settings_change(@category, category_params, old_permissions)
|
||||||
|
@ -262,24 +258,4 @@ class CategoriesController < ApplicationController
|
||||||
params[:include_topics] ||
|
params[:include_topics] ||
|
||||||
SiteSetting.desktop_category_page_style == "categories_with_featured_topics".freeze
|
SiteSetting.desktop_category_page_style == "categories_with_featured_topics".freeze
|
||||||
end
|
end
|
||||||
|
|
||||||
def fix_upload_url(url)
|
|
||||||
return if url.blank?
|
|
||||||
|
|
||||||
if Discourse.asset_host.present?
|
|
||||||
asset_host = UrlHelper.schemaless(Discourse.asset_host)
|
|
||||||
url.sub!(/^(https?:)?#{Regexp.escape(asset_host)}/, "")
|
|
||||||
end
|
|
||||||
|
|
||||||
if SiteSetting.enable_s3_uploads? && SiteSetting.s3_cdn_url.present?
|
|
||||||
s3_cdn_url = UrlHelper.schemaless(SiteSetting.s3_cdn_url)
|
|
||||||
url.sub!(/^(https?:)?#{Regexp.escape(s3_cdn_url)}/, Discourse.store.absolute_base_url)
|
|
||||||
end
|
|
||||||
|
|
||||||
base_url = UrlHelper.schemaless(Discourse.base_url_no_prefix)
|
|
||||||
url.sub!(/^(https?:)?#{Regexp.escape(base_url)}/, "")
|
|
||||||
|
|
||||||
url
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -40,14 +40,4 @@ class BasicCategorySerializer < ApplicationSerializer
|
||||||
def notification_level
|
def notification_level
|
||||||
object.notification_level
|
object.notification_level
|
||||||
end
|
end
|
||||||
|
|
||||||
def logo_url
|
|
||||||
url = object.logo_url
|
|
||||||
url.present? && UrlHelper.is_local(url) ? UrlHelper.schemaless(UrlHelper.absolute(url)) : url
|
|
||||||
end
|
|
||||||
|
|
||||||
def background_url
|
|
||||||
url = object.background_url
|
|
||||||
url.present? && UrlHelper.is_local(url) ? UrlHelper.schemaless(UrlHelper.absolute(url)) : url
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -3,7 +3,7 @@ class UploadUrlValidator < ActiveModel::EachValidator
|
||||||
if value.present?
|
if value.present?
|
||||||
uri = URI.parse(value) rescue nil
|
uri = URI.parse(value) rescue nil
|
||||||
|
|
||||||
unless uri && Discourse.store.has_been_uploaded?(value)
|
unless uri && Upload.exists?(url: value)
|
||||||
record.errors[attribute] << (options[:message] || I18n.t('errors.messages.invalid'))
|
record.errors[attribute] << (options[:message] || I18n.t('errors.messages.invalid'))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -230,26 +230,6 @@ describe CategoriesController do
|
||||||
|
|
||||||
expect(UserHistory.count).to eq(5) # 2 + 3 (bootstrap mode)
|
expect(UserHistory.count).to eq(5) # 2 + 3 (bootstrap mode)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "fix both logo and background urls" do
|
|
||||||
Discourse.stubs(:asset_host).returns("http://foo.bar")
|
|
||||||
Discourse.stubs(:base_url_no_prefix).returns("http://bar.foo")
|
|
||||||
|
|
||||||
upload = build(:upload)
|
|
||||||
|
|
||||||
xhr :put, :update, id: @category.id,
|
|
||||||
name: @category.name,
|
|
||||||
color: @category.color,
|
|
||||||
text_color: @category.text_color,
|
|
||||||
slug: @category.slug,
|
|
||||||
logo_url: UrlHelper.schemaless(UrlHelper.absolute(upload.url)),
|
|
||||||
background_url: UrlHelper.absolute_without_cdn(upload.url)
|
|
||||||
|
|
||||||
@category.reload
|
|
||||||
expect(@category.logo_url).to eq(upload.url)
|
|
||||||
expect(@category.background_url).to eq(upload.url)
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -14,20 +14,19 @@ describe Category do
|
||||||
|
|
||||||
context "url validation" do
|
context "url validation" do
|
||||||
let(:user) { Fabricate(:user) }
|
let(:user) { Fabricate(:user) }
|
||||||
|
|
||||||
let(:upload) { Fabricate(:upload) }
|
let(:upload) { Fabricate(:upload) }
|
||||||
|
|
||||||
it "ensures logo_url is valid" do
|
it "ensures logo_url is valid" do
|
||||||
expect(Fabricate.build(:category, user: user, logo_url: "---%")).not_to be_valid
|
expect(Fabricate.build(:category, user: user, logo_url: "---%")).not_to be_valid
|
||||||
expect(Fabricate.build(:category, user: user, logo_url: "http://example.com/made-up.jpg")).not_to be_valid
|
expect(Fabricate.build(:category, user: user, logo_url: "http://example.com/made-up.jpg")).not_to be_valid
|
||||||
expect(Fabricate.build(:category, user: user, logo_url: upload.url)).to be_valid
|
expect(Fabricate.build(:category, user: user, logo_url: upload.url)).to be_valid
|
||||||
expect(Fabricate.build(:category, user: user, logo_url: UrlHelper.schemaless(UrlHelper.absolute(upload.url)))).to be_valid
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it "ensures background_url is valid" do
|
it "ensures background_url is valid" do
|
||||||
expect(Fabricate.build(:category, user: user, background_url: ";test")).not_to be_valid
|
expect(Fabricate.build(:category, user: user, background_url: ";test")).not_to be_valid
|
||||||
expect(Fabricate.build(:category, user: user, background_url: "http://example.com/no.jpg")).not_to be_valid
|
expect(Fabricate.build(:category, user: user, background_url: "http://example.com/no.jpg")).not_to be_valid
|
||||||
expect(Fabricate.build(:category, user: user, background_url: upload.url)).to be_valid
|
expect(Fabricate.build(:category, user: user, background_url: upload.url)).to be_valid
|
||||||
expect(Fabricate.build(:category, user: user, background_url: UrlHelper.schemaless(UrlHelper.absolute(upload.url)))).to be_valid
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue