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 ba6f9b6432 Qu1003 (#621)
* use new peeringdb client (1.0.0) for pdb_load_data sync (#599)

* drop django-mobi for lack of py3/dj2 support (#492)
remove django-forms-bootstrap for lack of py3/dj2 support (#492)

* black formatted

* django2.2 and py3 upgrade (#492)

* drop ixlans (#21) ui and api changes

* drop local_asn (#168)

* org search (#193)

* phone number validation (#50)

* implement help text tooltips (#228)

* Mark own ASN as transit-free (#394)

* py3 fix for `pdb_migrate_ixlans` command when writing migration report

* pdb_migrate_ixlans: properly handle py3 Runtime error if ixlan dict changes during iteration

* set rest DEFAULT_SCHEMA_CLASS to coreapi to fix swagger apidocs
fix migration 0027 missing from facsimile manifest

* fix swagger doc strings

* fix tests that were broken from api doc fixes

* fix UniqueFieldValidator for netixlan ipaddress validation that broke during django/drf upgrade

* fix org merge tool layout issues

* travis config

* update pipfile and lock

* black formatting

* update travis dist

* beta mode banner (#411)

* add beta banner template (#411)

* automatically scheduled sync may not always be on, add a flag that lets us reflect that state in the beta banner message
clean up beta banner implementation (#411)

* add tests for beta banner (#411)
2020-01-08 13:29:58 -06: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("Merging %s into %s" % (ixp_from.name, 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("Moving IXLAN %s to %s" % (ixlan.id, 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,
)