@ -240,7 +240,23 @@ end
get "/admin/users/:id/ban" do
auth_denied unless get_current_user.admin?
id = params[:id].to_i
user = User.find_by_id id
user.banned = true
flash[:error] = "Banned user '#{user.name}'"
redirect "/admin"
end
get "/admin/users/:id/unban" do
user.banned = false
flash[:success] = "Unbanned user '#{user.name}'"
# ADMIN ROLE MANAGEMENT
@ -174,9 +174,11 @@ class User < EntityModel
def banned=(b)
if b then
resp = User_Role_relation.give_role(@id, ROLE_IDS[:banned])
# Add the "banned" role
resp = User_Role_relation.give_role(@id, ROLES[:banned][:id])
else
# Remove the "banned" role
resp = User_Role_relation.revoke_role(@id, ROLES[:banned][:id])
@ -87,7 +87,9 @@ class EntityModel
def self.delete(filter="", *args)
self.query "DELETE FROM #{self.name} #{self.apply_filter(filter)}", *args
q = "DELETE FROM #{self.name}"
q = self.apply_filter(q, filter)
self.query q, *args
def self.set(attr, data, filter="") # slower but more lazy