openfoodfacts / smooth-app

🤳🥫 The new Open Food Facts mobile application for Android and iOS, crafted with Flutter and Dart
https://world.openfoodfacts.org/open-food-facts-mobile-app?utm_source=off&utf_medium=web&utm_campaign=github-repo
Apache License 2.0
852 stars 282 forks source link

An issue that may cause errors in background tasks #4663

Open g123k opened 1 year ago

g123k commented 1 year ago

Hi everyone,

I have digged a little bit in the code today, trying to find some explanations for this kind of error: Exception: Could not save product - [{impact: {id: failure, name: Failure, Ic_name: Failure}, message: {id: invalid_user_id_and_password, name: Invalid user id and password, Ic_name: Invalid user id and password}}]

I'm pretty sure there is also an issue on the server BUT we may have a loophole in our implementation:

Now, let's imagine this scenario:

I suggest changing a little bit the implementation to this one:

I know that the second fix is not perfect (edit assigned to another user), but still better than data lost forever. Another idea would be to use a generic user.

monsieurtanuki commented 12 months ago

In a background task, if the user ID is the same as the one in the secured storage, use the password from the secure storage In a background task, if the user ID is different from the current one, as we can't fix the situation, use the credentials from the secured storage instead.

@g123k That means always use the secure storage credentials, right?

What if the user disconnects: we'll still try forever to run background tasks that will fail. Or assign it to our default user, smoothie-app. And I'm afraid it won't solve the issue, as it happened even for users that didn't change their passwords, according to @NixedSec in https://github.com/openfoodfacts/smooth-app/issues/4637#issuecomment-1726255533

I have also not changed the password on this account via the app or website any time recently.

That said, it's somehow healthier not to store the password in background tasks, isn't it?

NixedSec commented 11 months ago

@monsieurtanuki I think I have managed to work out the issue, at least in my case. It appears that the "£" character being used within a password seems to cause issues. I tested several different characters and lengths with different accounts and using that within another account's password seemed to cause issues on that account. Though I am unsure why this should be an issue if the password is being hashed before checked.

monsieurtanuki commented 11 months ago

Very interesting, @NixedSec!

I'm not surprised that £ is problematic as it's not an ASCII character. Remember, we're only in 2023!

Or it's a problem when we store securely the user/password.

@stephanegigandet Typically they say something like lowercase, uppercase, digits and a restricted set of special characters - are there similar restrictions for user and password in OFF?

monsieurtanuki commented 11 months ago

Aha!

I've changed my password in order to include a £ and have witnessed no problem in most cases:

BUT: I've encountered a problem with the new packagings feature, which is the only case to be saved with a PATCH request (temporarySaveProductV3, /api/v3/product/$barcode).

@stephanegigandet Any idea why the PATCH request would not accept a password with a £, whereas the /cgi/product_jqm2.pl POST works correctly?

patch param value
uri https://world.openfoodfacts.org/api/v3/product/9780000000001
header {Accept: application/json, User-Agent: - Smoothie - OpenFoodFacts - 0.0.0+734 - android+sdk_gphone64_x86_64-userdebug 12 SE1A.220203.002.A1 8151367 dev-keys - https://world.openfoodfacts.org/ - , From: monsieurtanuki}
body {"user_id":"monsieurtanuki","password":"something with a £","product":{"packagings":[{"shape":{"lc_name":"Bouteille"},"material":{"lc_name":"Verre"},"recycling":{"lc_name":"Recycler"},"number_of_units":1}]},"lc":"fr","tags_lc":"fr","cc":"fr","app_name":"Smoothie - OpenFoodFacts","app_version":"0.0.0+734","app_uuid":"6bd6aeef88464d03","app_platform":"android+sdk_gphone64_x86_64-userdebug 12 SE1A.220203.002.A1 8151367 dev-keys","comment":""}