Browse Source

New GETINFO target to check if geoip is loaded

Closes ticket 23237.
Nick Mathewson 6 years ago
parent
commit
96aed28f14
2 changed files with 13 additions and 0 deletions
  1. 4 0
      changes/feature23237
  2. 9 0
      src/or/geoip.c

+ 4 - 0
changes/feature23237

@@ -0,0 +1,4 @@
+  o Minor features (controller):
+    - Added new GETINFO targets ip-to-country/{ipv4,ipv6}-available, so
+      controllers can tell whether the geoip databases are loaded.
+      Closes ticket 23237.

+ 9 - 0
src/or/geoip.c

@@ -1665,6 +1665,15 @@ getinfo_helper_geoip(control_connection_t *control_conn,
     sa_family_t family;
     tor_addr_t addr;
     question += strlen("ip-to-country/");
+
+    if (!strcmp(question, "ipv4-available") ||
+        !strcmp(question, "ipv6-available")) {
+      family = !strcmp(question, "ipv4-available") ? AF_INET : AF_INET6;
+      const int available = geoip_is_loaded(family);
+      tor_asprintf(answer, "%d", !! available);
+      return 0;
+    }
+
     family = tor_addr_parse(&addr, question);
     if (family != AF_INET && family != AF_INET6) {
       *errmsg = "Invalid address family";