解析400错误请求setACL

时间:2014-07-14 17:55:36

标签: javascript parse-platform

我有一个“管理员”角色,我想分配给我Parse中当前的所有User对象。但是,无论我尝试什么,我都会收到400错误。当我尝试通过仪表板手动添加ACL时,它不会保存。例如,我将输入“{”角色:Administrator“:{”read“:true,”write“:true}}”并且它将在刷新时恢复为(undefined)。

修改,所以我尝试创建了一个Cloud Code功能。在尝试运行该功能时,仍然会收到400错误以及“结果:错误:未定义未授权”。

main.js(Cloud Code):

Parse.initialize("*****", "*****");
Parse.Cloud.define("modifyUser", function(request, response) {
    if (!request.user) {
        response.error("Must be signed in to call this Cloud Function.")
    return;
    }

    // The rest of the function operates on the assumption that request.user is *authorized*
    Parse.Cloud.useMasterKey();

    var query = new Parse.Query(Parse.User);
    query.find({
        success: function(results) {
        response.success("Successfully retrieved " + results.length + " scores.");
        // Do something with the returned Parse.Object values
        for (var i = 0; i < results.length; i++) { 
            var object = results[i];
            alert(object.id + ' - ' + object.get('objectId'));
        }
        },
        error: function(error) {
            response.error("Error: " + error.code + " " + error.message);
        }
    });

});

我的客户端.js文件:     $(function(){         console.log(“运行仪表板”);         Parse.initialize(“ **”,“** ”);

    Parse.Cloud.run('modifyUser', {username: "myusername@email.com"}, {
        success: function(result) {
        // result is 'Hello world!'
        console.log(result);
         },
        error: function(error) {
            console.log("error: " + error.code + " " + error.message);
        }
    });
});

更新前: 理想情况下,我想循环遍历Javascript文件中的所有用户,并使用以下代码更新其角色:

// set up ACL for User object
var userACL = new Parse.ACL();
userACL.setRoleWriteAccess("Administrator", true);
userACL.setRoleReadAccess("Administrator", true);

// grab all Users
var user_query = new Parse.Query(Parse.User);
user_query.find( {
    success: function(users) {
        // querying all users works successfully
        console.log(users);
        // assign Administrator ACL to each user
        for (var i=0; i<users.length; i++) {
            users[i].setACL(userACL);
            users[i].save(null, {
                success: function(user) {
                    console.log("save successfully");
                },
                error: function(error) {
                    console.log("error saving: " + error.code + " " + error.message);
                }
            });
        }
    },
    error: function(error) {
        console.log("error: " + error.code + " " + error.message);
    }
});

但是,这会返回以下内容:我尝试保存的每个用户的POST https://api.parse.com/1/classes/_User/userIDhere 400(错误请求)以及“用户对象不允许其他用户写入”,尽管我的用户列在管理员角色下。

非常感谢任何帮助。

1 个答案:

答案 0 :(得分:3)

好吧,我已经解决了我的问题。您不应该在您的Cloud Code功能中使用Parse.initialize,并且您当然不能将它与useMasterKey一起使用。这是我偶然发现的链接:https://www.parse.com/questions/usemasterkey-and-modifying-user-results-in-unauthorized

这应该在Cloud Code文档中。