Используя express и express-ntlm, как я могу создать конечную точку http://localhost:3000/api/bug/, которая создает ошибку для меня в TFS, нажимая API TFS?
Я могу сделать это с помощью 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. Это не создает ошибку в TFS, поскольку текущий пользователь использует экспресс-API, а вместо этого создает ошибку как пользователь myUserName.
Можно ли с помощью пакета express-ntlm выполнить соединение http.post с http://tfsinstance/collection/project/..., используя учетные данные NTLM, возвращенные из этого пакета?
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
});
}));
});





express-ntlm действует как прокси между клиентом и контроллером домена. Таким образом, контроллер домена будет обрабатывать аутентификацию клиента и express-ntlm просто действовать как человек посередине, пока аутентификация не будет успешной.
Если вы можете использовать какого-либо пользователя API и использовать express-ntlm, чтобы просто получить правильное имя пользователя и передать его API TFS, это будет самый простой способ сделать, в противном случае я бы предложил вам создать свой собственный прокси между вашим клиентом и TFS. API.