Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/GhostManager/DomainCheck
DomainCheck is designed to assist operators with monitoring changes related to their domain names. This includes negative changes in categorization, VirusTotal detections, and appearances on malware blacklists. DomainCheck currently works only with NameCheap.
https://github.com/GhostManager/DomainCheck
Last synced: 22 days ago
JSON representation
DomainCheck is designed to assist operators with monitoring changes related to their domain names. This includes negative changes in categorization, VirusTotal detections, and appearances on malware blacklists. DomainCheck currently works only with NameCheap.
- Host: GitHub
- URL: https://github.com/GhostManager/DomainCheck
- Owner: GhostManager
- Created: 2018-12-03T01:34:48.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-01-16T15:52:51.000Z (almost 6 years ago)
- Last Synced: 2024-11-15T13:16:12.759Z (28 days ago)
- Language: Python
- Homepage: https://posts.specterops.io/being-a-good-domain-shepherd-57754edd955f
- Size: 20.5 KB
- Stars: 231
- Watchers: 10
- Forks: 29
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-hacking-lists - GhostManager/DomainCheck - DomainCheck is designed to assist operators with monitoring changes related to their domain names. This includes negative changes in categorization, VirusTotal detections, and appearances on malware b (Python)
README
# DomainCheck
DomainCheck is designed to assist operators with monitoring changes related to their domain names. This includes negative changes in categorization, VirusTotal detections, and appearances on malware blacklists. DomainCheck currently works only with Namecheap.
DomainCheck pulls a list of domains registered under the provided Namecheap account and then reviews each one to ensure it is ready to be used. This involves checking to see if Namecheap's WhoisGuard is enabled, the domain is not expired, the domain is properly categorized, the domain has not been flagged in VirusTotal or tagged with a bad category, and the domain is not blacklisted for spam.
## Shepherd
If you like DomainCheck, you may want to look at the Shepherd project. More information here: https://posts.specterops.io/being-a-good-domain-shepherd-part-2-5e8597c3fe63
Shepherd is a Django application with DomainCheck's functionality baked in, scheduled domain update tasks, and more.
## Information Sources
DomainReview uses the following sources to check the health of a domain name:
* VirusTotal
* Cisco Talos
* Bluecoat
* IBM X-Force
* Fortiguard
* TrendMicro
* OpenDNS
* MXToolboxAdditionally, DomainCheck pulls the latest list of "bad" domains from malwaredomains.com and checks if any of the Namecheap domain names make an appearance.
## Operation Modes
DomainCheck supports two modes:
### Checkup Mode
In checkup mode, DomainCheck pulls the list of domain names and checks each one just once. Once the checks are finished, DomainCheck outputs the data as a csv file. Optionally, if the `--wiki` flag is provided, DomainCheck also produces the results in the markup language understood by Confluence wikis. This markup can be copy and pasted into a wiki to create a nicely formatted table.
To do this, edit a Confluence wiki page, click "Insert," insert a Markup section, and paste in the DomainCheck-generated markup.
#### Usage
The following command checks all domains under the Namecheap account:
`./domaincheck.py checkup --wiki`
This command checks only the domains provided for the `--filter-list` parameter:
`./domaincheck.py checkup --wiki --filter-list domaincheck.com,spectreoops.net`
### Monitor Mode
In monitor mode, DomainCheck will continuously check the domains, either all of the Namecheap domain names or just those the user provides on the command line. A time interval is set (in minutes) and DomainCheck will sleep for that amount of time before re-checking the domains.
Note: The Namecheap API is only queried at the start of a monitoring session, so monitoring must be restarted if new domains are added to the account that also require monitoring.
If the `--slack` flag is provided and a Slack WebHook is configured, DomainCheck will send your configured Slack message whenever an issue (negative categorization, VirusTotal hit, domain added to a watch list) is detected. These messages are sent in addition to warnings displayed in the terminal.
#### Usage
The following command checks the named domains every 60 minutes and sends a Slack message if an issue is detected:
`./domaincheck.py monitor --domains domaincheck.com,spectreoops.net -i 60 --slack`
## Installation
Using pipenv for managing the required libraries is the best option to avoid Python installations getting mixed-up. Do this:
1. Run: `pip3 install --user pipenv` or `python3 -m pip install --user pipenv`
2. Clone DomainCheck's repo.
3. Run: `cd DomainCheck && pipenv install`
4. Start using DomainCheck by running: `pipenv shell`If you would prefer to not use pipenv, the list of required packages can be found in the Pipfile file.
### Final Configurations
DomainCheck uses a domaincheck.config file. A sample is provided which can be edited and renamed (to remove `.sample` from the end). You will need your Namecheap account and API information, a VirusTotal API key (a free key is fine), and (optional) your Slack WebHook URL. Enter this information into the config file, name it domaincheck.config, and DomainCheck is ready to be used.
## Acknowledgments
Special thanks to [SpecterOps](https://specterops.io) for supporting this project!
## Change Log
### 21 December 2018
* Made some improvements and tweaks to the wiki and csv output.
* Added missing logic that would mark a domain as burned if one its categories appeared in the category blacklist.