Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

📝 Update README to reflect the recent changes #37

Merged
merged 4 commits into from
Jun 25, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
120 changes: 68 additions & 52 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,80 +1,96 @@
# dns
# 🌐 MoJ DNS Management

[![repo standards badge](https://img.shields.io/endpoint?labelColor=231f20&color=005ea5&style=for-the-badge&label=MoJ%20Compliant&url=https%3A%2F%2Foperations-engineering-reports.cloud-platform.service.justice.gov.uk%2Fapi%2Fv1%2Fcompliant_public_repositories%2Fendpoint%2Fdns&logo=)](https://operations-engineering-reports.cloud-platform.service.justice.gov.uk/public-report/dns)
[![repo standards badge](https://img.shields.io/endpoint?labelColor=231f20&color=005ea5&style=for-the-badge&label=MoJ%20Compliant&url=https%3A%2F%2Foperations-engineering-reports.cloud-platform.service.justice.gov.uk%2Fapi%2Fv2%2Fcompliant-repository%2Fdns&logo=)](https://operations-engineering-reports-prod.cloud-platform.service.justice.gov.uk/public-report/dns)

This repo currently contains dumps of the existing `dsd.io` and
`justice.gov.uk` hosted zones, as well as tools for bulk-registration of
domains and managing our defensive domains estate (for which this
repository is the source of truth, and will override changes made in Route53).
This repository manages DNS records for the Ministry of Justice using [octoDNS](https://github.com/octodns/octodns). It provides a streamlined, code-based approach to DNS management, ensuring consistency and enabling version control for our DNS records.

It uses [OctoDNS](https://github.com/github/octodns) for the bulk of
its interactions with our DNS provider (Route53).
## Repository Structure

## `dsd.io` and `justice.gov.uk` dumps

Exported with octodns to the `output/` folder in this repo. See upstream docs for details on usage.

The simplest way to dump a single zone is:
```
octodns-dump --config-file config/mojdsd.yaml --lenient --output-dir output/ <zone-name> route53
.
├── .github/ # GitHub Actions workflows
├── hostedzones/ # DNS zone files
├── .gitignore
├── LICENSE
├── Makefile
├── README.md
├── config.yaml # octoDNS configuration
└── requirements.txt # Python dependencies
```

## Domain registration
## How It Works

To register a batch of domains, call the `register-domains.sh` script like this:
1. DNS records are stored as YAML files in the `hostedzones/` directory. Each file represents a single hosted zone and contains all records for that zone.

```bash
$ ./script/register-domains.sh first-domain.com second-domain.net third-domain.org
2. Changes are proposed via Pull Requests.

3. A CI/CD pipeline runs `octodns-sync` in dry-run mode for each PR, allowing for review of proposed changes.

4. Upon merging to the `main` branch, changes are automatically applied to our Route53 hosted zones.

## Making Changes

1. Clone this repository.
2. Create a new branch for your changes.
3. Edit the appropriate zone file in the `hostedzones/` directory.
4. Ensure changes are made in alphabetical order within the file.
5. Commit your changes and create a Pull Request.

Example of adding a new A record to `example.com.yaml`:

```yaml
---
'':
type: A
values:
- 192.0.2.1
api:
type: CNAME
value: api.example.net.
# New record (note alphabetical order)
blog:
type: A
values:
- 203.0.113.10
www:
type: CNAME
value: example.com.
```

It will use your existing AWS CLI credentials, and register the domains
in your default account. For the moment, there is no way to change this,
so if registering domains, please ensure you're using `mojdsd` as your
default account, as that's where we currently keep our domains.
## Configuration

## Defensive domain management
The `config.yaml` file is set up dynamically to encompass all hosted zones in the mojdsd AWS account. We use the `lenient` option due to historical non-uniform record creation.

We have hundreds of defensively-registered domains, and need to [apply the same DNS records](https://ministryofjustice.github.io/security-guidance/defensive-domain-registration/#defensive-domain-registrations) to all of them. Unfortunately, at the
time of writing, [OctoDNS doesn't support applying records to multiple
zones](https://github.com/github/octodns/issues/7), so we're using
[Make](https://www.gnu.org/software/make/manual/make.html) to automate
generation of OctoDNS config for each domain.
## CI/CD Pipeline

This repository's code is the source of truth for our defensive domain
config, and the list of repos *should* be complete.
- Pull Requests: Triggers a dry-run of `octodns-sync` to preview changes.
- Merge to `main`: Applies changes to Route53 using `octodns-sync --doit`. Changes typically take about 2 minutes to propagate.

### Managing defensive domain DNS config
## AWS IAM User

All our defensive domains are listed in `defensive-domains/domains.mk`,
as a single `$DEFENSIVE_DOMAINS` variable that contains a
whitespace-separated string which Make can then use to generate separate
OctoDNS config files for each of them (output to
`defensive-domains/config/<domain>.yaml`), based on the OctoDNS config
template in `defensive-domains/dns.tmpl.yaml`. This config is not dynamic
at present, as all the DNS records should be identical, and don't depend
on the domain names in any way.
The AWS IAM user required for this DNS management system is not created or managed within this repository. Instead, it is provisioned and maintained in the separate [operations-engineering repository](https://github.com/ministyofjustice/operations-engineering).

These config files are only generated when Make needs them to carry out
some other action you specify.
This approach centralises our IAM user management and ensures that the DNS management system uses credentials that are consistently managed alongside our other operational resources.

### Updating defensive domain DNS records
## Requirements to Run Locally

If you update the list of defensive domains, or the OctoDNS config
template, you can validate your changes:
- Python 3.x
- AWS IAM user with appropriate Route53 permissions

```bash
$ make defensive-domains-validate
# Prints nothing and returns 0 if everything is valid
```
:warning: **Caution:** We strongly recommend you don't run `octodns-sync --doit` locally. Instead, use the CI/CD pipeline to apply changes.

Once you're happy with your changes, you can test them without applying them:
To install dependencies:

```bash
$ make defensive-domains-noop
pip install -r requirements.txt
```

And, once you're confident that they're good to be deployed, you can apply them:
And then run the following command to preview changes:

```bash
$ make defensive-domains-apply
octodns-sync --config-file=./config.yaml
```

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.