mirror of
https://github.com/we-promise/sure.git
synced 2026-04-07 14:31:25 +00:00
* Domain model sketch * Scaffold out rules domain * Migrations * Remove existing data enrichment for clean slate * Sketch out business logic and basic tests * Simplify rule scope building and action executions * Get generator working again * Basic implementation + tests * Remove manual merchant management (rules will replace) * Revert "Remove manual merchant management (rules will replace)" This reverts commit 83dcbd9ff0aa7bbee211796b71aa48b71df5e57e. * Family and Provider merchants model * Fix brakeman warnings * Fix notification loader * Update notification position * Add Rule action and condition registries * Rule form with compound conditions and tests * Split out notification types, add CTA type * Rules form builder and Stimulus controller * Clean up rule registry domain * Clean up rules stimulus controller * CTA message for rule when user changes transaction category * Fix tests * Lint updates * Centralize notifications in Notifiable concern * Implement category rule prompts with auto backoff and option to disable * Fix layout bug caused by merge conflict * Initialize rule with correct action for category CTA * Add rule deletions, get rules working * Complete dynamic rule form, split Stimulus controllers by resource * Fix failing tests * Change test password to avoid chromium conflicts * Update integration tests * Centralize all test password references * Add re-apply rule action * Rule confirm modal * Run migrations * Trigger rule notification after inline category updates * Clean up rule styles * Basic attribute locking for rules * Apply attribute locks on user edits * Log data enrichments, only apply rules to unlocked attributes * Fix merge errors * Additional merge conflict fixes * Form UI improvements, ignore attribute locks on manual rule application * Batch AI auto-categorization of transactions * Auto merchant detection, ai enrichment in batches * Fix Plaid merchant assignments * Plaid category matching * Cleanup 1 * Test cleanup * Remove stale route * Fix desktop chat UI issues * Fix mobile nav styling issues
99 lines
2.9 KiB
Ruby
99 lines
2.9 KiB
Ruby
class UsersController < ApplicationController
|
|
before_action :set_user
|
|
before_action :ensure_admin, only: :reset
|
|
|
|
def update
|
|
@user = Current.user
|
|
|
|
if email_changed?
|
|
if @user.initiate_email_change(user_params[:email])
|
|
if Rails.application.config.app_mode.self_hosted? && !Setting.require_email_confirmation
|
|
handle_redirect(t(".success"))
|
|
else
|
|
redirect_to settings_profile_path, notice: t(".email_change_initiated")
|
|
end
|
|
else
|
|
error_message = @user.errors.any? ? @user.errors.full_messages.to_sentence : t(".email_change_failed")
|
|
redirect_to settings_profile_path, alert: error_message
|
|
end
|
|
else
|
|
was_ai_enabled = @user.ai_enabled
|
|
@user.update!(user_params.except(:redirect_to, :delete_profile_image))
|
|
@user.profile_image.purge if should_purge_profile_image?
|
|
|
|
# Add a special notice if AI was just enabled
|
|
notice = if !was_ai_enabled && @user.ai_enabled
|
|
"AI Assistant has been enabled successfully."
|
|
else
|
|
t(".success")
|
|
end
|
|
|
|
respond_to do |format|
|
|
format.html { handle_redirect(notice) }
|
|
format.json { head :ok }
|
|
end
|
|
end
|
|
end
|
|
|
|
def reset
|
|
FamilyResetJob.perform_later(Current.family)
|
|
redirect_to settings_profile_path, notice: t(".success")
|
|
end
|
|
|
|
def destroy
|
|
if @user.deactivate
|
|
Current.session.destroy
|
|
redirect_to root_path, notice: t(".success")
|
|
else
|
|
redirect_to settings_profile_path, alert: @user.errors.full_messages.to_sentence
|
|
end
|
|
end
|
|
|
|
def rule_prompt_settings
|
|
@user.update!(rule_prompt_settings_params)
|
|
redirect_back_or_to settings_profile_path
|
|
end
|
|
|
|
private
|
|
def handle_redirect(notice)
|
|
case user_params[:redirect_to]
|
|
when "onboarding_preferences"
|
|
redirect_to preferences_onboarding_path
|
|
when "home"
|
|
redirect_to root_path
|
|
when "preferences"
|
|
redirect_to settings_preferences_path, notice: notice
|
|
else
|
|
redirect_to settings_profile_path, notice: notice
|
|
end
|
|
end
|
|
|
|
def should_purge_profile_image?
|
|
user_params[:delete_profile_image] == "1" &&
|
|
user_params[:profile_image].blank?
|
|
end
|
|
|
|
def email_changed?
|
|
user_params[:email].present? && user_params[:email] != @user.email
|
|
end
|
|
|
|
def rule_prompt_settings_params
|
|
params.require(:user).permit(:rule_prompt_dismissed_at, :rule_prompts_disabled)
|
|
end
|
|
|
|
def user_params
|
|
params.require(:user).permit(
|
|
:first_name, :last_name, :email, :profile_image, :redirect_to, :delete_profile_image, :onboarded_at, :show_sidebar, :default_period, :show_ai_sidebar, :ai_enabled, :theme,
|
|
family_attributes: [ :name, :currency, :country, :locale, :date_format, :timezone, :id ]
|
|
)
|
|
end
|
|
|
|
def set_user
|
|
@user = Current.user
|
|
end
|
|
|
|
def ensure_admin
|
|
redirect_to settings_profile_path, alert: I18n.t("users.reset.unauthorized") unless Current.user.admin?
|
|
end
|
|
end
|