Parse Cloud Code Error: Parse.Error {code: 141, сообщение: "успех / ошибка не была вызвана"}

Я хочу условно обновить несколько объектов Parse.Object с использованием облачного кода. Предполагается, что функция сохраняет выбранные данные в новый столбец, если она применяется к рассматриваемому пользователю.

У меня возникли серьезные проблемы с этим в моей первой функции облачного кода. Я думаю, что у меня есть большая часть этого права, но я продолжаю получать успех / ошибка не была названа ошибкой.

Я использую следующий код:

Parse.Cloud.define("someFunction", function(request, response) {

var user = Parse.Object.extend("User");
var query = new Parse.Query(Parse.User);
var Table1 = Parse.Object.extend("Table1");
var table1Query = new Parse.Query(Table1);
var Table2 = Parse.Object.extend("Table2");
var table2Query = new Parse.Query(Table2);

var Ids = req.body //this is an array of Parse.Object Ids

var array = [];

var x = Ids.length

while (x--){
var Id = Ids[x];

table1Query.equalTo("user", {__type: "Pointer", className: "_User",                                                                              
                             objectId: Id});
table1Query.find({
success: function (results) {
         var resultIds = _.map(results, function (n) {
                           return n.id});

         var resultObjs = _.map(results, function (n) {
                           return return _.extend(_.find(n), {id: n.id})});

var a = resultIds.length
while (a--) {
var resultId = resultIds[a];

table2Query.equalTo("user", {__type: "Pointer", className: "_User",                                                                              
                             objectId: resultId});
table2Query.find({
success: function (items) {
var MA = _.map(_.flatten(items), function (n) {
return _.find(n)});

var step3 = _.map(resultObjs, function (n) {return _.extend(n, {
Matched: _.filter(MA, function (a) {return a.result.id == n.id})})});

var total = Math.round(_.reduce(_.map(step3, function (n) {return n.Bill
}), function (memo, num) {return memo + num;}, 0) * 100) / 100;

var duty = function (total, id) {
var promise = new Parse.Promise();
table2Query.get(id, {
success: function (Answer) {
Answer.set("duty", total);
Answer.save().then(function (difresult) {
response.success(difresult);
}, function (error) {
response.error(error);})
}
});
}
    array.push(duty(Answer, Id))
    }
})
}
}
})
}
return Parse.Promise.when(array);
})

1 ответ

Решение

Я надеюсь, что это поможет кому-то однажды. Ответ / разницу в коде можно найти в самом конце, когда я добавил.hen, чтобы поставить response.success/error:

Parse.Cloud.define("someFunction", function(request, response) {

var user = Parse.Object.extend("User");
var query = new Parse.Query(Parse.User);
var Table1 = Parse.Object.extend("Table1");
var table1Query = new Parse.Query(Table1);
var Table2 = Parse.Object.extend("Table2");
var table2Query = new Parse.Query(Table2);

var Ids = req.body //this is an array of Parse.Object Ids

var array = [];

var x = Ids.length

while (x--){
var Id = Ids[x];

table1Query.equalTo("user", {__type: "Pointer", className: "_User",                                                                              
                             objectId: Id});
table1Query.find({
success: function (results) {
         var resultIds = _.map(results, function (n) {
                           return n.id});

         var resultObjs = _.map(results, function (n) {
                           return return _.extend(_.find(n), {id: n.id})});

var a = resultIds.length
while (a--) {
var resultId = resultIds[a];

table2Query.equalTo("user", {__type: "Pointer", className: "_User",                                                                              
                             objectId: resultId});
table2Query.find({
success: function (items) {
var MA = _.map(_.flatten(items), function (n) {
return _.find(n)});

var step3 = _.map(resultObjs, function (n) {return _.extend(n, {
Matched: _.filter(MA, function (a) {return a.result.id == n.id})})});

var total = Math.round(_.reduce(_.map(step3, function (n) {return n.Bill
}), function (memo, num) {return memo + num;}, 0) * 100) / 100;

var duty = function (total, id) {
var promise = new Parse.Promise();
table2Query.get(id, {
success: function (Answer) {
Answer.set("duty", total);
Answer.save().then(function (difresult) {
response.success(difresult);
}, function (error) {
response.error(error);})
}
});
}
    array.push(duty(Answer, Id))
    }
})
}
}
})
}
return 

Parse.Promise.when(array).then(function() {
    response.success("Successfully retrieved Total Bills.");
},
    function(error) {
        response.error("Something is still wrong");
        console.log(error);
    });;
    })
Другие вопросы по тегам