angularjs - How to protect a route from being accessed when logged in? -


i have error handling function responds errors in routing, , redirects user landing page if user not authenticated:

core.run(['$rootscope', '$location', function($rootscope, $location) {   $rootscope.$on('$routechangeerror', function(event, next, previous, error) {     if (error === 'auth_required') {       $location.path('/');     }   }); }]); 

now want reverse this, if user authenticated, route not available:

.when('/', {   templateurl: 'views/pages/landing.html',   resolve: {     'isauth': ['fbrefs', function(fbrefs) {       return fbrefs.getauthobj().$waitforauth();     }]   } }) 

how alter resolve above check if user is authenticated , if so, redirect /home instead of /?

i tried manually rejecting promise returned resolve makes route disabled no matter if user authenticated or not.

you handle manually $q

.when('/', {   templateurl: 'views/pages/landing.html',   resolve: {     'isauth': ['fbrefs', function(fbrefs, $q) {       var onloggedin = function() {         return $q.reject('no_auth_required');       }        var onloggedout = function(fbdata) {         return fbdata;       }        return fbrefs.getauthobj().$requireauth()         .then(onloggedin, onloggedout);     }]   } }) 

...

core.run(['$rootscope', '$location', function($rootscope, $location) {   $rootscope.$on('$routechangeerror', function(event, next, previous, error) {     if (error === 'auth_required') {       $location.path('/');     } else if (error === 'no_auth_required') {       $location.path('/home');     }   }); }]); 

Comments

Popular posts from this blog

Android : Making Listview full screen -

javascript - Parse JSON from the body of the POST -

javascript - How to Hide Date Menu from Datepicker in yii2 -