mirror of
https://github.com/discourse/discourse.git
synced 2025-02-25 18:55:32 -06:00
FIX: reset embedding settings when no embeddable host, log host changes (#7264)
This commit is contained in:
@@ -1,23 +1,24 @@
|
||||
class Admin::EmbeddableHostsController < Admin::AdminController
|
||||
|
||||
def create
|
||||
save_host(EmbeddableHost.new)
|
||||
save_host(EmbeddableHost.new, :create)
|
||||
end
|
||||
|
||||
def update
|
||||
host = EmbeddableHost.where(id: params[:id]).first
|
||||
save_host(host)
|
||||
save_host(host, :update)
|
||||
end
|
||||
|
||||
def destroy
|
||||
host = EmbeddableHost.where(id: params[:id]).first
|
||||
host.destroy
|
||||
StaffActionLogger.new(current_user).log_embeddable_host(host, UserHistory.actions[:embeddable_host_destroy])
|
||||
render json: success_json
|
||||
end
|
||||
|
||||
protected
|
||||
|
||||
def save_host(host)
|
||||
def save_host(host, action)
|
||||
host.host = params[:embeddable_host][:host]
|
||||
host.path_whitelist = params[:embeddable_host][:path_whitelist]
|
||||
host.class_name = params[:embeddable_host][:class_name]
|
||||
@@ -25,6 +26,8 @@ class Admin::EmbeddableHostsController < Admin::AdminController
|
||||
host.category_id = SiteSetting.uncategorized_category_id if host.category_id.blank?
|
||||
|
||||
if host.save
|
||||
changes = host.saved_changes if action == :update
|
||||
StaffActionLogger.new(current_user).log_embeddable_host(host, UserHistory.actions[:"embeddable_host_#{action}"], changes: changes)
|
||||
render_serialized(host, EmbeddableHostSerializer, root: 'embeddable_host', rest_serializer: true)
|
||||
else
|
||||
render_json_error(host)
|
||||
|
||||
@@ -3,6 +3,7 @@ require_dependency 'url_helper'
|
||||
class EmbeddableHost < ActiveRecord::Base
|
||||
validate :host_must_be_valid
|
||||
belongs_to :category
|
||||
after_destroy :reset_embedding_settings
|
||||
|
||||
before_validation do
|
||||
self.host.sub!(/^https?:\/\//, '')
|
||||
@@ -53,6 +54,12 @@ class EmbeddableHost < ActiveRecord::Base
|
||||
|
||||
private
|
||||
|
||||
def reset_embedding_settings
|
||||
unless EmbeddableHost.exists?
|
||||
Embedding.settings.each { |s| SiteSetting.set(s.to_s, SiteSetting.defaults[s]) }
|
||||
end
|
||||
end
|
||||
|
||||
def host_must_be_valid
|
||||
if host !~ /\A[a-z0-9]+([\-\.]{1}[a-z0-9]+)*\.[a-z]{2,10}(:[0-9]{1,5})?(\/.*)?\Z/i &&
|
||||
host !~ /\A(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})(:[0-9]{1,5})?(\/.*)?\Z/ &&
|
||||
|
||||
@@ -88,7 +88,10 @@ class UserHistory < ActiveRecord::Base
|
||||
approve_user: 69,
|
||||
web_hook_create: 70,
|
||||
web_hook_update: 71,
|
||||
web_hook_destroy: 72
|
||||
web_hook_destroy: 72,
|
||||
embeddable_host_create: 73,
|
||||
embeddable_host_update: 74,
|
||||
embeddable_host_destroy: 75
|
||||
)
|
||||
end
|
||||
|
||||
@@ -155,7 +158,10 @@ class UserHistory < ActiveRecord::Base
|
||||
:approve_user,
|
||||
:web_hook_create,
|
||||
:web_hook_update,
|
||||
:web_hook_destroy
|
||||
:web_hook_destroy,
|
||||
:embeddable_host_create,
|
||||
:embeddable_host_update,
|
||||
:embeddable_host_destroy
|
||||
]
|
||||
end
|
||||
|
||||
|
||||
@@ -589,15 +589,7 @@ class StaffActionLogger
|
||||
"payload_url: #{web_hook.payload_url}"
|
||||
]
|
||||
|
||||
if changes = opts[:changes]
|
||||
changes.reject! { |k, v| k == "updated_at" }
|
||||
old_values = []
|
||||
new_values = []
|
||||
changes.each do |k, v|
|
||||
old_values << "#{k}: #{v[0]}"
|
||||
new_values << "#{k}: #{v[1]}"
|
||||
end
|
||||
end
|
||||
old_values, new_values = get_changes(opts[:changes])
|
||||
|
||||
UserHistory.create!(params(opts).merge(
|
||||
action: action,
|
||||
@@ -607,8 +599,33 @@ class StaffActionLogger
|
||||
))
|
||||
end
|
||||
|
||||
def log_embeddable_host(embeddable_host, action, opts = {})
|
||||
old_values, new_values = get_changes(opts[:changes])
|
||||
|
||||
UserHistory.create!(params(opts).merge(
|
||||
action: action,
|
||||
context: "host: #{embeddable_host.host}",
|
||||
previous_value: old_values&.join(", "),
|
||||
new_value: new_values&.join(", ")
|
||||
))
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def get_changes(changes)
|
||||
return unless changes
|
||||
|
||||
changes.delete("updated_at")
|
||||
old_values = []
|
||||
new_values = []
|
||||
changes.each do |k, v|
|
||||
old_values << "#{k}: #{v[0]}"
|
||||
new_values << "#{k}: #{v[1]}"
|
||||
end
|
||||
|
||||
[old_values, new_values]
|
||||
end
|
||||
|
||||
def params(opts = nil)
|
||||
opts ||= {}
|
||||
{ acting_user_id: @admin.id, context: opts[:context] }
|
||||
|
||||
Reference in New Issue
Block a user