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_load_data.py
Matt Griswold c9108741cf fix atomicity (#1087)
* remove survey notifications

* fixes #1086 atomicity issues

Co-authored-by: Stefan Pratter <stefan@20c.com>
2021-11-12 11:16:25 -06:00

117 lines
3.7 KiB
Python

"""
Load initial data from another peeringdb instance using the REST API.
"""
from confu.schema import apply_defaults
from django.conf import settings
from django.core.management.base import BaseCommand
from django.db.models.signals import pre_save
from django_peeringdb import models as djpdb_models
import peeringdb._fetch
from peeringdb import SUPPORTED_BACKENDS, resource
from peeringdb.client import Client
from peeringdb.config import ClientSchema
from peeringdb_server import models as pdb_models
from peeringdb_server import signals
_fetch_all_latest = peeringdb._fetch.Fetcher.fetch_all_latest
def fetch_all_latest(self, R, depth, params={}, since=None):
"""
Some foreign keys differ in peeringdb_server from how they
are exposed in the api, these need to be adjusted before
returning the retrieved data to the sync process
Affected fields
`net_id` -> `network_id`
`fac_id` -> `facility_id`
We do this by monkey patching the `fetch_all_latest` function
of the peeringdb `Fetcher` class
Additionally we fix some common validation issues
"""
result = _fetch_all_latest(self, R, depth, params=params, since=since)
for row in result[0]:
for k, v in list(row.items()):
if k in ["latitude", "longitude"] and v:
row[k] = f"{float(v):3.6f}"
elif k == "fac_id":
row["facility_id"] = v
del row["fac_id"]
elif k == "net_id":
row["network_id"] = v
del row["net_id"]
return result
peeringdb._fetch.Fetcher.fetch_all_latest = fetch_all_latest
class Command(BaseCommand):
help = "Load initial data from another peeringdb instance"
def add_arguments(self, parser):
parser.add_argument("--url", default="https://www.peeringdb.com/api/", type=str)
parser.add_argument(
"--commit", action="store_true", help="will commit the changes"
)
def handle(self, *args, **options):
if settings.RELEASE_ENV != "dev" and not settings.TUTORIAL_MODE:
self.stdout.write(
"Command can only be run on dev instances and instances "
"with tutorial mode enabled"
)
return
if not options.get("commit"):
self.stdout.write(
"This will sync data from {url} to this instance, and will take "
"roughly 20 minutes to complete on a fresh db. "
"Run the command with `--commit` if you are sure you want "
"to do this.".format(**options)
)
return
# settings.USE_TZ = True
db_settings = settings.DATABASES.get("default")
config = {
"sync": {"url": options.get("url")},
"orm": {
"secret_key": settings.SECRET_KEY,
"backend": "peeringdb_server",
"migrate": False,
"database": {k.lower(): v for k, v in db_settings.items()},
},
}
apply_defaults(ClientSchema(), config)
pre_save.disconnect(signals.addressmodel_save, sender=pdb_models.Facility)
djpdb_models.all_models = [
pdb_models.Organization,
pdb_models.Facility,
pdb_models.Network,
pdb_models.InternetExchange,
pdb_models.InternetExchangeFacility,
pdb_models.IXLan,
pdb_models.IXLanPrefix,
pdb_models.NetworkContact,
pdb_models.NetworkFacility,
pdb_models.NetworkIXLan,
]
SUPPORTED_BACKENDS["peeringdb_server"] = "peeringdb_server.client_adaptor"
client = Client(config)
client.update_all(resource.all_resources(), since=None)