public inbox for location@lists.ipfire.org
 help / color / mirror / Atom feed
From: Michael Tremer <michael.tremer@ipfire.org>
To: location@lists.ipfire.org
Subject: Re: What generates database.db from database.txt?
Date: Tue, 20 Oct 2020 17:08:19 +0100	[thread overview]
Message-ID: <0A556AF2-9F53-467C-9627-1208A6E20CAA@ipfire.org> (raw)
In-Reply-To: <4eaccd86-f9d9-d53d-738a-6103179a15ef@gmail.com>

[-- Attachment #1: Type: text/plain, Size: 2653 bytes --]

Hello Gisle,

Thank you for your email.

> On 19 Oct 2020, at 16:53, Gisle Vanem <gisle.vanem(a)gmail.com> wrote:
> 
> Hello list, my ports post.
> 
> I'm on Windows and have little interest in installing
> IPFire or do any Linux related. But the 'libloc'
> library caught my interest. So I did a port to
> MSVC, MinGW and clang-cl (x86 only) in a hurry.

That sounds great!

We are looking for someone with some experience with Windows to port libloc. It should not be super complicated, but since I am not the expert I am not too sure.

Would you be willing to tidy up your code (if required) and submit them on here so that we can officially support Windows?

> Running all the 'test-*' programs, it worked seemingly
> well. Until I built the Python3 module and played with
> e.g. 'location dump' and 'verify'. Nothing worked :-(

What didn’t work specifically? Reading and writing the database?

> So I reckon the .db file is hosed somehow. AFAICS, it's
> not an issue with structure packing or 'fopen(path, "r")'.

Hmm… it would be interesting to debug that.

> Anyway, I want to regenerate 'database.db' from 'database.txt'
> 'countries.txt' and the 'override' files myself. But how?

We do not generate the database from database.txt. database.txt is being generated from the database. The text dump is just there so that we have a (sort of) human-readable version which we can diff against the previous one to manually verify any changes.

What you will need to import the raw data is location-importer which comes with libloc and a PostgreSQL server.

location-importer —help will show you how you pass the database credentials.

On our servers we regularly run “location-import update-overrides file-a.txt file-b.txt”, then "location-importer update-whois”, then we run “location-importer update-announcements” which connects to a locally running instance of Bird with a full BGP feed to import those.

Finally we run “location-importer write … database.db” (fill in the gaps with your vendor name, description, key, etc.) and finally you can run “location -d database.db dump” to export it into the text format.

Generating the whole database might take a couple of hours depending on how beefy your machine is.

Let me know if this works for you.

> According to the git log at:
>  git://git.ipfire.org/location/location-database.git
> 
> there once was a 'compile-database' script. Not now.

Yes, this has all been moved into “location-importer” so that we separate code and data in two different Git repositories.

Best,
-Michael

> 
> -- 
> --gv


  reply	other threads:[~2020-10-20 16:08 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-10-19 15:53 Gisle Vanem
2020-10-20 16:08 ` Michael Tremer [this message]
2020-10-20 19:14   ` Gisle Vanem
2020-10-20 20:49     ` Michael Tremer
2020-10-20 22:46       ` Gisle Vanem
2020-10-21  9:34         ` Michael Tremer
2020-10-21 11:07           ` Gisle Vanem
2020-10-21 13:15             ` Michael Tremer
     [not found] <b63ffe0e-6eca-7168-bb13-07281eff208f@gmail.com>
2020-10-22 10:17 ` Michael Tremer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=0A556AF2-9F53-467C-9627-1208A6E20CAA@ipfire.org \
    --to=michael.tremer@ipfire.org \
    --cc=location@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox