Angular2,工厂守卫可能吗?

时间:2018-02-06 11:35:05

标签: javascript angular angular2-routing angular2-services angular-guards

我在我的网站上有很多信任,所以为了建立安全路线,我建立了下一个警卫:

export class TrustGuard implements CanActivate {
    constructor(private router: Router) {
    }

    canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
        return /*Check if user has the trust or not*/;
    }
}

所以,在路线中,我可以添加像canActivate: [TrustGuard]

这样的守卫

问题在于我有太多的信任,因此我需要为每个信任建立一个警卫。因此,我正在努力建立一个警卫工厂,以避免实施太多类似的警卫。

我的目标是找到设置路线的方式 canActivate: [FactoryTrustGuard(Trust.seeDashboard)]

这可能吗?

1 个答案:

答案 0 :(得分:3)

这可能会产生AOT问题,因为路由定义应该是静态的。

守卫可以干掉以消除大部分样板代码:

export abstract class TrustGuard  {
    protected abstract trust: string;

    canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
        /* check against this.trust */
    }
}

export class FooTrustGuard extends TrustGuard {
    protected trust = Trust.foo;
}

如果有几十个类似的守卫,可以使它成为一个单一的守卫并通过路线数据传递一个角色:

export class TrustGuard  {
    canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
        const trust = route.data['trust'];
        if (trust in Trust) {
          ...
        } else {
          throw ...;
        }
    }
}

并像

一样使用它
{ route: ..., canActivate: [TrustGuard], data: { trust: Trust.seeDashboard } }