Javascript FeathersJS:在挂钩内创建记录

Javascript FeathersJS:在挂钩内创建记录,javascript,feathersjs,Javascript,Feathersjs,我是FeathersJS的新手,我正在努力做到以下几点: 我的应用程序有两个实体,分别名为公司和用户。当有人注册一家新公司时,会通知其所有者的姓名、电子邮件和密码 然后,在my Companys表中为公司创建记录后,我需要: 1) 检索新公司的id 2) 使用此idadcompanyId、所有者姓名、所有者电子邮件和给定密码创建用户 当然,对于companys服务,这应该在insert hook之后的中完成,但是我对如何调用users服务来执行此插入感到非常困惑 这是我的companys.mod

我是FeathersJS的新手,我正在努力做到以下几点:

我的应用程序有两个实体,分别名为
公司
用户
。当有人注册一家新公司时,会通知其所有者的姓名、电子邮件和密码

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

1) 检索新公司的
id

2) 使用此
id
ad
companyId
、所有者姓名、所有者电子邮件和给定密码创建用户

当然,对于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
对象包含对FeathersJS
app
对象的引用,该对象是正在运行的应用程序,包含其所有服务和挂钩以及所有内容。因此,为了按照问题中的要求创建用户,您所要做的就是:

编辑文件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]//