2020-01-21 03:13:32 +08:00
`GANDI_V5` uses the v5 API and can act as a registrar provider
2022-05-09 02:41:33 +08:00
or a DNS provider. It is only able to work with domains
migrated to the new LiveDNS API, which should be all domains.
API keys are assigned to particular users. Go to User Settings,
"Manage the user account and security settings", the "Security"
tab, then regenerate the "Production API key".
2020-01-21 03:13:32 +08:00
* API Documentation: https://api.gandi.net/docs
* API Endpoint: https://api.gandi.net/
## Configuration
2022-05-09 02:41:33 +08:00
To use this provider, add an entry to `creds.json` with `TYPE` set to `GANDI_V5`
along your Gandi.net API key. The [sharing_id ](https://api.gandi.net/docs/reference/ ) is optional.
2020-01-21 03:13:32 +08:00
2020-03-01 22:36:12 +08:00
The `sharing_id` selects between different organizations which your account is
a member of; to manage domains in multiple organizations, you can use multiple
2022-06-18 00:11:44 +08:00
`creds.json` entries.
How to find the `sharing_id` : The sharing ID is the second hex string found in
the URL on the portal. Log into the Gandi website, click on "organizations" in
the leftnav, and click on the organization name. The URL will be something
like:
2022-11-01 06:09:43 +08:00
```text
2022-06-18 00:11:44 +08:00
https://admin.gandi.net/organizations/[not this hex string]/PLTS/[sharing id]/profile
```
2020-03-01 22:36:12 +08:00
2022-05-09 02:41:33 +08:00
Example:
2023-03-03 05:17:27 +08:00
{% code title="creds.json" %}
2022-02-18 01:22:31 +08:00
```json
2020-01-21 03:13:32 +08:00
{
2020-03-01 22:36:12 +08:00
"gandi": {
2022-05-09 02:41:33 +08:00
"TYPE": "GANDI_V5",
2020-01-21 03:13:32 +08:00
"apikey": "your-gandi-key",
"sharing_id": "your-sharing_id"
}
}
2022-02-18 01:22:31 +08:00
```
2023-03-03 05:17:27 +08:00
{% endcode %}
2020-01-21 03:13:32 +08:00
## Metadata
This provider does not recognize any special metadata fields unique to Gandi.
2020-03-01 22:36:12 +08:00
## Limitations
This provider does not support using `ALIAS` in combination with DNSSEC,
whether `AUTODNSSEC` or otherwise.
This provider only supports `ALIAS` on the `"@"` zone apex, not on any other
names.
2020-01-21 03:13:32 +08:00
## Usage
2023-03-11 21:42:01 +08:00
An example configuration:
2020-01-21 03:13:32 +08:00
2023-03-11 21:42:01 +08:00
{% code title="dnsconfig.js" %}
2023-01-20 20:56:20 +08:00
```javascript
2022-05-09 02:41:33 +08:00
var REG_GANDI = NewRegistrar("gandi");
var DSP_GANDI = NewDnsProvider("gandi");
2020-01-21 03:13:32 +08:00
2022-05-09 02:41:33 +08:00
D("example.tld", REG_GANDI, DnsProvider(DSP_GANDI),
A("test", "1.2.3.4")
2020-01-21 03:13:32 +08:00
);
2022-02-18 01:22:31 +08:00
```
2023-03-11 21:42:01 +08:00
{% endcode %}
2020-01-21 03:13:32 +08:00
2020-03-01 22:36:12 +08:00
If you are converting from the old "GANDI" provider,
simply change "GANDI" to "GANDI_V5" in `dnsconfig.js` .
Be sure to test with `dnscontrol preview` before running `dnscontrol push` .
2020-01-21 03:13:32 +08:00
## New domains
If a domain does not exist in your Gandi account, DNSControl will *not* automatically add it with the `create-domains` command. You'll need to do that via the web UI manually.
## Common errors
2022-06-18 00:11:44 +08:00
#### Error getting corrections
2020-01-21 03:13:32 +08:00
2022-02-18 01:22:31 +08:00
```text
2020-01-21 03:13:32 +08:00
Error getting corrections: 401: The server could not verify that you authorized to access the document you requested. Either you supplied the wrong credentials (e.g., bad api key), or your access token has expired
```
2022-06-18 00:11:44 +08:00
This is the error you'll see if your `apikey` in `creds.json` is wrong or invalid.
#### Domain does not exist in profile
2022-11-01 06:09:43 +08:00
```text
2022-06-18 00:11:44 +08:00
WARNING: Domain 'example.com' does not exist in the 'secname' profile and will be added automatically.
```
This error is caused by the internal `ListZones()` functions returning no domain names. This is usually because your `creds.json` information is pointing at an empty organization or no organization. The solution is to set
`sharing_id` in `creds.json` .
#### get-zones "nameonly" returns nothing
If a `dnscontrol get-zones --format=nameonly CredId - all` returns nothing,
this is usually because your `creds.json` information is pointing at an empty
organization or no organization. The solution is to set `sharing_id` in
`creds.json` .