2022-07-04 20:32:18 +08:00

65 lines
1.6 KiB
TypeScript

import { Context, Next } from '@nocobase/actions';
import UsersPlugin from '../server';
export function parseToken(options?: { plugin: UsersPlugin }) {
return async function parseToken(ctx: Context, next: Next) {
const user = await findUserByToken(ctx, options.plugin);
if (user) {
ctx.state.currentUser = user;
setCurrentRole(ctx);
}
return next();
};
}
export function setCurrentRole(ctx) {
let currentRole = ctx.get('X-Role');
if (currentRole === 'anonymous') {
ctx.state.currentRole = currentRole;
return;
}
const userRoles = ctx.state.currentUser.roles;
if (userRoles.length == 1) {
currentRole = userRoles[0].name;
} else if (userRoles.length > 1) {
const role = userRoles.find((role) => role.name === currentRole);
if (!role) {
const defaultRole = userRoles.find((role) => role?.rolesUsers?.default);
currentRole = (defaultRole || userRoles[0])?.name;
}
}
if (currentRole) {
ctx.state.currentRole = currentRole;
}
}
async function findUserByToken(ctx: Context, plugin: UsersPlugin) {
const token = ctx.getBearerToken();
if (!token) {
return null;
}
try {
const { userId } = await plugin.jwtService.decode(token);
const collection = ctx.db.getCollection('users');
const appends = ['roles'];
for (const [, field] of collection.fields) {
if (field.type === 'belongsTo') {
appends.push(field.name);
}
}
return await ctx.db.getRepository('users').findOne({
appends,
filter: {
id: userId,
},
});
} catch (error) {
return null;
}
}