-
-
Notifications
You must be signed in to change notification settings - Fork 403
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
Uploaded images via the API does not appear on the site #4174
Comments
There is no manual check, so it must be the code. There used to be a check for image size. They should not be to small. That was to prevent images picked from the web. |
Does this happen on existing products as well? |
@aleene thanks for the fast response
i'm uploading big-enough images (all are took with iPhone 11 Pro) and the call returns success. When testing i used small images and saw the error you talk about but that would be a here is the cURL for my request (excluding the user_id/pass, i'm using those but not sharing here)
and the image is here. this is the product with barcode 9001414441350 (notice that the photo uploaded with OFF is on the site but the one uploaded with the cURL is not while getting
here is a barcode of a product already existing but with a new front image uploaded by me - 9001414041116. still can't see my own photo what could be wrong? i would like the api call to fail and let me know if it's something i do wrong |
Is the result json you show, not the one for the fields save. I have/use another result json for an image upload. |
the above is an example of the image upload, the fields update works. i don't see a connection |
The docs do show the image upload like your cURL, but is the documentation actually correct? The cURL equivalent what the official apps are doing is more like: curl --location --request POST 'https://world.openfoodfacts.org/cgi/product_image_upload.pl' \
--form 'imgupload_front=@/Users/radu/Downloads/IMG_9535.jpg' \
--form 'code=59474203' \
--form 'imagefield=front' It's like this in the old documentation |
In the changes history there is a user openfoodfacts-contributors. That will be your attempt to upload an image. (A username and pw is not needed for images). So I guess the upload did not finish. In the code of the ios-app, there is a part that lets you see the upload progress. It might help you to see if the upload is really happening. |
The image upload results json is different, so you need to check that one out. |
i changed product_image_upload.pl/imgupload_front to imgupload_front and there are still no changes, still success on the api call but no image on product page
as stated in my initial post, i built the uploader around that code, yet it's not working the same. is there any way to activate a debug mode? |
Did you notice the different endpoint
|
thank you, i did miss that, sorry i'm now getting ["error": The picture is too small. Please do not upload pictures found on the Internet and only send photos you have taken yourself., "status": status not ok, "imgid": -4, "files": <__NSSingleObjectArrayI 0x280c386d0>(
{
code = 0094393698890;
}
)
, "debug": product_id: 0094393698890 - userid: - imagefield: front_en - size of image file received: 0 - saved jpg: - could not read image: Exception 410: no images defined `Image::Magick::Q16' @ error/Q16.xs/XS_Image__Magick__Q16_Write/15081 - image too small - width: - height: ] even tho the image is huge i'll keep digging, i'm doing something wrong with the image data, i don't think it's related to OFF anymore. |
Yeah, my guess is that receives 0 bytes, hence 'too small' The question about the documentation still stands. @teolemon @stephanegigandet or whoever known, is the way in the new documentation supposed to work? |
i've found the 'issue' on my part. currently OFF is using the obsolete Alamofire v4 for networking, i'm using v5.2.2. so, in Swift: multipartFormData.append(imgUrl, withName: "imgupload_front") instead of multipartFormData.append(image.asData()!, withName: "imgupload_front", mimeType: "image/jpeg") i'm not happy with this, i've done this countless times using EDIT: seems like the API don't accept base64 strings for images but a constant stream of that data. why is that? |
The new documentation is incorrect indeed. |
@rursache just curious, is your app live ? |
yes, it is |
This issue has been open 90 days with no activity. Can you give it a little love by linking it to a parent issue, adding relevant labels and projets, creating a mockup if applicable, adding code pointers from https://github.com/openfoodfacts/openfoodfacts-server/blob/main/.github/labeler.yml, giving it a priority, editing the original issue to have a more comprehensive description… Thank you very much for your contribution to 🍊 Open Food Facts |
Describe the bug
I'm working on a food inventory app on iOS and users can scan products and autofill items using OpenFoodFacts.
I thought that uploading the items not found in the database back to you would be helpful and i've read the documentation and took a look at your iOS app and build a upload system for images and product names.
Expected behavior
However, after uploading a new product (code, name and image) i cannot see the image on the site. example
This doesn't happen on the OFF iOS app. example
Additional details
Here is how i'm calling the api when uploading images:
Here is the response:
["status_verbose": fields saved, "status": 1]
Full endpoint (
getURL(.uploadProduct)
) -https://world.openfoodfacts.org/cgi/product_image_upload.pl
Question
Is there some kind of manual check for the images or there is an issue with my code?
The text was updated successfully, but these errors were encountered: