summaryrefslogtreecommitdiff
path: root/app/models/user.rb
diff options
context:
space:
mode:
authorMrYummy <elemental428@gmail.com>2017-06-02 19:14:28 +0200
committerMrYummy <elemental428@gmail.com>2017-06-18 13:11:36 -0400
commite2a16f3ae6e4c557a986d6170c1a7420e0ca08e0 (patch)
tree91be20c40233115a9fbde9b5dc926cc2b25a1c41 /app/models/user.rb
parenta250c411eb0a94613f5fbac3039ec979bdc06c52 (diff)
ordered searching to match SQL clauses, moved role&badge filtering to User.search
Diffstat (limited to 'app/models/user.rb')
-rw-r--r--app/models/user.rb16
1 files changed, 14 insertions, 2 deletions
diff --git a/app/models/user.rb b/app/models/user.rb
index a96410a..3098cfc 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -175,7 +175,19 @@ class User < ActiveRecord::Base
self.email_token ||= SecureRandom.hex(16)
end
- def self.search (users, search)
- return users.where("users.name like ? OR ign like ?", "%#{User.send(:sanitize_sql_like, search)}%", "%#{User.send(:sanitize_sql_like, search)}%")
+ def self.search (search, role, badge)
+ if role
+ if role.downcase == "staff"
+ users = User.joins(:role).where("roles.value >= ?", Role.get(:mod).to_i)
+ elsif r = Role.get(role)
+ users = User.joins(:role).where(role: r)
+ else
+ end
+ elsif badge && b = Badge.get(badge)
+ users = User.joins(:badge).where(badge: b)
+ else
+ users = User.joins(:role).where.not(id: User.first.id) #Remove first user
+ end
+ return users.where("users.name like ? OR ign like ?", "%#{User.send(:sanitize_sql_like, search.to_s)}%", "%#{User.send(:sanitize_sql_like, search.to_s)}%")
end
end