6

I have been struggling with saving a file I retrieve from an HTTP Request for a a few days now. Here is my code:

    Parse.Cloud.httpRequest({
    url: "https://ss1.4sqi.net/img/categories_v2/food/vietnamese_88.png",
    success: function(httpImgFile) 
    {
        console.log("httpImgFile: " + String(httpImgFile.buffer));
        var imgFile = new Parse.File("imgFile1.png", httpImgFile.buffer);                                               
        object.set("location", "newYork"); //object is a PFObject retrieved earlier
        object.set("icon1", imgFile);
        object.save(null, {
          success: function(gameScore) {
            response.success("saved object");
          },
          error: function(gameScore, error) {
            response.error("failed to save object");
          }
        });     
    },
    error: function(httpResponse) 
    {
        console.log("unsuccessful http request");
        response.error(responseString);
    }
});

The error I get is:

Failed with: TypeError: Cannot call method 'then' of undefined
    at Object.b.File.save (Parse.js:2:14963)
    at null.<anonymous> (Parse.js:2:30041)
    at e (Parse.js:2:6339)
    at Parse.js:2:7092
    at g (Parse.js:2:6829)
    at c.extend.then (Parse.js:2:7077)
    at Parse.js:2:30016
    at Array.forEach (native)
    at Function.x.each.x.forEach (Parse.js:1:661)
    at Function.b.Object._deepSaveAsync (Parse.js:2:29993)

The weirdest part about all this is that the error only occurs when I include the line object.set("icon1", imgFile) I am able to to modify the location of object without problem. The error occurs solely when I try to save the imgFile to icon1

Any help would be greatly appreciated. Thanks!

Ankush Agrawal
  • 395
  • 2
  • 14

1 Answers1

4

As per the documentation (https://parse.com/docs/js_guide#files) you have to save the Parse File before you can set it on another object.

Typically:

imgFile.save().then(function () {

    ...
    object.set("icon1", imgFile);

    return object.save();

}).then(function (gameScore) {
    response.success("saved object");
}, function (error) {
   response.error("failed to save object");
});

I also rewrote this part of the function to illustrate the promise pattern, as it is a little easier when dealing with a series of requests like this.

Tom Erik Støwer
  • 1,399
  • 9
  • 19
  • Hi Tom. Thanks for the suggestion. I tried saving the imgFile before setting like you described but I'm still encountering the same error unfortunately. Do you think it has something to do with the format of the downloaded imgFile? – Ankush Agrawal Sep 24 '14 at 03:46
  • Can you try the following var imgFile = httpImgFile.buffer.toString('base64'); – Tom Erik Støwer Sep 25 '14 at 08:40
  • Thanks for the suggestion Tom. Unfortunately, still no luck: Error: Uncaught Creating a Parse.File from a String is not yet supported. (Code: 141, Version: 1.2.21) entered result block – Ankush Agrawal Sep 30 '14 at 00:04
  • 4
    Try var imgFile = new Parse.File("imgFile1.png", {base64: httpImgFile.buffer.toString('base64')}); – bandw May 22 '15 at 17:18