require "sidekiq/web" require "sidekiq/cron/web" Rails.application.routes.draw do use_doorkeeper # MFA routes resource :mfa, controller: "mfa", only: [ :new, :create ] do get :verify post :verify, to: "mfa#verify_code" delete :disable end mount Lookbook::Engine, at: "/design-system" # Uses basic auth - see config/initializers/sidekiq.rb mount Sidekiq::Web => "/sidekiq" # AI chats resources :chats do resources :messages, only: :create member do post :retry end end get "changelog", to: "pages#changelog" get "feedback", to: "pages#feedback" resource :current_session, only: %i[update] resource :registration, only: %i[new create] resources :sessions, only: %i[new create destroy] resource :password_reset, only: %i[new create edit update] resource :password, only: %i[edit update] resource :email_confirmation, only: :new resources :users, only: %i[update destroy] do delete :reset, on: :member patch :rule_prompt_settings, on: :member end resource :onboarding, only: :show do collection do get :preferences get :goals get :trial end end namespace :settings do resource :profile, only: [ :show, :destroy ] resource :preferences, only: :show resource :hosting, only: %i[show update] do delete :clear_cache, on: :collection end resource :billing, only: :show resource :security, only: :show resource :api_key, only: [ :show, :new, :create, :destroy ] end resource :subscription, only: %i[new show create] do collection do get :upgrade get :success end end resources :tags, except: :show do resources :deletions, only: %i[new create], module: :tag delete :destroy_all, on: :collection end namespace :category do resource :dropdown, only: :show end resources :categories, except: :show do resources :deletions, only: %i[new create], module: :category post :bootstrap, on: :collection delete :destroy_all, on: :collection end resources :budgets, only: %i[index show edit update], param: :month_year do get :picker, on: :collection resources :budget_categories, only: %i[index show update] end resources :family_merchants, only: %i[index new create edit update destroy] resources :transfers, only: %i[new create destroy show update] resources :imports, only: %i[index new show create destroy] do member do post :publish put :revert put :apply_template end resource :upload, only: %i[show update], module: :import resource :configuration, only: %i[show update], module: :import resource :clean, only: :show, module: :import resource :confirm, only: :show, module: :import resources :rows, only: %i[show update], module: :import resources :mappings, only: :update, module: :import end resources :accounts, only: %i[index new], shallow: true do member do post :sync get :chart get :sparkline end end resources :holdings, only: %i[index new show destroy] resources :trades, only: %i[show new create update destroy] resources :valuations, only: %i[show new create update destroy] namespace :transactions do resource :bulk_deletion, only: :create resource :bulk_update, only: %i[new create] end resources :transactions, only: %i[index new create show update destroy] do resource :transfer_match, only: %i[new create] resource :category, only: :update, controller: :transaction_categories collection do delete :clear_filter end end resources :accountable_sparklines, only: :show, param: :accountable_type direct :entry do |entry, options| if entry.new_record? route_for entry.entryable_name.pluralize, options else route_for entry.entryable_name, entry, options end end resources :rules, except: :show do member do get :confirm post :apply end collection do delete :destroy_all end end # Convenience routes for polymorphic paths # Example: account_path(Account.new(accountable: Depository.new)) => /depositories/123 direct :account do |model, options| route_for model.accountable_name, model, options end direct :edit_account do |model, options| route_for "edit_#{model.accountable_name}", model, options end resources :depositories, except: :index resources :investments, except: :index resources :properties, except: :index resources :vehicles, except: :index resources :credit_cards, except: :index resources :loans, except: :index resources :cryptos, except: :index resources :other_assets, except: :index resources :other_liabilities, except: :index resources :securities, only: :index resources :invite_codes, only: %i[index create] resources :invitations, only: [ :new, :create, :destroy ] do get :accept, on: :member end # API routes namespace :api do namespace :v1 do # Production API endpoints resources :accounts, only: [ :index ] resources :transactions, only: [ :index, :show, :create, :update, :destroy ] resource :usage, only: [ :show ], controller: "usage" resources :chats, only: [ :index, :show, :create, :update, :destroy ] do resources :messages, only: [ :create ] do post :retry, on: :collection end end # Test routes for API controller testing (only available in test environment) if Rails.env.test? get "test", to: "test#index" get "test_not_found", to: "test#not_found" get "test_family_access", to: "test#family_access" get "test_scope_required", to: "test#scope_required" get "test_multiple_scopes_required", to: "test#multiple_scopes_required" end end end resources :currencies, only: %i[show] resources :impersonation_sessions, only: [ :create ] do post :join, on: :collection delete :leave, on: :collection member do put :approve put :reject put :complete end end resources :plaid_items, only: %i[new edit create destroy] do member do post :sync end end namespace :webhooks do post "plaid" post "plaid_eu" post "stripe" end get "redis-configuration-error", to: "pages#redis_configuration_error" # Reveal health status on /up that returns 200 if the app boots with no exceptions, otherwise 500. # Can be used by load balancers and uptime monitors to verify that the app is live. get "up" => "rails/health#show", as: :rails_health_check # Render dynamic PWA files from app/views/pwa/* get "service-worker" => "rails/pwa#service_worker", as: :pwa_service_worker get "manifest" => "rails/pwa#manifest", as: :pwa_manifest get "imports/:import_id/upload/sample_csv", to: "import/uploads#sample_csv", as: :import_upload_sample_csv get "privacy", to: redirect("https://maybefinance.com/privacy") get "terms", to: redirect("https://maybefinance.com/tos") # Defines the root path route ("/") root "pages#dashboard" end