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:
@ -65,7 +65,7 @@ class UsersController < ApplicationController
|
||||
end
|
||||
|
||||
def username
|
||||
requires_parameter(:new_username)
|
||||
params.require(:new_username)
|
||||
|
||||
user = fetch_user_from_params
|
||||
guardian.ensure_can_edit!(user)
|
||||
@ -86,14 +86,14 @@ class UsersController < ApplicationController
|
||||
end
|
||||
|
||||
def is_local_username
|
||||
requires_parameter(:username)
|
||||
params.require(:username)
|
||||
u = params[:username].downcase
|
||||
r = User.exec_sql('select 1 from users where username_lower = ?', u).values
|
||||
render json: {valid: r.length == 1}
|
||||
end
|
||||
|
||||
def check_username
|
||||
requires_parameter(:username)
|
||||
params.require(:username)
|
||||
|
||||
validator = UsernameValidator.new(params[:username])
|
||||
if !validator.valid_format?
|
||||
@ -259,7 +259,7 @@ class UsersController < ApplicationController
|
||||
end
|
||||
|
||||
def change_email
|
||||
requires_parameter(:email)
|
||||
params.require(:email)
|
||||
user = fetch_user_from_params
|
||||
guardian.ensure_can_edit!(user)
|
||||
lower_email = Email.downcase(params[:email]).strip
|
||||
|
Reference in New Issue
Block a user