角色 - Parse.com Javascript

时间:2015-03-16 12:57:02

标签: javascript parse-platform roles

目前我有javascript允许(_User)表中的所有用户登录。我在角色表中设置了一个名为(Admins)的角色,并为此角色分配了一个用户。这会是if语句吗?

目前这是用户成功登录的方式

$scope.logIn = function(form) {
Parse.User.logIn(form.username, form.password, {
  success: function(user) {
    $scope.currentUser = user;
    $scope.$apply();
    window.location.href = "TEST.html";
  },

1 个答案:

答案 0 :(得分:1)

检查任何用户是否属于角色都很容易。唯一棘手的部分是要意识到检查包含一个查询,因此是一个异步操作。首先,通用角色检查功能:

function userHasRole(user, roleName) {
    var query = new Parse.Query(Parse.Role);
    query.equalTo("name", roleName);
    query.equalTo("users", user);
    return query.find().then(function(roles) {
        return roles.length > 0;
    });
}

这将返回一个将使用布尔值实现的promise,因此您可以这样调用它:

var currentUser = Parse.User.current();
// is the user an "admin"?
userHasRole(currentUser, "admin").then(function(isAdmin) {
    console.log((isAdmin)? "user is admin" : "user is not admin");
});

在您的代码中将此类似的应用。在视图中:

<form role="form" name="loginForm">
    <div class="form-group">
        <label>Email</label>
        <input type="email" class="form-control" name="email" ng-model="user.username" />
    </div>
    <div class="form-group">
        <label>Password</label>
        <input type="password" class="form-control" name="password" ng-model="user.password" />
    </div>
    <div class="form-group">
        <button class="btn btn-ar btn-primary" ng-click="pressedLogIn()">Log in</button>
    </div>
</form>

在控制器中:

(function() {
    'use strict';
    angular.module('myApp.controllers').controller('LogInController', LogInController);

    LogInController.$inject = ['$scope'];

    function LogInController($scope) {
        $scope.user = { username:"", password:""};

        function userHasRole(user, roleName) {
            // defined exactly as above
            // my real app has a user service, and this would be better placed there
        }

        $scope.pressedLogIn = function() {
            if ($scope.loginForm.$valid) {
                Parse.User.logIn($scope.user.username, $scope.user.password).then(function(user) {
                    $scope.user = user;
                    return userHasRole(user, "administrator");
                }).then(function(isAdmin) {
                    alert("user is admin = " + isAdmin);
                }, function(e) {
                    alert(error.message);
                });
            }
        };
    }
})();