2017-08-16 01:46:31 +08:00
|
|
|
---
|
|
|
|
name: TXT
|
|
|
|
parameters:
|
|
|
|
- name
|
|
|
|
- contents
|
|
|
|
- modifiers...
|
|
|
|
---
|
|
|
|
|
|
|
|
TXT adds an TXT record To a domain. The name should be the relative
|
|
|
|
label for the record. Use `@` for the domain apex.
|
|
|
|
|
2018-01-05 08:19:35 +08:00
|
|
|
The contents is either a single or multiple strings. To
|
2021-03-08 03:34:00 +08:00
|
|
|
specify multiple strings, specify them as an array.
|
2018-01-05 08:19:35 +08:00
|
|
|
|
|
|
|
Each string is a JavaScript string (quoted using single or double
|
2017-08-16 01:46:31 +08:00
|
|
|
quotes). The (somewhat complex) quoting rules of the DNS protocol
|
|
|
|
will be done for you.
|
|
|
|
|
2019-05-12 09:32:52 +08:00
|
|
|
Modifiers can be any number of [record modifiers](#record-modifiers) or json objects, which will be merged into the record's metadata.
|
2017-08-16 01:46:31 +08:00
|
|
|
|
2022-03-04 20:49:03 +08:00
|
|
|
{% capture example %}
|
2022-02-18 01:22:31 +08:00
|
|
|
```js
|
2020-11-22 22:16:56 +08:00
|
|
|
D("example.com", REGISTRAR, ....,
|
|
|
|
TXT('@', '598611146-3338560'),
|
|
|
|
TXT('listserve', 'google-site-verification=12345'),
|
|
|
|
TXT('multiple', ['one', 'two', 'three']), // Multiple strings
|
|
|
|
TXT('quoted', 'any "quotes" and escapes? ugh; no worries!'),
|
|
|
|
TXT('_domainkey', 't=y; o=-;'), // Escapes are done for you automatically.
|
2021-03-08 03:34:00 +08:00
|
|
|
TXT('long', 'X'.repeat(300)) // Long strings are split automatically.
|
2020-11-22 22:16:56 +08:00
|
|
|
);
|
2022-02-18 01:22:31 +08:00
|
|
|
```
|
2022-03-04 20:49:03 +08:00
|
|
|
{% endcapture %}
|
2022-02-18 01:22:31 +08:00
|
|
|
|
2022-03-04 20:49:03 +08:00
|
|
|
{% include example.html content=example %}
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
NOTE: In the past, long strings had to be annotated with the keyword
|
|
|
|
`AUTOSPLIT`. This is no longer required. The keyword is now a no-op.
|
|
|
|
|
2021-03-08 03:50:42 +08:00
|
|
|
### Long strings
|
2021-03-08 03:34:00 +08:00
|
|
|
|
|
|
|
Strings that are longer than 255 octets (bytes) will be quietly
|
|
|
|
split into 255-octets chunks or the provider may report an error
|
|
|
|
if it does not handle multiple strings.
|
|
|
|
|
|
|
|
|
2021-03-08 03:50:42 +08:00
|
|
|
### TXT record edge cases.
|
2021-03-08 03:34:00 +08:00
|
|
|
|
|
|
|
Most providers do not support the full possibilities of what a TXT
|
|
|
|
record can store. DNSControl can not handle all the edge cases
|
|
|
|
and incompatibles that providers have introduced. Instead, it
|
|
|
|
stores the string(s) that you provide and passes them to the provider
|
|
|
|
verbatim. The provider may opt to accept the data, fix it, or
|
|
|
|
reject it. This happens early in the processing, long before
|
|
|
|
the DNSControl talks to the provider's API.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
The RFCs specify that a TXT record stores one or more strings,
|
|
|
|
each is up to 255 octets (bytes) long. We call these individual
|
|
|
|
strings *chunks*. Each chunk may be zero to 255 octets long.
|
|
|
|
There is no limit to the number of chunks in a TXT record,
|
|
|
|
other than IP packet length restrictions. The contents of each chunk
|
|
|
|
may be octets of value from 0x00 to 0xff.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
In reality DNS Service Providers (DSPs) place many restrictions on TXT
|
|
|
|
records.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
Some DSPs only support a single string of 255 octets or fewer.
|
|
|
|
Multiple strings, or any one string being longer than 255 octets will
|
|
|
|
result in an error. One provider limits the string to 254 octets,
|
|
|
|
which makes me think they're code has an off-by-one error.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
Some DSPs only support one string, but it may be of any length.
|
|
|
|
Behind the scenes the provider splits it into 255-octet chunks
|
|
|
|
(except the last one, of course).
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
Some DSPs support multiple strings, but API requests must be 512-bytes
|
|
|
|
or fewer, and with quoting, escaping, and other encoding mishegoss
|
|
|
|
you can't be sure what will be permitted until you actually try it.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
Regardless of the quantity and length of strings, some providers ban
|
|
|
|
double quotes, back-ticks, or other chars.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:50:42 +08:00
|
|
|
### Testing the support of a provider
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:50:42 +08:00
|
|
|
#### How can you tell if a provider will support a particular `TXT()` record?
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
Include the `TXT()` record in a `D()` as usual, along
|
|
|
|
with the `DnsProvider()` for that provider. Run `dnscontrol check` to
|
|
|
|
see if any errors are produced. The check command does not talk to
|
|
|
|
the provider's API, thus permitting you to do this without having an
|
|
|
|
account at that provider.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:50:42 +08:00
|
|
|
#### What if the provider rejects a string that is supported?
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
Suppose I can create the TXT record using the DSP's web portal but
|
|
|
|
DNSControl rejects the string?
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
It is possible that the provider code in DNSControl rejects strings
|
|
|
|
that the DSP accepts. This is because the test is done in code, not
|
|
|
|
by querying the provider's API. It is possible that the code was
|
|
|
|
written to work around a bug (such as rejecting a string with a
|
|
|
|
back-tick) but now that bug has been fixed.
|
2020-11-22 22:16:56 +08:00
|
|
|
|
2021-03-08 03:34:00 +08:00
|
|
|
All such checks are in `providers/${providername}/auditrecords.go`.
|
|
|
|
You can try removing the check that you feel is in error and see if
|
|
|
|
the provider's API accepts the record. You can do this by running the
|
|
|
|
integration tests, or by simply adding that record to an existing
|
|
|
|
`dnsconfig.js` and seeing if `dnscontrol push` is able to push that
|
|
|
|
record into production. (Be careful if you are testing this on a
|
|
|
|
domain used in production.)
|