FeathersJS:在钩子内创建记录



我是FeathersJS的新手,我正在尝试执行以下操作:

我的应用有两个名为CompanyUser的实体。当有人注册新公司时,会通知所有者的名称,电子邮件和密码。

然后,在我的公司表中为公司创建记录后,我需要:

(一)取回新公司的id;

2)使用此id广告companyId,所有者的姓名,所有者的电子邮件和给定的密码创建用户。

当然,这应该在公司服务的after insert hook中完成,但我对如何调用用户服务来执行此插入感到非常困惑。

这是我的公司模型.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;
};

这是我的用户模型.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;
};

我知道在我的文件companies.hooks中.js我应该有类似的东西

module.exports = {
before: {
all: [],
...
},
after: {
...
create: [ insertUser() ],
...
},
error: {
...
}
};

但除此之外,我真的不知道我应该如何编写我的insertUser()函数或将其放在哪里。正如我告诉你的,我是FeathersJS的新手,这是我的第一天。

编辑:

回答了问题的第一部分。我在这里和那里使用了一些console.log(),发现当你在after钩子中时,context传递给钩子的对象里面有一个名为result的对象,情况就是如此。现在使用此对象具有所有者的公司 ID、姓名和电子邮件。

这一切都在context里面。

当您在 FeatherJS 中使用hook时,您的hook function会收到一个名为context的对象,并且该对象包含您所需的一切。

after hook我们有context.result,一个具有上一个查询结果的对象。在插入查询中,就像在问题中一样,context.result包含所有插入的信息,包括插入公司的 ID。

此外,context对象包含对 FeathersJSapp对象的引用,该对象是正在运行的应用程序,及其所有服务和钩子以及所有内容。因此,为了按照问题中的要求创建用户,您所要做的就是:

编辑文件src/services/companies/companies.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: []
}
};

大功告成!每次创建新公司时,都会执行after hook,并创建一个与该公司关联的新用户。

单击此处了解有关 FeathersJS 钩子的更多信息。

相关内容

  • 没有找到相关文章

最新更新