2023-04-15 03:22:23 +08:00
|
|
|
package zonerecs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/StackExchange/dnscontrol/v3/models"
|
|
|
|
)
|
|
|
|
|
|
|
|
// CorrectZoneRecords calls both GetZoneRecords, does any
|
|
|
|
// post-processing, and then calls GetZoneRecordsCorrections. The
|
|
|
|
// name sucks because all the good names were taken.
|
|
|
|
func CorrectZoneRecords(driver models.DNSProvider, dc *models.DomainConfig) ([]*models.Correction, error) {
|
|
|
|
existingRecords, err := driver.GetZoneRecords(dc.Name)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// downcase
|
|
|
|
models.Downcase(existingRecords)
|
|
|
|
|
|
|
|
// Copy dc so that any corrections code that wants to
|
|
|
|
// modify the records may. For example, if the provider only
|
|
|
|
// supports certain TTL values, it will adjust the ones in
|
|
|
|
// dc.Records.
|
|
|
|
dc, err = dc.Copy()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// punycode
|
|
|
|
dc.Punycode()
|
|
|
|
// FIXME(tlim) It is a waste to PunyCode every iteration.
|
|
|
|
// This should be moved to where the JavaScript is processed.
|
|
|
|
|
|
|
|
return driver.GetZoneRecordsCorrections(dc, existingRecords)
|
|
|
|
}
|
2023-04-24 02:28:18 +08:00
|
|
|
|
|
|
|
// CountActionable returns the number of corrections that have
|
|
|
|
// actions. It is like `len(corrections)` but doesn't count any
|
|
|
|
// corrections that are purely informational. (i.e. `.F` is nil)
|
|
|
|
func CountActionable(corrections []*models.Correction) int {
|
|
|
|
count := 0
|
2023-05-02 06:40:10 +08:00
|
|
|
for i := range corrections {
|
2023-04-24 02:28:18 +08:00
|
|
|
if corrections[i].F != nil {
|
|
|
|
count++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return count
|
|
|
|
}
|