也许我不理解Promise.promisifyAll
的工作方式。我试图宣传coinbase包裹。
基本上,客户端的功能是有效的,但这些功能返回的帐户似乎没有异步版本:[TypeError: acc.getTransactionsAsync is not a function]
。
我已尝试按照an answer to a similar question中的建议将{multiArgs:true}
作为选项传递给Promise.promisifyAll()
,但它并没有解决问题。任何建议都表示赞赏。
使用包的正常方式(有效):
var Client = require('coinbase').Client
var client = new Client({
'apiKey': '<snip>',
'apiSecret': '<snip>',
'baseApiUri': 'https://api.sandbox.coinbase.com/v2/',
'tokenUri': 'https://api.sandbox.coinbase.com/oauth/token'
});
//Callbacks
client.getAccounts({}, function(err, accounts) {
accounts.forEach(function(acc) {
acc.getTransactions(null, function(err, txns) {
txns.forEach(function(txn) {
console.log('txn: ' + txn.id);
});
});
});
});
Promisified版本无效(getTransactionsAsync
未定义,但getAccountsAsync
正确返回帐户):
var Promise = require('bluebird');
var Client = require('coinbase').Client;
var client = new Client({
'apiKey': '<snip>',
'apiSecret': '<snip>',
'baseApiUri': 'https://api.sandbox.coinbase.com/v2/',
'tokenUri': 'https://api.sandbox.coinbase.com/oauth/token'
});
Promise.promisifyAll(client);
//Promises
client.getAccountsAsync({}) //Works perfectly, returns the accounts
.then(function(accounts) {
return Promise.map(accounts, function(acc) {
return acc.getTransactionsAsync(null); //This function call is throwing the TypeError
});
})
.then(function(transactions) {
console.log('Transactions:');
transactions.forEach(function(tx) {
console.log(tx);
});
})
.catch(function(err) {
console.log(err);
});
修改
通过我想要宣传的包,我意识到我试图调用的函数来自包返回的模型对象。我认为promisifyAll
只解析客户端函数,并且模型没有被处理。我不太了解如何进行解析:(
这是index.js(模块导出)
var Account = require('./lib/model/Account.js'),
Address = require('./lib/model/Address.js'),
Buy = require('./lib/model/Buy.js'),
Checkout = require('./lib/model/Checkout.js'),
Client = require('./lib/Client.js'),
Deposit = require('./lib/model/Deposit.js'),
Merchant = require('./lib/model/Merchant.js'),
Notification = require('./lib/model/Notification.js'),
Order = require('./lib/model/Order.js'),
PaymentMethod = require('./lib/model/PaymentMethod.js'),
Sell = require('./lib/model/Sell.js'),
Transaction = require('./lib/model/Transaction.js'),
User = require('./lib/model/User.js'),
Withdrawal = require('./lib/model/Withdrawal.js');
var model = {
'Account' : Account,
'Address' : Address,
'Buy' : Buy,
'Checkout' : Checkout,
'Deposit' : Deposit,
'Merchant' : Merchant,
'Notification' : Notification,
'Order' : Order,
'PaymentMethod' : PaymentMethod,
'Sell' : Sell,
'Transaction' : Transaction,
'User' : User,
'Withdrawal' : Withdrawal
};
module.exports = {
'Client' : Client,
'model' : model
};
编辑2:
客户端需要它自己的模型模块,因此Promise.promisifyAll
应该与对象的属性一样正常,而不会使之前的编辑干扰。在这一点上,我认为可能没有其他选择可以为我不需要直接生活在客户端下的所有功能制作自己的Promise。
答案 0 :(得分:3)
我认为
promisifyAll
只解析客户端功能,而且模型没有被处理。
不完全是。这与promisifyAll
查看方法和属性的方式无关。相反,您只是明确地传递了要实现的客户端方法:
var Client = require('coinbase').Client; var client = new Client(…); Promise.promisifyAll(client);
client
与模型之间没有链接。 而是尝试在整个模块上调用 promisifyAll
,而不仅仅是Client
类:
var Client = Promise.promisifyAll(require('coinbase')).Client;
或者如果不起作用,在promisifyAll
类和Client
类集合上调用models
:
var coinbase = require('coinbase');
var Client = Promise.promisifyAll(coinbase.Client);
Promise.promisifyAll(coinbase.model);
答案 1 :(得分:0)
因此,我没有再次编辑问题,而是添加了我的临时解决方法(函数调用略有不同,但问题是没有Async
函数)。这样就可以通过它自己来模仿模型模块,只要我需要在客户返回的模型的非保证版本上使用一个有效的函数,我就需要按需创建它们。
这不是我想做的事情,因为每个模型需要更多的内存分配,我想要进行一个有希望的函数调用。但我更喜欢这种方法,而不是创建用于分组new Promise(...)
函数的新模块。
如果建议更好的解决方案,我仍然会将其标记为已解决。
var Promise = require('bluebird');
var Client = require('coinbase').Client;
var cbModel = require('coinbase').model;
var client = new Client({
'apiKey': '<snip>',
'apiSecret': '<snip>',
'baseApiUri': 'https://api.sandbox.coinbase.com/v2/',
'tokenUri': 'https://api.sandbox.coinbase.com/oauth/token'
});
Promise.promisifyAll(client);
Promise.promisifyAll(cbModel);
//Promises
client.getAccountAsync('primary')
.then(function(account) {
account = new cbModel.Account(client, account);
return account.getTransactionsAsync(null);
})
.then(function(transactions) {
console.log('Transactions:');
transactions.forEach(function(tx) {
console.log(tx.id);
});
})
.catch(function(err) {
console.log(err);
});