Perform a client request (http) with a digest authentication, a simple node http digest client.
Only tested against one server and spec is not followed fully. It works for me and for what I am doing. I often try to improve this npm and I answer to your pull-request and issue ASAP in order to improve your experience with this package. Pay attention, it only works with MD5 algorithm currently.
var digestRequest = require('request-digest')('username', 'password');
digestRequest.request({
host: 'http://test.com',
path: '/api/v1/test.json',
port: 80,
method: 'GET',
headers: {
'Custom-Header': 'OneValue',
'Other-Custom-Header': 'OtherValue'
}
}, function (error, response, body) {
if (error) {
throw error;
}
console.log(body);
});
var digestRequest = require('request-digest')('username', 'password');
digestRequest.requestAsync({
host: 'http://test.com',
path: '/api/v1/test.json',
port: 80,
method: 'GET',
headers: {
'Custom-Header': 'OneValue',
'Other-Custom-Header': 'OtherValue'
}
})
.then(function (response) {
console.log(response.body);
})
.catch(function (error) {
console.log(error.statusCode);
console.log(error.body);
});
The digest client will make one request to the server, authentication response is calculated and then the request is made again. Hopefully you will then be authorized.
- Response object :
response = {
response,
body
};
- Error object :
error = {
response,
body,
statusCode
};
Pay attention, after version 1.0.0 I have implemented promise support and add a better support of errors with statusCode >= 400.
Feel free to contribute and extend this package and if you have bugs or if you want more specs make an issue. Have fun !
Made by Coenen Benjamin with love