Javascript FeathersJS:在挂钩内创建记录
我是FeathersJS的新手,我正在努力做到以下几点: 我的应用程序有两个实体,分别名为Javascript FeathersJS:在挂钩内创建记录,javascript,feathersjs,Javascript,Feathersjs,我是FeathersJS的新手,我正在努力做到以下几点: 我的应用程序有两个实体,分别名为公司和用户。当有人注册一家新公司时,会通知其所有者的姓名、电子邮件和密码 然后,在my Companys表中为公司创建记录后,我需要: 1) 检索新公司的id 2) 使用此idadcompanyId、所有者姓名、所有者电子邮件和给定密码创建用户 当然,对于companys服务,这应该在insert hook之后的中完成,但是我对如何调用users服务来执行此插入感到非常困惑 这是我的companys.mod
公司
和用户
。当有人注册一家新公司时,会通知其所有者的姓名、电子邮件和密码
然后,在my Companys表中为公司创建记录后,我需要:
1) 检索新公司的id
2) 使用此id
adcompanyId
、所有者姓名、所有者电子邮件和给定密码创建用户
当然,对于companys服务,这应该在insert hook之后的中完成,但是我对如何调用users服务来执行此插入感到非常困惑
这是我的companys.model.js文件:
module.exports = function (app) {
const sequelizeClient = app.get('sequelizeClient');
const companies = sequelizeClient.define('companies', {
company: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
cpfcnpj: {
type: DataTypes.STRING,
allowNull: false,
size: 25
},
owner: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
cpf: {
type: DataTypes.STRING,
allowNull: false,
size: 25
},
email: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
addr1: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
addr2: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
city: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
state: {
type: DataTypes.STRING,
allowNull: false,
size: 2
},
zip: {
type: DataTypes.STRING,
allowNull: false,
size: 10
},
phone: {
type: DataTypes.STRING,
allowNull: false,
size: 50
}
}, {
hooks: {
beforeCount(options) {
options.raw = true;
}
}
});
companies.associate = function (models) {
};
return companies;
};
这是我的users.model.js:
module.exports = function (app) {
const sequelizeClient = app.get('sequelizeClient');
const users = sequelizeClient.define('users', {
companyID: {
type: DataTypes.INTEGER,
allowNull false,
size: 11
},
name: {
type: DataTypes.STRING,
allowNull: false,
size: 100
},
email: {
type: DataTypes.STRING,
allowNull: false,
unique: true,
size: 100
},
password: {
type: DataTypes.STRING,
allowNull: false
},
type: {
type: DataTypes.STRING,
allowNull: false,
default: 'CL',
size: 2
}
}, {
hooks: {
beforeCount(options) {
options.raw = true;
}
}
});
users.associate = function (models) {
};
return users;
};
我知道在我的文件companys.hooks.js中应该有
module.exports = {
before: {
all: [],
...
},
after: {
...
create: [ insertUser() ],
...
},
error: {
...
}
};
但除此之外,我真的不知道应该如何编写insertUser()
函数,或者将其放在哪里。正如我告诉你的,我是FeathersJS的新手,这是我的第一天
编辑:
问题的第一部分已经回答。我在这里和那里使用了一些console.log()
s,发现传递给钩子的对象context
中有一个名为result
的对象,当您在after
hook中时,就是这样。现在,使用此对象可以获得公司id、所有者的姓名和电子邮件。所有内容都在上下文中
在FeatherJS中使用钩子
时,您的钩子函数
接收一个名为上下文
的对象,该对象具有您所需的所有内容
在钩子之后的中,我们有context.result
,一个具有上一个查询结果的对象。在插入查询中,如问题中所示,context.result
包含所有插入的信息,包括插入公司的id
此外,context
对象包含对FeathersJSapp
对象的引用,该对象是正在运行的应用程序,包含其所有服务和挂钩以及所有内容。因此,为了按照问题中的要求创建用户,您所要做的就是:
编辑文件src/services/companys/companys.hooks.js并在导入后的开头添加如下函数
const createUser = function(context) {
const userRecord = {
companyID: context.result.id,
name: context.result.owner,
email: context.result.email,
// Get all other information you need here
};
context.app.service('users').create(userRecord);
};
在同一文件的右下方注册此钩子
module.exports = {
before: {
all: [authenticate('jwt')],
find: [],
get: [],
create: [],
update: [],
patch: [],
remove: []
},
after: {
all: [],
find: [],
get: [],
create: [ createUser ], // <<=== registering the hook
update: [],
patch: [],
remove: []
},
error: {
all: [],
find: [],
get: [],
create: [],
update: [],
patch: [],
remove: []
}
};
module.exports={
之前:{
全部:[验证('jwt')],
查找:[],
获取:[],
创建:[],
更新:[],
修补程序:[],
删除:[]
},
之后:{
全部:[],
查找:[],
获取:[],
create:[createUser]//