使用express和express-ntlm,我如何通过点击TFS来创建一个在TFS中为我创建错误的http://localhost:3000/api/bug/端点?
我现在可以使用request-ntlm-promise来做这件事,我就是这样做的。
const ntlm = require('request-ntlm-promise');
const ntlmOptions = {
username: 'myUserName',
password: 'myPassword',
url: 'http://tfsinstance/collection/project/_apis/wit/workitems/$bug?api-version=4.1',
headers: {
'Content-Type': 'application/json-patch+json'
}
};
const tfsBugObject =[{
'op': 'add',
'path': '/fields/System.Title',
'value': 'Test title'
}, {
'op': 'add',
'path': '/fields/Microsoft.VSTS.TCM.SystemInfo',
'value': 'Test system info'
}, {
'op': 'add',
'path': '/fields/Microsoft.VSTS.TCM.ReproSteps',
'value': 'test reproduction steps'
}];
ntlm.post(ntlmOptions, tfsBugObject).then((response) => { return res.send(response); });问题是我必须在ntlmOptions对象中提供用户名和密码。这样做并不会在当前用户点击express API时在TFS中创建bug,而是会在用户'myUserName‘中创建bug。
使用express-ntlm程序包,是否可以使用从该程序包返回的http.post凭据对http://tfsinstance/collection/project/...执行http.post操作?
TFS需要身份验证才能使用API。
使用express-ntlm,我希望我能做到以下几点。
const express = require('express');
const ntlm = require('express-ntlm');
const http = require('http');
const app = express();
app.use(ntlm({ domain: 'mydomain', domaincontroller: 'ldap://domaincontroller' });然后
httpOptions = {
protocol: 'http',
hostname: 'tfsinstance',
pathname: '/collection/project/_apis/wit/workitems/$bug?api-version=4.1',
port: 8080,
method: 'POST',
headers: {
'Content-Type': 'application/json-patch+json'
}
};
app.post('/report/bug', (req, res, next) => {
const request = http.request(httpOptions, (response => {
response.on('data', data => {
// return response from TFS through express to user
});
}));
});发布于 2019-05-26 22:02:02
express-ntlm充当客户端和域控制器之间的代理。因此,域控制器将处理与客户端的身份验证,而express-ntlm只是充当中间人,直到身份验证成功。
如果您可以使用某种类型的API用户并使用express-ntlm获取正确的用户名并将其传递给TFS,这将是最简单的方法,否则我建议您在客户端和TFS之间创建自己的代理。
https://stackoverflow.com/questions/54952258
复制相似问题