调用自定义API方法的功能

Feathers calling custom API method

本文关键字:功能 方法 API 自定义 调用      更新时间:2023-09-26

我用以下内容定义我的api:

class MyFeathersApi {
  feathersClient: any;
  accountsAPI: any;
  productsAPI: any;
  constructor(app) {
    var port: number = app.get('port');
    this.accountsAPI = app.service('/api/accounts');
    this.productsAPI = app.service('/api/products');
  }
  findAdminAccounts(filter: any, cb: (err:Error, accounts:Models.IAccount[]) => void) {
    filter = { query: { adminProfile: { $exists: true } } }
    this.accountsAPI.find(filter, cb);
  }

当我想使用数据库适配器方法时,从客户端,即查找和/或创建,我会执行以下操作:

var accountsAPIService = app.service('/api/accounts');
accountsAPIService.find( function(error, accounts) {
  ...
});

如何从客户端调用自定义方法,如findAdminAccounts()?

您只能在客户端上使用正常的服务接口。我们发现,对自定义方法的支持(以及它带来的从明确定义的接口到任意方法名称和参数的所有问题)并不是真正必要的,因为一切本身都可以描述为资源(服务)。

到目前为止,其好处(如安全性、可预测性和发送定义良好的实时事件)远远超过了在概念化应用程序逻辑时所需的思想上的微小变化。

在您的示例中,您可以制作一个包装器服务,以获得如下管理帐户:

class AdminAccounts {
  find(params) {
    const accountService = this.app.service('/api/accounts');
    return accountService.find({ query: { adminProfile: { $exists: true } } });
  }
  setup(app) {
    this.app = app;
  }
}
app.use('/api/adminAccounts', new AdminAccounts());

或者,您可以实现一个钩子,将查询参数映射到更大的查询,如下所示:

app.service('/api/accounts').hooks({
  before: {
    find(hook) {
      if(hook.params.query.admin) {
        hook.params.query.adminProfile = { $exists: true };
      }
    }
  }
});

这将允许调用类似/api/accounts?admin的内容。

有关更多信息,请参阅本常见问题解答。