2024-10-08 15:01:32 +00:00
|
|
|
import csv
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from django.core.management.base import BaseCommand
|
2024-11-15 08:24:49 +00:00
|
|
|
from ...models import SustainerPayment
|
2024-10-08 15:01:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
|
|
|
help = "Closes the specified poll for voting"
|
|
|
|
|
|
|
|
def handle(self, *args, **options):
|
2024-11-15 08:24:49 +00:00
|
|
|
payments = SustainerPayment.objects.select_related('order').order_by('paid_time')
|
2024-12-17 23:20:49 +00:00
|
|
|
columns = ['order_time', 'payment_time', 'name', 'email', 'amount', 'transaction_id', 'recurring', 'subscription_id', 'public_ack', 'shirt_size', 'join_list', 'street', 'city', 'state', 'zip_code', 'country']
|
2024-10-08 15:01:32 +00:00
|
|
|
writer = csv.writer(sys.stdout)
|
|
|
|
writer.writerow(columns)
|
2024-11-15 08:24:49 +00:00
|
|
|
for payment in payments:
|
|
|
|
order = payment.order
|
2024-10-08 15:01:32 +00:00
|
|
|
writer.writerow([
|
|
|
|
order.created_time,
|
2024-11-15 08:24:49 +00:00
|
|
|
payment.paid_time,
|
2024-10-08 15:01:32 +00:00
|
|
|
order.name,
|
|
|
|
order.email,
|
2024-11-15 08:24:49 +00:00
|
|
|
payment.amount,
|
|
|
|
payment.stripe_payment_intent_ref,
|
2024-12-17 23:20:49 +00:00
|
|
|
order.recurring,
|
|
|
|
order.stripe_subscription_ref,
|
2024-10-08 15:01:32 +00:00
|
|
|
order.acknowledge_publicly,
|
|
|
|
repr(order.tshirt_size if order.tshirt_size else ''),
|
|
|
|
order.add_to_mailing_list,
|
|
|
|
order.street,
|
|
|
|
order.city,
|
|
|
|
order.state,
|
|
|
|
order.zip_code,
|
|
|
|
order.country,
|
|
|
|
])
|