mirror of
https://github.com/discourse/discourse.git
synced 2025-02-25 18:55:32 -06:00
DEV: Replace #pluck_first freedom patch with AR #pick in core (#19893)
The #pluck_first freedom patch, first introduced by @danielwaterworth has served us well, and is used widely throughout both core and plugins. It seems to have been a common enough use case that Rails 6 introduced it's own method #pick with the exact same implementation. This allows us to retire the freedom patch and switch over to the built-in ActiveRecord method. There is no replacement for #pluck_first!, but a quick search shows we are using this in a very limited capacity, and in some cases incorrectly (by assuming a nil return rather than an exception), which can quite easily be replaced with #pick plus some extra handling.
This commit is contained in:
@@ -843,7 +843,7 @@ class TopicsController < ApplicationController
|
||||
|
||||
if params[:title].present?
|
||||
# when creating a new topic, ensure the 1st post is a regular post
|
||||
if Post.where(topic: topic, id: post_ids).order(:post_number).pluck_first(:post_type) !=
|
||||
if Post.where(topic: topic, id: post_ids).order(:post_number).pick(:post_type) !=
|
||||
Post.types[:regular]
|
||||
return(
|
||||
render_json_error(
|
||||
|
||||
Reference in New Issue
Block a user