FEATURE: Allow complex post params from plugin (#8598)

This commit is contained in:
Mark VanLandingham 2019-12-20 10:37:12 -06:00 committed by GitHub
parent 1e4a83cc2a
commit 6ec3d42b16
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 69 additions and 4 deletions

View File

@ -684,8 +684,17 @@ class PostsController < ApplicationController
:draft_key :draft_key
] ]
Post.plugin_permitted_create_params.each do |key, plugin| Post.plugin_permitted_create_params.each do |key, value|
permitted << key if plugin.enabled? if value[:plugin].enabled?
permitted << case value[:type]
when :string
key.to_sym
when :array
{ key => [] }
when :hash
{ key => {} }
end
end
end end
# param munging for WordPress # param munging for WordPress

View File

@ -250,9 +250,9 @@ class Plugin::Instance
end end
# Add a permitted_create_param to Post, respecting if the plugin is enabled # Add a permitted_create_param to Post, respecting if the plugin is enabled
def add_permitted_post_create_param(name) def add_permitted_post_create_param(name, type = :string)
reloadable_patch do |plugin| reloadable_patch do |plugin|
::Post.plugin_permitted_create_params[name] = plugin ::Post.plugin_permitted_create_params[name] = { plugin: plugin, type: type }
end end
end end

View File

@ -1871,4 +1871,60 @@ describe PostsController do
expect(public_post.custom_fields[Post::NOTICE_ARGS]).to eq(nil) expect(public_post.custom_fields[Post::NOTICE_ARGS]).to eq(nil)
end end
end end
describe Plugin::Instance do
describe '#add_permitted_post_create_param' do
fab!(:user) { Fabricate(:user) }
let(:instance) { Plugin::Instance.new }
let(:request) do
Proc.new {
post "/posts.json", params: {
raw: 'this is the test content',
title: 'this is the test title for the topic',
composer_open_duration_msecs: 204,
typing_duration_msecs: 100,
reply_to_post_number: 123,
string_arg: '123',
hash_arg: { key1: 'val' },
array_arg: ['1', '2', '3']
}
}
end
before do
sign_in(user)
SiteSetting.min_first_post_typing_time = 0
end
it 'allows strings to be added' do
request.call
expect(@controller.send(:create_params)).not_to include(string_arg: '123')
instance.add_permitted_post_create_param(:string_arg)
request.call
expect(@controller.send(:create_params)).to include(string_arg: '123')
end
it 'allows hashes to be added' do
instance.add_permitted_post_create_param(:hash_arg)
request.call
expect(@controller.send(:create_params)).not_to include(hash_arg: { key1: 'val' })
instance.add_permitted_post_create_param(:hash_arg, :hash)
request.call
expect(@controller.send(:create_params)).to include(hash_arg: { key1: 'val' })
end
it 'allows strings to be added' do
instance.add_permitted_post_create_param(:array_arg)
request.call
expect(@controller.send(:create_params)).not_to include(array_arg: ['1', '2', '3'])
instance.add_permitted_post_create_param(:array_arg, :array)
request.call
expect(@controller.send(:create_params)).to include(array_arg: ['1', '2', '3'])
end
end
end
end end