Fix search by IP not using alternative browser sessions in admin UI (#12904)
This commit is contained in:
		
							parent
							
								
									2d5addde03
								
							
						
					
					
						commit
						ba16d4b413
					
				
					 2 changed files with 2 additions and 1 deletions
				
			
		|  | @ -65,7 +65,7 @@ class AccountFilter | |||
|     when 'email' | ||||
|       accounts_with_users.merge User.matches_email(value) | ||||
|     when 'ip' | ||||
|       valid_ip?(value) ? accounts_with_users.where('users.current_sign_in_ip <<= ?', value) : Account.none | ||||
|       valid_ip?(value) ? accounts_with_users.merge(User.matches_ip(value)) : Account.none | ||||
|     when 'staff' | ||||
|       accounts_with_users.merge User.staff | ||||
|     else | ||||
|  |  | |||
|  | @ -93,6 +93,7 @@ class User < ApplicationRecord | |||
|   scope :inactive, -> { where(arel_table[:current_sign_in_at].lt(ACTIVE_DURATION.ago)) } | ||||
|   scope :active, -> { confirmed.where(arel_table[:current_sign_in_at].gteq(ACTIVE_DURATION.ago)).joins(:account).where(accounts: { suspended_at: nil }) } | ||||
|   scope :matches_email, ->(value) { where(arel_table[:email].matches("#{value}%")) } | ||||
|   scope :matches_ip, ->(value) { left_joins(:session_activations).where('users.current_sign_in_ip <<= ?', value).or(left_joins(:session_activations).where('users.last_sign_in_ip <<= ?', value)).or(left_joins(:session_activations).where('session_activations.ip <<= ?', value)) } | ||||
|   scope :emailable, -> { confirmed.enabled.joins(:account).merge(Account.searchable) } | ||||
| 
 | ||||
|   before_validation :sanitize_languages | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue