Skip to content

Commit

Permalink
Prevent double-ZTP when RTC comes online
Browse files Browse the repository at this point in the history
  • Loading branch information
PaulZC committed Jul 9, 2024
1 parent 268ed4c commit 09a4b45
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 26 deletions.
5 changes: 3 additions & 2 deletions Firmware/RTK_Everywhere/MQTT_Client.ino
Original file line number Diff line number Diff line change
Expand Up @@ -457,8 +457,9 @@ void mqttClientReceiveMessage(int messageSize)

settings.pointPerfectNextKeyDuration = (1000LL * 60 * 60 * 24 * 28) - 1; // Assume next key duration is 28 days

settings.lastKeyAttempt = rtc.getEpoch(); // Mark it

if (online.rtc)
settings.lastKeyAttempt = rtc.getEpoch(); // Mark it - but only if RTC is online

recordSystemSettings(); // Record these settings to unit

if (settings.debugCorrections == true)
Expand Down
47 changes: 23 additions & 24 deletions Firmware/RTK_Everywhere/menuPP.ino
Original file line number Diff line number Diff line change
Expand Up @@ -1209,8 +1209,8 @@ void provisioningSetState(uint8_t newState)
}
}

unsigned long provisioningStartTime;
const unsigned long provisioningTimeout = 120000;
unsigned long provisioningStartTime_millis;
const unsigned long provisioningTimeout_ms = 120000;

void updateProvisioning()
{
Expand All @@ -1229,14 +1229,15 @@ void updateProvisioning()
default:
case PROVISIONING_OFF:
{
provisioningStartTime = millis(); // Record the start time so we can timeout
provisioningStartTime_millis = millis(); // Record the start time so we can timeout
provisioningSetState(PROVISIONING_WAIT_RTC);
}
break;
case PROVISIONING_WAIT_RTC:
{
if ((online.rtc)
|| (millis() > (provisioningStartTime + provisioningTimeout))
// If RTC is not online after provisioningTimeout_ms, try to provision anyway
|| (millis() > (provisioningStartTime_millis + provisioningTimeout_ms))
|| (settings.requestKeyUpdate))
provisioningSetState(PROVISIONING_NOT_STARTED);
}
Expand All @@ -1258,6 +1259,7 @@ void updateProvisioning()
systemPrintln("Invalid certificates or keys. Starting provisioning");
provisioningSetState(PROVISIONING_CHECK_NETWORK);
}
// If RTC is not online, we have to skip PROVISIONING_CHECK_ATTEMPT
else if (!online.rtc)
{
if (settings.debugPpCertificate)
Expand All @@ -1266,21 +1268,21 @@ void updateProvisioning()
}
else
{
// Determine days until next key expires
// RTC is online. Determine days until next key expires
int daysRemaining =
daysFromEpoch(settings.pointPerfectNextKeyStart + settings.pointPerfectNextKeyDuration + 1);

if (settings.debugPpCertificate)
systemPrintf("Days until keys expire: %d\r\n", daysRemaining);

if (daysRemaining > 28)
provisioningSetState(PROVISIONING_KEYS_REMAINING);
provisioningSetState(PROVISIONING_KEYS_REMAINING); // Don't need new keys
else
provisioningSetState(PROVISIONING_CHECK_ATTEMPT);
provisioningSetState(PROVISIONING_CHECK_ATTEMPT); // Do need new keys
}
}
break;
case PROVISIONING_CHECK_ATTEMPT:
case PROVISIONING_CHECK_ATTEMPT: // Requires RTC to be online
{
// When did we last try to get keys? Attempt every 24 hours - or always for DEVELOPER
//if (rtc.getEpoch() - settings.lastKeyAttempt > ( ENABLE_DEVELOPER ? 0 : (60 * 60 * 24)))
Expand Down Expand Up @@ -1317,22 +1319,22 @@ void updateProvisioning()
recordSystemSettings(); // Record these settings to unit
ztpResponse = ZTP_NOT_STARTED; // HTTP_Client will update this
httpClientModeNeeded = true; // This will start the HTTP_Client
provisioningStartTime = millis(); // Record the start time so we can timeout
provisioningStartTime_millis = millis(); // Record the start time so we can timeout
paintGettingKeys();
provisioningSetState(PROVISIONING_STARTED);
}
case PROVISIONING_STARTED:
{
if (millis() > (provisioningStartTime + provisioningTimeout))
if (millis() > (provisioningStartTime_millis + provisioningTimeout_ms))
{
httpClientModeNeeded = false; // Tell HTTP_Client to give up. (But it probably already has...)
paintKeyUpdateFail(5000);
provisioningSetState(PROVISIONING_KEYS_REMAINING);
}
else if (ztpResponse == ZTP_SUCCESS)
{
httpClientModeNeeded = false; // Tell HTTP_Client to give up. (But it probably already has...)
recordSystemSettings();
httpClientModeNeeded = false; // Tell HTTP_Client to give up
recordSystemSettings(); // Make sure the new cert and keys are recorded
provisioningSetState(PROVISIONING_KEYS_REMAINING);
}
else if (ztpResponse == ZTP_DEACTIVATED)
Expand All @@ -1356,7 +1358,7 @@ void updateProvisioning()
"subscription. Please reference device ID: %s\r\n",
landingPageUrl, hardwareID);

httpClientModeNeeded = false; // Tell HTTP_Client to give up. (But it probably already has...)
httpClientModeNeeded = false; // Tell HTTP_Client to give up
displayAccountExpired(5000);

provisioningSetState(PROVISIONING_KEYS_REMAINING);
Expand All @@ -1382,7 +1384,7 @@ void updateProvisioning()
"activated. Please reference device ID: %s\r\n",
landingPageUrl, hardwareID);

httpClientModeNeeded = false; // Tell HTTP_Client to give up. (But it probably already has...)
httpClientModeNeeded = false; // Tell HTTP_Client to give up
displayNotListed(5000);

provisioningSetState(PROVISIONING_KEYS_REMAINING);
Expand All @@ -1398,7 +1400,7 @@ void updateProvisioning()
"[email protected] for more assistance. Please reference device ID: %s\r\n",
hardwareID);

httpClientModeNeeded = false; // Tell HTTP_Client to give up. (But it probably already has...)
httpClientModeNeeded = false; // Tell HTTP_Client to give up
displayAlreadyRegistered(5000);

provisioningSetState(PROVISIONING_KEYS_REMAINING);
Expand All @@ -1407,7 +1409,7 @@ void updateProvisioning()
{
systemPrintln("updateProvisioning: ZTP_UNKNOWN_ERROR");

httpClientModeNeeded = false; // Tell HTTP_Client to give up. (But it probably already has...)
httpClientModeNeeded = false; // Tell HTTP_Client to give up

provisioningSetState(PROVISIONING_KEYS_REMAINING);
}
Expand Down Expand Up @@ -1439,24 +1441,21 @@ void updateProvisioning()

gnssApplyPointPerfectKeys(); // Send current keys, if available, to GNSS

provisioningStartTime_millis = millis(); // Record the time so we can restart after 24 hours
provisioningSetState(PROVISIONING_WAIT_ATTEMPT);
}
break;
case PROVISIONING_WAIT_ATTEMPT:
{
if (settings.requestKeyUpdate)
provisioningSetState(PROVISIONING_STARTING);
provisioningSetState(PROVISIONING_CHECK_REMAINING);
else if (!settings.enablePointPerfectCorrections || !settings.autoKeyRenewal)
provisioningSetState(PROVISIONING_OFF);
// When did we last try to get keys? Attempt every 24 hours - or every 15 mins for DEVELOPER
//else if (online.rtc && (rtc.getEpoch() - settings.lastKeyAttempt > ( ENABLE_DEVELOPER ? (15 * 60) : (60 * 60 * 24))))
//else if (millis() > (provisioningStartTime_millis + ( ENABLE_DEVELOPER ? (1000 * 60 * 15) : (1000 * 60 * 60 * 24))))
// When did we last try to get keys? Attempt every 24 hours
else if (online.rtc && (rtc.getEpoch() - settings.lastKeyAttempt > (60 * 60 * 24)))
{
settings.lastKeyAttempt = rtc.getEpoch(); // Mark it
recordSystemSettings(); // Record these settings to unit
provisioningSetState(PROVISIONING_STARTING);
}
else if (millis() > (provisioningStartTime_millis + (1000 * 60 * 60 * 24))) // Don't use settings.lastKeyAttempt (#419)
provisioningSetState(PROVISIONING_CHECK_REMAINING);
}
break;
}
Expand Down

0 comments on commit 09a4b45

Please sign in to comment.