解析云代码-通知不起作用,对象不删除



我有一个解析云代码函数,它将作为我的后台工作。现在我正处于调试阶段。函数没有抛出错误,也没有执行它应该执行的操作。名为"backgroundJob"的函数应该遍历所有已创建的"Group"对象。每个"Group"对象都有一个"Event"对象的数组,关于"Event"的对象,您只需要知道它有一个名为"date"的日期属性。

该函数应遍历每个组对象的所有事件,如果事件的日期与当前时间相同,则该函数应向该组中的所有"用户"发送通知,然后删除该事件。现在的功能是如果事件与当前时间相同并且不通知组成员,则不删除该事件。

我的功能如下。

Parse.Cloud.define("backgroundJob", function(request, response) {
Parse.Cloud.useMasterKey();
var moments = require("cloud/moment.js");
moments().format();
var _ = require('cloud/underscore.js');
// Get the actual time, for use in non testing
// var now = moments();
// For testing edit time in ()
var now = moments("2015-23-11 19:30", "YYYY-MM-DD HH:mm");
var out = now;
console.log(out);
var groupObject = Parse.Object.extend("Group");
var query = new Parse.Query(groupObject);
var eventObject = Parse.Object.extend("Event");
query.find().then(function(groups) {
    var promise = Parse.Promise.as();
    var groupArray = groups;
    for (var i = 0; i < groupArray.length; i++) {
        promise = promise.then(function() {
            var count = 0;
            var eventArray = groupArray[i].get("Events");
            for (count = 0; count < eventArray.length; count++) {
                if (now == eventArray[count].get('date')) {
                    var curEvent = eventArray[count];
                    eventArray[count].destory();
                    var relationc = result.get("created");
                    var createdq = relationc.query();
                    var relationj = result.get("created");
                    var joinedq = relationj.query();
                    var partOnee = curEvent.get("name");
                    var outString = partOnee.concat(" is now");
                    Parse.Push.send({
                        where : createdq,
                        data : {
                            alert : outString
                        }
                    }).then(function() {
                        response.success();
                    }, function(error) {
                        response.error(error);
                    });
                    Parse.Push.send({
                        where : joinedq,
                        data : {
                            alert : outString
                        }
                    }).then(function() {
                        response.success();
                    }, function(error) {
                        response.error(error);
                    });
                    var e = eventArray[count];
                    var destroyp = Parse.Promise.as();
                    destroyp = promise.then(function() {
                        return e.destroy();
                    }, function(error) {
                        response.error(error);
                    });
                }
            }
        });
    }
}).then(function() {
    response.success()
}, function(error) {
    response.error(error);
});
});

谢谢。

为了在代码中引用,与用户有两个独立的关系,一个是"创建的",一个为"连接的",这就是为什么在代码中我有一个创建的查询和一个反应查询。

您的代码中有一个拼写错误。也许这不是问题的原因,但无论如何,请检查一下。

eventArray[count].destory();

看起来很傻,但是,谁知道呢。。。

最新更新