# frozen_string_literal: true # License: AGPL-3.0-or-later WITH Web-Template-Output-Additional-Permission-3.0-or-later module Nonprofits class BankAccountsController < ApplicationController include Controllers::Nonprofit::Current include Controllers::Nonprofit::Authorization before_action :authenticate_nonprofit_admin! # post /nonprofits/:nonprofit_id/bank_account # must pass in the user's password as params[:password] def create if password_was_confirmed(params[:pw_token]) render_json { InsertBankAccount.with_stripe(current_nonprofit, current_user, params[:bank_account]) } else render json: ['Please confirm your password'], status: :unprocessable_entity end end # get /nonprofits/:nonprofit_id/bank_account/confirmation def confirmation @nonprofit = Nonprofit.find(params[:nonprofit_id]) @bank_account = @nonprofit.bank_account end # post /nonprofits/:nonprofit_id/bank_account/confirmation def confirm npo = current_nonprofit ba = npo.bank_account if params[:token] == ba.confirmation_token ba.update_attribute(:pending_verification, false) flash[:notice] = 'Your bank account is now confirmed!' redirect_to nonprofits_payouts_path(npo) else redirect_to(nonprofits_donations_path(npo), flash: { error: 'We could not confirm this bank account. Please follow the exact link provided in the confirmation email.' }) end end # get /nonprofits/:nonprofit_id/bank_account/cancellation def cancellation @nonprofit = Nonprofit.find(params[:nonprofit_id]) @bank_account = @nonprofit.bank_account end # post /nonprofits/:nonprofit_id/bank_account/cancel def cancel npo = current_nonprofit ba = npo.bank_account if params[:token] == ba.confirmation_token ba.destroy flash[:notice] = 'Your bank account has been removed.' redirect_to nonprofits_donations_path(npo) else redirect_to(nonprofits_donations_path(npo), flash: { error: 'We could not remove this bank account. Please follow the exact link provided in the email.' }) end end def resend_confirmation npo = current_nonprofit ba = npo.bank_account BankAccountCreateJob.perform_later(ba) if ba.valid? respond_to { |format| format.json { render json: {} } } end private def required_params params.permit(:name, :confirmation_token, :account_number, :bank_name, :pending_verification, :status, :email, :deleted, :stripe_bank_account_token, :stripe_bank_account_id, :nonprofit_id) end end end