本文整理匯總了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();
}