reader identity in settings

This commit is contained in:
Matthew Frost 2024-04-13 23:51:35 +02:00
parent a29b52463a
commit 76da74aa61
5 changed files with 90 additions and 6 deletions

View file

@ -178,8 +178,12 @@ class ACLWebServerClass{
acl.saveToEEPROM(); acl.saveToEEPROM();
request->send(201); // Created request->send(201); // Created
}); });
} }
// deprecated, keeping for backward compatibility // deprecated, keeping for backward compatibility
void loop() { void loop() {
} }

View file

@ -46,7 +46,7 @@ class MainWebServerClass{
return request->requestAuthentication(); return request->requestAuthentication();
} }
} }
request->send(200, "application/json", "{\"version\":\"3.1.9\"}"); request->send(200, "application/json", "{\"version\":\"3.2.3\"}");
}); });
_server->onNotFound([&](AsyncWebServerRequest *request){ _server->onNotFound([&](AsyncWebServerRequest *request){
@ -153,6 +153,45 @@ class MainWebServerClass{
request->send(response); request->send(response);
} }
}); });
_server->on("/settings/get/tinanceCreds", HTTP_GET, [&] (AsyncWebServerRequest *request) {
if(_authRequired){
if(!request->authenticate(_username.c_str(), _password.c_str())){
return request->requestAuthentication();
}
}
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"identifier\":\""+String(settings.getTinance2ReaderIdentifier())+"\", \"key\":\""+String(settings.getTinance2ReaderKey())+"\"}");
request->send(response);
});
_server->on("/settings/set/tinanceCreds", HTTP_GET, [&] (AsyncWebServerRequest *request) {
if(_authRequired){
if(!request->authenticate(_username.c_str(), _password.c_str())){
return request->requestAuthentication();
}
}
if(request->hasParam("identifier", true)) {} //This is important, otherwise the sketch will crash if there is no body
else {
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No identifier\"}");
request->send(response);
}
String identifier = String(request->arg("identifier"));
if(request->hasParam("key", true)) {} //This is important, otherwise the sketch will crash if there is no body
else {
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No key\"}");
request->send(response);
}
String key = String(request->arg("key"));
settings.setTinance2ReaderIdentifier(identifier);
settings.setTinance2ReaderKey(key);
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"Tinance credentials updated\"}");
request->send(response);
});
} }
// deprecated, keeping for backward compatibility // deprecated, keeping for backward compatibility

View file

@ -14,18 +14,28 @@ class Settings {
private: private:
bool disableDoor; bool disableDoor;
String doorMode; String doorMode;
String tinance2ReaderIdentifier;
String tinance2ReaderKey;
public: public:
Settings(); Settings();
void loadFromEEPROM(); void loadFromEEPROM();
void saveToEEPROM(); void saveToEEPROM();
void saveStringToEEPROM(String string, String value);
void saveBoolToEEPROM(String string, String value);
void setDisableDoor(bool value); void setDisableDoor(bool value);
bool getDoorDisabled(); bool getDoorDisabled();
void setDoorMode(String value); void setDoorMode(String value);
String getDoorMode(); String getDoorMode();
void setTinance2ReaderIdentifier(String value);
String getTinance2ReaderIdentifier();
void setTinance2ReaderKey(String value);
String getTinance2ReaderKey();
}; };
extern Settings settings; extern Settings settings;

View file

@ -6,17 +6,30 @@ Settings::Settings() : disableDoor(false), doorMode("LATCH") {
} }
void Settings::loadFromEEPROM() { void Settings::loadFromEEPROM() {
settings_preferences.begin("settings"); settings_preferences.begin("settings", false);
disableDoor = settings_preferences.getBool("disableDoor", false); disableDoor = settings_preferences.getBool("disableDoor", false);
doorMode = settings_preferences.getString("doorMode", "LATCH"); doorMode = settings_preferences.getString("doorMode", "LATCH");
settings_preferences.end(); settings_preferences.end();
settings_preferences.begin("t2", false);
tinance2ReaderIdentifier = settings_preferences.getString("ri", "default");
tinance2ReaderKey = settings_preferences.getString("rk", "default");
settings_preferences.end();
} }
void Settings::saveToEEPROM() { void Settings::saveToEEPROM() {
settings_preferences.begin("settings"); settings_preferences.begin("settings", false);
settings_preferences.putBool("disableDoor", disableDoor); settings_preferences.putBool("disableDoor", disableDoor);
settings_preferences.putString("doorMode", doorMode); settings_preferences.putString("doorMode", doorMode);
settings_preferences.end(); settings_preferences.end();
settings_preferences.begin("t2", false);
settings_preferences.putString("ri", tinance2ReaderIdentifier);
settings_preferences.putString("rk", tinance2ReaderKey);
settings_preferences.end();
// Save the settings to EEPROM
} }
void Settings::setDisableDoor(bool value) { void Settings::setDisableDoor(bool value) {
@ -65,4 +78,22 @@ String Settings::getDoorMode() {
return doorMode; return doorMode;
} }
void Settings::setTinance2ReaderIdentifier(String value) {
tinance2ReaderIdentifier = value;
saveToEEPROM();
}
String Settings::getTinance2ReaderIdentifier() {
return tinance2ReaderIdentifier;
}
void Settings::setTinance2ReaderKey(String value){
tinance2ReaderKey = value;
saveToEEPROM();
}
String Settings::getTinance2ReaderKey(){
return tinance2ReaderKey;
}
Settings settings; Settings settings;

View file

@ -17,8 +17,8 @@ HTTPClient tinance2_http;
// Set the headers // Set the headers
tinance2_http.addHeader("Content-Type", "application/json"); tinance2_http.addHeader("Content-Type", "application/json");
tinance2_http.addHeader("X-Identifier", tinance2_reader_identifer); tinance2_http.addHeader("X-Identifier", settings.getTinance2ReaderIdentifier());
tinance2_http.addHeader("X-Access-Key", tinance2_reader_key); tinance2_http.addHeader("X-Access-Key", settings.getTinance2ReaderKey());
// Set the HTTP timeout to 5 seconds // Set the HTTP timeout to 5 seconds
tinance2_http.setTimeout(5000); tinance2_http.setTimeout(5000);