2018-11-08 19:45:21 +00:00
|
|
|
from django.core.management.base import BaseCommand
|
|
|
|
|
from peeringdb_server.mail import mail_users_entity_merge
|
|
|
|
|
|
|
|
|
|
import reversion
|
|
|
|
|
import peeringdb_server.models as pdbm
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
|
|
|
|
args = "<from_ixp_id> <to_ixp_id>"
|
|
|
|
|
help = "merge one ixp into another ixp"
|
|
|
|
|
commit = False
|
|
|
|
|
|
|
|
|
|
def add_arguments(self, parser):
|
2019-12-05 16:57:52 +00:00
|
|
|
parser.add_argument("--target", help="merge into this ixp")
|
2018-11-08 19:45:21 +00:00
|
|
|
parser.add_argument(
|
2019-12-05 16:57:52 +00:00
|
|
|
"--ids",
|
|
|
|
|
help="merge these ixps (note: target ixp specified with the --target option)",
|
2018-11-08 19:45:21 +00:00
|
|
|
)
|
2019-12-05 16:57:52 +00:00
|
|
|
parser.add_argument("--commit", action="store_true", help="commit changes")
|
2018-11-08 19:45:21 +00:00
|
|
|
|
|
|
|
|
def log(self, msg):
|
|
|
|
|
if not self.commit:
|
2020-01-08 13:29:58 -06:00
|
|
|
print("%s [pretend]" % msg)
|
2018-11-08 19:45:21 +00:00
|
|
|
else:
|
2020-01-08 13:29:58 -06:00
|
|
|
print(msg)
|
2018-11-08 19:45:21 +00:00
|
|
|
|
|
|
|
|
@reversion.create_revision()
|
|
|
|
|
def handle(self, *args, **options):
|
|
|
|
|
|
|
|
|
|
args = list(args)
|
|
|
|
|
|
|
|
|
|
self.commit = options.get("commit", False)
|
|
|
|
|
|
|
|
|
|
ixp_from = pdbm.InternetExchange.objects.get(id=options.get("ids"))
|
|
|
|
|
ixp_to = pdbm.InternetExchange.objects.get(id=options.get("target"))
|
|
|
|
|
|
2020-09-30 01:13:38 +00:00
|
|
|
self.log(f"Merging {ixp_from.name} into {ixp_to.name}")
|
2018-11-08 19:45:21 +00:00
|
|
|
|
2019-12-05 16:57:52 +00:00
|
|
|
ixlans_from = pdbm.IXLan.objects.filter(ix=ixp_from).exclude(status="deleted")
|
2018-11-08 19:45:21 +00:00
|
|
|
for ixlan in ixlans_from:
|
|
|
|
|
ixlan.ix = ixp_to
|
2020-09-30 01:13:38 +00:00
|
|
|
self.log(f"Moving IXLAN {ixlan.id} to {ixp_to.name}")
|
2018-11-08 19:45:21 +00:00
|
|
|
if self.commit:
|
|
|
|
|
ixlan.save()
|
|
|
|
|
self.log("Soft Deleting %s" % ixp_from.name)
|
|
|
|
|
if self.commit:
|
|
|
|
|
ixp_from.delete()
|
|
|
|
|
mail_users_entity_merge(
|
|
|
|
|
ixp_from.org.admin_usergroup.user_set.all(),
|
2019-12-05 16:57:52 +00:00
|
|
|
ixp_to.org.admin_usergroup.user_set.all(),
|
|
|
|
|
ixp_from,
|
|
|
|
|
ixp_to,
|
|
|
|
|
)
|