2022-02-11 10:13:14 +00:00
|
|
|
import { Collection } from '@nocobase/database';
|
|
|
|
import { Plugin } from '@nocobase/server';
|
|
|
|
import { resolve } from 'path';
|
2021-12-08 01:10:44 +00:00
|
|
|
import * as actions from './actions/users';
|
2022-04-09 06:54:46 +00:00
|
|
|
import { JwtOptions, JwtService } from './jwt-service';
|
2022-04-09 07:30:43 +00:00
|
|
|
import * as middlewares from './middlewares';
|
2022-04-10 14:05:18 +00:00
|
|
|
import { UserModel } from './models/UserModel';
|
2022-04-09 06:54:46 +00:00
|
|
|
|
|
|
|
export interface UserPluginConfig {
|
|
|
|
jwt: JwtOptions;
|
|
|
|
|
2022-04-17 02:00:42 +00:00
|
|
|
installing?: {
|
2022-04-09 06:54:46 +00:00
|
|
|
adminNickname: string;
|
|
|
|
adminEmail: string;
|
|
|
|
adminPassword: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export default class UsersPlugin extends Plugin<UserPluginConfig> {
|
|
|
|
public jwtService: JwtService;
|
|
|
|
|
|
|
|
constructor(app, options) {
|
|
|
|
super(app, options);
|
|
|
|
this.jwtService = new JwtService(options?.jwt);
|
|
|
|
}
|
2021-12-08 01:10:44 +00:00
|
|
|
|
2022-02-28 13:49:50 +00:00
|
|
|
async beforeLoad() {
|
2022-04-10 14:05:18 +00:00
|
|
|
this.db.registerModels({ UserModel });
|
2022-02-06 17:14:00 +00:00
|
|
|
this.db.on('users.afterCreateWithAssociations', async (model, options) => {
|
2022-01-30 02:37:27 +00:00
|
|
|
const { transaction } = options;
|
2022-04-10 14:54:05 +00:00
|
|
|
const repository = this.app.db.getRepository('roles');
|
|
|
|
if (!repository) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const defaultRole = await repository.findOne({
|
|
|
|
filter: {
|
|
|
|
default: true,
|
|
|
|
},
|
|
|
|
transaction,
|
|
|
|
});
|
|
|
|
if (defaultRole && (await model.countRoles({ transaction })) == 0) {
|
|
|
|
await model.addRoles(defaultRole, { transaction });
|
2022-01-30 02:37:27 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2022-02-06 17:14:00 +00:00
|
|
|
this.db.on('afterDefineCollection', (collection: Collection) => {
|
2021-12-08 01:10:44 +00:00
|
|
|
let { createdBy, updatedBy } = collection.options;
|
|
|
|
if (createdBy === true) {
|
|
|
|
collection.setField('createdById', {
|
|
|
|
type: 'context',
|
|
|
|
dataType: 'integer',
|
|
|
|
dataIndex: 'state.currentUser.id',
|
|
|
|
createOnly: true,
|
2022-04-12 04:02:58 +00:00
|
|
|
visible: true,
|
2021-12-08 01:10:44 +00:00
|
|
|
});
|
|
|
|
collection.setField('createdBy', {
|
|
|
|
type: 'belongsTo',
|
|
|
|
target: 'users',
|
|
|
|
foreignKey: 'createdById',
|
|
|
|
targetKey: 'id',
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if (updatedBy === true) {
|
|
|
|
collection.setField('updatedById', {
|
|
|
|
type: 'context',
|
|
|
|
dataType: 'integer',
|
|
|
|
dataIndex: 'state.currentUser.id',
|
2022-04-12 04:02:58 +00:00
|
|
|
visible: true,
|
2021-12-08 01:10:44 +00:00
|
|
|
});
|
|
|
|
collection.setField('updatedBy', {
|
|
|
|
type: 'belongsTo',
|
|
|
|
target: 'users',
|
|
|
|
foreignKey: 'updatedById',
|
|
|
|
targetKey: 'id',
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
for (const [key, action] of Object.entries(actions)) {
|
2022-02-06 17:14:00 +00:00
|
|
|
this.app.resourcer.registerActionHandler(`users:${key}`, action);
|
2021-12-08 01:10:44 +00:00
|
|
|
}
|
|
|
|
|
2022-04-09 07:30:43 +00:00
|
|
|
this.app.resourcer.use(middlewares.parseToken({ plugin: this }));
|
2022-03-11 02:10:57 +00:00
|
|
|
|
|
|
|
const publicActions = ['check', 'signin', 'signup', 'lostpassword', 'resetpassword', 'getUserByResetToken'];
|
|
|
|
const loggedInActions = ['signout', 'updateProfile', 'changePassword', 'setDefaultRole'];
|
|
|
|
|
|
|
|
publicActions.forEach((action) => this.app.acl.skip('users', action));
|
|
|
|
loggedInActions.forEach((action) => this.app.acl.skip('users', action, 'logged-in'));
|
2022-02-06 17:14:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
async load() {
|
|
|
|
await this.db.import({
|
2022-02-11 10:13:14 +00:00
|
|
|
directory: resolve(__dirname, 'collections'),
|
2022-02-06 17:14:00 +00:00
|
|
|
});
|
|
|
|
}
|
2022-02-28 14:10:04 +00:00
|
|
|
|
2022-03-11 02:10:57 +00:00
|
|
|
getRootUserInfo() {
|
2022-02-28 14:10:04 +00:00
|
|
|
const {
|
|
|
|
adminNickname = 'Super Admin',
|
|
|
|
adminEmail = 'admin@nocobase.com',
|
|
|
|
adminPassword = 'admin123',
|
2022-04-09 07:30:43 +00:00
|
|
|
} = this.options.installing || {};
|
2022-02-28 14:10:04 +00:00
|
|
|
|
2022-03-11 02:10:57 +00:00
|
|
|
return {
|
|
|
|
adminNickname,
|
|
|
|
adminEmail,
|
|
|
|
adminPassword,
|
|
|
|
};
|
|
|
|
}
|
2022-04-09 06:54:46 +00:00
|
|
|
|
2022-03-11 02:10:57 +00:00
|
|
|
async install() {
|
|
|
|
const { adminNickname, adminPassword, adminEmail } = this.getRootUserInfo();
|
|
|
|
|
2022-02-28 14:10:04 +00:00
|
|
|
const User = this.db.getCollection('users');
|
2022-04-10 14:05:18 +00:00
|
|
|
const user = await User.repository.create<UserModel>({
|
2022-02-28 14:10:04 +00:00
|
|
|
values: {
|
|
|
|
nickname: adminNickname,
|
|
|
|
email: adminEmail,
|
|
|
|
password: adminPassword,
|
2022-04-10 11:22:39 +00:00
|
|
|
roles: ['root', 'admin'],
|
2022-02-28 14:10:04 +00:00
|
|
|
},
|
|
|
|
});
|
2022-04-09 06:54:46 +00:00
|
|
|
|
2022-04-10 14:05:18 +00:00
|
|
|
await user.setDefaultRole('root');
|
|
|
|
|
2022-03-02 10:35:49 +00:00
|
|
|
const repo = this.db.getRepository<any>('collections');
|
|
|
|
if (repo) {
|
|
|
|
await repo.db2cm('users');
|
|
|
|
}
|
2022-02-28 14:10:04 +00:00
|
|
|
}
|
2022-03-28 14:01:10 +00:00
|
|
|
|
|
|
|
getName(): string {
|
|
|
|
return this.getPackageName(__dirname);
|
|
|
|
}
|
2022-02-06 17:14:00 +00:00
|
|
|
}
|