Terraform Module for managing AWS Route 53 DNS Records for G Suite.
This module requires Terraform version 0.13.0
or newer.
This module depends on a correctly configured AWS Provider in your Terraform codebase.
Add the module to your Terraform resources like so:
module "gsuite_records" {
source = "operatehappy/route53-gsuite-records/aws"
version = "1.0.0"
zone_id = "Z3P5QSUBK4POTI"
mx_verification_record_prefix = "2vw...juq"
dkim_record_value = "v=DKIM1; k=rsa; p=MIG...QAB"
custom_gmail_subdomain = "mail"
custom_calendar_subdomain = "calendar"
custom_docs_subdomain = "docs"
custom_drive_subdomain = "drive"
custom_sites_subdomain = "sites"
custom_groups_subdomain = "groups"
dmarc_report_recipient = "hostmaster@example.com"
apex_verification_txt = "google-site-verification=EXAMPLE"
}
Then, fetch the module from the Terraform Registry using terraform get
.
Name | Description | Type | Default |
---|---|---|---|
apex_verification_txt | Google Domain Verification Record | string |
n/a |
custom_calendar_subdomain | Subdomain for custom Calendar URL | string |
n/a |
custom_docs_subdomain | Subdomain for custom Docs URL | string |
n/a |
custom_drive_subdomain | Subdomain for custom Drive URL | string |
n/a |
custom_gmail_subdomain | Subdomain for custom Gmail URL | string |
n/a |
custom_groups_subdomain | Subdomain for custom Groups for Business URL | string |
n/a |
custom_sites_subdomain | Subdomain for custom Sites URL | string |
n/a |
dkim_record_value | DKIM Identifier Value | string |
n/a |
dmarc_report_recipient | Recipient of DMARC Reports | string |
n/a |
mx_verification_record_prefix | MX Verification Record Prefix (without .mx-verification.google.com ) |
string |
n/a |
zone_id | ID of the DNS Zone to store Records in | string |
n/a |
apex_domain_redirect_records | n/a | list |
[ |
apex_spf_txt | SPF Record for Gmail | string |
"v=spf1 include:_spf.google.com ~all" |
dkim_record_key | DKIM Identifier Record (without ._domainkey ) |
string |
"google" |
dmarc_dkim_alignment_mode | Alignment mode for DKIM Signatures | string |
"r" |
dmarc_policy_percentage | Percentage of suspicious messages the Policy should apply to | string |
100 |
dmarc_policy_type | Type of DMARC Policy | string |
"none" |
dmarc_protocol_version | Version of DMARC Protocol | string |
"DMARC1" |
dmarc_spf_alignment_mode | Alignment mode for SPF Records | string |
"r" |
dmarc_subdomain_policy_type | Type of DMARC Policy for Subdomains | string |
"none" |
dnssec_mx_records | List of MX Records | list(string) |
[ |
gsuite_custom_url_cname | CNAME Record for custom Application URLs | string |
"ghs.googlehosted.com" |
mx_records | List of MX Records | list(string) |
[ |
mx_verification_record_priority | MX Verification Record Priority | string |
15 |
mx_verification_record_suffix | MX Verification Record Suffix | string |
".mx-verification.google.com" |
record_ttl | TTL for all DNS records | string |
3600 |
redirect_naked_domain | Toggle to redirect naked domain | bool |
false |
use_dnssec_signed_records | Toggle to enable DNSSEC-signed Records for Gmail | bool |
false |
Name | Description |
---|---|
apex_txt_record | interpolated value of local.apex_txt_record |
dmarc_policy | interpolated value of local.dmarc_policy |
gsuite-toolbox-check-mx-url | Direct Link to G Suite Toolbox Check MX tool |
On top of adding the required MX
records, this module supports a variety of optional settings that can be useful for better integrating with G Suite.
This section contains step-by-step guides with additional information and helpful links to the G Suite Admin Help Center.
Google provides a number of tools for G Suite administrators that are geared towards debugging.
You can verify your domain's records (MX
, SPF
, DKIM
, and DMARC
) are correctly set up by using the Check MX tool.
To make using this tool easier, this Terraform module generates a direct link as part of the module outputs. This link pre-fills your G Suite domain and DKIM key.
The output is part of the module and can be retrieved via terraform console
, but it can also be bubbled up to display as an output in your Terraform configuration using the following example:
output "gsuite-toolbox-check-mx-url" {
value = module.gsuite-records.gsuite-toolbox-check-mx-url
description = "Direct Link to G Suite Toolbox Check MX tool"
}
Note that in the above example, the output requires this module to be referenced as gsuite-records
. Should you use a different name, you will need to adjust the value
reference to reflect this.
Once you have completed a terraform apply
run, the direct link to the Check MX tool can be found using terraform output gsuite-toolbox-check-mx-url
.
You can flush Google's DNS cache for a domains specific record types by using the Flush Cache tool.
Note the instructions on that page for further explanations.
Described in Help Center article Help prevent email spoofing with SPF records
, this module sets a default SPF record of v=spf1 include:_spf.google.com ~all
, automatically.
This value can be changed by setting the contents of the apex_spf_txt
variable to a policy of your chosing.
Using DomainKeys Identified Mail (DKIM) helps prevent spoofing on outgoing messages sent from your domain.
Described in Help Center article Set up DKIM to prevent email spoofing, the required steps to enable this feature are:
- Open the Google Admin interface
- Click on the Apps icon
- Click on the G Suite icon
- Click on the Gmail menu item
- Click on the Authenticate email menu item
- Verify that the value in the Selected domain drop down menu is correct
- Click on the GENERATE NEW RECORD button
- Select a DKIM key bit length of
1024
bits - Select a Prefix selector (or keep the default of
google
) - Click on the GENERATE button
Once these steps have been completed, the DKIM Authentication interface will generate a DNS record for you.
Copy the TXT record value (starting with v=DKIM1; k=rsa;
) and add it to the module's configuration using the dkim_record_value
variable.
If you chose to change the _Prefix selector (step 9), add it to the module's configuration using the dkim_record_key
variable.
module "gsuite-records" {
// module configuration as listed above
dkim_record_value = "v=DKIM1; k=rsa; p=MIG...QAB"
dkim_record_key = "google"
}
After applying these changes (using terraform apply
), return to the Authenticate email interface and click the START AUTHENTICATION button.
Note that if you are activating Gmail (the service) for your G Suite account for the first time, the interface may impose a 24 to 72 hour wait before DKIM records can be generated.
Once the records have been generated and applied, it may take up to 72 hours more for DNS changes to fully propagate. See the Flushing DNS Cache Notes for additional help.
Using Domain-based Message Authentication, Reporting, and Conformance (DMARC) helps manage suspicious emails.
Described in Help Center article Turn on DMARC, the required steps to enable this feature are:
- Craft a DMARC policy, consisting of the following items:
- Version of DMARC Protocol, configured through the
dmarc_protocol_version
variable - Type of DMARC Policy, configured through the
dmarc_policy_type
variable - Percentage of suspicious messages the Policy should apply to, configured through the
dmarc_policy_percentage
variable - Recipient of DMARC Reports, configured through the
dmarc_report_recipient
variable - Type of DMARC Policy for Subdomains, configured through the
dmarc_subdomain_policy_type
variable - Alignment mode for DKIM Signatures, configured through the
dmarc_dkim_alignment_mode
variable - Alignment mode for SPF Records, configured through the
dmarc_spf_alignment_mode
variable
- Version of DMARC Protocol, configured through the
Except for the dmarc_report_recipient
variable, all of these settings have sane defaults. Their default values can be found in the Inputs section.
Note that setting a value for the dmarc_report_recipient
variable will result in the following policy to be applied:
"v=DMARC1; p=none; pct=100; rua=mailto:${var.dmarc_report_recipient}; sp=none adkim=r; aspf=r"
Crafting a "correct" DMARC Policy is highly specific to your organization's use case and outside the scope of this document. The Help Center article on DMARC values provides a good starting point.
The module-generated DMARC Policy is also available as an output under the dmarc_policy
identifier.
Described in Help Center article Customize a G Suite service URL, the required steps for creating one (or all) redirects are:
- Open the Google Admin interface
- Click on the Company profile icon
- Click on the Show more menu item to display additional options
- Click on the Custom URLs menu item
- Enter custom URLs for any (or all) of the following services:
- Gmail
- Calendar
- Drive
- Sites
- Groups for Business
Then, using those same values, set the following variables in this module's configuration:
custom_gmail_subdomain = "mail"
custom_calendar_subdomain = "calendar"
custom_drive_subdomain = "drive"
custom_sites_subdomain = "sites"
custom_groups_subdomain = "groups"
Note that these are example values; your actual values might differ.
As indicated in the interface, these services need to be subdomains of a(ny) domain as added in the Manage Domains interface.
Described in Help Center article Set up the "naked" domain address for your site, the required steps for redirecting your domain apex (e.g.: example.com
) are:
- Enter a value in the Google Admin interface for naked domain redirects. This could be a redirect from
example.com
towww.example.com
- Create an A Record for the domain by setting by setting the
redirect_naked_domain
variable to true - Should the set of Google-provided IP addresses differ from the set specified in the
apex_domain_redirect_records
variable (seevariables.tf
), you can override them by passing your own list to the module:
This module is maintained by the contributors listed on GitHub.
Development of this module was sponsored by Operate Happy.
Licensed under the Apache License, Version 2.0 (the "License").
You may obtain a copy of the License at apache.org/licenses/LICENSE-2.0.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" basis, without WARRANTIES or conditions of any kind, either express or implied.
See the License for the specific language governing permissions and limitations under the License.