Skip to main content

Plugins for DNSMule

Project description

Plugins for DNSMule

It is recommended to look through each module to see what arguments they take.

Certcheck

Arguments:

rules:
  - certcheck:
    record: A
    type: 'ip.certs'
    ports: # Ports to scan
      - 443
      - 8443
    timeout: 1 # timeout for cert fetching
    stdlib: false # Prefer STDLIB implementation
    callback: false # Whether a callback should be called for resolved domains

Scans any resolved A or AAAA record for certificates from a given list of ports. There are two ways to scan for certificates, a Python stdlib solution and one with cryptography library parsing certs.

Tags are produced for cert issuer:

IP::CERTS::{rule_name}::ISSUER::{issuer_rfc_string}

More data is available in result.data:

result.data['resolvedCertificates'] = certificates_as_list_of_dicts

See the Certificate dataclass to_json method in certificates.py.

The plugin takes a callback argument for any domains resolved from certificate common and alternative names.

This plugin requires the following dependencies:

  • cryptography (optional)

IPRanges

Arguments:

rules:
  - ipranges:
    record: A
    type: 'ip.ranges'
    providers: # Lowercase only
      - amazon
      - google
      - microsoft

Scans any resolved A or AAAA record for addresses in the major cloud provider ranges. Currently, supports the following providers:

  • Microsoft
  • Google Cloud
  • Amazon AWS

Provider IP ranges are refreshed on one hour intervals.

This provides tags like:

IP::RANGES::{rule_name}::{provider}::{service}::{region}
IP::RANGES::SAMPLE_RULE::AMAZON::LAMBDA::US-WEST-1

This plugin requires the following dependencies:

  • httpx

PTRScan

Arguments:

rules:
  - ptrscan:
    record: A
    type: 'ip.ptr'

Scans any resolved A or AAAA record for a matching PTR record. The pointer is used to discover automatically generated cloud provider pointer records for services. The plugin tries to detect pointer records where the ip of the A or AAAA record is present in any of the following forms:

  • dot separated
  • dot separated reversed
  • dash separated
  • dash separated reversed
  • Any of the above anywhere in the string

This resolves to a provider with the prefix removed from the record.

For example a PTR of the form with a rule name sample_rule

123.456.789.000 IN PTR CDN-123-456-789-000.area.hoster.example.com

would produce a tag of the form

IP::PTR::SAMPLE_RULE::AREA.HOSTER.EXAMPLE.COM

Any resolved PTR records are also added to result.data['resolvedPointers'].

This plugin requires the following dependencies:

  • dnspython
  • dnsmule.backends.DNSPythonBackend

Example

Here is an example of how to add a ruleset containing all plugins to a DNSMule instance. This will change in the future when a plugins directive is supported in the rules.yml config.

import os

from dnsmule import DNSMule
from dnsmule.rules.utils import load_rules
from dnsmule_plugins import certcheck, ipranges

mule = DNSMule.load(os.getenv('MULE_CONFIG'))

certcheck.plugin_certcheck(mule.rules, lambda ds: mule.store_domains(*ds))
ipranges.plugin_ipranges(mule.rules)

load_rules([
    {
        'record': 'A',
        'type': 'ip.certs',
        'name': 'certcheck',
    },
    {
        'record': 'A',
        'type': 'ip.ranges',
        'name': 'ipranges',
        'providers': [
            'amazon',
            'microsoft',
            'google',
        ]
    },
], rules=mule.rules)

if mule.backend == 'DNSPythonBackend':
    from dnsmule_plugins import ptrscan

    ptrscan.plugin_ptr_scan(mule.rules, mule.get_backend())
    load_rules([
        {
            'record': 'A',
            'type': 'ip.ptr',
            'name': 'ptrscan',
        },
    ], rules=mule.rules)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dnsmule-plugins-0.1.0.tar.gz (12.3 kB view details)

Uploaded Source

Built Distribution

dnsmule_plugins-0.1.0-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file dnsmule-plugins-0.1.0.tar.gz.

File metadata

  • Download URL: dnsmule-plugins-0.1.0.tar.gz
  • Upload date:
  • Size: 12.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.4

File hashes

Hashes for dnsmule-plugins-0.1.0.tar.gz
Algorithm Hash digest
SHA256 5b895fd311edd95f6fa1b214fda6be3c97c971ed0761f73c8fbb2c728b372f70
MD5 d832726e3d95c355665271c51a9c0d87
BLAKE2b-256 dfc77a5fd98f963e74274263d8dee9a1ec4fd4631d300d7a4a81feb252fca59c

See more details on using hashes here.

File details

Details for the file dnsmule_plugins-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for dnsmule_plugins-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ee05b04b00834449c7698601efc10cc57320b66c6ebca3fc5ec720e863fc2765
MD5 a69078264c80468e489fdac7270a2c3e
BLAKE2b-256 60337068b34dea83c96ab0da5561cb3899d8dc7f95987e65e64e2b325b3fc82f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page