Iron Router授权控制器

时间:2013-08-26 20:13:36

标签: routing meteor iron-router

我想知道是否有人可以演示如何在处理用户身份验证的路由器控制器类上使用全局'before'操作,并根据结果显示相应的路由/模板。

我的用例是让AppController充当身份验证防火墙,并在用户注销时阻止任何子控制器操作。 E.g。

// Create a primary app controller stub with the auth firewall
AppController = RouteController.extend({});

// Extend the AppController with all the other app routes
MainController = AppController.extend({});

任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:5)

在我用流星写的博客中,我使用代码:

AppController = RouteController.extend({
  before:function(){
    if(_.isNull(Meteor.user())){
      Router.go(Router.path('home'));
    }
  }
})

AdminPostController = AppController.extend({
  waitOn: function() { return App.subs.posts}
});

Router.map(function(){
  this.route('submitPost', {
    path: '/submitPost',
    controller:'AdminPostController',
    template:'postCreate'
  });
  this.route('editPost', {
    path: '/post/:slug/edit',
    controller:'AdminPostController',
    template:'postEdit'
  });
})