routeprovider解决不限制使用parse.com进行访问的问题

时间:2018-02-23 18:13:46

标签: angularjs parse-platform roles route-provider

我想将页面限制为仅限管理员。我发现我的auth工厂没有在resolve返回路由回答之前完成。当我关注/观察代码路径页面在工厂完成之前加载。 我想我需要做更好的承诺和/或" .then()"。

任何帮助将不胜感激。感谢

我的路线代码:

.when("/admin", {
    templateUrl : "templates/admin.htm",
    controller: 'AdminCtrl',
    resolve : {
            'auth' : function(AuthService){
                return AuthService.isAdmin();
            }
    }
}).run(function($rootScope, $location){
    $rootScope.$on('$routeChangeError', function(event, current, previous, rejection){
        if(rejection === 'Not Administrator'){
            $location.path('/404');
        }
        if(rejection === 'Not Authenticated'){
            $location.path('/404');
        }
    });
});

我的工厂:

    app.factory('AuthService', function($q){
    var isAuthenticated = Parse.User.current();
    var isAdmin = undefined;
    var currentUser = Parse.User.current();
        return {
            authenticate : function(){
                if(isAuthenticated){
                    return true;
                } else {
                    return $q.reject('Not Authenticated');
                }
            },
            isAdmin : function(){
                if(isAuthenticated){
                    userHasRole(currentUser, "Administrator").then(function(isRole) {
                        console.log((isRole)? "user is admin" : "user is not admin");
                        isAdmin = isRole;
                        return isAdmin;
                    }).then(function(isAdmin){
                        if(isAdmin){
                            return true;
                        } else {
                            return $q.reject('Not Administrator');
                        }
                    });
                } else {
                    return $q.reject('Not Authenticated');
                }
            }
        };
});  

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) {
        if(roles.length > 0){
            return true;
        }else{
            return false;
        }
    });
}

1 个答案:

答案 0 :(得分:0)

如此接近。

isAdmin返回未定义,因为您在userHasRole之前错过了return语句,因此您正在调用它,但随后isAdmin命中if( isAuthenticated ) {1}}阻止没有返回值,因为它不知道它应该返回userHasRole的结果。