/DomainMapper

A tool for scanning and resolving DNS names into IP addresses

Primary LanguagePythonMIT LicenseMIT

Domain Mapper

Что нового (нажать чтоб открыть)

Описание: Инструмент на языке Python, предназначенный для разрешения DNS имен популярных веб-сервисов в IP-адреса.

Поддерживаемые сервисы (нажать чтобы открыть)

Функции:

  • Преобразование доменных имен популярных сервисов в IP-адреса.
  • Агрегация маршрутов до сетей /16 (255.255.0.0), /24 (255.255.255.0).
  • Фильтрация IP-адресов Cloudflare (опционально).
  • Восемь вариантов сохранения результатов.

Ключевые особенности

  • Возможность выбора системного, публичного DNS-сервера или их комбинации.
  • При разрешении доменного имени используется каждый из указанных DNS-серверов, при этом процесс продолжается до получения всех возможных IP-адресов, а не останавливается на первом успешном ответе.
  • Автоматическое исключение дубликатов IP-адресов, а также "заглушек" (например, IP самих DNS-серверов, редиректов на 0.0.0.0 и localhost).
  • Поддержка работы в "тихом" режиме без взаимодействия с пользователем, настройка через конфигурационный файл.
  • В конфигурационном файле можно указать команду для автоматического запуска другого скрипта или программы по завершении работы.

Использование:

  1. Установите зависимости:

    pip install -r requirements.txt
  2. Отредактируйте config.ini под свои задачи (опционально)

  3. Запустите скрипт:

    python main.py
Локальный режим работы (нажать чтобы открыть)

В этом режиме списки DNS-серверов и сервисов загружаются из локальных файлов в папке со скриптом, а не из сети.

Для включения загрузки списка сервисов из локального файла platformdb, укажите localplatform = yes в config.ini.

  • Формат файла platformdb: название сервиса и путь к локальному файлу через двоеточие. Пример:
Torrent Truckers: platforms/dns-ttruckers.lst
Search engines: dns-search-engines.txt
Twitch: platforms/service/dns-twitch.txt

Для включения загрузки списка DNS-серверов из локального файла dnsdb, укажите localdns = yes в config.ini.

  • Формат файла dnsdb: название DNS-сервера и его IP-адреса через двоеточие и пробел. Пример:
CleanBrowsing: 185.228.168.9 185.228.169.9
Alternate DNS: 76.76.19.19 76.223.122.150
AdGuard DNS: 94.140.14.14 94.140.15.15

Важно: названия сервисов и нумерация DNS-серверов в config.ini должны соответствовать тем, что указаны в файлах platformdb и dnsdb.

  • Формат файла с доменными именами: по одному домену на строку. Пример:
ab.chatgpt.com
api.openai.com
arena.openai.com

Указание URL вместо доменного имени (например, ab.chatgpt.com/login вместо ab.chatgpt.com) приведет к ошибке.

Запуск скрипта с файлом конфигурации, отличным от `config.ini` (нажать чтобы открыть)
  • Указать путь к другому конфигурационному файлу при запуске скрипта можно с помощью опции -c (или --config). Если параметр не указан, по умолчанию будет использоваться файл config.ini.

Пример использования: main.py -c myconfig.ini, python main.py -c config2.ini или main.py -c srv5.ini и т.д.

Личный (локальный) список с доменными именами (нажать чтобы открыть)
  • Создайте файл custom-dns-list.txt, запишите в него доменные имена и разместите его рядом со скриптом. Список будет автоматически подхвачен при запуске и появится в меню как "Custom DNS list".

  • Пример файла custom-dns-list.txt:

ab.chatgpt.com
api.openai.com
arena.openai.com

Указание URL вместо доменного имени (например, ab.chatgpt.com/login вместо ab.chatgpt.com) приведет к ошибке.

Для пользователей Windows, не знающих "как", но кому "очень нужно" (нажать чтобы открыть)
  • Загляните в директорию Windows репозитория.
Протестировано в Ubuntu 20.04, macOS Sonoma и Windows 10/11