4

我想用当前与它们关联ListView的一个Array或一个ArrayList不同的 s 填充 a 。我认为这需要对当前用户进行某种查询,但是我只是不确定如何返回角色以及如何将它们返回到我可以用来填充. 我知道您可以使用以下方法获取当前用户:ParseRoleParseUserArrayArrayListListView

ParseUser.getCurrentUser();

但是,我似乎无法从那里找到您如何建立用户已分配的角色。

编辑:

我现在也尝试过这个:

ParseQuery<ParseRole> query = ParseRole.getQuery();
query.whereEqualTo("users", ParseUser.getCurrentUser().getObjectId());
query.findInBackground(new FindCallback<ParseRole>() {
   @Override
   public void done(List<ParseRole> objects, ParseException e) {
      if(e == null) {
         Toast.makeText(getApplicationContext(), objects.size() + "", Toast.LENGTH_SHORT).show();
      } else {
         Toast.makeText(getApplicationContext(), "ERROR", Toast.LENGTH_SHORT).show();
      }
   }                      
});

但我似乎仍然无法得到任何与此相关的工作。我目前已经尝试了所有我能想到的东西,但并没有真正取得任何进展,因为“对象”的大小仍然始终为 0。

提前致谢!

回答:

在实现 Marius Falkenberg Waldal 的答案背后的逻辑并将其移植到 Android 之后,我终于找到了适合我情况的解决方案。我决定发布它以防将来对任何人有所帮助:

    ParseQuery<ParseRole> roleQuery = ParseRole.getQuery();
    List<ParseRole> allRoles = null;
    try {
        allRoles = roleQuery.find();
    } catch (ParseException e) {
        e.printStackTrace();
    }
    userRoles = new ArrayList<ParseRole>();
    userRolesNames = new ArrayList<String>();
    for(ParseRole role : allRoles) {
        ParseQuery usersQuery = role.getRelation("users").getQuery();
        usersQuery.whereEqualTo("objectId", ParseUser.getCurrentUser().getObjectId());
        try {
            if(usersQuery.count() > 0) {
                userRoles.add(role);
                userRolesNames.add(role.getName().toString());
            }
        } catch (ParseException e) {
            e.printStackTrace();
        }
    }               

    GroupAdapter adapter = new GroupAdapter(this, userRolesNames);
    workspaces.setAdapter(adapter);
4

3 回答 3

2

我在尝试确认某些事情时偶然发现了这一点,并意识到有一种更简单的方法:

安卓

ParseQuery<ParseRole> query = ParseRole.getQuery();
query.whereEqualTo('users', ParseUser.getCurrentUser());
query.findInBackground(new FindCallback<ParseRole>() {
    public void done(List<ParseRole> roles, ParseException e) {
        // do your thing with the roles list
    }
});

为了其他人的利益,这是其他几种语言的答案。

iOS 目标-C

PFQuery *query = [PFRole query];
[query whereKey:@"users" equalTo:[PFUser currentUser]];
[query findObjectsInBackgroundWithBlock:^(NSArray *roles, NSError *error) {
  if (!error) {
    // Do something with the found roles
  }
}];

iOS 斯威夫特

var query = PFRole.query();
query.whereKey('users', equalTo:PFUser.currentUser());
query.findObjectsInBackgroundWithBlock {
  (roles: [PFObject]!, error:NSError!) -> Void in
  if error == nil {
    // do your thing with the roles
  }
}

JavaScript

var query = new Parse.Query(Parse.Role);
query.equalTo('users', Parse.User.current());
query.find().then(function(roles) {
  // do your thing with the roles array
});
于 2014-11-26T10:17:04.867 回答
1

您可能需要遍历角色,检查当前用户是否在每个角色中。抱歉,我无法为您提供一些 android 代码,因为我是一名 iOS 程序员,但这是您如何使用 iOS 进行操作的示例,希望您可以将其移植到 android。在 iOS 中,我会为此代码创建一个方法,或者可能是一个类别:

PFQuery *rolesQuery = [PFRole query]; 
NSArray *allRoles = [rolesQuery findObjects];
NSMutableArray *userRoles = [NSMutableArray arrayWithCapacity:10];
for (PFRole *role in allRoles) {
    PFQuery *usersQuery = [role relationforKey:@"users"].query;
    [usersQuery whereKey:@"objectId" equalTo:[PFUser currentUser].objectId];
    if ([usersQuery countObjects]) {
        [userRoles addObject:role];
    }
}

希望这能让你走上正确的道路......

于 2014-02-05T10:31:26.190 回答
0

像这样使用

ParseRole myroles= (ParseRole) new ParseQuery("Role").whereEqualTo("name", "AppName-"+currentuserid).getFirst();


Here  "name" -----------Column in Role Table

      "AppName" --------eg: "MyApp-23"   in your _User table



I think this helps...
于 2014-02-04T06:54:48.900 回答