- Add Payout model with associations to User and Event - Create payout requests for completed events with proper earnings calculation - Exclude refunded tickets from payout calculations - Add promoter dashboard views for managing payouts - Implement admin interface for processing payouts - Integrate with Stripe for actual payment processing - Add comprehensive tests for payout functionality Co-authored-by: Qwen-Coder <qwen-coder@alibabacloud.com>
31 lines
837 B
Ruby
31 lines
837 B
Ruby
class Admin::PayoutsController < ApplicationController
|
|
before_action :authenticate_user!
|
|
before_action :ensure_admin!
|
|
|
|
def index
|
|
@payouts = Payout.includes(:event, :user)
|
|
.order(created_at: :desc)
|
|
.page(params[:page])
|
|
end
|
|
|
|
def create
|
|
@payout = Payout.find(params[:id])
|
|
|
|
begin
|
|
@payout.process_payout!
|
|
redirect_to admin_payouts_path, notice: "Payout processed successfully."
|
|
rescue => e
|
|
redirect_to admin_payouts_path, alert: "Failed to process payout: #{e.message}"
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def ensure_admin!
|
|
# For now, we'll just check if the user has a stripe account
|
|
# In a real app, you'd have an admin role check
|
|
unless current_user.has_stripe_account?
|
|
redirect_to dashboard_path, alert: "Access denied."
|
|
end
|
|
end
|
|
end |