dnscontrol/integrationTest/providers.json

281 lines
7.1 KiB
JSON
Raw Normal View History

{
"AKAMAIEDGEDNS": {
"TYPE": "AKAMAIEDGEDNS",
"access_token": "$AED_ACCESS_TOKEN",
"client_secret": "$AED_CLIENT_SECRET",
"client_token": "$AED_CLIENT_TOKEN",
"contract_id": "$AED_CONTRACT_ID",
"domain": "$AED_DOMAIN",
"group_id": "$AED_GROUP_ID",
"host": "$AED_HOST"
},
"AUTODNS": {
"TYPE": "AUTODNS",
"context": "$AUTODNS_CONTEXT",
"domain": "$AUTODNS_DOMAIN",
"password": "$AUTODNS_PASSWORD",
"username": "$AUTODNS_USERNAME"
},
"AXFRDDNS": {
"TYPE": "AXFRDDNS",
"domain": "$AXFRDDNS_DOMAIN",
"master": "$AXFRDDNS_MASTER",
"nameservers": "ns.example.com",
"transfer-key": "$AXFRDDNS_TRANSFER_KEY",
"update-key": "$AXFRDDNS_UPDATE_KEY",
"buggy-cname": "$AXFRDDNS_BUGGY_CNAME"
},
"AZURE_DNS": {
"ClientID": "$AZURE_DNS_CLIENT_ID",
"ClientSecret": "$AZURE_DNS_CLIENT_SECRET",
"ResourceGroup": "$AZURE_DNS_RESOURCE_GROUP",
"SubscriptionID": "$AZURE_DNS_SUBSCRIPTION_ID",
"TYPE": "AZURE_DNS",
"TenantID": "$AZURE_DNS_TENANT_ID",
"domain": "$AZURE_DNS_DOMAIN"
},
"BIND": {
"TYPE": "BIND",
"domain": "$BIND_DOMAIN"
},
"CLOUDFLAREAPI": {
"TYPE": "CLOUDFLAREAPI",
"accountid": "$CLOUDFLAREAPI_ACCOUNTID",
"apikey": "$CLOUDFLAREAPI_KEY",
"apitoken": "$CLOUDFLAREAPI_TOKEN",
"apiuser": "$CLOUDFLAREAPI_USER",
"domain": "$CLOUDFLAREAPI_DOMAIN"
},
"CLOUDFLAREAPI_OLD": {
"TYPE": "CLOUDFLAREAPI_OLD",
"apikey": "$CF_KEY",
"apiuser": "$CF_USER",
"domain": "$CF_DOMAIN",
"knownFailures": "54"
},
"CLOUDNS": {
"TYPE": "CLOUDNS",
"auth-id": "$CLOUDNS_AUTH_ID",
"auth-password": "$CLOUDNS_AUTH_PASSWORD",
"domain": "$CLOUDNS_DOMAIN",
"sub-auth-id": "$CLOUDNS_SUB_AUTH_ID"
},
"CSCGLOBAL": {
"TYPE": "CSCGLOBAL",
"api-key": "$CSCGLOBAL_APIKEY",
"domain": "$CSCGLOBAL_DOMAIN",
"notification_emails": "$CSCGLOBAL_NOTIFICATION",
"user-token": "$CSCGLOBAL_USERTOKEN"
},
"DESEC": {
"TYPE": "DESEC",
"auth-token": "$DESEC_TOKEN",
"domain": "$DESEC_DOMAIN"
},
"DIGITALOCEAN": {
"TYPE": "DIGITALOCEAN",
"domain": "$DIGITALOCEAN_DOMAIN",
"token": "$DIGITALOCEAN_TOKEN"
},
"DNSIMPLE": {
"TYPE": "DNSIMPLE",
"baseurl": "https://api.sandbox.dnsimple.com",
"domain": "$DNSIMPLE_DOMAIN",
"token": "$DNSIMPLE_TOKEN"
},
"DNSMADEEASY": {
"TYPE": "DNSMADEEASY",
"api_key": "$DNSMADEEASY_API_KEY",
"domain": "$DNSMADEEASY_DOMAIN",
"sandbox": "true",
"secret_key": "$DNSMADEEASY_SECRET_KEY"
},
"DOMAINNAMESHOP": {
"TYPE": "DOMAINNAMESHOP",
"domain": "$DOMAINNAMESHOP_DOMAIN",
"secret": "$DOMAINNAMESHOP_SECRET",
"token": "$DOMAINNAMESHOP_TOKEN"
},
"EXOSCALE": {
"TYPE": "EXOSCALE",
"apikey": "$EXOSCALE_API_KEY",
"apizone": "ch-gva-2",
"dns-endpoint": "https://api.exoscale.com/v2",
"domain": "$EXOSCALE_DOMAIN",
"secretkey": "$EXOSCALE_SECRET_KEY"
},
"GANDI_V5": {
"TYPE": "GANDI_V5",
"apikey": "$GANDI_V5_APIKEY",
"domain": "$GANDI_V5_DOMAIN"
},
"GCLOUD": {
"TYPE": "GCLOUD",
"client_email": "$GCLOUD_EMAIL",
"domain": "$GCLOUD_DOMAIN",
"private_key": "$GCLOUD_PRIVATEKEY",
"project_id": "$GCLOUD_PROJECT",
"type": "$GCLOUD_TYPE"
},
2022-11-16 01:40:08 +08:00
"GCORE": {
"TYPE": "GCORE",
2022-11-16 01:40:08 +08:00
"api-key": "$GCORE_API_KEY",
"domain": "$GCORE_DOMAIN"
},
"HEDNS": {
"TYPE": "HEDNS",
"domain": "$HEDNS_DOMAIN",
"password": "$HEDNS_PASSWORD",
"session-file-path": ".",
"totp-key": "$HEDNS_TOTP_SECRET",
"username": "$HEDNS_USERNAME"
},
NEW PROVIDER: HETZNER DNS Console (#904) * HETZNER: implement the provider for Hetzner DNS Console Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: apply review feedback - add domain into error messages - insert sub-strings using `%q` - insert sub-errors using `%w` - change api.getZone() signature to return a (potentially `nil`) Zone pointer instead of a (potentially empty) Zone value - sort imports and confirm with `$ goimports -w providers/hetzner/` - use exact 'api_key' term in error message of settings validation - add blank line for logic separation - drop internal record id from correction messages Co-Authored-By: Tom Limoncelli <tlimoncelli@stackoverflow.com> Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: add request rate-limiting handling There are a limited number of data-points on how their rate-limiting works at this time. I deduce from my account to others and use a fixed/ constant backoff of 1s as the initial delay. Thereafter exponential increase with factor 2 (not needed at this time). Hetzner has not made any official statements on rate-limiting, so this is guesswork only. Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: address golint complaints - baseUrl -> baseURL - mark Record as private -> record - mark Zone as private -> zone - mark RequestRateLimiter as private -> requestRateLimiter - capitalize Id fields as ID - keep delay logic on same level, move return out of branch Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: rate_limited: init the response timestamp on requestRateLimiter Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: requestRateLimiter: align local variable with struct name Signed-off-by: Jakob Ackermann <das7pad@outlook.com> Co-authored-by: Tom Limoncelli <tlimoncelli@stackoverflow.com>
2020-10-22 21:44:21 +08:00
"HETZNER": {
"TYPE": "HETZNER",
NEW PROVIDER: HETZNER DNS Console (#904) * HETZNER: implement the provider for Hetzner DNS Console Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: apply review feedback - add domain into error messages - insert sub-strings using `%q` - insert sub-errors using `%w` - change api.getZone() signature to return a (potentially `nil`) Zone pointer instead of a (potentially empty) Zone value - sort imports and confirm with `$ goimports -w providers/hetzner/` - use exact 'api_key' term in error message of settings validation - add blank line for logic separation - drop internal record id from correction messages Co-Authored-By: Tom Limoncelli <tlimoncelli@stackoverflow.com> Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: add request rate-limiting handling There are a limited number of data-points on how their rate-limiting works at this time. I deduce from my account to others and use a fixed/ constant backoff of 1s as the initial delay. Thereafter exponential increase with factor 2 (not needed at this time). Hetzner has not made any official statements on rate-limiting, so this is guesswork only. Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: address golint complaints - baseUrl -> baseURL - mark Record as private -> record - mark Zone as private -> zone - mark RequestRateLimiter as private -> requestRateLimiter - capitalize Id fields as ID - keep delay logic on same level, move return out of branch Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: rate_limited: init the response timestamp on requestRateLimiter Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: requestRateLimiter: align local variable with struct name Signed-off-by: Jakob Ackermann <das7pad@outlook.com> Co-authored-by: Tom Limoncelli <tlimoncelli@stackoverflow.com>
2020-10-22 21:44:21 +08:00
"api_key": "$HETZNER_API_KEY",
"domain": "$HETZNER_DOMAIN"
NEW PROVIDER: HETZNER DNS Console (#904) * HETZNER: implement the provider for Hetzner DNS Console Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: apply review feedback - add domain into error messages - insert sub-strings using `%q` - insert sub-errors using `%w` - change api.getZone() signature to return a (potentially `nil`) Zone pointer instead of a (potentially empty) Zone value - sort imports and confirm with `$ goimports -w providers/hetzner/` - use exact 'api_key' term in error message of settings validation - add blank line for logic separation - drop internal record id from correction messages Co-Authored-By: Tom Limoncelli <tlimoncelli@stackoverflow.com> Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: add request rate-limiting handling There are a limited number of data-points on how their rate-limiting works at this time. I deduce from my account to others and use a fixed/ constant backoff of 1s as the initial delay. Thereafter exponential increase with factor 2 (not needed at this time). Hetzner has not made any official statements on rate-limiting, so this is guesswork only. Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: address golint complaints - baseUrl -> baseURL - mark Record as private -> record - mark Zone as private -> zone - mark RequestRateLimiter as private -> requestRateLimiter - capitalize Id fields as ID - keep delay logic on same level, move return out of branch Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: rate_limited: init the response timestamp on requestRateLimiter Signed-off-by: Jakob Ackermann <das7pad@outlook.com> * HETZNER: requestRateLimiter: align local variable with struct name Signed-off-by: Jakob Ackermann <das7pad@outlook.com> Co-authored-by: Tom Limoncelli <tlimoncelli@stackoverflow.com>
2020-10-22 21:44:21 +08:00
},
2018-08-30 20:54:42 +08:00
"HEXONET": {
"TYPE": "HEXONET",
"apientity": "$HEXONET_ENTITY",
2018-08-30 20:54:42 +08:00
"apilogin": "$HEXONET_UID",
"apipassword": "$HEXONET_PW",
"debugmode": "$HEXONET_DEBUGMODE",
"domain": "$HEXONET_DOMAIN",
"ipaddress": "$HEXONET_IP"
2018-08-30 20:54:42 +08:00
},
"HOSTINGDE": {
"TYPE": "HOSTINGDE",
"authToken": "$HOSTINGDE_AUTHTOKEN",
"domain": "$HOSTINGDE_DOMAIN"
},
"INWX": {
"TYPE": "INWX",
"domain": "$INWX_DOMAIN",
"password": "$INWX_PASSWORD",
"sandbox": "1",
"username": "$INWX_USER"
},
2017-11-15 12:08:06 +08:00
"LINODE": {
"TYPE": "LINODE",
2017-11-15 12:08:06 +08:00
"domain": "$LINODE_DOMAIN",
"token": "$LINODE_TOKEN"
2017-11-15 12:08:06 +08:00
},
"LOOPIA": {
"TYPE": "LOOPIA",
"domain": "$LOOPIA_DOMAIN",
"password": "$LOOPIA_PASSWORD",
"username": "$LOOPIA_USERNAME"
},
2023-03-09 23:15:59 +08:00
"LUADNS": {
"TYPE": "LUADNS",
"apikey": "$LUADNS_APIKEY",
2023-03-09 23:15:59 +08:00
"domain": "$LUADNS_DOMAIN",
"email": "$LUADNS_EMAIL"
2023-03-09 23:15:59 +08:00
},
"MSDNS": {
"TYPE": "MSDNS",
"dnsserver": "$MSDNS_DNSSERVER",
"domain": "$MSDNS_DOMAIN",
"pssession": "$MSDNS_PSSESSION"
},
"MYTHICBEASTS": {
"TYPE": "MYTHICBEASTS",
"keyID": "$MYTHICBEASTS_KEYID",
"secret": "$MYTHICBEASTS_SECRET",
"domain": "$MYTHICBEASTS_DOMAIN"
},
"NAMECHEAP": {
"BaseURL": "$NAMECHEAP_BASEURL",
"TYPE": "NAMECHEAP",
"apikey": "$NAMECHEAP_KEY",
"apiuser": "$NAMECHEAP_USER",
"domain": "$NAMECHEAP_DOMAIN"
},
2017-07-13 22:39:55 +08:00
"NAMEDOTCOM": {
"TYPE": "NAMEDOTCOM",
2017-07-13 22:39:55 +08:00
"apikey": "$NAMEDOTCOM_KEY",
"apiurl": "$NAMEDOTCOM_URL",
"apiuser": "$NAMEDOTCOM_USER",
"domain": "$NAMEDOTCOM_DOMAIN"
2017-07-13 22:39:55 +08:00
},
"NETCUP": {
"TYPE": "NETCUP",
"api-key": "$NETCUP_KEY",
"api-password": "$NETCUP_PASSWORD",
"customer-number": "$NETCUP_CUSTOMER_NUMBER",
"domain": "$NETCUP_DOMAIN"
},
"NETLIFY": {
"TYPE": "NETLIFY",
"domain": "$NETLIFY_DOMAIN",
"slug": "$NETLIFY_ACCOUNT_SLUG",
"token": "$NETLIFY_TOKEN"
},
"NS1": {
"TYPE": "NS1",
"api_token": "$NS1_TOKEN",
"domain": "$NS1_DOMAIN"
},
"ORACLE": {
"TYPE": "ORACLE",
"compartment": "$ORACLE_COMPARTMENT",
"domain": "$ORACLE_DOMAIN",
"fingerprint": "$ORACLE_FINGERPRINT",
"private_key": "$ORACLE_PRIVATE_KEY",
"region": "$ORACLE_REGION",
"tenancy_ocid": "$ORACLE_TENANCY_OCID",
"user_ocid": "$ORACLE_USER_OCID"
},
"OVH": {
"TYPE": "OVH",
"app-key": "$OVH_APP_KEY",
"app-secret-key": "$OVH_APP_SECRET_KEY",
"consumer-key": "$OVH_CONSUMER_KEY",
"domain": "$OVH_DOMAIN",
"endpoint": "$OVH_ENDPOINT"
},
"PACKETFRAME": {
"TYPE": "PACKETFRAME",
"domain": "$PACKETFRAME_DOMAIN",
"token": "$PACKETFRAME_TOKEN"
},
"PORKBUN": {
"TYPE": "PORKBUN",
"api_key": "$PORKBUN_API_KEY",
"domain": "$PORKBUN_DOMAIN",
"secret_key": "$PORKBUN_SECRET_KEY"
},
"POWERDNS": {
"TYPE": "POWERDNS",
"apiKey": "$POWERDNS_APIKEY",
"apiUrl": "$POWERDNS_APIURL",
"domain": "$POWERDNS_DOMAIN",
"serverName": "$POWERDNS_SERVERNAME"
},
"ROUTE53": {
"KeyId": "$ROUTE53_KEY_ID",
"SecretKey": "$ROUTE53_KEY",
"TYPE": "ROUTE53",
"domain": "$ROUTE53_DOMAIN"
},
"SOFTLAYER": {
"TYPE": "SOFTLAYER",
"api_key": "$SL_API_KEY",
"domain": "$SL_DOMAIN",
"username": "$SL_USERNAME"
},
"TRANSIP": {
"AccessToken": "$TRANSIP_ACCESS_TOKEN",
"AccountName": "$TRANSIP_ACCOUNT_NAME",
"PrivateKey": "$TRANSIP_PRIVATE_KEY",
"TYPE": "TRANSIP",
"domain": "$TRANSIP_DOMAIN"
},
"VULTR": {
"TYPE": "VULTR",
"domain": "$VULTR_DOMAIN",
"token": "$VULTR_TOKEN"
}
2017-09-30 03:49:39 +08:00
}