1
0
mirror of https://github.com/peeringdb/peeringdb.git synced 2024-05-11 05:55:09 +00:00
Files
peeringdb-peeringdb/peeringdb_server/management/commands/pdb_ixp_merge.py
Matt Griswold 04f1928b3c Updates 2.23 (#843)
* pipenv lock and pyupgrade

* pyupgrade, black format, add docs

* update for py3.7
2020-09-29 20:13:38 -05:00

54 lines
1.7 KiB
Python

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):
parser.add_argument("--target", help="merge into this ixp")
parser.add_argument(
"--ids",
help="merge these ixps (note: target ixp specified with the --target option)",
)
parser.add_argument("--commit", action="store_true", help="commit changes")
def log(self, msg):
if not self.commit:
print("%s [pretend]" % msg)
else:
print(msg)
@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"))
self.log(f"Merging {ixp_from.name} into {ixp_to.name}")
ixlans_from = pdbm.IXLan.objects.filter(ix=ixp_from).exclude(status="deleted")
for ixlan in ixlans_from:
ixlan.ix = ixp_to
self.log(f"Moving IXLAN {ixlan.id} to {ixp_to.name}")
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(),
ixp_to.org.admin_usergroup.user_set.all(),
ixp_from,
ixp_to,
)