FIX: Theme import error handling needs to happen inside the hijack block (#18866)

Otherwise the errors don't get caught.
This commit is contained in:
Daniel Waterworth 2022-11-03 14:02:26 -05:00 committed by GitHub
parent 943c43ddc5
commit 1398bd5f1f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 20 deletions

View File

@ -97,32 +97,32 @@ class Admin::ThemesController < Admin::AdminController
return return
end end
begin hijack do
branch = params[:branch] ? params[:branch] : nil begin
private_key = params[:public_key] ? Discourse.redis.get("ssh_key_#{params[:public_key]}") : nil branch = params[:branch] ? params[:branch] : nil
return render_json_error I18n.t("themes.import_error.ssh_key_gone") if params[:public_key].present? && private_key.blank? private_key = params[:public_key] ? Discourse.redis.get("ssh_key_#{params[:public_key]}") : nil
return render_json_error I18n.t("themes.import_error.ssh_key_gone") if params[:public_key].present? && private_key.blank?
hijack do
@theme = RemoteTheme.import_theme(remote, theme_user, private_key: private_key, branch: branch) @theme = RemoteTheme.import_theme(remote, theme_user, private_key: private_key, branch: branch)
render json: @theme, status: :created render json: @theme, status: :created
end rescue RemoteTheme::ImportError => e
rescue RemoteTheme::ImportError => e if params[:force]
if params[:force] theme_name = params[:remote].gsub(/.git$/, "").split("/").last
theme_name = params[:remote].gsub(/.git$/, "").split("/").last
remote_theme = RemoteTheme.new remote_theme = RemoteTheme.new
remote_theme.private_key = private_key remote_theme.private_key = private_key
remote_theme.branch = params[:branch] ? params[:branch] : nil remote_theme.branch = params[:branch] ? params[:branch] : nil
remote_theme.remote_url = params[:remote] remote_theme.remote_url = params[:remote]
remote_theme.save! remote_theme.save!
@theme = Theme.new(user_id: theme_user&.id || -1, name: theme_name) @theme = Theme.new(user_id: theme_user&.id || -1, name: theme_name)
@theme.remote_theme = remote_theme @theme.remote_theme = remote_theme
@theme.save! @theme.save!
render json: @theme, status: :created render json: @theme, status: :created
else else
render_json_error e.message render_json_error e.message
end
end end
end end
elsif params[:bundle] || (params[:theme] && THEME_CONTENT_TYPES.include?(params[:theme].content_type)) elsif params[:bundle] || (params[:theme] && THEME_CONTENT_TYPES.include?(params[:theme].content_type))

View File

@ -230,6 +230,14 @@ RSpec.describe Admin::ThemesController do
expect(response.status).to eq(201) expect(response.status).to eq(201)
end end
it 'fails to import with a failing status' do
post "/admin/themes/import.json", params: {
remote: 'non-existant'
}
expect(response.status).to eq(422)
end
it 'can lookup a private key by public key' do it 'can lookup a private key by public key' do
Discourse.redis.setex('ssh_key_abcdef', 1.hour, 'rsa private key') Discourse.redis.setex('ssh_key_abcdef', 1.hour, 'rsa private key')