2023-04-15 03:22:23 +08:00
|
|
|
package zonerecs
|
|
|
|
|
|
|
|
import (
|
2023-05-21 01:21:45 +08:00
|
|
|
"github.com/StackExchange/dnscontrol/v4/models"
|
2023-04-15 03:22:23 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// CorrectZoneRecords calls both GetZoneRecords, does any
|
|
|
|
// post-processing, and then calls GetZoneRecordsCorrections. The
|
|
|
|
// name sucks because all the good names were taken.
|
2023-05-16 22:42:08 +08:00
|
|
|
func CorrectZoneRecords(driver models.DNSProvider, dc *models.DomainConfig) ([]*models.Correction, []*models.Correction, error) {
|
2023-05-03 01:04:59 +08:00
|
|
|
|
|
|
|
existingRecords, err := driver.GetZoneRecords(dc.Name, dc.Metadata)
|
2023-04-15 03:22:23 +08:00
|
|
|
if err != nil {
|
2023-05-16 22:42:08 +08:00
|
|
|
return nil, nil, err
|
2023-04-15 03:22:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// downcase
|
|
|
|
models.Downcase(existingRecords)
|
2023-06-03 03:27:43 +08:00
|
|
|
models.Downcase(dc.Records)
|
|
|
|
models.CanonicalizeTargets(existingRecords, dc.Name)
|
|
|
|
models.CanonicalizeTargets(dc.Records, dc.Name)
|
2023-04-15 03:22:23 +08:00
|
|
|
|
|
|
|
// 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 {
|
2023-05-16 22:42:08 +08:00
|
|
|
return nil, nil, err
|
2023-04-15 03:22:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// punycode
|
|
|
|
dc.Punycode()
|
|
|
|
// FIXME(tlim) It is a waste to PunyCode every iteration.
|
|
|
|
// This should be moved to where the JavaScript is processed.
|
|
|
|
|
2023-05-16 22:42:08 +08:00
|
|
|
everything, err := driver.GetZoneRecordsCorrections(dc, existingRecords)
|
|
|
|
reports, corrections := splitReportsAndCorrections(everything)
|
|
|
|
return reports, corrections, err
|
2023-04-15 03:22:23 +08:00
|
|
|
}
|
2023-04-24 02:28:18 +08:00
|
|
|
|
2023-05-16 22:42:08 +08:00
|
|
|
func splitReportsAndCorrections(everything []*models.Correction) (reports, corrections []*models.Correction) {
|
|
|
|
for i := range everything {
|
|
|
|
if everything[i].F == nil {
|
|
|
|
reports = append(reports, everything[i])
|
|
|
|
} else {
|
|
|
|
corrections = append(corrections, everything[i])
|
2023-04-24 02:28:18 +08:00
|
|
|
}
|
|
|
|
}
|
2023-05-16 22:42:08 +08:00
|
|
|
return reports, corrections
|
2023-04-24 02:28:18 +08:00
|
|
|
}
|