mirror of
https://github.com/discourse/discourse.git
synced 2025-05-22 22:43:33 +08:00
Enabled strong_parameters across all models/controllers.
All models are now using ActiveModel::ForbiddenAttributesProtection, which shifts the responsibility for parameter whitelisting for mass-assignments from the model to the controller. attr_accessible has been disabled and removed as this functionality replaces that. The require_parameters method in the ApplicationController has been removed in favor of strong_parameters' #require method. It is important to note that there is still some refactoring required to get all parameters to pass through #require and #permit so that we can guarantee that parameter values are scalar. Currently strong_parameters, in most cases, is only being utilized to require parameters and to whitelist the few places that do mass-assignments.
This commit is contained in:
@ -25,7 +25,7 @@ class PostsController < ApplicationController
|
||||
end
|
||||
|
||||
def create
|
||||
requires_parameter(:post)
|
||||
params.require(:post)
|
||||
|
||||
post_creator = PostCreator.new(current_user,
|
||||
raw: params[:post][:raw],
|
||||
@ -55,7 +55,7 @@ class PostsController < ApplicationController
|
||||
end
|
||||
|
||||
def update
|
||||
requires_parameter(:post)
|
||||
params.require(:post)
|
||||
|
||||
post = Post.where(id: params[:id]).first
|
||||
post.image_sizes = params[:image_sizes] if params[:image_sizes].present?
|
||||
@ -138,7 +138,7 @@ class PostsController < ApplicationController
|
||||
|
||||
def destroy_many
|
||||
|
||||
requires_parameters(:post_ids)
|
||||
params.require(:post_ids)
|
||||
|
||||
posts = Post.where(id: params[:post_ids])
|
||||
raise Discourse::InvalidParameters.new(:post_ids) if posts.blank?
|
||||
|
Reference in New Issue
Block a user