domain-watchdog/README.md

116 lines
6.2 KiB
Markdown
Raw Normal View History

<p align="center"><img src="https://github.com/user-attachments/assets/942ddfd0-2c76-4b00-bd9f-727cfddc0103" alt="Domain Watchdog" width="150" height="150" /></p>
<h1 align="center"><b>Domain Watchdog</b></h1>
<p align="center">Your companion in the quest for domain names 🔍 <br/><a href="https://domainwatchdog.eu">domainwatchdog.eu »</a></p>
<br/>
2024-07-17 16:49:46 +02:00
Domain Watchdog is an app that uses RDAP to collect publicly available info about domains, track their history, and purchase them.
For more information please check [the wiki](https://github.com/maelgangloff/domain-watchdog/wiki) !
2024-07-17 16:49:46 +02:00
## Why use it?
- **Historical Tracking**: Know the history of a domain name, from its inception to its release into the public domain.
- **Detailed Monitoring**: Follow the evolution of a domain name and the entities that manage it in detail.
2024-07-31 01:08:46 +02:00
- **Auto-purchase Domain**: You want the domain name of your dreams, but it is already taken? Domain Watchdog detects
the deletion of the domain name on WHOIS and can trigger the purchase of the domain name via a provider's API
2024-07-17 16:49:46 +02:00
Although the RDAP and WHOIS protocols allow you to obtain precise information about a domain, it is not possible to
perform a reverse search to discover a list of domain names associated with an entity. Additionally, accessing a
detailed history of events (ownership changes, renewals, etc.) is not feasible with these protocols.
## Install
> [!TIP]
> For more details on the installation procedure, please refer to [INSTALL.md](/INSTALL.md).
### Docker Deployment
1. Clone the repository
2024-08-19 01:53:05 +02:00
2. Modify environment variables (.env) and add static files to customize your instance (see [INSTALL.md](/INSTALL.md))
3. Pull the latest version of the Domain Watchdog image from Docker Hub.
2024-08-14 17:01:43 +02:00
```shell
2024-08-19 01:53:05 +02:00
docker compose pull
2024-08-14 17:01:43 +02:00
```
2024-08-19 01:53:05 +02:00
4. Start the project in production environment. If you want, you can also build the Docker image to use yourself.
2024-08-14 17:01:43 +02:00
```shell
2024-08-19 01:53:05 +02:00
docker compose up
2024-08-14 17:01:43 +02:00
```
2024-08-19 01:53:05 +02:00
By default, the container listens on http://localhost:8080, but you can configure this in environment variables.
See the [Docker Compose file](./docker-compose.yml).
## Features
2024-07-17 16:49:46 +02:00
2024-08-19 01:53:05 +02:00
### Auto-purchase domain
2024-08-08 13:17:03 +02:00
A connector is a way to order a domain name. It is important to mention that this project does not act as a payment
intermediary.
Indeed, the user's credentials are directly used to enable the purchase via the provider's API. To this end, the user
gives his consent to define the legal framework in which the use of his account with the provider's API will be made.
The table below lists the supported API connector providers:
2025-03-31 16:12:15 +02:00
| Provider | Supported |
|:--------------------------------------------------------------------------:|:----------------:|
| [OVH](https://api.ovh.com) | **Yes** |
| [GANDI](https://api.gandi.net/docs/domains/) | **Yes** |
| [NAMECHEAP](https://www.namecheap.com/support/api/methods/domains/create/) | **Yes** |
| [AUTODNS](https://cloud.autodns.com/) | **Yes** |
| [NAME.COM](https://www.name.com/en-en/api-docs/) | **Yes** |
| Custom EPP Server | **EXPERIMENTAL** |
If a domain has expired and a connector is linked to the Watchlist, then Domain Watchdog will try to order it via the
2024-07-31 01:08:46 +02:00
connector provider's API.
2024-08-19 01:53:05 +02:00
Note: If the same domain name is present on several Watchlists, it is not possible to predict in advance which user will
win the domain name. The choice is left to chance.
2024-07-31 01:08:46 +02:00
2024-08-19 01:53:05 +02:00
### Monitoring
2024-07-29 13:11:56 +02:00
![Watchlist Diagram](https://github.com/user-attachments/assets/c3454572-3ac5-4b39-bc5e-6b7cf72fab92)
2024-08-19 01:53:05 +02:00
A watchlist is a list of domain names, triggers and possibly an API connector.
2024-08-19 01:53:05 +02:00
They allow you to follow the life of the listed domain names and send you a notification when a change has been
detected.
2024-08-19 01:53:05 +02:00
A notification to the user is sent when a new event occurs on one of the domain names in the Watchlist. This can be an
email or a chat via Webhook (Slack, Mattermost, Discord, ...). An iCalendar export of domain events is possible.
### RDAP search
The latest version of the WHOIS protocol was standardized in 2004 by RFC 3912.[^1] This protocol allows anyone to
retrieve key information concerning a domain name, an IP address, or an entity registered with a registry.
ICANN launched a global vote in 2023 to propose replacing the WHOIS protocol with RDAP. As a result, registries and
registrars will no longer be required to support WHOIS from 2025 (*WHOIS Sunset Date*).[^2]
Domain Watchdog uses the RDAP protocol, which will soon be the new standard for retrieving information concerning domain
names.
2024-07-17 16:49:46 +02:00
2024-08-07 02:13:39 +02:00
## Disclaimer
2024-08-14 17:01:43 +02:00
> [!IMPORTANT]
2024-08-07 02:13:39 +02:00
> * Domain Watchdog is an opensource project distributed under *GNU Affero General Public License v3.0 or later* license
> * In the internal operation, everything is done to perform the least possible RDAP requests: rate limit, intelligent
2024-08-07 02:13:39 +02:00
caching system, etc.
> * Please note that this project is NOT affiliated IN ANY WAY with the API Providers used to order domain names.
> * The project installers are responsible for the use of their own instance.
> * Under no circumstances will the owner of this project be held responsible for other cases over which he has no control.
2024-08-07 02:13:39 +02:00
2024-08-19 01:53:05 +02:00
## Useful documentation
> [!NOTE]
> - [RFC 7482 : Registration Data Access Protocol (RDAP) Query Format](https://datatracker.ietf.org/doc/html/rfc7482)
> - [RFC 7483 : JSON Responses for the Registration Data Access Protocol (RDAP)](https://datatracker.ietf.org/doc/html/rfc7483)
> - [RFC 7484 : Finding the Authoritative Registration Data (RDAP) Service](https://datatracker.ietf.org/doc/html/rfc7484)
2024-07-20 09:54:04 +02:00
## Licensing
2024-07-29 13:11:56 +02:00
2024-07-31 01:08:46 +02:00
This source code of this project is licensed under *GNU Affero General Public License v3.0 or later*.
2024-07-20 09:54:04 +02:00
Contributions are welcome as long as they do not contravene the Code of Conduct.
2024-07-17 16:49:46 +02:00
[^1]: RFC 3912 : WHOIS Protocol Specification. (2004). IETF Datatracker. https://datatracker.ietf.org/doc/html/rfc3912
[^2]: 2023 Global Amendments to the Base gTLD Registry Agreement (RA), Specification 13, and 2013 Registrar
2024-08-04 15:49:38 +02:00
Accreditation Agreement (RAA) - ICANN. (2023). https://www.icann.org/resources/pages/global-amendment-2023-en