Allow assigning applications to a group from the group form

Adds an "Assigned Applications" checkbox list to the group new/edit
form so admins can grant a group access to multiple apps from one
screen, instead of editing each application individually.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
Dan Milne
2026-05-28 21:17:43 +10:00
parent bbfb564e1c
commit a399907dfd
3 changed files with 95 additions and 0 deletions

View File

@@ -15,6 +15,7 @@ module Admin
def new
@group = Group.new
@available_users = User.order(:email_address)
@available_applications = Application.order(:name)
end
def create
@@ -28,6 +29,7 @@ module Admin
@group = Group.new
@group.errors.add(:custom_claims, "must be valid JSON")
@available_users = User.order(:email_address)
@available_applications = Application.order(:name)
render :new, status: :unprocessable_entity
return
end
@@ -45,15 +47,23 @@ module Admin
@group.users = User.where(id: user_ids)
end
# Handle application assignments
if params[:group][:application_ids].present?
application_ids = params[:group][:application_ids].reject(&:blank?)
@group.applications = Application.where(id: application_ids)
end
redirect_to admin_group_path(@group), notice: "Group created successfully."
else
@available_users = User.order(:email_address)
@available_applications = Application.order(:name)
render :new, status: :unprocessable_entity
end
end
def edit
@available_users = User.order(:email_address)
@available_applications = Application.order(:name)
end
def update
@@ -66,6 +76,7 @@ module Admin
rescue JSON::ParserError
@group.errors.add(:custom_claims, "must be valid JSON")
@available_users = User.order(:email_address)
@available_applications = Application.order(:name)
render :edit, status: :unprocessable_entity
return
end
@@ -83,9 +94,18 @@ module Admin
@group.users = []
end
# Handle application assignments
if params[:group][:application_ids].present?
application_ids = params[:group][:application_ids].reject(&:blank?)
@group.applications = Application.where(id: application_ids)
else
@group.applications = []
end
redirect_to admin_group_path(@group), notice: "Group updated successfully."
else
@available_users = User.order(:email_address)
@available_applications = Application.order(:name)
render :edit, status: :unprocessable_entity
end
end