dynamicweb/datacenterlight/management/commands/deleteuser.py

217 lines
8.7 KiB
Python
Raw Normal View History

2019-04-28 21:14:14 +00:00
import logging
2019-04-28 21:57:39 +00:00
import oca
2019-04-28 21:14:14 +00:00
import sys
import stripe
from django.core.management.base import BaseCommand
from membership.models import CustomUser, DeletedUser
2019-04-28 21:14:14 +00:00
from hosting.models import (
HostingOrder, HostingBill, VMDetail, UserCardDetail, UserHostingKey
)
2019-04-28 21:57:39 +00:00
from opennebula_api.models import OpenNebulaManager
2019-04-28 21:14:14 +00:00
logger = logging.getLogger(__name__)
def query_yes_no(question, default="yes"):
"""Ask a yes/no question via raw_input() and return their answer.
"question" is a string that is presented to the user.
"default" is the presumed answer if the user just hits <Enter>.
It must be "yes" (the default), "no" or None (meaning
an answer is required of the user).
The "answer" return value is True for "yes" or False for "no".
"""
valid = {"yes": True, "y": True, "ye": True,
"no": False, "n": False}
if default is None:
prompt = " [y/n] "
elif default == "yes":
prompt = " [Y/n] "
elif default == "no":
prompt = " [y/N] "
else:
raise ValueError("invalid default answer: '%s'" % default)
while True:
sys.stdout.write(question + prompt)
choice = input().lower()
if default is not None and choice == '':
return valid[default]
elif choice in valid:
return valid[choice]
else:
sys.stdout.write("Please respond with 'yes' or 'no' "
"(or 'y' or 'n').\n")
class Command(BaseCommand):
help = '''Deletes all resources of the user from the project'''
def add_arguments(self, parser):
parser.add_argument('customer_email', nargs='+', type=str)
def handle(self, *args, **options):
try:
for email in options['customer_email']:
r = query_yes_no("Are you sure you want to delete {} ?".format(
email, None
))
if r:
logger.debug("Deleting user {}".format(email))
# Get stripe customer instance and delete the customer
try:
cus_user = CustomUser.objects.get(email=email)
except CustomUser.DoesNotExist as dne:
logger.error("CustomUser with email {} does "
"not exist".format(email))
sys.exit(1)
stripe_customer = cus_user.stripecustomer
2019-04-28 22:17:59 +00:00
c = stripe.Customer.retrieve(
2019-04-28 21:14:14 +00:00
stripe_customer.stripe_id
)
2019-04-28 22:53:06 +00:00
cus_delete_obj = c.delete()
if cus_delete_obj.deleted:
2019-04-28 21:14:14 +00:00
logger.debug(
"StripeCustomer {} associated with {} deleted"
"".format(stripe_customer.stripe_id, email)
)
else:
logger.error("Error while deleting the StripeCustomer")
hosting_orders = HostingOrder.objects.filter(
customer=stripe_customer.id
)
vm_ids = []
for order in hosting_orders:
vm_ids.append(order.vm_id)
2019-05-06 06:30:50 +00:00
2019-04-28 21:14:14 +00:00
# Delete Billing Address
2019-05-06 06:30:50 +00:00
if order.billing_address is not None:
order.billing_address.delete()
logger.debug(
"Billing Address {} associated with {} deleted"
"".format(order.billing_address.id, email)
)
else:
logger.error(
"Error while deleting the billing_address")
2019-04-28 21:14:14 +00:00
# Delete Order Detail
2019-05-06 06:30:50 +00:00
if order.order_detail is not None:
order.order_detail.delete()
logger.debug(
"Order Detail {} associated with {} deleted"
"".format(order.order_detail.id, email)
)
else:
logger.error(
"Error while deleting the order_detail. None")
2019-04-28 21:14:14 +00:00
# Delete order
2019-05-06 06:30:50 +00:00
if order is not None:
order.delete()
logger.debug(
"Order {} associated with {} deleted"
"".format(order.id, email)
)
else:
logger.error(
"Error while deleting the Order")
2019-04-28 21:14:14 +00:00
hosting_bills = HostingBill.objects.filter(
customer=stripe_customer.id
)
# delete hosting bills
for bill in hosting_bills:
2019-05-06 06:30:50 +00:00
if bill.billing_address is not None:
bill.billing_address.delete()
logger.debug(
"HostingBills billing address {} associated with {} deleted"
"".format(bill.billing_address.id, email)
)
else:
logger.error(
"Error while deleting the HostingBill's Billing address")
if bill is not None:
bill.delete()
logger.debug(
"HostingBill {} associated with {} deleted"
"".format(bill.id, email)
)
else:
logger.error(
"Error while deleting the HostingBill")
2019-04-28 21:14:14 +00:00
# delete VMDetail
for vm_id in vm_ids:
2019-04-28 22:53:06 +00:00
vm_detail = VMDetail.objects.get(vm_id=vm_id)
2019-05-06 06:30:50 +00:00
if vm_detail is not None:
vm_detail.delete()
logger.debug(
"vm_detail {} associated with {} deleted"
"".format(vm_detail.id, email)
)
else:
logger.error(
"Error while deleting the vm_detail")
2019-04-28 21:14:14 +00:00
# delete UserCardDetail
2019-04-28 22:53:06 +00:00
ucds = UserCardDetail.objects.filter(
stripe_customer=stripe_customer
2019-04-28 21:14:14 +00:00
)
2019-04-28 22:53:06 +00:00
for ucd in ucds:
2019-05-06 06:30:50 +00:00
if ucd is not None:
ucd.delete()
logger.debug(
"User Card Detail {} associated with {} deleted"
"".format(ucd.id, email)
)
else:
logger.error(
"Error while deleting the User Card Detail")
2019-04-28 21:14:14 +00:00
# delete UserHostingKey
uhks = UserHostingKey.objects.filter(
2019-04-28 22:53:06 +00:00
user=cus_user
2019-04-28 21:14:14 +00:00
)
for uhk in uhks:
uhk.delete()
# delete stripe customer
stripe_customer.delete()
# add user to deleteduser
DeletedUser.objects.create(
email=cus_user.email, name=cus_user.name,
user_id = cus_user.id
)
2019-05-05 14:56:56 +00:00
# delete CustomUser
2019-04-28 21:14:14 +00:00
cus_user.delete()
2019-04-28 21:57:39 +00:00
# remove user from OpenNebula
manager = OpenNebulaManager()
user_pool = manager._get_user_pool()
on_user = user_pool.get_by_name(email)
if on_user.id > 0:
logger.debug(
"Deleting user {} => ID={} from opennebula".format(
email, on_user.id)
)
manager.oneadmin_client.call(
oca.User.METHODS['delete'], on_user.id
)
else:
logger.error(
"User not found with email {}. "
"Not doing anything".format(email)
)
2019-04-28 21:57:39 +00:00
2019-04-28 21:14:14 +00:00
logger.debug("Deleted {} SUCCESSFULLY.".format(email))
except Exception as e:
print(" *** Error occurred. Details {}".format(str(e)))