Skip to content

Commit

Permalink
privatelink: actuator reconcile functions to requeue on every change
Browse files Browse the repository at this point in the history
  • Loading branch information
jstuever committed Dec 16, 2024
1 parent 5fd4267 commit f5afd12
Show file tree
Hide file tree
Showing 4 changed files with 673 additions and 44 deletions.
104 changes: 104 additions & 0 deletions pkg/controller/privatelink/actuator/awsactuator/awshubactuator.go
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,7 @@ func (a *AWSHubActuator) Reconcile(cd *hivev1.ClusterDeployment, metadata *hivev
if err != nil {
return reconcile.Result{}, errors.Wrap(err, "failed to update condition on cluster deployment")
}
return reconcile.Result{Requeue: true}, nil
}

logger.Debug("reconciling Hosted Zone Records")
Expand All @@ -158,6 +159,7 @@ func (a *AWSHubActuator) Reconcile(cd *hivev1.ClusterDeployment, metadata *hivev
if err != nil {
return reconcile.Result{}, errors.Wrap(err, "failed to update condition on cluster deployment")
}
return reconcile.Result{Requeue: true}, nil
}

logger.Debug("reconciling Hosted Zone Associations")
Expand All @@ -177,6 +179,7 @@ func (a *AWSHubActuator) Reconcile(cd *hivev1.ClusterDeployment, metadata *hivev
if err != nil {
return reconcile.Result{}, errors.Wrap(err, "failed to update condition on cluster deployment")
}
return reconcile.Result{Requeue: true}, nil
}

return reconcile.Result{}, nil
Expand Down Expand Up @@ -374,11 +377,112 @@ func (a *AWSHubActuator) cleanupHostedZone(cd *hivev1.ClusterDeployment, metadat
}

func (a *AWSHubActuator) ReconcileHostedZoneRecords(cd *hivev1.ClusterDeployment, hostedZoneID string, dnsRecord *actuator.DnsRecord, apiDomain string, logger log.FieldLogger) (bool, error) {
hzLog := logger.WithField("hostedZoneID", hostedZoneID)
modified := false

rSet, err := a.recordSet(cd, apiDomain, dnsRecord)
if err != nil {
return false, errors.Wrap(err, "error generating DNS records")
}

recordsResp, err := a.awsClientHub.ListResourceRecordSets(&route53.ListResourceRecordSetsInput{
HostedZoneId: aws.String(hostedZoneID),
})
if err != nil {
return false, errors.Wrapf(err, "failed to list the hosted zone %s", hostedZoneID)
}

for _, record := range recordsResp.ResourceRecordSets {
if *record.Name == *rSet.Name {
if rSet.ResourceRecords != nil {
if aws.StringValue(record.Type) != aws.StringValue(rSet.Type) {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
"type": aws.StringValue(rSet.Type),
}).Debug("updating record type")
}
if aws.Int64Value(record.TTL) != aws.Int64Value(rSet.TTL) {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
"ttl": aws.Int64Value(rSet.TTL),
}).Debug("updating record ttl")
}

oldRecords := sets.NewString()
for _, record := range record.ResourceRecords {
oldRecords.Insert(aws.StringValue(record.Value))
}

desiredRecords := sets.NewString()
for _, record := range rSet.ResourceRecords {
desiredRecords.Insert(aws.StringValue(record.Value))
}

added := desiredRecords.Difference(oldRecords).List()
removed := oldRecords.Difference(desiredRecords).List()

if len(added) > 0 || len(removed) > 0 {
modified = true
hzLog.WithFields(log.Fields{
"added": added,
"removed": removed,
}).Debug("updating the addresses assigned to the dns record")
}

if !modified {
return false, nil
}
} else if rSet.AliasTarget != nil {
logger.Debugf("AliasTarget")
if record.AliasTarget == nil {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
}).Debug("updating the record to use alias target")
break
}

if aws.StringValue(record.Type) != aws.StringValue(rSet.Type) {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
"type": aws.StringValue(rSet.Type),
}).Debug("updating record type")
}

if aws.StringValue(record.AliasTarget.DNSName) != aws.StringValue(rSet.AliasTarget.DNSName) {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
"dnsName": aws.StringValue(rSet.AliasTarget.DNSName),
}).Debug("updating the aliasTarget dnsName")
}

if aws.StringValue(record.AliasTarget.HostedZoneId) != aws.StringValue(rSet.AliasTarget.HostedZoneId) {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
"hostedZoneId": aws.StringValue(rSet.AliasTarget.HostedZoneId),
}).Debug("updating the aliasTarget hostedZoneId")
}

if aws.BoolValue(record.AliasTarget.EvaluateTargetHealth) != aws.BoolValue(rSet.AliasTarget.EvaluateTargetHealth) {
modified = true
hzLog.WithFields(log.Fields{
"record": aws.StringValue(rSet.Name),
"evaluateTargetHealth": aws.BoolValue(rSet.AliasTarget.EvaluateTargetHealth),
}).Debug("updating the aliasTarget evaluateTargetHealth")
}

if !modified {
return false, nil
}
}
break
}
}
_, err = a.awsClientHub.ChangeResourceRecordSets(&route53.ChangeResourceRecordSetsInput{
HostedZoneId: aws.String(hostedZoneID),
ChangeBatch: &route53.ChangeBatch{
Expand Down
Loading

0 comments on commit f5afd12

Please sign in to comment.