-
Notifications
You must be signed in to change notification settings - Fork 36
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Having custom password fields in the AP config replace password with ***********s #33
Comments
Valdez skribis 2024-01-06 16:42 (-0800):
Is there a way to make it so when you have a custom password input string field in the AP configuration page, like an MQTT password it ************'s out the password when a user logs into the AP Configuration page like it does the WiFi password.
Currently that feature does not exist except for the WiFi password, which is handled separately from the custom fields.
Or is there any easy way to add this functionality to the WiFiSettings.cpp file to have another function like WiFiSettings.passwordstring() in addition to the .string() and .integer() functions?
Displaying it as a password field would be easy: just copy WiFiSettingsString to a new class, e.g. WiFiSettingsPasswordString, and add `type=password` to the `<input>` element.
However, this would still leak the password in the `value`. For the WiFi password, the value is set to `##**##**##**` in the HTML. Upon saving the settings, the new value is only stored if it is unequal to that hardcoded value. A similar thing would be needed for the new class.
The nice way to do that would be to override `store()` with a wrapper, but it would also be feasible to just add it to the loop over `params`, line 410.
I don't have time to write and test this right now, but I would be open to a well written and tested pull request that adds this feature.
|
Thanks for the quick response Juerd. In WiFiSettings.cpp I copied the "struct WiFiSettingsString" to a new "struct WiFiSettingsPasswordString" and manually entered, value = '**********' into h, and I also removed the h.replace("{value}", html_entities(value)); so it would not attempt to update the html value. So the WiFiSettingsPasswordString struct code added looks like this:
Then I copied "String WiFiSettingsClass::string..." to a new "WiFiSettingsClass::passwordstring..." and changed the struct references to the struct WiFiSettingsPasswordString, so the new class added looks like this:
Editted as per below - I also changed the loop at line 410 to check if the value is "**********" so that it only stores it if it has been changed. The loop now looks like this:
Lastly in WiFiSettings.h I added: In my code where I declare the custom variable fields for the AP Config I declare |
Nevermind... I see a problem with my code. It hides the value of the password but any time you re-save the Config without re-entering the custom password it updates your your custom password to "**********" as its hardcoded into the value. Need to put in a check to see if its ********** and ignore it if so. I also see you tried explaining that to me 🥴! Working on it now. |
Now it works! Changed the loop at line 410 in WiFiSettings.cpp to check if the value is "**********" before storing:
Updated the post above with this code. I'll probably change the password mask to |
Is there a way to make it so when you have a custom password input string field in the AP configuration page, like an MQTT password it ************'s out the password when a user logs into the AP Configuration page like it does the WiFi password. Or is there any easy way to add this functionality to the WiFiSettings.cpp file to have another function like WiFiSettings.passwordstring() in addition to the .string() and .integer() functions?
The text was updated successfully, but these errors were encountered: