Thank you. Merged. Do we plan a release because of this soon? > On 19 Jul 2021, at 22:34, Peter Müller wrote: > > A decent amount of autnum objects - especially, but not exclusively in > the APNIC sector - does not contain a link to an organisation handle. > > In such cases, this patch is going to use the first description line of > the atunum object in question (if available) as a string for its name. > The overwhelming majority of affected ASNs contains a valuable > information there, so this is almost as good as having an organisation > handle linked to it. > > Fixes: #12660 > > Signed-off-by: Peter Müller > --- > src/python/location-importer.in | 28 +++++++++++++++++++++++++--- > 1 file changed, 25 insertions(+), 3 deletions(-) > > diff --git a/src/python/location-importer.in b/src/python/location-importer.in > index d4b0ca2..bec0b62 100644 > --- a/src/python/location-importer.in > +++ b/src/python/location-importer.in > @@ -393,11 +393,11 @@ class CLI(object): > with self.db.transaction(): > # Create some temporary tables to store parsed data > self.db.execute(""" > - CREATE TEMPORARY TABLE _autnums(number integer, organization text, source text NOT NULL) > + CREATE TEMPORARY TABLE _autnums(number integer NOT NULL, organization text NOT NULL, source text NOT NULL) > ON COMMIT DROP; > CREATE UNIQUE INDEX _autnums_number ON _autnums(number); > > - CREATE TEMPORARY TABLE _organizations(handle text, name text NOT NULL, source text NOT NULL) > + CREATE TEMPORARY TABLE _organizations(handle text NOT NULL, name text NOT NULL, source text NOT NULL) > ON COMMIT DROP; > CREATE UNIQUE INDEX _organizations_handle ON _organizations(handle); > > @@ -604,10 +604,32 @@ class CLI(object): > elif key == "org": > autnum[key] = val.upper() > > + elif key == "descr": > + # Save the first description line as well... > + if not key in autnum: > + autnum[key] = val > + > # Skip empty objects > - if not autnum: > + if not autnum or not "asn" in autnum: > return > > + # Insert a dummy organisation handle into our temporary organisations > + # table in case the AS does not have an organisation handle set, but > + # has a description (a quirk often observed in APNIC area), so we can > + # later display at least some string for this AS. > + if not "org" in autnum: > + if "descr" in autnum: > + autnum["org"] = "LIBLOC-%s-ORGHANDLE" % autnum.get("asn") > + > + self.db.execute("INSERT INTO _organizations(handle, name, source) \ > + VALUES(%s, %s, %s) ON CONFLICT (handle) DO NOTHING", > + autnum.get("org"), autnum.get("descr"), source_key, > + ) > + else: > + log.warning("ASN %s neither has an organisation handle nor a description line set, omitting" % \ > + autnum.get("asn")) > + return > + > # Insert into database > self.db.execute("INSERT INTO _autnums(number, organization, source) \ > VALUES(%s, %s, %s) ON CONFLICT (number) DO UPDATE SET \ > -- > 2.20.1 >