因此,我正在使用Domo开发人员工具(他们喜欢将其称为IDE)构建连接器,但似乎无法使身份验证文件与它们的库一起工作。
Domo使用httprequest
库进行基本和oauth身份验证类型。
我无法通过Domo重新获得令牌,但是我可以通过curl
或使用Postman api工具轻松实现。
这是下面的代码:
var client_id = '4969e1ea-71b9-3267-ae7d-4ce0ac6bfa28';
var client_secret = '*****************************';
var user = '*********';
var pass = '*********';
var postData =
{
data: {
'grant_type': 'password',
'username': user,
'password': pass,
'client_id': client_id,
'client_secret': client_secret,
'scope': 'internal'
}
};
var res = httprequest.post('https://rest.synthesio.com/security/v1/oauth/token', postData);
DOMO.log('res: ' + res);
请让我知道您是否有其他解决方法。我试图在
postData
对象本身内添加标题,以及删除data
变量,也将属性保持原样。 最佳答案
当您将postData作为这样的对象传递时,DOMO将通过JSON.stringify运行它并将结果发送到请求正文中。
您可以手动对请求正文进行编码,也可以使用其httprequest.addParameter函数添加它们。尝试这样的事情:
var client_id = '4969e1ea-71b9-3267-ae7d-4ce0ac6bfa28';
var client_secret = '*****************************';
var user = '*********';
var pass = '*********';
httprequest.addParameter('grant_type', 'password');
httprequest.addParameter('username', user);
httprequest.addParameter('password', pass);
httprequest.addParameter('client_id', client_id);
httprequest.addParameter('client_secret', client_secret);
httprequest.addParameter('scope', 'internal');
var res = httprequest.post('https://rest.synthesio.com/security/v1/oauth/token');
DOMO.log('res: ' + res);