aboutsummaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
Diffstat (limited to 'modules')
-rw-r--r--modules/ip_addresses.py47
1 files changed, 37 insertions, 10 deletions
diff --git a/modules/ip_addresses.py b/modules/ip_addresses.py
index 88bd9a56..74e848af 100644
--- a/modules/ip_addresses.py
+++ b/modules/ip_addresses.py
@@ -2,32 +2,59 @@
import re, socket
from src import ModuleManager, utils
+import dns.resolver
URL_GEOIP = "http://ip-api.com/json/%s"
REGEX_IPv6 = r"(?:(?:[a-f0-9]{1,4}:){2,}|[a-f0-9:]*::)[a-f0-9:]*"
REGEX_IPv4 = r"(?:\d{1,3}\.){3}\d{1,3}"
REGEX_IP = re.compile("(%s)|(%s)" % (REGEX_IPv4, REGEX_IPv6), re.I)
+def _dns_validate(s):
+ if utils.is_ip(s):
+ return s
+ return None
+
+@utils.export("serverset", {"setting": "dns-nameserver",
+ "help": "Set DNS nameserver", "example": "8.8.8.8"})
class Module(ModuleManager.BaseModule):
@utils.hook("received.command.dns", min_args=1)
def dns(self, event):
"""
:help: Get all addresses for a given hostname (IPv4/IPv6)
- :usage: <hostname>
+ :usage: <hostname> [type [type ...]]
:prefix: DNS
"""
hostname = event["args_split"][0]
- try:
- address_info = socket.getaddrinfo(hostname, 1, 0,
- socket.SOCK_DGRAM)
- except socket.gaierror:
- raise utils.EventError("Failed to find hostname")
+ nameserver = event["server"].get_setting("dns-nameserver", None)
+ has_nameserver = not nameserver == None
+
+ record_types = ["A?", "AAAA?"]
+ if len(event["args_split"]) > 1:
+ record_types = [t.upper() for t in event["args_split"][1:]]
+
+ if not nameserver == None:
+ resolver = dns.resolver.Resolver(configure=False)
+ resolver.nameservers = [nameserver]
+ else:
+ resolver = dns.resolver
+
+ results = []
- ips = []
- for _, _, _, _, address in address_info:
- ips.append(address[0])
- event["stdout"].write("%s: %s" % (hostname, ", ".join(ips)))
+ for record_type in record_types:
+ try:
+ record_type_strip = record_type.rstrip("?")
+ query_result = resolver.query(hostname, record_type_strip)
+ query_results = [q.to_text() for q in query_result]
+ results.append([record_type_strip, query_results])
+ except dns.resolver.NXDOMAIN:
+ raise utils.EventError("Domain not found")
+ except dns.resolver.NoAnswer:
+ if not record_type.endswith("?"):
+ raise utils.EventError("Domain does not have a '%s' record"
+ % record_type)
+ results_str = ["%s: %s" % (t, ", ".join(r)) for t, r in results]
+ event["stdout"].write("(%s) %s" % (hostname, " | ".join(results_str)))
@utils.hook("received.command.geoip", min_args=1)
def geoip(self, event):