本文整理汇总了TypeScript中@nestjs/core.Reflector类的典型用法代码示例。如果您正苦于以下问题:TypeScript Reflector类的具体用法?TypeScript Reflector怎么用?TypeScript Reflector使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Reflector类的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: canActivate
canActivate(context: ExecutionContext): boolean {
const roles = this.reflector.get<string[]>('role', context.getHandler());
if (!roles) {
return true;
}
const request = context.switchToHttp().getRequest();
const user = request.user;
const hasRole = () => roles.includes(user.role);
return user && user.role && hasRole();
}
示例2: canActivate
canActivate(context: ExecutionContext): boolean {
const roles = this.reflector.get<string[]>('roles', context.getHandler());
if (!roles) {
return true;
}
const request = context.switchToHttp().getRequest();
const user = request.user;
const hasRole = user.roles.some((role) => !!roles.find((item) => item === role));
return user && user.roles && hasRole();
}
示例3: canActivate
canActivate(data, context: ExecutionContext): boolean {
const { parent, handler } = context;
const roles = this.reflector.get<string[]>('roles', handler);
if (!roles) {
return true;
}
/*
跟Route Guard有點不一樣,req改成data,data泛指傳遞過來的訊息。
為了 demo用,data是前端push過來的訊息,裏頭有roles 陣列,放著該前端使用者的角色。
*/
const hasRole = () => !!data.roles.find((role) => !!roles.find((item) => item === role));
return data && data.roles && hasRole();
}
示例4: canActivate
canActivate(req, context: ExecutionContext): boolean {
const { parent, handler } = context;
const roles = this.reflector.get<string[]>('roles', handler);
if (!roles) {
return true;
}
/*req.user是假資料,這是在模擬登入後,有一組user資訊放在req object裡,
也可以放在session等,登入資訊的roles表示角色權限,是陣列,一個帳號可能有多個角色。
而Ted的角色是general,能夠請求通過帶有@Roles('general')裝飾器的目標。
*/
req.user = { "account": "Ted", "roles": ["general"] };
const user = req.user;
const hasRole = () => !!user.roles.find((role) => !!roles.find((item) => item === role));
return user && user.roles && hasRole();
}