forked from fixin.me/fixin.me
Replace the CLI-only setup (db:seed + manual application.rb edits) with a web wizard shown automatically on first visit when no admin account exists yet. SetupController (GET/POST /setup) collects the admin e-mail and password, a "skip e-mail confirmation" toggle, and an option to seed the built-in default units. Once submitted it creates the admin User, persists the chosen options as Setting records, and redirects to the sign-in page. ApplicationController gains a redirect_to_setup_if_needed before_action that catches every request (including Devise routes) when no admin exists, so a fresh installation always lands on the wizard rather than an empty sign-in form. A new Setting model provides a lightweight key-value store for runtime options that were previously hard-coded in application.rb (e.g. skip_email_confirmation). RegistrationsController now reads that flag from the database instead of from the application config. Seeds.rb is kept for headless / automated deployments and skips admin creation when an admin already exists (idempotent), with a comment pointing to the web wizard as the preferred path. Also extends the SQLite nil-limit fix (|| Float::INFINITY) to the Quantity model, which suffered the same ArgumentError as Unit. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
36 lines
1.0 KiB
Ruby
36 lines
1.0 KiB
Ruby
class RegistrationsController < Devise::RegistrationsController
|
|
before_action :authenticate_user!, only: [:edit, :update, :destroy]
|
|
|
|
def destroy
|
|
# TODO: Disallow/disable deletion for last admin account; update :edit view
|
|
super
|
|
end
|
|
|
|
protected
|
|
|
|
def build_resource(hash = {})
|
|
super
|
|
# Skip the email confirmation step when the admin has enabled this option
|
|
# via the web setup wizard (stored as the "skip_email_confirmation" Setting).
|
|
# The account becomes active immediately so the user can sign in right after
|
|
# registering.
|
|
resource.skip_confirmation! if Setting.get("skip_email_confirmation") == "true"
|
|
end
|
|
|
|
def update_resource(resource, params)
|
|
# Based on update_with_password()
|
|
if params[:password].blank?
|
|
params.delete(:password)
|
|
params.delete(:password_confirmation) if params[:password_confirmation].blank?
|
|
end
|
|
|
|
result = resource.update(params)
|
|
resource.clean_up_passwords
|
|
result
|
|
end
|
|
|
|
def after_inactive_sign_up_path_for(resource)
|
|
new_user_session_path
|
|
end
|
|
end
|