mirror of
https://github.com/1f349/orchid.git
synced 2025-03-10 05:53:11 +00:00
Only update the agent last sync when all copies were successful
This commit is contained in:
parent
8407f21090
commit
56be812ff5
@ -159,6 +159,8 @@ func (a *Agent) syncSingleAgentCertPairs(startTime time.Time, agent syncAgent, r
|
||||
return fmt.Errorf("scp client: %w", err)
|
||||
}
|
||||
|
||||
hadError := false
|
||||
|
||||
for _, row := range rows {
|
||||
err := a.copySingleCertPair(&scpClient, row)
|
||||
if err != nil {
|
||||
@ -166,10 +168,13 @@ func (a *Agent) syncSingleAgentCertPairs(startTime time.Time, agent syncAgent, r
|
||||
// same agent from copying.
|
||||
err = fmt.Errorf("copySingleCertPair: %w", err)
|
||||
Logger.Warn("Agent certificate sync failed", "agent", row.AgentID, "cert", row.CertID, "not after", row.CertNotAfter, "err", err)
|
||||
hadError = true
|
||||
continue
|
||||
}
|
||||
}
|
||||
|
||||
// The agent last sync will only update if all scp copies were successful.
|
||||
if !hadError {
|
||||
// Update last sync to the time when the database request happened. This ensures
|
||||
// that certificates updated after the database request and before the agent
|
||||
// syncing are updated properly.
|
||||
@ -180,6 +185,7 @@ func (a *Agent) syncSingleAgentCertPairs(startTime time.Time, agent syncAgent, r
|
||||
if err != nil {
|
||||
return fmt.Errorf("error updating agent last sync: %v", err)
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user