2 libloc - A library to determine the location of someone on the Internet
4 Copyright (C) 2017 IPFire Development Team <info@ipfire.org>
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
17 #ifndef LIBLOC_FORMAT_H
18 #define LIBLOC_FORMAT_H
22 #define LOC_DATABASE_MAGIC "LOCDBXX"
24 enum loc_database_version
{
25 LOC_DATABASE_VERSION_UNSET
= 0,
26 LOC_DATABASE_VERSION_1
= 1,
29 #define LOC_DATABASE_VERSION_LATEST LOC_DATABASE_VERSION_1
33 #define LOC_DATABASE_DOMAIN "_v%u._db.location.ipfire.org"
35 #define LOC_DATABASE_PAGE_SIZE 4096
37 #define LOC_SIGNATURE_MAX_LENGTH 4096
39 struct loc_database_magic
{
42 // Database version information
46 struct loc_database_header_v1
{
47 // UNIX timestamp when the database was created
50 // Vendor who created the database
53 // Description of the database
56 // License of the database
59 // Tells us where the ASes start
63 // Tells us where the networks start
64 uint32_t network_data_offset
;
65 uint32_t network_data_length
;
67 // Tells us where the network nodes start
68 uint32_t network_tree_offset
;
69 uint32_t network_tree_length
;
71 // Tells us where the countries start
72 uint32_t countries_offset
;
73 uint32_t countries_length
;
75 // Tells us where the pool starts
80 uint32_t signature_length
;
81 char signature
[LOC_SIGNATURE_MAX_LENGTH
];
83 // Add some padding for future extensions
87 struct loc_database_network_node_v1
{
94 struct loc_database_network_v1
{
95 // The start address and prefix will be encoded in the tree
97 // The country this network is located in
110 struct loc_database_as_v1
{
118 struct loc_database_country_v1
{
120 char continent_code
[2];
122 // Name in the string pool