mirror of
https://github.com/StackExchange/dnscontrol.git
synced 2025-09-04 20:24:23 +08:00
CLOUDFLARE: get-zones now outputs "orange cloud" status (#952)
* CLOUDFLARE: get-zones now outputs "orange cloud" status
This commit is contained in:
parent
6fe4ca6996
commit
d6b191bae4
4 changed files with 39 additions and 6 deletions
|
@ -50,6 +50,7 @@ The columns in --format=tsv are:
|
|||
TTL
|
||||
Record Type (A, AAAA, CNAME, etc.)
|
||||
Target and arguments (quoted like in a zonefile)
|
||||
Either empty or a comma-separated list of properties like "cloudflare_proxy=true"
|
||||
|
||||
The --ttl flag only applies to zone/js/djs formats.
|
||||
|
||||
|
@ -93,7 +94,7 @@ ARGUMENTS:
|
|||
provider: The name of the provider (second parameter to NewDnsProvider() in dnsconfig.js)
|
||||
|
||||
EXAMPLES:
|
||||
dnscontrol get-zones myr53 ROUTE53
|
||||
dnscontrol get-zones myr53 ROUTE53
|
||||
dnscontrol get-zones --out=/dev/null myr53 ROUTE53`,
|
||||
}
|
||||
}())
|
||||
|
@ -229,8 +230,16 @@ func GetZone(args GetZoneArgs) error {
|
|||
|
||||
case "tsv":
|
||||
for _, rec := range recs {
|
||||
fmt.Fprintf(w, "%s\t%s\t%d\tIN\t%s\t%s\n",
|
||||
rec.NameFQDN, rec.Name, rec.TTL, rec.Type, rec.GetTargetCombined())
|
||||
|
||||
cfproxy := ""
|
||||
if cp, ok := rec.Metadata["cloudflare_proxy"]; ok {
|
||||
if cp == "true" {
|
||||
cfproxy = "\tcloudflare_proxy=true"
|
||||
}
|
||||
}
|
||||
|
||||
fmt.Fprintf(w, "%s\t%s\t%d\tIN\t%s\t%s%s\n",
|
||||
rec.NameFQDN, rec.Name, rec.TTL, rec.Type, rec.GetTargetCombined(), cfproxy)
|
||||
}
|
||||
|
||||
default:
|
||||
|
@ -251,6 +260,13 @@ func formatDsl(zonename string, rec *models.RecordConfig, defaultTTL uint32) str
|
|||
ttlop = fmt.Sprintf(", TTL(%d)", ttl)
|
||||
}
|
||||
|
||||
cfproxy := ""
|
||||
if cp, ok := rec.Metadata["cloudflare_proxy"]; ok {
|
||||
if cp == "true" {
|
||||
cfproxy = ", CF_PROXY_ON"
|
||||
}
|
||||
}
|
||||
|
||||
switch rec.Type { // #rtype_variations
|
||||
case "CAA":
|
||||
return makeCaa(rec, ttlop)
|
||||
|
@ -286,7 +302,7 @@ func formatDsl(zonename string, rec *models.RecordConfig, defaultTTL uint32) str
|
|||
target = "'" + target + "'"
|
||||
}
|
||||
|
||||
return fmt.Sprintf("%s('%s', %s%s)", rec.Type, rec.Name, target, ttlop)
|
||||
return fmt.Sprintf("%s('%s', %s%s%s)", rec.Type, rec.Name, target, cfproxy, ttlop)
|
||||
}
|
||||
|
||||
func makeCaa(rec *models.RecordConfig, ttlop string) string {
|
||||
|
|
|
@ -82,6 +82,7 @@ The columns in `--format=tsv` are:
|
|||
TTL
|
||||
Record Type (A, AAAA, CNAME, etc.)
|
||||
Target and arguments (quoted like in a zonefile)
|
||||
Either empty or a comma-separated list of properties like "cloudflare_proxy=true"
|
||||
|
||||
The `--ttl` flag only applies to zone/js/djs formats.
|
||||
|
||||
|
|
|
@ -134,8 +134,16 @@ func (z *ZoneGenData) generateZoneFileHelper(w io.Writer) error {
|
|||
// the remaining line
|
||||
target := rr.GetTargetCombined()
|
||||
|
||||
fmt.Fprintf(w, "%s%s\n",
|
||||
prefix, formatLine([]int{10, 5, 2, 5, 0}, []string{name, ttl, "IN", typeStr, target}))
|
||||
// comment
|
||||
comment := ""
|
||||
if cp, ok := rr.Metadata["cloudflare_proxy"]; ok {
|
||||
if cp == "true" {
|
||||
comment = " ; CF_PROXY_ON"
|
||||
}
|
||||
}
|
||||
|
||||
fmt.Fprintf(w, "%s%s%s\n",
|
||||
prefix, formatLine([]int{10, 5, 2, 5, 0}, []string{name, ttl, "IN", typeStr, target}), comment)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
|
@ -121,6 +121,14 @@ func (c *cloudflareProvider) GetZoneRecords(domain string) (models.Records, erro
|
|||
if rec.TTL == 1 {
|
||||
rec.TTL = 0
|
||||
}
|
||||
// Store the proxy status ("orange cloud") for use by get-zones:
|
||||
m := getProxyMetadata(rec)
|
||||
if p, ok := m["proxy"]; ok {
|
||||
if rec.Metadata == nil {
|
||||
rec.Metadata = map[string]string{}
|
||||
}
|
||||
rec.Metadata["cloudflare_proxy"] = p
|
||||
}
|
||||
}
|
||||
return records, nil
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue